{"version":3,"sources":["node_modules/tslib/tslib.es6.mjs","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isFunction.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/config.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/hostReportError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/Observer.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isArray.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isObject.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/UnsubscriptionError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/Subscription.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/symbol/rxSubscriber.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/Subscriber.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/canReportError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/toSubscriber.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/symbol/observable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/identity.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/pipe.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/Observable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/subscribeToArray.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/subscribeToPromise.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/symbol/iterator.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/subscribeToIterable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/subscribeToObservable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isArrayLike.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isPromise.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/subscribeTo.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/innerSubscribe.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/audit.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/Action.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/AsyncAction.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/src/internal/Scheduler.ts","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/AsyncScheduler.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/async.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isNumeric.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isScheduler.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/timer.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/auditTime.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/buffer.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/bufferCount.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/bufferTime.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/InnerSubscriber.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/subscribeToResult.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/OuterSubscriber.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/bufferToggle.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/bufferWhen.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/catchError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduled/scheduleArray.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/fromArray.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/combineLatest.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/combineAll.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduled/scheduleObservable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduled/schedulePromise.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduled/scheduleIterable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isInteropObservable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isIterable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduled/scheduled.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/from.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/combineLatest.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/of.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/map.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/mergeMap.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/mergeAll.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/concatAll.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/concat.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/concat.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/concatMap.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/concatMapTo.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/count.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/debounce.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/debounceTime.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/defaultIfEmpty.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isDate.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/empty.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/throwError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/Notification.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/delay.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/delayWhen.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/dematerialize.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/distinct.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/distinctUntilChanged.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/distinctUntilKeyChanged.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/ArgumentOutOfRangeError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/filter.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/EmptyError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/throwIfEmpty.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/take.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/elementAt.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/endWith.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/every.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/exhaust.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/exhaustMap.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/expand.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/finalize.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/find.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/findIndex.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/first.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/ObjectUnsubscribedError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/SubjectSubscription.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/Subject.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/groupBy.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/ignoreElements.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/isEmpty.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/takeLast.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/last.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/mapTo.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/materialize.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/scan.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/reduce.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/max.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/merge.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/merge.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/mergeMapTo.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/mergeScan.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/min.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/refCount.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/ConnectableObservable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/multicast.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/observeOn.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/onErrorResumeNext.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/pairwise.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/not.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/partition.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/pluck.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/publish.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/BehaviorSubject.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/publishBehavior.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/AsyncSubject.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/publishLast.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/QueueAction.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/QueueScheduler.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/queue.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/ReplaySubject.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/publishReplay.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/race.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/race.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/repeat.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/repeatWhen.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/retry.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/retryWhen.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/sample.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/sampleTime.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/sequenceEqual.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/share.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/shareReplay.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/single.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/skip.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/skipLast.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/skipUntil.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/skipWhile.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/startWith.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/Immediate.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/AsapAction.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/AsapScheduler.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/asap.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/SubscribeOnObservable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/subscribeOn.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/switchMap.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/switchAll.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/switchMapTo.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/takeUntil.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/takeWhile.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/noop.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/tap.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/throttle.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/throttleTime.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/defer.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/timeInterval.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/TimeoutError.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/timeoutWith.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/timeout.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/timestamp.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/toArray.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/window.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/windowCount.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/windowTime.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/windowToggle.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/windowWhen.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/withLatestFrom.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/zip.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/zip.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/operators/zipAll.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/operators/index.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/AnimationFrameAction.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/AnimationFrameScheduler.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/animationFrame.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/scheduler/VirtualTimeScheduler.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/util/isObservable.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/bindCallback.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/bindNodeCallback.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/forkJoin.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/fromEvent.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/fromEventPattern.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/generate.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/iif.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/interval.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/never.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/onErrorResumeNext.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/pairs.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/partition.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/range.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/internal/observable/using.js","node_modules/@listat/blockchain-providers/node_modules/rxjs/_esm2015/index.js","node_modules/color-name/index.js","node_modules/color-convert/conversions.js","node_modules/color-convert/route.js","node_modules/color-convert/index.js","node_modules/ansi-styles/index.js","node_modules/supports-color/browser.js","node_modules/chalk/source/util.js","node_modules/chalk/source/templates.js","node_modules/chalk/source/index.js","node_modules/@ethersproject/abstract-provider/lib.esm/_version.js","node_modules/@ethersproject/abstract-provider/lib.esm/index.js","node_modules/@ethersproject/networks/lib.esm/_version.js","node_modules/@ethersproject/networks/lib.esm/index.js","node_modules/@ethersproject/basex/lib.esm/index.js","node_modules/@ethersproject/sha2/lib.esm/types.js","node_modules/@ethersproject/sha2/lib.esm/_version.js","node_modules/@ethersproject/sha2/lib.esm/sha2.js","node_modules/@ethersproject/sha2/lib.esm/index.js","node_modules/@ethersproject/web/lib.esm/_version.js","node_modules/@ethersproject/web/lib.esm/geturl.js","node_modules/@ethersproject/web/lib.esm/index.js","node_modules/@ethersproject/providers/lib.esm/_version.js","node_modules/@ethersproject/providers/lib.esm/formatter.js","node_modules/@ethersproject/providers/lib.esm/base-provider.js","node_modules/@ethersproject/abstract-signer/lib.esm/_version.js","node_modules/@ethersproject/abstract-signer/lib.esm/index.js","node_modules/@ethersproject/providers/lib.esm/json-rpc-provider.js","node_modules/@ethersproject/providers/lib.esm/ws.js","node_modules/@ethersproject/providers/lib.esm/websocket-provider.js","node_modules/@ethersproject/providers/lib.esm/url-json-rpc-provider.js","node_modules/@ethersproject/providers/lib.esm/alchemy-provider.js","node_modules/@ethersproject/providers/lib.esm/ankr-provider.js","node_modules/@ethersproject/providers/lib.esm/cloudflare-provider.js","node_modules/@ethersproject/providers/lib.esm/etherscan-provider.js","node_modules/@ethersproject/random/lib.esm/_version.js","node_modules/@ethersproject/random/lib.esm/random.js","node_modules/@ethersproject/random/lib.esm/shuffle.js","node_modules/@ethersproject/random/lib.esm/index.js","node_modules/@ethersproject/providers/lib.esm/fallback-provider.js","node_modules/@ethersproject/providers/lib.esm/ipc-provider.js","node_modules/@ethersproject/providers/lib.esm/infura-provider.js","node_modules/@ethersproject/providers/lib.esm/json-rpc-batch-provider.js","node_modules/@ethersproject/providers/lib.esm/nodesmith-provider.js","node_modules/@ethersproject/providers/lib.esm/pocket-provider.js","node_modules/@ethersproject/providers/lib.esm/web3-provider.js","node_modules/@ethersproject/providers/lib.esm/index.js","node_modules/@ethersproject/abi/lib.esm/_version.js","node_modules/@ethersproject/abi/lib.esm/fragments.js","node_modules/@ethersproject/abi/lib.esm/coders/abstract-coder.js","node_modules/@ethersproject/abi/lib.esm/coders/address.js","node_modules/@ethersproject/abi/lib.esm/coders/anonymous.js","node_modules/@ethersproject/abi/lib.esm/coders/array.js","node_modules/@ethersproject/abi/lib.esm/coders/boolean.js","node_modules/@ethersproject/abi/lib.esm/coders/bytes.js","node_modules/@ethersproject/abi/lib.esm/coders/fixed-bytes.js","node_modules/@ethersproject/abi/lib.esm/coders/null.js","node_modules/@ethersproject/abi/lib.esm/coders/number.js","node_modules/@ethersproject/abi/lib.esm/coders/string.js","node_modules/@ethersproject/abi/lib.esm/coders/tuple.js","node_modules/@ethersproject/abi/lib.esm/abi-coder.js","node_modules/@ethersproject/abi/lib.esm/interface.js","node_modules/@ethersproject/abi/lib.esm/index.js","node_modules/rlp/dist.browser/index.js","node_modules/buffer/index.js","node_modules/ethereumjs-util/dist.browser/externals.js","node_modules/ethereumjs-util/dist.browser/constants.js","node_modules/has-tostringtag/shams.js","node_modules/set-function-length/index.js","node_modules/call-bind/index.js","node_modules/call-bind/callBound.js","node_modules/is-arguments/index.js","node_modules/is-generator-function/index.js","node_modules/is-callable/index.js","node_modules/for-each/index.js","node_modules/possible-typed-array-names/index.js","node_modules/available-typed-arrays/index.js","node_modules/which-typed-array/index.js","node_modules/is-typed-array/index.js","node_modules/util/support/types.js","node_modules/util/support/isBufferBrowser.js","node_modules/util/util.js","node_modules/assert/build/internal/assert/assertion_error.js","node_modules/object.assign/implementation.js","node_modules/object.assign/polyfill.js","node_modules/object-is/implementation.js","node_modules/object-is/polyfill.js","node_modules/object-is/shim.js","node_modules/object-is/index.js","node_modules/is-nan/implementation.js","node_modules/is-nan/polyfill.js","node_modules/is-nan/shim.js","node_modules/is-nan/index.js","node_modules/assert/build/internal/util/comparisons.js","node_modules/assert/build/assert.js","node_modules/assert/build/internal/errors.js","node_modules/assert/build/assert.js","node_modules/secp256k1/lib/index.js","node_modules/secp256k1/lib/elliptic.js","node_modules/secp256k1/elliptic.js","node_modules/safe-buffer/index.js","node_modules/randombytes/browser.js","node_modules/ethereum-cryptography/random.js","node_modules/ethereum-cryptography/secp256k1.js","node_modules/ethereumjs-util/dist.browser/internal.js","node_modules/ethereumjs-util/dist.browser/helpers.js","node_modules/ethereumjs-util/dist.browser/bytes.js","node_modules/ethereum-cryptography/hash-utils.js","node_modules/events/events.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/stream-browser.js","node_modules/util/util.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/buffer_list.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/destroy.js","node_modules/keccak/node_modules/readable-stream/errors-browser.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/state.js","node_modules/util-deprecate/browser.js","node_modules/keccak/node_modules/readable-stream/lib/_stream_writable.js","node_modules/keccak/node_modules/readable-stream/lib/_stream_duplex.js","node_modules/string_decoder/node_modules/safe-buffer/index.js","node_modules/string_decoder/lib/string_decoder.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/end-of-stream.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/async_iterator.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/from-browser.js","node_modules/keccak/node_modules/readable-stream/lib/_stream_readable.js","node_modules/keccak/node_modules/readable-stream/lib/_stream_transform.js","node_modules/keccak/node_modules/readable-stream/lib/_stream_passthrough.js","node_modules/keccak/node_modules/readable-stream/lib/internal/streams/pipeline.js","node_modules/keccak/node_modules/readable-stream/readable-browser.js","node_modules/keccak/lib/api/keccak.js","node_modules/keccak/lib/api/shake.js","node_modules/keccak/lib/api/index.js","node_modules/keccak/lib/keccak-state-unroll.js","node_modules/keccak/lib/keccak.js","node_modules/keccak/js.js","node_modules/ethereum-cryptography/keccak.js","node_modules/hash-base/index.js","node_modules/md5.js/index.js","node_modules/ripemd160/index.js","node_modules/sha.js/hash.js","node_modules/sha.js/sha.js","node_modules/sha.js/sha1.js","node_modules/sha.js/sha256.js","node_modules/sha.js/sha224.js","node_modules/sha.js/sha512.js","node_modules/sha.js/sha384.js","node_modules/sha.js/index.js","node_modules/cipher-base/index.js","node_modules/create-hash/browser.js","node_modules/ethereumjs-util/dist.browser/hash.js","node_modules/ethereumjs-util/dist.browser/types.js","node_modules/ethereumjs-util/dist.browser/account.js","node_modules/ethereumjs-util/dist.browser/address.js","node_modules/ethereumjs-util/dist.browser/signature.js","node_modules/ethereumjs-util/dist.browser/object.js","node_modules/ethereumjs-util/dist.browser/index.js","node_modules/@ethereumjs/tx/dist.browser/types.js","node_modules/crc-32/crc32.js","node_modules/@ethereumjs/common/dist.browser/chains/mainnet.json","node_modules/@ethereumjs/common/dist.browser/chains/ropsten.json","node_modules/@ethereumjs/common/dist.browser/chains/rinkeby.json","node_modules/@ethereumjs/common/dist.browser/chains/kovan.json","node_modules/@ethereumjs/common/dist.browser/chains/goerli.json","node_modules/@ethereumjs/common/dist.browser/chains/sepolia.json","node_modules/@ethereumjs/common/dist.browser/chains/index.js","node_modules/@ethereumjs/common/dist.browser/hardforks/chainstart.json","node_modules/@ethereumjs/common/dist.browser/hardforks/homestead.json","node_modules/@ethereumjs/common/dist.browser/hardforks/dao.json","node_modules/@ethereumjs/common/dist.browser/hardforks/tangerineWhistle.json","node_modules/@ethereumjs/common/dist.browser/hardforks/spuriousDragon.json","node_modules/@ethereumjs/common/dist.browser/hardforks/byzantium.json","node_modules/@ethereumjs/common/dist.browser/hardforks/constantinople.json","node_modules/@ethereumjs/common/dist.browser/hardforks/petersburg.json","node_modules/@ethereumjs/common/dist.browser/hardforks/istanbul.json","node_modules/@ethereumjs/common/dist.browser/hardforks/muirGlacier.json","node_modules/@ethereumjs/common/dist.browser/hardforks/berlin.json","node_modules/@ethereumjs/common/dist.browser/hardforks/london.json","node_modules/@ethereumjs/common/dist.browser/hardforks/shanghai.json","node_modules/@ethereumjs/common/dist.browser/hardforks/arrowGlacier.json","node_modules/@ethereumjs/common/dist.browser/hardforks/grayGlacier.json","node_modules/@ethereumjs/common/dist.browser/hardforks/mergeForkIdTransition.json","node_modules/@ethereumjs/common/dist.browser/hardforks/merge.json","node_modules/@ethereumjs/common/dist.browser/hardforks/index.js","node_modules/@ethereumjs/common/dist.browser/eips/1153.json","node_modules/@ethereumjs/common/dist.browser/eips/1559.json","node_modules/@ethereumjs/common/dist.browser/eips/2315.json","node_modules/@ethereumjs/common/dist.browser/eips/2537.json","node_modules/@ethereumjs/common/dist.browser/eips/2565.json","node_modules/@ethereumjs/common/dist.browser/eips/2718.json","node_modules/@ethereumjs/common/dist.browser/eips/2929.json","node_modules/@ethereumjs/common/dist.browser/eips/2930.json","node_modules/@ethereumjs/common/dist.browser/eips/3198.json","node_modules/@ethereumjs/common/dist.browser/eips/3529.json","node_modules/@ethereumjs/common/dist.browser/eips/3540.json","node_modules/@ethereumjs/common/dist.browser/eips/3541.json","node_modules/@ethereumjs/common/dist.browser/eips/3554.json","node_modules/@ethereumjs/common/dist.browser/eips/3607.json","node_modules/@ethereumjs/common/dist.browser/eips/3651.json","node_modules/@ethereumjs/common/dist.browser/eips/3670.json","node_modules/@ethereumjs/common/dist.browser/eips/3675.json","node_modules/@ethereumjs/common/dist.browser/eips/3855.json","node_modules/@ethereumjs/common/dist.browser/eips/3860.json","node_modules/@ethereumjs/common/dist.browser/eips/4345.json","node_modules/@ethereumjs/common/dist.browser/eips/4399.json","node_modules/@ethereumjs/common/dist.browser/eips/5133.json","node_modules/@ethereumjs/common/dist.browser/eips/index.js","node_modules/@ethereumjs/common/dist.browser/genesisStates/mainnet.json","node_modules/@ethereumjs/common/dist.browser/genesisStates/ropsten.json","node_modules/@ethereumjs/common/dist.browser/genesisStates/rinkeby.json","node_modules/@ethereumjs/common/dist.browser/genesisStates/kovan.json","node_modules/@ethereumjs/common/dist.browser/genesisStates/goerli.json","node_modules/@ethereumjs/common/dist.browser/genesisStates/sepolia.json","node_modules/@ethereumjs/common/dist.browser/index.js","node_modules/@ethereumjs/tx/dist.browser/baseTransaction.js","node_modules/@ethereumjs/tx/dist.browser/util.js","node_modules/@ethereumjs/tx/dist.browser/legacyTransaction.js","node_modules/@ethereumjs/tx/dist.browser/eip2930Transaction.js","node_modules/@ethereumjs/tx/dist.browser/transactionFactory.js","node_modules/@ethereumjs/tx/dist.browser/eip1559Transaction.js","node_modules/@ethereumjs/tx/dist.browser/index.js","node_modules/number-to-bn/node_modules/bn.js/lib/bn.js","node_modules/is-hex-prefixed/src/index.js","node_modules/strip-hex-prefix/src/index.js","node_modules/number-to-bn/src/index.js","node_modules/ethjs-unit/node_modules/bn.js/lib/bn.js","node_modules/ethjs-unit/lib/index.js","node_modules/@opengsn/common/dist/web3js/Web3JSUtils.js","node_modules/@ethersproject/contracts/lib.esm/_version.js","node_modules/@ethersproject/contracts/lib.esm/index.js","node_modules/@ethersproject/pbkdf2/lib.esm/pbkdf2.js","node_modules/@ethersproject/pbkdf2/lib.esm/index.js","node_modules/@ethersproject/wordlists/lib.esm/_version.js","node_modules/@ethersproject/wordlists/lib.esm/wordlist.js","node_modules/@ethersproject/wordlists/lib.esm/lang-en.js","node_modules/@ethersproject/wordlists/lib.esm/wordlists.js","node_modules/@ethersproject/wordlists/lib.esm/index.js","node_modules/@ethersproject/hdnode/lib.esm/_version.js","node_modules/@ethersproject/hdnode/lib.esm/index.js","node_modules/@ethersproject/json-wallets/node_modules/aes-js/index.js","node_modules/@ethersproject/json-wallets/lib.esm/_version.js","node_modules/@ethersproject/json-wallets/lib.esm/utils.js","node_modules/@ethersproject/json-wallets/lib.esm/crowdsale.js","node_modules/@ethersproject/json-wallets/lib.esm/inspect.js","node_modules/scrypt-js/scrypt.js","node_modules/@ethersproject/json-wallets/lib.esm/keystore.js","node_modules/@ethersproject/json-wallets/lib.esm/index.js","node_modules/@ethersproject/wallet/lib.esm/_version.js","node_modules/@ethersproject/wallet/lib.esm/index.js","node_modules/@ethersproject/solidity/lib.esm/_version.js","node_modules/@ethersproject/solidity/lib.esm/index.js","node_modules/@ethersproject/units/lib.esm/_version.js","node_modules/@ethersproject/units/lib.esm/index.js","node_modules/ethers/lib.esm/utils.js","node_modules/ethers/lib.esm/_version.js","node_modules/ethers/lib.esm/ethers.js","node_modules/ethers/lib.esm/index.js","node_modules/ethers/lib/utils.js","node_modules/@opengsn/common/dist/Utils.js","node_modules/@opengsn/common/dist/interfaces/IPaymaster.json","node_modules/@opengsn/common/dist/interfaces/IRelayHub.json","node_modules/@opengsn/common/dist/interfaces/IForwarder.json","node_modules/@opengsn/common/dist/interfaces/IStakeManager.json","node_modules/@opengsn/common/dist/interfaces/IPenalizer.json","node_modules/@opengsn/common/dist/interfaces/IRelayRegistrar.json","node_modules/@opengsn/common/dist/Constants.js","node_modules/@opengsn/common/dist/AmountRequired.js","node_modules/@opengsn/common/dist/ConfigResponse.js","node_modules/@opengsn/common/dist/interfaces/IERC2771Recipient.json","node_modules/@opengsn/common/dist/interfaces/IERC20Token.json","node_modules/semver/internal/constants.js","node_modules/semver/internal/debug.js","node_modules/semver/internal/re.js","node_modules/semver/internal/parse-options.js","node_modules/semver/internal/identifiers.js","node_modules/semver/classes/semver.js","node_modules/semver/functions/parse.js","node_modules/semver/functions/valid.js","node_modules/semver/functions/clean.js","node_modules/semver/functions/inc.js","node_modules/semver/functions/diff.js","node_modules/semver/functions/major.js","node_modules/semver/functions/minor.js","node_modules/semver/functions/patch.js","node_modules/semver/functions/prerelease.js","node_modules/semver/functions/compare.js","node_modules/semver/functions/rcompare.js","node_modules/semver/functions/compare-loose.js","node_modules/semver/functions/compare-build.js","node_modules/semver/functions/sort.js","node_modules/semver/functions/rsort.js","node_modules/semver/functions/gt.js","node_modules/semver/functions/lt.js","node_modules/semver/functions/eq.js","node_modules/semver/functions/neq.js","node_modules/semver/functions/gte.js","node_modules/semver/functions/lte.js","node_modules/semver/functions/cmp.js","node_modules/semver/functions/coerce.js","node_modules/semver/internal/lrucache.js","node_modules/semver/classes/range.js","node_modules/semver/classes/comparator.js","node_modules/semver/functions/satisfies.js","node_modules/semver/ranges/to-comparators.js","node_modules/semver/ranges/max-satisfying.js","node_modules/semver/ranges/min-satisfying.js","node_modules/semver/ranges/min-version.js","node_modules/semver/ranges/valid.js","node_modules/semver/ranges/outside.js","node_modules/semver/ranges/gtr.js","node_modules/semver/ranges/ltr.js","node_modules/semver/ranges/intersects.js","node_modules/semver/ranges/simplify.js","node_modules/semver/ranges/subset.js","node_modules/semver/index.js","node_modules/@opengsn/common/dist/VersionsManager.js","node_modules/@opengsn/common/dist/ErrorReplacerJSON.js","node_modules/@opengsn/common/dist/LightTruffleContract.js","node_modules/@opengsn/common/package.json","node_modules/@opengsn/common/dist/Version.js","node_modules/@opengsn/common/dist/types/GSNContractsDataTypes.js","node_modules/@opengsn/common/dist/types/TransactionType.js","node_modules/@opengsn/common/dist/environments/MainnetCalldataGasEstimation.js","node_modules/@opengsn/common/dist/environments/AsyncZeroAddressCalldataGasEstimation.js","node_modules/@opengsn/common/dist/ContractInteractor.js","node_modules/@opengsn/common/dist/environments/Environments.js","node_modules/@opengsn/common/dist/GSNContractsDeployment.js","node_modules/@opengsn/common/dist/HttpClient.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/bind.js","node_modules/@opengsn/common/node_modules/axios/lib/utils.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/buildURL.js","node_modules/@opengsn/common/node_modules/axios/lib/core/InterceptorManager.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/normalizeHeaderName.js","node_modules/@opengsn/common/node_modules/axios/lib/core/enhanceError.js","node_modules/@opengsn/common/node_modules/axios/lib/core/createError.js","node_modules/@opengsn/common/node_modules/axios/lib/core/settle.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/cookies.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/isAbsoluteURL.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/combineURLs.js","node_modules/@opengsn/common/node_modules/axios/lib/core/buildFullPath.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/parseHeaders.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/isURLSameOrigin.js","node_modules/@opengsn/common/node_modules/axios/lib/adapters/xhr.js","node_modules/@opengsn/common/node_modules/axios/lib/defaults.js","node_modules/@opengsn/common/node_modules/axios/lib/core/transformData.js","node_modules/@opengsn/common/node_modules/axios/lib/cancel/isCancel.js","node_modules/@opengsn/common/node_modules/axios/lib/core/dispatchRequest.js","node_modules/@opengsn/common/node_modules/axios/lib/core/mergeConfig.js","node_modules/@opengsn/common/node_modules/axios/package.json","node_modules/@opengsn/common/node_modules/axios/lib/helpers/validator.js","node_modules/@opengsn/common/node_modules/axios/lib/core/Axios.js","node_modules/@opengsn/common/node_modules/axios/lib/cancel/Cancel.js","node_modules/@opengsn/common/node_modules/axios/lib/cancel/CancelToken.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/spread.js","node_modules/@opengsn/common/node_modules/axios/lib/helpers/isAxiosError.js","node_modules/@opengsn/common/node_modules/axios/lib/axios.js","node_modules/@opengsn/common/node_modules/axios/index.js","node_modules/@opengsn/common/dist/HttpWrapper.js","node_modules/@opengsn/common/dist/LoggerInterface.js","node_modules/@opengsn/common/dist/PingResponse.js","node_modules/@opengsn/common/dist/StatsResponse.js","node_modules/@opengsn/common/dist/types/Aliases.js","node_modules/@opengsn/common/dist/EIP712/ForwardRequest.js","node_modules/@opengsn/common/dist/EIP712/RelayData.js","node_modules/@opengsn/common/dist/EIP712/RelayRequest.js","node_modules/@metamask/eth-sig-util/node_modules/bn.js/lib/bn.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/secp256k1v3-lib/index.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/secp256k1v3-lib/der.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/secp256k1v3-adapter.js","node_modules/ethjs-util/lib/index.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/constants.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/bytes.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/hash.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/account.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/signature.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/object.js","node_modules/@metamask/eth-sig-util/node_modules/ethereumjs-util/dist/index.js","node_modules/@metamask/eth-sig-util/dist/utils.js","node_modules/@metamask/eth-sig-util/dist/personal-sign.js","node_modules/ethereumjs-abi/node_modules/bn.js/lib/bn.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/secp256k1v3-lib/index.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/secp256k1v3-lib/der.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/secp256k1v3-adapter.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/constants.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/bytes.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/hash.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/account.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/signature.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/object.js","node_modules/ethereumjs-abi/node_modules/ethereumjs-util/dist/index.js","node_modules/ethereumjs-abi/lib/index.js","node_modules/ethereumjs-abi/index.js","node_modules/@metamask/eth-sig-util/dist/sign-typed-data.js","node_modules/tweetnacl/nacl-fast.js","node_modules/tweetnacl-util/nacl-util.js","node_modules/@metamask/eth-sig-util/dist/encryption.js","node_modules/@metamask/eth-sig-util/dist/index.js","node_modules/@opengsn/common/dist/EIP712/TypedRequestData.js","node_modules/callsites/index.js","node_modules/ow/dist/utils/infer-label.browser.js","node_modules/@sindresorhus/is/dist/index.js","node_modules/ow/dist/utils/generate-stack.js","node_modules/ow/dist/argument-error.js","node_modules/ow/dist/utils/random-id.js","node_modules/ow/dist/operators/not.js","node_modules/ow/dist/predicates/base-predicate.js","node_modules/ow/dist/utils/generate-argument-error-message.js","node_modules/ow/dist/predicates/predicate.js","node_modules/vali-date/index.js","node_modules/ow/dist/predicates/string.js","node_modules/ow/dist/predicates/number.js","node_modules/ow/dist/predicates/bigint.js","node_modules/ow/dist/predicates/boolean.js","node_modules/lodash.isequal/index.js","node_modules/ow/dist/test.js","node_modules/ow/dist/utils/match-shape.js","node_modules/ow/dist/utils/of-type.js","node_modules/ow/dist/predicates/array.js","node_modules/is-obj/index.js","node_modules/dot-prop/index.js","node_modules/ow/dist/utils/has-items.js","node_modules/ow/dist/utils/of-type-deep.js","node_modules/ow/dist/predicates/object.js","node_modules/ow/dist/predicates/date.js","node_modules/ow/dist/predicates/error.js","node_modules/ow/dist/predicates/map.js","node_modules/ow/dist/predicates/weak-map.js","node_modules/ow/dist/predicates/set.js","node_modules/ow/dist/predicates/weak-set.js","node_modules/ow/dist/predicates/typed-array.js","node_modules/ow/dist/predicates/array-buffer.js","node_modules/ow/dist/predicates/data-view.js","node_modules/ow/dist/predicates/any.js","node_modules/ow/dist/predicates.js","node_modules/ow/dist/modifiers.js","node_modules/ow/dist/index.js","node_modules/@opengsn/common/dist/types/AuditRequest.js","node_modules/@opengsn/common/dist/types/GsnTransactionDetails.js","node_modules/@opengsn/common/dist/types/PaymasterConfiguration.js","node_modules/@opengsn/common/dist/types/PenalizerConfiguration.js","node_modules/@opengsn/common/dist/types/RelayFailureInfo.js","node_modules/@opengsn/common/dist/types/RelayHubConfiguration.js","node_modules/@opengsn/common/dist/types/RelayInfo.js","node_modules/@opengsn/common/dist/types/RelayTransactionRequest.js","node_modules/@opengsn/common/dist/web3js/FeeHistoryResult.js","node_modules/@opengsn/common/dist/web3js/JsonRpcPayload.js","node_modules/@opengsn/common/dist/web3js/JsonRpcResponse.js","node_modules/@opengsn/common/dist/web3js/RLPEncodedTransaction.js","node_modules/@opengsn/common/dist/index.js","node_modules/base-x/src/index.js","node_modules/bs58/index.js","node_modules/bs58check/base.js","node_modules/bs58check/index.js","node_modules/ethereum-cryptography/pure/ripemd160.js","node_modules/ethereum-cryptography/pure/sha256.js","node_modules/create-hmac/legacy.js","node_modules/create-hash/md5.js","node_modules/create-hmac/browser.js","node_modules/ethereum-cryptography/pure/shims/hdkey-crypto.js","node_modules/ethereum-cryptography/shims/hdkey-secp256k1v3.js","node_modules/ethereum-cryptography/pure/shims/hdkey-secp256k1v3.js","node_modules/ethereum-cryptography/pure/vendor/hdkey-without-crypto.js","node_modules/ethereum-cryptography/pure/hdkey.js","node_modules/ethereumjs-wallet/dist.browser/hdkey.js","node_modules/utf8/utf8.js","node_modules/aes-js/index.js","node_modules/ethereumjs-wallet/dist.browser/thirdparty.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/rng.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/regex.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/validate.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/stringify.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/v1.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/parse.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/v35.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/md5.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/v3.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/v4.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/sha1.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/v5.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/nil.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/version.js","node_modules/ethereumjs-wallet/node_modules/uuid/dist/esm-browser/index.js","node_modules/ethereumjs-wallet/dist.browser/index.js","node_modules/@opengsn/provider/dist/AccountManager.js","node_modules/@opengsn/provider/dist/GSNConfigurator.js","node_modules/@opengsn/provider/dist/GsnEvents.js","node_modules/@opengsn/provider/dist/KnownRelaysManager.js","node_modules/@opengsn/provider/dist/RelaySelectionManager.js","node_modules/@opengsn/provider/dist/VerifierUtils.js","node_modules/@opengsn/provider/dist/RelayedTransactionValidator.js","node_modules/@opengsn/provider/dist/RelayClient.js","node_modules/@noble/curves/node_modules/@noble/hashes/_assert.js","node_modules/@noble/curves/node_modules/@noble/hashes/crypto.js","node_modules/@noble/curves/node_modules/@noble/hashes/utils.js","node_modules/@noble/curves/node_modules/@noble/hashes/_md.js","node_modules/@noble/curves/node_modules/@noble/hashes/sha256.js","node_modules/@noble/curves/node_modules/@noble/hashes/hmac.js","node_modules/@noble/curves/abstract/utils.js","node_modules/@noble/curves/abstract/modular.js","node_modules/@noble/curves/abstract/curve.js","node_modules/@noble/curves/abstract/weierstrass.js","node_modules/@noble/curves/_shortw_utils.js","node_modules/@noble/curves/abstract/hash-to-curve.js","node_modules/@noble/curves/secp256k1.js","node_modules/@ethereumjs/util/node_modules/ethereum-cryptography/secp256k1.js","node_modules/@ethereumjs/util/dist/constants.js","node_modules/@ethereumjs/util/dist/units.js","node_modules/@ethereumjs/rlp/dist/index.js","node_modules/@ethereumjs/util/node_modules/@noble/hashes/_assert.js","node_modules/@ethereumjs/util/node_modules/@noble/hashes/_u64.js","node_modules/@ethereumjs/util/node_modules/@noble/hashes/crypto.js","node_modules/@ethereumjs/util/node_modules/@noble/hashes/utils.js","node_modules/@ethereumjs/util/node_modules/@noble/hashes/sha3.js","node_modules/@ethereumjs/util/node_modules/ethereum-cryptography/utils.js","node_modules/@ethereumjs/util/node_modules/ethereum-cryptography/keccak.js","node_modules/@ethereumjs/util/dist/internal.js","node_modules/@ethereumjs/util/dist/helpers.js","node_modules/@ethereumjs/util/dist/bytes.js","node_modules/@ethereumjs/util/dist/account.js","node_modules/@ethereumjs/util/dist/address.js","node_modules/@ethereumjs/util/dist/types.js","node_modules/@ethereumjs/util/dist/withdrawal.js","node_modules/@ethereumjs/util/dist/signature.js","node_modules/@ethereumjs/util/dist/encoding.js","node_modules/@ethereumjs/util/dist/asyncEventEmitter.js","node_modules/@ethereumjs/util/dist/lock.js","node_modules/punycode/punycode.js","node_modules/object-inspect/index.js","node_modules/side-channel/index.js","node_modules/qs/lib/formats.js","node_modules/qs/lib/utils.js","node_modules/qs/lib/stringify.js","node_modules/qs/lib/parse.js","node_modules/qs/lib/index.js","node_modules/url/url.js","node_modules/micro-ftch/index.js","node_modules/@ethereumjs/util/dist/provider.js","node_modules/@ethereumjs/util/dist/index.js","node_modules/ethereum-bloom-filters/dist/utils.js","node_modules/ethereum-bloom-filters/dist/index.js","node_modules/web3-utils/node_modules/@noble/hashes/_assert.js","node_modules/web3-utils/node_modules/@noble/hashes/_u64.js","node_modules/web3-utils/node_modules/@noble/hashes/crypto.js","node_modules/web3-utils/node_modules/@noble/hashes/utils.js","node_modules/web3-utils/node_modules/@noble/hashes/sha3.js","node_modules/web3-utils/node_modules/ethereum-cryptography/utils.js","node_modules/web3-utils/node_modules/ethereum-cryptography/keccak.js","node_modules/web3-utils/lib/utils.js","node_modules/web3-utils/lib/soliditySha3.js","node_modules/web3-utils/lib/index.js","node_modules/web3-eth-abi/lib/index.js","node_modules/abi-decoder/index.js","node_modules/@opengsn/provider/dist/RelayProvider.js","node_modules/@opengsn/provider/dist/WrapContract.js","node_modules/@opengsn/provider/dist/index.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/heartbeat/node_modules/tslib/tslib.es6.js","node_modules/@walletconnect/events/dist/esm/events.js","node_modules/@walletconnect/events/dist/esm/index.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/heartbeat/dist/cjs/types/heartbeat.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/heartbeat/dist/cjs/types/index.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/heartbeat/dist/cjs/constants/heartbeat.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/heartbeat/dist/cjs/constants/index.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/heartbeat/dist/cjs/heartbeat.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/heartbeat/dist/cjs/index.js","node_modules/quick-format-unescaped/index.js","node_modules/pino/browser.js","node_modules/@walletconnect/environment/node_modules/tslib/tslib.es6.js","node_modules/@walletconnect/environment/dist/cjs/crypto.js","node_modules/@walletconnect/environment/dist/cjs/env.js","node_modules/@walletconnect/environment/dist/cjs/index.js","node_modules/ws/browser.js","node_modules/unfetch/dist/unfetch.module.js","node_modules/isomorphic-unfetch/browser.js","node_modules/cross-fetch/dist/browser-ponyfill.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/assets/wallet-logo.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/constants.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/lib/ScopedLocalStorage.js","node_modules/@listat/blockchain-providers/node_modules/@metamask/safe-event-emitter/index.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/connection/DiagnosticLogger.js","node_modules/fast-safe-stringify/index.js","node_modules/@listat/blockchain-providers/node_modules/eth-rpc-errors/dist/classes.js","node_modules/@listat/blockchain-providers/node_modules/eth-rpc-errors/dist/error-constants.js","node_modules/@listat/blockchain-providers/node_modules/eth-rpc-errors/dist/utils.js","node_modules/@listat/blockchain-providers/node_modules/eth-rpc-errors/dist/errors.js","node_modules/@listat/blockchain-providers/node_modules/eth-rpc-errors/dist/index.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/Web3Method.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/Web3Response.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/version.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/errors.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/types.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/util.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/Session.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/WalletSDKRelayAbstract.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/vendor-js/eth-eip712-util/util.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/vendor-js/eth-eip712-util/abi.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/vendor-js/eth-eip712-util/index.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/provider/FilterPolyfill.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/provider/JSONRPC.js","node_modules/json-rpc-random-id/index.js","node_modules/eth-block-tracker/node_modules/pify/index.js","node_modules/eth-block-tracker/node_modules/@metamask/safe-event-emitter/index.js","node_modules/eth-block-tracker/dist/BaseBlockTracker.js","node_modules/@metamask/utils/node_modules/superstruct/dist/index.mjs","node_modules/@metamask/utils/dist/assert.js","node_modules/@metamask/utils/dist/base64.js","node_modules/@metamask/utils/dist/hex.js","node_modules/@metamask/utils/dist/bytes.js","node_modules/@metamask/utils/dist/checksum.js","node_modules/@metamask/utils/dist/coercers.js","node_modules/@metamask/utils/dist/collections.js","node_modules/@metamask/utils/dist/misc.js","node_modules/@metamask/utils/dist/json.js","node_modules/ms/index.js","node_modules/debug/src/common.js","node_modules/debug/src/browser.js","node_modules/@metamask/utils/dist/logging.js","node_modules/@metamask/utils/dist/number.js","node_modules/@metamask/utils/dist/opaque.js","node_modules/@metamask/utils/dist/time.js","node_modules/@metamask/utils/dist/versions.js","node_modules/@metamask/utils/dist/index.js","node_modules/eth-block-tracker/dist/logging-utils.js","node_modules/eth-block-tracker/dist/PollingBlockTracker.js","node_modules/eth-block-tracker/dist/SubscribeBlockTracker.js","node_modules/eth-block-tracker/dist/types.js","node_modules/eth-block-tracker/dist/index.js","node_modules/eth-json-rpc-filters/node_modules/@metamask/safe-event-emitter/index.js","node_modules/json-rpc-engine/dist/getUniqueId.js","node_modules/json-rpc-engine/dist/idRemapMiddleware.js","node_modules/json-rpc-engine/dist/createAsyncMiddleware.js","node_modules/json-rpc-engine/dist/createScaffoldMiddleware.js","node_modules/json-rpc-engine/node_modules/@metamask/safe-event-emitter/index.js","node_modules/eth-rpc-errors/dist/classes.js","node_modules/eth-rpc-errors/dist/error-constants.js","node_modules/eth-rpc-errors/dist/utils.js","node_modules/eth-rpc-errors/dist/errors.js","node_modules/eth-rpc-errors/dist/index.js","node_modules/json-rpc-engine/dist/JsonRpcEngine.js","node_modules/json-rpc-engine/dist/mergeMiddleware.js","node_modules/json-rpc-engine/dist/index.js","node_modules/async-mutex/lib/Semaphore.js","node_modules/async-mutex/lib/Mutex.js","node_modules/async-mutex/lib/withTimeout.js","node_modules/async-mutex/lib/index.js","node_modules/xtend/immutable.js","node_modules/eth-query/index.js","node_modules/eth-json-rpc-filters/node_modules/pify/index.js","node_modules/eth-json-rpc-filters/base-filter.js","node_modules/eth-json-rpc-filters/base-filter-history.js","node_modules/eth-json-rpc-filters/hexUtils.js","node_modules/eth-json-rpc-filters/log-filter.js","node_modules/eth-json-rpc-filters/getBlocksForRange.js","node_modules/eth-json-rpc-filters/block-filter.js","node_modules/eth-json-rpc-filters/tx-filter.js","node_modules/eth-json-rpc-filters/index.js","node_modules/eth-json-rpc-filters/subscriptionManager.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/provider/SubscriptionManager.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/provider/CoinbaseWalletProvider.js","node_modules/preact/dist/preact.module.js","node_modules/clsx/dist/clsx.m.js","node_modules/preact/hooks/dist/hooks.module.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/CloseIcon.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/coinbase-round-svg.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/coinbase-wallet-round-svg.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/QRCodeIcon.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/QRLogoCoinbase.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/QRLogoWallet.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/StatusDotIcon.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/vendor-js/qrcode-svg/index.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/QRCode.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/Spinner/Spinner-css.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/Spinner/Spinner.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/ConnectContent/ConnectContent-css.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/ConnectContent/ConnectContent.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/ArrowLeftIcon.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/LaptopIcon.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/icons/SafeIcon.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/TryExtensionContent/TryExtensionContent-css.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/TryExtensionContent/TryExtensionContent.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/ConnectDialog/ConnectDialog-css.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/ConnectDialog/ConnectDialog.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/LinkFlow/LinkFlow.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/Snackbar/Snackbar-css.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/components/Snackbar/Snackbar.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/lib/cssReset-css.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/lib/cssReset.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/provider/WalletSDKUI.js","node_modules/bind-decorator/index.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/connection/ClientMessage.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/connection/RxWebSocket.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/connection/ServerMessage.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/connection/WalletSDKConnection.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/aes256gcm.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/RelayMessage.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/Web3RequestCanceledMessage.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/Web3RequestMessage.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/Web3ResponseMessage.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/WalletSDKRelay.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/relay/WalletSDKRelayEventManager.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/CoinbaseWalletSDK.js","node_modules/@listat/blockchain-providers/node_modules/@coinbase/wallet-sdk/dist/index.js","node_modules/rxjs/dist/esm/internal/util/createErrorClass.js","node_modules/rxjs/dist/esm/internal/util/EmptyError.js","node_modules/rxjs/dist/esm/internal/util/isFunction.js","node_modules/rxjs/dist/esm/internal/util/UnsubscriptionError.js","node_modules/rxjs/dist/esm/internal/util/arrRemove.js","node_modules/rxjs/dist/esm/internal/Subscription.js","node_modules/rxjs/dist/esm/internal/config.js","node_modules/rxjs/dist/esm/internal/scheduler/timeoutProvider.js","node_modules/rxjs/dist/esm/internal/util/reportUnhandledError.js","node_modules/rxjs/dist/esm/internal/util/noop.js","node_modules/rxjs/dist/esm/internal/NotificationFactories.js","node_modules/rxjs/dist/esm/internal/util/errorContext.js","node_modules/rxjs/dist/esm/internal/Subscriber.js","node_modules/rxjs/dist/esm/internal/firstValueFrom.js","node_modules/rxjs/dist/esm/internal/symbol/observable.js","node_modules/rxjs/dist/esm/internal/util/identity.js","node_modules/rxjs/dist/esm/internal/util/pipe.js","node_modules/rxjs/dist/esm/internal/Observable.js","node_modules/rxjs/dist/esm/internal/util/lift.js","node_modules/rxjs/dist/esm/internal/operators/OperatorSubscriber.js","node_modules/rxjs/dist/esm/internal/operators/refCount.js","node_modules/rxjs/dist/esm/internal/observable/ConnectableObservable.js","node_modules/rxjs/dist/esm/internal/scheduler/animationFrameProvider.js","node_modules/rxjs/dist/esm/internal/util/ObjectUnsubscribedError.js","node_modules/rxjs/dist/esm/internal/Subject.js","node_modules/rxjs/dist/esm/internal/BehaviorSubject.js","node_modules/rxjs/dist/esm/internal/scheduler/dateTimestampProvider.js","node_modules/rxjs/dist/esm/internal/ReplaySubject.js","node_modules/rxjs/dist/esm/internal/scheduler/Action.js","node_modules/rxjs/dist/esm/internal/scheduler/intervalProvider.js","node_modules/rxjs/dist/esm/internal/scheduler/AsyncAction.js","node_modules/rxjs/dist/esm/internal/util/Immediate.js","node_modules/rxjs/dist/esm/internal/scheduler/immediateProvider.js","node_modules/rxjs/dist/esm/internal/scheduler/AsapAction.js","node_modules/rxjs/dist/esm/internal/Scheduler.js","node_modules/rxjs/dist/esm/internal/scheduler/AsyncScheduler.js","node_modules/rxjs/dist/esm/internal/scheduler/AsapScheduler.js","node_modules/rxjs/dist/esm/internal/scheduler/asap.js","node_modules/rxjs/dist/esm/internal/scheduler/async.js","node_modules/rxjs/dist/esm/internal/scheduler/AnimationFrameAction.js","node_modules/rxjs/dist/esm/internal/scheduler/AnimationFrameScheduler.js","node_modules/rxjs/dist/esm/internal/scheduler/animationFrame.js","node_modules/rxjs/dist/esm/internal/observable/empty.js","node_modules/rxjs/dist/esm/internal/util/isScheduler.js","node_modules/rxjs/dist/esm/internal/util/args.js","node_modules/rxjs/dist/esm/internal/observable/innerFrom.js","node_modules/rxjs/dist/esm/internal/util/isArrayLike.js","node_modules/rxjs/dist/esm/internal/util/isPromise.js","node_modules/rxjs/dist/esm/internal/util/isInteropObservable.js","node_modules/rxjs/dist/esm/internal/util/isAsyncIterable.js","node_modules/rxjs/dist/esm/internal/util/throwUnobservableError.js","node_modules/rxjs/dist/esm/internal/symbol/iterator.js","node_modules/rxjs/dist/esm/internal/util/isIterable.js","node_modules/rxjs/dist/esm/internal/util/isReadableStreamLike.js","node_modules/rxjs/dist/esm/internal/util/executeSchedule.js","node_modules/rxjs/dist/esm/internal/operators/observeOn.js","node_modules/rxjs/dist/esm/internal/operators/subscribeOn.js","node_modules/rxjs/dist/esm/internal/scheduled/scheduleObservable.js","node_modules/rxjs/dist/esm/internal/scheduled/schedulePromise.js","node_modules/rxjs/dist/esm/internal/scheduled/scheduleArray.js","node_modules/rxjs/dist/esm/internal/scheduled/scheduleIterable.js","node_modules/rxjs/dist/esm/internal/scheduled/scheduleAsyncIterable.js","node_modules/rxjs/dist/esm/internal/scheduled/scheduleReadableStreamLike.js","node_modules/rxjs/dist/esm/internal/scheduled/scheduled.js","node_modules/rxjs/dist/esm/internal/observable/from.js","node_modules/rxjs/dist/esm/internal/observable/of.js","node_modules/rxjs/dist/esm/internal/observable/throwError.js","node_modules/rxjs/dist/esm/internal/util/isObservable.js","node_modules/rxjs/dist/esm/internal/util/isDate.js","node_modules/rxjs/dist/esm/internal/operators/map.js","node_modules/rxjs/dist/esm/internal/util/mapOneOrManyArgs.js","node_modules/rxjs/dist/esm/internal/util/argsArgArrayOrObject.js","node_modules/rxjs/dist/esm/internal/util/createObject.js","node_modules/rxjs/dist/esm/internal/observable/combineLatest.js","node_modules/rxjs/dist/esm/internal/operators/mergeInternals.js","node_modules/rxjs/dist/esm/internal/operators/mergeMap.js","node_modules/rxjs/dist/esm/internal/operators/mergeAll.js","node_modules/rxjs/dist/esm/internal/operators/concatAll.js","node_modules/rxjs/dist/esm/internal/observable/concat.js","node_modules/rxjs/dist/esm/internal/observable/defer.js","node_modules/rxjs/dist/esm/internal/observable/forkJoin.js","node_modules/rxjs/dist/esm/internal/observable/fromEvent.js","node_modules/rxjs/dist/esm/internal/observable/timer.js","node_modules/rxjs/dist/esm/internal/observable/merge.js","node_modules/rxjs/dist/esm/internal/operators/filter.js","node_modules/rxjs/dist/esm/internal/operators/audit.js","node_modules/rxjs/dist/esm/internal/operators/auditTime.js","node_modules/rxjs/dist/esm/internal/operators/catchError.js","node_modules/rxjs/dist/esm/internal/operators/scanInternals.js","node_modules/rxjs/dist/esm/internal/operators/concatMap.js","node_modules/rxjs/dist/esm/internal/operators/debounceTime.js","node_modules/rxjs/dist/esm/internal/operators/defaultIfEmpty.js","node_modules/rxjs/dist/esm/internal/operators/take.js","node_modules/rxjs/dist/esm/internal/operators/mapTo.js","node_modules/rxjs/dist/esm/internal/operators/throwIfEmpty.js","node_modules/rxjs/dist/esm/internal/operators/finalize.js","node_modules/rxjs/dist/esm/internal/operators/first.js","node_modules/rxjs/dist/esm/internal/operators/takeLast.js","node_modules/rxjs/dist/esm/internal/operators/last.js","node_modules/rxjs/dist/esm/internal/operators/scan.js","node_modules/rxjs/dist/esm/internal/operators/startWith.js","node_modules/rxjs/dist/esm/internal/operators/switchMap.js","node_modules/rxjs/dist/esm/internal/operators/takeUntil.js","node_modules/rxjs/dist/esm/internal/operators/takeWhile.js","node_modules/rxjs/dist/esm/internal/operators/tap.js","node_modules/@angular/core/fesm2022/primitives/signals.mjs","node_modules/@angular/core/fesm2022/core.mjs","node_modules/@angular/common/fesm2022/common.mjs","node_modules/@angular/common/fesm2022/http.mjs","node_modules/@angular/platform-browser/fesm2022/platform-browser.mjs","node_modules/@angular/router/fesm2022/router.mjs","node_modules/@angular/forms/fesm2022/forms.mjs","node_modules/@listat/blockchain-providers/node_modules/@ng-select/ng-select/fesm2022/ng-select-ng-select.mjs","node_modules/@listat/blockchain-providers/fesm2022/listat-blockchain-providers.mjs","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-account-button/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-button/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-button/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-connect-button/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-network-button/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-network-button/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-router/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/modal/w3m-router/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-account-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-account-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-all-wallets-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-connect-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-connect-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/utils/w3m-connecting-widget/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/utils/w3m-connecting-widget/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-connecting-external-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-connecting-siwe-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-connecting-wc-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-downloads-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-get-wallet-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-network-switch-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-network-switch-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-networks-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-networks-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-transactions-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-transactions-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-what-is-a-network-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-what-is-a-wallet-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-email-verify-otp-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/wallet/dist/esm/src/W3mFrameConstants.js","node_modules/zod/lib/index.mjs","node_modules/@listat/blockchain-providers/node_modules/@web3modal/wallet/dist/esm/src/W3mFrameSchema.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/wallet/dist/esm/src/W3mFrameStorage.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/wallet/dist/esm/src/W3mFrameHelpers.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-email-verify-otp-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-email-verify-device-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-email-verify-device-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-approve-transaction-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-approve-transaction-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-upgrade-wallet-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-update-email-wallet-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-update-email-wallet-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-update-email-wallet-waiting-view/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/views/w3m-update-email-wallet-waiting-view/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-all-wallets-list/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/utils/markWalletsAsInstalled.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-all-wallets-list/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-all-wallets-search/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-all-wallets-search/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-header/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-wc-browser/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-wc-desktop/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-wc-mobile/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-wc-qrcode/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-wc-qrcode/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-siwe/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-siwe/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-wc-unsupported/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-connecting-wc-web/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-header/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-header/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-help-widget/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-legal-footer/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-legal-footer/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-mobile-download-links/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-mobile-download-links/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-snackbar/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-snackbar/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-email-login-widget/styles.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/partials/w3m-email-login-widget/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold/dist/esm/src/client.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold-utils/dist/esm/src/ConstantsUtil.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold-utils/dist/esm/src/PresetsUtil.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold-utils/dist/esm/src/HelpersUtil.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/ethereum-provider/dist/index.es.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/utils/dist/index.es.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/core/dist/index.es.js","node_modules/destr/dist/index.mjs","node_modules/unstorage/dist/shared/unstorage.d569726e.mjs","node_modules/unstorage/dist/index.mjs","node_modules/idb-keyval/dist/index.js","node_modules/@walletconnect/keyvaluestorage/dist/index.es.js","node_modules/@walletconnect/logger/dist/index.es.js","node_modules/@walletconnect/types/dist/index.es.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/jsonrpc-provider/dist/esm/provider.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/index.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/constants.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/error.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/env.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/format.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/routing.js","node_modules/@walletconnect/jsonrpc-types/dist/index.es.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/url.js","node_modules/@walletconnect/jsonrpc-utils/dist/esm/validators.js","node_modules/@walletconnect/jsonrpc-ws-connection/dist/index.es.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/sign-client/dist/index.es.js","node_modules/@walletconnect/jsonrpc-http-connection/dist/index.es.js","node_modules/@listat/blockchain-providers/node_modules/@walletconnect/universal-provider/dist/index.es.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/ethers5/dist/esm/src/client.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold-utils/dist/esm/src/EthersConstantsUtil.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold-utils/dist/esm/src/EthersHelpersUtil.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/scaffold-utils/dist/esm/src/EthersStoreUtil.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/polyfills/dist/esm/index.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/ethers5/dist/esm/src/utils/defaultConfig.js","node_modules/@listat/blockchain-providers/node_modules/@web3modal/ethers5/dist/esm/exports/index.js"],"sourcesContent":["/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\n\nvar extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n};\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\nexport var __assign = function () {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n}\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length,\n r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc,\n d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\nexport function __param(paramIndex, decorator) {\n return function (target, key) {\n decorator(target, key, paramIndex);\n };\n}\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) {\n if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\");\n return f;\n }\n var kind = contextIn.kind,\n key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _,\n done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) {\n if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\");\n extraInitializers.push(accept(f || null));\n };\n var result = (0, decorators[i])(kind === \"accessor\" ? {\n get: descriptor.get,\n set: descriptor.set\n } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n } else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n}\n;\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n}\n;\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n}\n;\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", {\n configurable: true,\n value: prefix ? \"\".concat(prefix, \" \", name) : name\n });\n}\n;\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\nexport function __generator(thisArg, body) {\n var _ = {\n label: 0,\n sent: function () {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n },\n f,\n y,\n t,\n g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function () {\n return this;\n }), g;\n function verb(n) {\n return function (v) {\n return step([n, v]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [0];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [6, e];\n y = 0;\n } finally {\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n}\nexport var __createBinding = Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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};\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j];\n return r;\n}\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []),\n i,\n q = [];\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () {\n return this;\n }, i;\n function awaitReturn(f) {\n return function (v) {\n return Promise.resolve(v).then(f, reject);\n };\n }\n function verb(n, f) {\n if (g[n]) {\n i[n] = function (v) {\n return new Promise(function (a, b) {\n q.push([n, v, a, b]) > 1 || resume(n, v);\n });\n };\n if (f) i[n] = f(i[n]);\n }\n }\n function resume(n, v) {\n try {\n step(g[n](v));\n } catch (e) {\n settle(q[0][3], e);\n }\n }\n function step(r) {\n r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n }\n function fulfill(value) {\n resume(\"next\", value);\n }\n function reject(value) {\n resume(\"throw\", value);\n }\n function settle(f, v) {\n if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n }\n}\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) {\n throw e;\n }), verb(\"return\"), i[Symbol.iterator] = function () {\n return this;\n }, i;\n function verb(n, f) {\n i[n] = o[n] ? function (v) {\n return (p = !p) ? {\n value: __await(o[n](v)),\n done: false\n } : f ? f(v) : v;\n } : f;\n }\n}\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator],\n i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () {\n return this;\n }, i);\n function verb(n) {\n i[n] = o[n] && function (v) {\n return new Promise(function (resolve, reject) {\n v = o[n](v), settle(resolve, reject, v.done, v.value);\n });\n };\n }\n function settle(resolve, reject, d, v) {\n Promise.resolve(v).then(function (v) {\n resolve({\n value: v,\n done: d\n });\n }, reject);\n }\n}\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) {\n Object.defineProperty(cooked, \"raw\", {\n value: raw\n });\n } else {\n cooked.raw = raw;\n }\n return cooked;\n}\n;\nvar __setModuleDefault = Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n};\nvar ownKeys = function (o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n};\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n}\nexport function __importDefault(mod) {\n return mod && mod.__esModule ? mod : {\n default: mod\n };\n}\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value), value;\n}\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || typeof receiver !== \"object\" && typeof receiver !== \"function\") throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose, inner;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n if (async) inner = dispose;\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n if (inner) dispose = function () {\n try {\n inner.call(this);\n } catch (e) {\n return Promise.reject(e);\n }\n };\n env.stack.push({\n value: value,\n dispose: dispose,\n async: async\n });\n } else if (async) {\n env.stack.push({\n async: true\n });\n }\n return value;\n}\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n var r,\n s = 0;\n function next() {\n while (r = env.stack.pop()) {\n try {\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\n if (r.dispose) {\n var result = r.dispose.call(r.value);\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function (e) {\n fail(e);\n return next();\n });\n } else s |= 1;\n } catch (e) {\n fail(e);\n }\n }\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\n if (env.hasError) throw env.error;\n }\n return next();\n}\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : d + ext + \".\" + cm.toLowerCase() + \"js\";\n });\n }\n return path;\n}\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __esDecorate,\n __runInitializers,\n __propKey,\n __setFunctionName,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n __rewriteRelativeImportExtension\n};","export function isFunction(x) {\n return typeof x === 'function';\n}\n","let _enable_super_gross_mode_that_will_cause_bad_things = false;\nexport const config = {\n Promise: undefined,\n set useDeprecatedSynchronousErrorHandling(value) {\n if (value) {\n const error = new Error();\n console.warn('DEPRECATED! RxJS was set to use deprecated synchronous error handling behavior by code at: \\n' + error.stack);\n } else if (_enable_super_gross_mode_that_will_cause_bad_things) {\n console.log('RxJS: Back to a better error behavior. Thank you. <3');\n }\n _enable_super_gross_mode_that_will_cause_bad_things = value;\n },\n get useDeprecatedSynchronousErrorHandling() {\n return _enable_super_gross_mode_that_will_cause_bad_things;\n }\n};\n","export function hostReportError(err) {\n setTimeout(() => {\n throw err;\n }, 0);\n}\n","import { config } from './config';\nimport { hostReportError } from './util/hostReportError';\nexport const empty = {\n closed: true,\n next(value) {},\n error(err) {\n if (config.useDeprecatedSynchronousErrorHandling) {\n throw err;\n } else {\n hostReportError(err);\n }\n },\n complete() {}\n};\n","export const isArray = (() => Array.isArray || (x => x && typeof x.length === 'number'))();\n","export function isObject(x) {\n return x !== null && typeof x === 'object';\n}\n","const UnsubscriptionErrorImpl = (() => {\n function UnsubscriptionErrorImpl(errors) {\n Error.call(this);\n this.message = errors ? `${errors.length} errors occurred during unsubscription:\n${errors.map((err, i) => `${i + 1}) ${err.toString()}`).join('\\n ')}` : '';\n this.name = 'UnsubscriptionError';\n this.errors = errors;\n return this;\n }\n UnsubscriptionErrorImpl.prototype = Object.create(Error.prototype);\n return UnsubscriptionErrorImpl;\n})();\nexport const UnsubscriptionError = UnsubscriptionErrorImpl;\n","import { isArray } from './util/isArray';\nimport { isObject } from './util/isObject';\nimport { isFunction } from './util/isFunction';\nimport { UnsubscriptionError } from './util/UnsubscriptionError';\nexport class Subscription {\n constructor(unsubscribe) {\n this.closed = false;\n this._parentOrParents = null;\n this._subscriptions = null;\n if (unsubscribe) {\n this._ctorUnsubscribe = true;\n this._unsubscribe = unsubscribe;\n }\n }\n unsubscribe() {\n let errors;\n if (this.closed) {\n return;\n }\n let {\n _parentOrParents,\n _ctorUnsubscribe,\n _unsubscribe,\n _subscriptions\n } = this;\n this.closed = true;\n this._parentOrParents = null;\n this._subscriptions = null;\n if (_parentOrParents instanceof Subscription) {\n _parentOrParents.remove(this);\n } else if (_parentOrParents !== null) {\n for (let index = 0; index < _parentOrParents.length; ++index) {\n const parent = _parentOrParents[index];\n parent.remove(this);\n }\n }\n if (isFunction(_unsubscribe)) {\n if (_ctorUnsubscribe) {\n this._unsubscribe = undefined;\n }\n try {\n _unsubscribe.call(this);\n } catch (e) {\n errors = e instanceof UnsubscriptionError ? flattenUnsubscriptionErrors(e.errors) : [e];\n }\n }\n if (isArray(_subscriptions)) {\n let index = -1;\n let len = _subscriptions.length;\n while (++index < len) {\n const sub = _subscriptions[index];\n if (isObject(sub)) {\n try {\n sub.unsubscribe();\n } catch (e) {\n errors = errors || [];\n if (e instanceof UnsubscriptionError) {\n errors = errors.concat(flattenUnsubscriptionErrors(e.errors));\n } else {\n errors.push(e);\n }\n }\n }\n }\n }\n if (errors) {\n throw new UnsubscriptionError(errors);\n }\n }\n add(teardown) {\n let subscription = teardown;\n if (!teardown) {\n return Subscription.EMPTY;\n }\n switch (typeof teardown) {\n case 'function':\n subscription = new Subscription(teardown);\n case 'object':\n if (subscription === this || subscription.closed || typeof subscription.unsubscribe !== 'function') {\n return subscription;\n } else if (this.closed) {\n subscription.unsubscribe();\n return subscription;\n } else if (!(subscription instanceof Subscription)) {\n const tmp = subscription;\n subscription = new Subscription();\n subscription._subscriptions = [tmp];\n }\n break;\n default:\n {\n throw new Error('unrecognized teardown ' + teardown + ' added to Subscription.');\n }\n }\n let {\n _parentOrParents\n } = subscription;\n if (_parentOrParents === null) {\n subscription._parentOrParents = this;\n } else if (_parentOrParents instanceof Subscription) {\n if (_parentOrParents === this) {\n return subscription;\n }\n subscription._parentOrParents = [_parentOrParents, this];\n } else if (_parentOrParents.indexOf(this) === -1) {\n _parentOrParents.push(this);\n } else {\n return subscription;\n }\n const subscriptions = this._subscriptions;\n if (subscriptions === null) {\n this._subscriptions = [subscription];\n } else {\n subscriptions.push(subscription);\n }\n return subscription;\n }\n remove(subscription) {\n const subscriptions = this._subscriptions;\n if (subscriptions) {\n const subscriptionIndex = subscriptions.indexOf(subscription);\n if (subscriptionIndex !== -1) {\n subscriptions.splice(subscriptionIndex, 1);\n }\n }\n }\n}\nSubscription.EMPTY = function (empty) {\n empty.closed = true;\n return empty;\n}(new Subscription());\nfunction flattenUnsubscriptionErrors(errors) {\n return errors.reduce((errs, err) => errs.concat(err instanceof UnsubscriptionError ? err.errors : err), []);\n}\n","export const rxSubscriber = (() => typeof Symbol === 'function' ? Symbol('rxSubscriber') : '@@rxSubscriber_' + Math.random())();\nexport const $$rxSubscriber = rxSubscriber;\n","import { isFunction } from './util/isFunction';\nimport { empty as emptyObserver } from './Observer';\nimport { Subscription } from './Subscription';\nimport { rxSubscriber as rxSubscriberSymbol } from '../internal/symbol/rxSubscriber';\nimport { config } from './config';\nimport { hostReportError } from './util/hostReportError';\nexport class Subscriber extends Subscription {\n constructor(destinationOrNext, error, complete) {\n super();\n this.syncErrorValue = null;\n this.syncErrorThrown = false;\n this.syncErrorThrowable = false;\n this.isStopped = false;\n switch (arguments.length) {\n case 0:\n this.destination = emptyObserver;\n break;\n case 1:\n if (!destinationOrNext) {\n this.destination = emptyObserver;\n break;\n }\n if (typeof destinationOrNext === 'object') {\n if (destinationOrNext instanceof Subscriber) {\n this.syncErrorThrowable = destinationOrNext.syncErrorThrowable;\n this.destination = destinationOrNext;\n destinationOrNext.add(this);\n } else {\n this.syncErrorThrowable = true;\n this.destination = new SafeSubscriber(this, destinationOrNext);\n }\n break;\n }\n default:\n this.syncErrorThrowable = true;\n this.destination = new SafeSubscriber(this, destinationOrNext, error, complete);\n break;\n }\n }\n [rxSubscriberSymbol]() {\n return this;\n }\n static create(next, error, complete) {\n const subscriber = new Subscriber(next, error, complete);\n subscriber.syncErrorThrowable = false;\n return subscriber;\n }\n next(value) {\n if (!this.isStopped) {\n this._next(value);\n }\n }\n error(err) {\n if (!this.isStopped) {\n this.isStopped = true;\n this._error(err);\n }\n }\n complete() {\n if (!this.isStopped) {\n this.isStopped = true;\n this._complete();\n }\n }\n unsubscribe() {\n if (this.closed) {\n return;\n }\n this.isStopped = true;\n super.unsubscribe();\n }\n _next(value) {\n this.destination.next(value);\n }\n _error(err) {\n this.destination.error(err);\n this.unsubscribe();\n }\n _complete() {\n this.destination.complete();\n this.unsubscribe();\n }\n _unsubscribeAndRecycle() {\n const {\n _parentOrParents\n } = this;\n this._parentOrParents = null;\n this.unsubscribe();\n this.closed = false;\n this.isStopped = false;\n this._parentOrParents = _parentOrParents;\n return this;\n }\n}\nexport class SafeSubscriber extends Subscriber {\n constructor(_parentSubscriber, observerOrNext, error, complete) {\n super();\n this._parentSubscriber = _parentSubscriber;\n let next;\n let context = this;\n if (isFunction(observerOrNext)) {\n next = observerOrNext;\n } else if (observerOrNext) {\n next = observerOrNext.next;\n error = observerOrNext.error;\n complete = observerOrNext.complete;\n if (observerOrNext !== emptyObserver) {\n context = Object.create(observerOrNext);\n if (isFunction(context.unsubscribe)) {\n this.add(context.unsubscribe.bind(context));\n }\n context.unsubscribe = this.unsubscribe.bind(this);\n }\n }\n this._context = context;\n this._next = next;\n this._error = error;\n this._complete = complete;\n }\n next(value) {\n if (!this.isStopped && this._next) {\n const {\n _parentSubscriber\n } = this;\n if (!config.useDeprecatedSynchronousErrorHandling || !_parentSubscriber.syncErrorThrowable) {\n this.__tryOrUnsub(this._next, value);\n } else if (this.__tryOrSetError(_parentSubscriber, this._next, value)) {\n this.unsubscribe();\n }\n }\n }\n error(err) {\n if (!this.isStopped) {\n const {\n _parentSubscriber\n } = this;\n const {\n useDeprecatedSynchronousErrorHandling\n } = config;\n if (this._error) {\n if (!useDeprecatedSynchronousErrorHandling || !_parentSubscriber.syncErrorThrowable) {\n this.__tryOrUnsub(this._error, err);\n this.unsubscribe();\n } else {\n this.__tryOrSetError(_parentSubscriber, this._error, err);\n this.unsubscribe();\n }\n } else if (!_parentSubscriber.syncErrorThrowable) {\n this.unsubscribe();\n if (useDeprecatedSynchronousErrorHandling) {\n throw err;\n }\n hostReportError(err);\n } else {\n if (useDeprecatedSynchronousErrorHandling) {\n _parentSubscriber.syncErrorValue = err;\n _parentSubscriber.syncErrorThrown = true;\n } else {\n hostReportError(err);\n }\n this.unsubscribe();\n }\n }\n }\n complete() {\n if (!this.isStopped) {\n const {\n _parentSubscriber\n } = this;\n if (this._complete) {\n const wrappedComplete = () => this._complete.call(this._context);\n if (!config.useDeprecatedSynchronousErrorHandling || !_parentSubscriber.syncErrorThrowable) {\n this.__tryOrUnsub(wrappedComplete);\n this.unsubscribe();\n } else {\n this.__tryOrSetError(_parentSubscriber, wrappedComplete);\n this.unsubscribe();\n }\n } else {\n this.unsubscribe();\n }\n }\n }\n __tryOrUnsub(fn, value) {\n try {\n fn.call(this._context, value);\n } catch (err) {\n this.unsubscribe();\n if (config.useDeprecatedSynchronousErrorHandling) {\n throw err;\n } else {\n hostReportError(err);\n }\n }\n }\n __tryOrSetError(parent, fn, value) {\n if (!config.useDeprecatedSynchronousErrorHandling) {\n throw new Error('bad call');\n }\n try {\n fn.call(this._context, value);\n } catch (err) {\n if (config.useDeprecatedSynchronousErrorHandling) {\n parent.syncErrorValue = err;\n parent.syncErrorThrown = true;\n return true;\n } else {\n hostReportError(err);\n return true;\n }\n }\n return false;\n }\n _unsubscribe() {\n const {\n _parentSubscriber\n } = this;\n this._context = null;\n this._parentSubscriber = null;\n _parentSubscriber.unsubscribe();\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function canReportError(observer) {\n while (observer) {\n const {\n closed,\n destination,\n isStopped\n } = observer;\n if (closed || isStopped) {\n return false;\n } else if (destination && destination instanceof Subscriber) {\n observer = destination;\n } else {\n observer = null;\n }\n }\n return true;\n}\n","import { Subscriber } from '../Subscriber';\nimport { rxSubscriber as rxSubscriberSymbol } from '../symbol/rxSubscriber';\nimport { empty as emptyObserver } from '../Observer';\nexport function toSubscriber(nextOrObserver, error, complete) {\n if (nextOrObserver) {\n if (nextOrObserver instanceof Subscriber) {\n return nextOrObserver;\n }\n if (nextOrObserver[rxSubscriberSymbol]) {\n return nextOrObserver[rxSubscriberSymbol]();\n }\n }\n if (!nextOrObserver && !error && !complete) {\n return new Subscriber(emptyObserver);\n }\n return new Subscriber(nextOrObserver, error, complete);\n}\n","export const observable = (() => typeof Symbol === 'function' && Symbol.observable || '@@observable')();\n","export function identity(x) {\n return x;\n}\n","import { identity } from './identity';\nexport function pipe(...fns) {\n return pipeFromArray(fns);\n}\nexport function pipeFromArray(fns) {\n if (fns.length === 0) {\n return identity;\n }\n if (fns.length === 1) {\n return fns[0];\n }\n return function piped(input) {\n return fns.reduce((prev, fn) => fn(prev), input);\n };\n}\n","import { canReportError } from './util/canReportError';\nimport { toSubscriber } from './util/toSubscriber';\nimport { observable as Symbol_observable } from './symbol/observable';\nimport { pipeFromArray } from './util/pipe';\nimport { config } from './config';\nexport let Observable = /*#__PURE__*/(() => {\n class Observable {\n constructor(subscribe) {\n this._isScalar = false;\n if (subscribe) {\n this._subscribe = subscribe;\n }\n }\n lift(operator) {\n const observable = new Observable();\n observable.source = this;\n observable.operator = operator;\n return observable;\n }\n subscribe(observerOrNext, error, complete) {\n const {\n operator\n } = this;\n const sink = toSubscriber(observerOrNext, error, complete);\n if (operator) {\n sink.add(operator.call(sink, this.source));\n } else {\n sink.add(this.source || config.useDeprecatedSynchronousErrorHandling && !sink.syncErrorThrowable ? this._subscribe(sink) : this._trySubscribe(sink));\n }\n if (config.useDeprecatedSynchronousErrorHandling) {\n if (sink.syncErrorThrowable) {\n sink.syncErrorThrowable = false;\n if (sink.syncErrorThrown) {\n throw sink.syncErrorValue;\n }\n }\n }\n return sink;\n }\n _trySubscribe(sink) {\n try {\n return this._subscribe(sink);\n } catch (err) {\n if (config.useDeprecatedSynchronousErrorHandling) {\n sink.syncErrorThrown = true;\n sink.syncErrorValue = err;\n }\n if (canReportError(sink)) {\n sink.error(err);\n } else {\n console.warn(err);\n }\n }\n }\n forEach(next, promiseCtor) {\n promiseCtor = getPromiseCtor(promiseCtor);\n return new promiseCtor((resolve, reject) => {\n let subscription;\n subscription = this.subscribe(value => {\n try {\n next(value);\n } catch (err) {\n reject(err);\n if (subscription) {\n subscription.unsubscribe();\n }\n }\n }, reject, resolve);\n });\n }\n _subscribe(subscriber) {\n const {\n source\n } = this;\n return source && source.subscribe(subscriber);\n }\n [Symbol_observable]() {\n return this;\n }\n pipe(...operations) {\n if (operations.length === 0) {\n return this;\n }\n return pipeFromArray(operations)(this);\n }\n toPromise(promiseCtor) {\n promiseCtor = getPromiseCtor(promiseCtor);\n return new promiseCtor((resolve, reject) => {\n let value;\n this.subscribe(x => value = x, err => reject(err), () => resolve(value));\n });\n }\n }\n Observable.create = subscribe => {\n return new Observable(subscribe);\n };\n return Observable;\n})();\nfunction getPromiseCtor(promiseCtor) {\n if (!promiseCtor) {\n promiseCtor = config.Promise || Promise;\n }\n if (!promiseCtor) {\n throw new Error('no Promise impl found');\n }\n return promiseCtor;\n}\n","export const subscribeToArray = array => subscriber => {\n for (let i = 0, len = array.length; i < len && !subscriber.closed; i++) {\n subscriber.next(array[i]);\n }\n subscriber.complete();\n};\n","import { hostReportError } from './hostReportError';\nexport const subscribeToPromise = promise => subscriber => {\n promise.then(value => {\n if (!subscriber.closed) {\n subscriber.next(value);\n subscriber.complete();\n }\n }, err => subscriber.error(err)).then(null, hostReportError);\n return subscriber;\n};\n","export function getSymbolIterator() {\n if (typeof Symbol !== 'function' || !Symbol.iterator) {\n return '@@iterator';\n }\n return Symbol.iterator;\n}\nexport const iterator = getSymbolIterator();\nexport const $$iterator = iterator;\n","import { iterator as Symbol_iterator } from '../symbol/iterator';\nexport const subscribeToIterable = iterable => subscriber => {\n const iterator = iterable[Symbol_iterator]();\n do {\n let item;\n try {\n item = iterator.next();\n } catch (err) {\n subscriber.error(err);\n return subscriber;\n }\n if (item.done) {\n subscriber.complete();\n break;\n }\n subscriber.next(item.value);\n if (subscriber.closed) {\n break;\n }\n } while (true);\n if (typeof iterator.return === 'function') {\n subscriber.add(() => {\n if (iterator.return) {\n iterator.return();\n }\n });\n }\n return subscriber;\n};\n","import { observable as Symbol_observable } from '../symbol/observable';\nexport const subscribeToObservable = obj => subscriber => {\n const obs = obj[Symbol_observable]();\n if (typeof obs.subscribe !== 'function') {\n throw new TypeError('Provided object does not correctly implement Symbol.observable');\n } else {\n return obs.subscribe(subscriber);\n }\n};\n","export const isArrayLike = x => x && typeof x.length === 'number' && typeof x !== 'function';\n","export function isPromise(value) {\n return !!value && typeof value.subscribe !== 'function' && typeof value.then === 'function';\n}\n","import { subscribeToArray } from './subscribeToArray';\nimport { subscribeToPromise } from './subscribeToPromise';\nimport { subscribeToIterable } from './subscribeToIterable';\nimport { subscribeToObservable } from './subscribeToObservable';\nimport { isArrayLike } from './isArrayLike';\nimport { isPromise } from './isPromise';\nimport { isObject } from './isObject';\nimport { iterator as Symbol_iterator } from '../symbol/iterator';\nimport { observable as Symbol_observable } from '../symbol/observable';\nexport const subscribeTo = result => {\n if (!!result && typeof result[Symbol_observable] === 'function') {\n return subscribeToObservable(result);\n } else if (isArrayLike(result)) {\n return subscribeToArray(result);\n } else if (isPromise(result)) {\n return subscribeToPromise(result);\n } else if (!!result && typeof result[Symbol_iterator] === 'function') {\n return subscribeToIterable(result);\n } else {\n const value = isObject(result) ? 'an invalid object' : `'${result}'`;\n const msg = `You provided ${value} where a stream was expected.` + ' You can provide an Observable, Promise, Array, or Iterable.';\n throw new TypeError(msg);\n }\n};\n","import { Subscriber } from './Subscriber';\nimport { Observable } from './Observable';\nimport { subscribeTo } from './util/subscribeTo';\nexport class SimpleInnerSubscriber extends Subscriber {\n constructor(parent) {\n super();\n this.parent = parent;\n }\n _next(value) {\n this.parent.notifyNext(value);\n }\n _error(error) {\n this.parent.notifyError(error);\n this.unsubscribe();\n }\n _complete() {\n this.parent.notifyComplete();\n this.unsubscribe();\n }\n}\nexport class ComplexInnerSubscriber extends Subscriber {\n constructor(parent, outerValue, outerIndex) {\n super();\n this.parent = parent;\n this.outerValue = outerValue;\n this.outerIndex = outerIndex;\n }\n _next(value) {\n this.parent.notifyNext(this.outerValue, value, this.outerIndex, this);\n }\n _error(error) {\n this.parent.notifyError(error);\n this.unsubscribe();\n }\n _complete() {\n this.parent.notifyComplete(this);\n this.unsubscribe();\n }\n}\nexport class SimpleOuterSubscriber extends Subscriber {\n notifyNext(innerValue) {\n this.destination.next(innerValue);\n }\n notifyError(err) {\n this.destination.error(err);\n }\n notifyComplete() {\n this.destination.complete();\n }\n}\nexport class ComplexOuterSubscriber extends Subscriber {\n notifyNext(_outerValue, innerValue, _outerIndex, _innerSub) {\n this.destination.next(innerValue);\n }\n notifyError(error) {\n this.destination.error(error);\n }\n notifyComplete(_innerSub) {\n this.destination.complete();\n }\n}\nexport function innerSubscribe(result, innerSubscriber) {\n if (innerSubscriber.closed) {\n return undefined;\n }\n if (result instanceof Observable) {\n return result.subscribe(innerSubscriber);\n }\n let subscription;\n try {\n subscription = subscribeTo(result)(innerSubscriber);\n } catch (error) {\n innerSubscriber.error(error);\n }\n return subscription;\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function audit(durationSelector) {\n return function auditOperatorFunction(source) {\n return source.lift(new AuditOperator(durationSelector));\n };\n}\nclass AuditOperator {\n constructor(durationSelector) {\n this.durationSelector = durationSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new AuditSubscriber(subscriber, this.durationSelector));\n }\n}\nclass AuditSubscriber extends SimpleOuterSubscriber {\n constructor(destination, durationSelector) {\n super(destination);\n this.durationSelector = durationSelector;\n this.hasValue = false;\n }\n _next(value) {\n this.value = value;\n this.hasValue = true;\n if (!this.throttled) {\n let duration;\n try {\n const {\n durationSelector\n } = this;\n duration = durationSelector(value);\n } catch (err) {\n return this.destination.error(err);\n }\n const innerSubscription = innerSubscribe(duration, new SimpleInnerSubscriber(this));\n if (!innerSubscription || innerSubscription.closed) {\n this.clearThrottle();\n } else {\n this.add(this.throttled = innerSubscription);\n }\n }\n }\n clearThrottle() {\n const {\n value,\n hasValue,\n throttled\n } = this;\n if (throttled) {\n this.remove(throttled);\n this.throttled = undefined;\n throttled.unsubscribe();\n }\n if (hasValue) {\n this.value = undefined;\n this.hasValue = false;\n this.destination.next(value);\n }\n }\n notifyNext() {\n this.clearThrottle();\n }\n notifyComplete() {\n this.clearThrottle();\n }\n}\n","import { Subscription } from '../Subscription';\nexport class Action extends Subscription {\n constructor(scheduler, work) {\n super();\n }\n schedule(state, delay = 0) {\n return this;\n }\n}\n","import { Action } from './Action';\nexport class AsyncAction extends Action {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n this.pending = false;\n }\n schedule(state, delay = 0) {\n if (this.closed) {\n return this;\n }\n this.state = state;\n const id = this.id;\n const scheduler = this.scheduler;\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, delay);\n }\n this.pending = true;\n this.delay = delay;\n this.id = this.id || this.requestAsyncId(scheduler, this.id, delay);\n return this;\n }\n requestAsyncId(scheduler, id, delay = 0) {\n return setInterval(scheduler.flush.bind(scheduler, this), delay);\n }\n recycleAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && this.delay === delay && this.pending === false) {\n return id;\n }\n clearInterval(id);\n return undefined;\n }\n execute(state, delay) {\n if (this.closed) {\n return new Error('executing a cancelled action');\n }\n this.pending = false;\n const error = this._execute(state, delay);\n if (error) {\n return error;\n } else if (this.pending === false && this.id != null) {\n this.id = this.recycleAsyncId(this.scheduler, this.id, null);\n }\n }\n _execute(state, delay) {\n let errored = false;\n let errorValue = undefined;\n try {\n this.work(state);\n } catch (e) {\n errored = true;\n errorValue = !!e && e || new Error(e);\n }\n if (errored) {\n this.unsubscribe();\n return errorValue;\n }\n }\n _unsubscribe() {\n const id = this.id;\n const scheduler = this.scheduler;\n const actions = scheduler.actions;\n const index = actions.indexOf(this);\n this.work = null;\n this.state = null;\n this.pending = false;\n this.scheduler = null;\n if (index !== -1) {\n actions.splice(index, 1);\n }\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, null);\n }\n this.delay = null;\n }\n}\n","import { Action } from './scheduler/Action';\nimport { Subscription } from './Subscription';\nimport { SchedulerLike, SchedulerAction } from './types';\n\n/**\n * An execution context and a data structure to order tasks and schedule their\n * execution. Provides a notion of (potentially virtual) time, through the\n * `now()` getter method.\n *\n * Each unit of work in a Scheduler is called an `Action`.\n *\n * ```ts\n * class Scheduler {\n * now(): number;\n * schedule(work, delay?, state?): Subscription;\n * }\n * ```\n *\n * @class Scheduler\n * @deprecated Scheduler is an internal implementation detail of RxJS, and\n * should not be used directly. Rather, create your own class and implement\n * {@link SchedulerLike}\n */\nexport class Scheduler implements SchedulerLike {\n\n /**\n * Note: the extra arrow function wrapper is to make testing by overriding\n * Date.now easier.\n * @nocollapse\n */\n public static now: () => number = () => Date.now();\n\n constructor(private SchedulerAction: typeof Action,\n now: () => number = Scheduler.now) {\n this.now = now;\n }\n\n /**\n * A getter method that returns a number representing the current time\n * (at the time this function was called) according to the scheduler's own\n * internal clock.\n * @return {number} A number that represents the current time. May or may not\n * have a relation to wall-clock time. May or may not refer to a time unit\n * (e.g. milliseconds).\n */\n public now: () => number;\n\n /**\n * Schedules a function, `work`, for execution. May happen at some point in\n * the future, according to the `delay` parameter, if specified. May be passed\n * some context object, `state`, which will be passed to the `work` function.\n *\n * The given arguments will be processed an stored as an Action object in a\n * queue of actions.\n *\n * @param {function(state: ?T): ?Subscription} work A function representing a\n * task, or some unit of work to be executed by the Scheduler.\n * @param {number} [delay] Time to wait before executing the work, where the\n * time unit is implicit and defined by the Scheduler itself.\n * @param {T} [state] Some contextual data that the `work` function uses when\n * called by the Scheduler.\n * @return {Subscription} A subscription in order to be able to unsubscribe\n * the scheduled work.\n */\n public schedule(work: (this: SchedulerAction, state?: T) => void, delay: number = 0, state?: T): Subscription {\n return new this.SchedulerAction(this, work).schedule(state, delay);\n }\n}\n","import { Scheduler } from '../Scheduler';\nexport class AsyncScheduler extends Scheduler {\n constructor(SchedulerAction, now = Scheduler.now) {\n super(SchedulerAction, () => {\n if (AsyncScheduler.delegate && AsyncScheduler.delegate !== this) {\n return AsyncScheduler.delegate.now();\n } else {\n return now();\n }\n });\n this.actions = [];\n this.active = false;\n this.scheduled = undefined;\n }\n schedule(work, delay = 0, state) {\n if (AsyncScheduler.delegate && AsyncScheduler.delegate !== this) {\n return AsyncScheduler.delegate.schedule(work, delay, state);\n } else {\n return super.schedule(work, delay, state);\n }\n }\n flush(action) {\n const {\n actions\n } = this;\n if (this.active) {\n actions.push(action);\n return;\n }\n let error;\n this.active = true;\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while (action = actions.shift());\n this.active = false;\n if (error) {\n while (action = actions.shift()) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n","import { AsyncAction } from './AsyncAction';\nimport { AsyncScheduler } from './AsyncScheduler';\nexport const asyncScheduler = new AsyncScheduler(AsyncAction);\nexport const async = asyncScheduler;\n","import { isArray } from './isArray';\nexport function isNumeric(val) {\n return !isArray(val) && val - parseFloat(val) + 1 >= 0;\n}\n","export function isScheduler(value) {\n return value && typeof value.schedule === 'function';\n}\n","import { Observable } from '../Observable';\nimport { async } from '../scheduler/async';\nimport { isNumeric } from '../util/isNumeric';\nimport { isScheduler } from '../util/isScheduler';\nexport function timer(dueTime = 0, periodOrScheduler, scheduler) {\n let period = -1;\n if (isNumeric(periodOrScheduler)) {\n period = Number(periodOrScheduler) < 1 && 1 || Number(periodOrScheduler);\n } else if (isScheduler(periodOrScheduler)) {\n scheduler = periodOrScheduler;\n }\n if (!isScheduler(scheduler)) {\n scheduler = async;\n }\n return new Observable(subscriber => {\n const due = isNumeric(dueTime) ? dueTime : +dueTime - scheduler.now();\n return scheduler.schedule(dispatch, due, {\n index: 0,\n period,\n subscriber\n });\n });\n}\nfunction dispatch(state) {\n const {\n index,\n period,\n subscriber\n } = state;\n subscriber.next(index);\n if (subscriber.closed) {\n return;\n } else if (period === -1) {\n return subscriber.complete();\n }\n state.index = index + 1;\n this.schedule(state, period);\n}\n","import { async } from '../scheduler/async';\nimport { audit } from './audit';\nimport { timer } from '../observable/timer';\nexport function auditTime(duration, scheduler = async) {\n return audit(() => timer(duration, scheduler));\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function buffer(closingNotifier) {\n return function bufferOperatorFunction(source) {\n return source.lift(new BufferOperator(closingNotifier));\n };\n}\nclass BufferOperator {\n constructor(closingNotifier) {\n this.closingNotifier = closingNotifier;\n }\n call(subscriber, source) {\n return source.subscribe(new BufferSubscriber(subscriber, this.closingNotifier));\n }\n}\nclass BufferSubscriber extends SimpleOuterSubscriber {\n constructor(destination, closingNotifier) {\n super(destination);\n this.buffer = [];\n this.add(innerSubscribe(closingNotifier, new SimpleInnerSubscriber(this)));\n }\n _next(value) {\n this.buffer.push(value);\n }\n notifyNext() {\n const buffer = this.buffer;\n this.buffer = [];\n this.destination.next(buffer);\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function bufferCount(bufferSize, startBufferEvery = null) {\n return function bufferCountOperatorFunction(source) {\n return source.lift(new BufferCountOperator(bufferSize, startBufferEvery));\n };\n}\nclass BufferCountOperator {\n constructor(bufferSize, startBufferEvery) {\n this.bufferSize = bufferSize;\n this.startBufferEvery = startBufferEvery;\n if (!startBufferEvery || bufferSize === startBufferEvery) {\n this.subscriberClass = BufferCountSubscriber;\n } else {\n this.subscriberClass = BufferSkipCountSubscriber;\n }\n }\n call(subscriber, source) {\n return source.subscribe(new this.subscriberClass(subscriber, this.bufferSize, this.startBufferEvery));\n }\n}\nclass BufferCountSubscriber extends Subscriber {\n constructor(destination, bufferSize) {\n super(destination);\n this.bufferSize = bufferSize;\n this.buffer = [];\n }\n _next(value) {\n const buffer = this.buffer;\n buffer.push(value);\n if (buffer.length == this.bufferSize) {\n this.destination.next(buffer);\n this.buffer = [];\n }\n }\n _complete() {\n const buffer = this.buffer;\n if (buffer.length > 0) {\n this.destination.next(buffer);\n }\n super._complete();\n }\n}\nclass BufferSkipCountSubscriber extends Subscriber {\n constructor(destination, bufferSize, startBufferEvery) {\n super(destination);\n this.bufferSize = bufferSize;\n this.startBufferEvery = startBufferEvery;\n this.buffers = [];\n this.count = 0;\n }\n _next(value) {\n const {\n bufferSize,\n startBufferEvery,\n buffers,\n count\n } = this;\n this.count++;\n if (count % startBufferEvery === 0) {\n buffers.push([]);\n }\n for (let i = buffers.length; i--;) {\n const buffer = buffers[i];\n buffer.push(value);\n if (buffer.length === bufferSize) {\n buffers.splice(i, 1);\n this.destination.next(buffer);\n }\n }\n }\n _complete() {\n const {\n buffers,\n destination\n } = this;\n while (buffers.length > 0) {\n let buffer = buffers.shift();\n if (buffer.length > 0) {\n destination.next(buffer);\n }\n }\n super._complete();\n }\n}\n","import { async } from '../scheduler/async';\nimport { Subscriber } from '../Subscriber';\nimport { isScheduler } from '../util/isScheduler';\nexport function bufferTime(bufferTimeSpan) {\n let length = arguments.length;\n let scheduler = async;\n if (isScheduler(arguments[arguments.length - 1])) {\n scheduler = arguments[arguments.length - 1];\n length--;\n }\n let bufferCreationInterval = null;\n if (length >= 2) {\n bufferCreationInterval = arguments[1];\n }\n let maxBufferSize = Number.POSITIVE_INFINITY;\n if (length >= 3) {\n maxBufferSize = arguments[2];\n }\n return function bufferTimeOperatorFunction(source) {\n return source.lift(new BufferTimeOperator(bufferTimeSpan, bufferCreationInterval, maxBufferSize, scheduler));\n };\n}\nclass BufferTimeOperator {\n constructor(bufferTimeSpan, bufferCreationInterval, maxBufferSize, scheduler) {\n this.bufferTimeSpan = bufferTimeSpan;\n this.bufferCreationInterval = bufferCreationInterval;\n this.maxBufferSize = maxBufferSize;\n this.scheduler = scheduler;\n }\n call(subscriber, source) {\n return source.subscribe(new BufferTimeSubscriber(subscriber, this.bufferTimeSpan, this.bufferCreationInterval, this.maxBufferSize, this.scheduler));\n }\n}\nclass Context {\n constructor() {\n this.buffer = [];\n }\n}\nclass BufferTimeSubscriber extends Subscriber {\n constructor(destination, bufferTimeSpan, bufferCreationInterval, maxBufferSize, scheduler) {\n super(destination);\n this.bufferTimeSpan = bufferTimeSpan;\n this.bufferCreationInterval = bufferCreationInterval;\n this.maxBufferSize = maxBufferSize;\n this.scheduler = scheduler;\n this.contexts = [];\n const context = this.openContext();\n this.timespanOnly = bufferCreationInterval == null || bufferCreationInterval < 0;\n if (this.timespanOnly) {\n const timeSpanOnlyState = {\n subscriber: this,\n context,\n bufferTimeSpan\n };\n this.add(context.closeAction = scheduler.schedule(dispatchBufferTimeSpanOnly, bufferTimeSpan, timeSpanOnlyState));\n } else {\n const closeState = {\n subscriber: this,\n context\n };\n const creationState = {\n bufferTimeSpan,\n bufferCreationInterval,\n subscriber: this,\n scheduler\n };\n this.add(context.closeAction = scheduler.schedule(dispatchBufferClose, bufferTimeSpan, closeState));\n this.add(scheduler.schedule(dispatchBufferCreation, bufferCreationInterval, creationState));\n }\n }\n _next(value) {\n const contexts = this.contexts;\n const len = contexts.length;\n let filledBufferContext;\n for (let i = 0; i < len; i++) {\n const context = contexts[i];\n const buffer = context.buffer;\n buffer.push(value);\n if (buffer.length == this.maxBufferSize) {\n filledBufferContext = context;\n }\n }\n if (filledBufferContext) {\n this.onBufferFull(filledBufferContext);\n }\n }\n _error(err) {\n this.contexts.length = 0;\n super._error(err);\n }\n _complete() {\n const {\n contexts,\n destination\n } = this;\n while (contexts.length > 0) {\n const context = contexts.shift();\n destination.next(context.buffer);\n }\n super._complete();\n }\n _unsubscribe() {\n this.contexts = null;\n }\n onBufferFull(context) {\n this.closeContext(context);\n const closeAction = context.closeAction;\n closeAction.unsubscribe();\n this.remove(closeAction);\n if (!this.closed && this.timespanOnly) {\n context = this.openContext();\n const bufferTimeSpan = this.bufferTimeSpan;\n const timeSpanOnlyState = {\n subscriber: this,\n context,\n bufferTimeSpan\n };\n this.add(context.closeAction = this.scheduler.schedule(dispatchBufferTimeSpanOnly, bufferTimeSpan, timeSpanOnlyState));\n }\n }\n openContext() {\n const context = new Context();\n this.contexts.push(context);\n return context;\n }\n closeContext(context) {\n this.destination.next(context.buffer);\n const contexts = this.contexts;\n const spliceIndex = contexts ? contexts.indexOf(context) : -1;\n if (spliceIndex >= 0) {\n contexts.splice(contexts.indexOf(context), 1);\n }\n }\n}\nfunction dispatchBufferTimeSpanOnly(state) {\n const subscriber = state.subscriber;\n const prevContext = state.context;\n if (prevContext) {\n subscriber.closeContext(prevContext);\n }\n if (!subscriber.closed) {\n state.context = subscriber.openContext();\n state.context.closeAction = this.schedule(state, state.bufferTimeSpan);\n }\n}\nfunction dispatchBufferCreation(state) {\n const {\n bufferCreationInterval,\n bufferTimeSpan,\n subscriber,\n scheduler\n } = state;\n const context = subscriber.openContext();\n const action = this;\n if (!subscriber.closed) {\n subscriber.add(context.closeAction = scheduler.schedule(dispatchBufferClose, bufferTimeSpan, {\n subscriber,\n context\n }));\n action.schedule(state, bufferCreationInterval);\n }\n}\nfunction dispatchBufferClose(arg) {\n const {\n subscriber,\n context\n } = arg;\n subscriber.closeContext(context);\n}\n","import { Subscriber } from './Subscriber';\nexport class InnerSubscriber extends Subscriber {\n constructor(parent, outerValue, outerIndex) {\n super();\n this.parent = parent;\n this.outerValue = outerValue;\n this.outerIndex = outerIndex;\n this.index = 0;\n }\n _next(value) {\n this.parent.notifyNext(this.outerValue, value, this.outerIndex, this.index++, this);\n }\n _error(error) {\n this.parent.notifyError(error, this);\n this.unsubscribe();\n }\n _complete() {\n this.parent.notifyComplete(this);\n this.unsubscribe();\n }\n}\n","import { InnerSubscriber } from '../InnerSubscriber';\nimport { subscribeTo } from './subscribeTo';\nimport { Observable } from '../Observable';\nexport function subscribeToResult(outerSubscriber, result, outerValue, outerIndex, innerSubscriber = new InnerSubscriber(outerSubscriber, outerValue, outerIndex)) {\n if (innerSubscriber.closed) {\n return undefined;\n }\n if (result instanceof Observable) {\n return result.subscribe(innerSubscriber);\n }\n return subscribeTo(result)(innerSubscriber);\n}\n","import { Subscriber } from './Subscriber';\nexport class OuterSubscriber extends Subscriber {\n notifyNext(outerValue, innerValue, outerIndex, innerIndex, innerSub) {\n this.destination.next(innerValue);\n }\n notifyError(error, innerSub) {\n this.destination.error(error);\n }\n notifyComplete(innerSub) {\n this.destination.complete();\n }\n}\n","import { Subscription } from '../Subscription';\nimport { subscribeToResult } from '../util/subscribeToResult';\nimport { OuterSubscriber } from '../OuterSubscriber';\nexport function bufferToggle(openings, closingSelector) {\n return function bufferToggleOperatorFunction(source) {\n return source.lift(new BufferToggleOperator(openings, closingSelector));\n };\n}\nclass BufferToggleOperator {\n constructor(openings, closingSelector) {\n this.openings = openings;\n this.closingSelector = closingSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new BufferToggleSubscriber(subscriber, this.openings, this.closingSelector));\n }\n}\nclass BufferToggleSubscriber extends OuterSubscriber {\n constructor(destination, openings, closingSelector) {\n super(destination);\n this.closingSelector = closingSelector;\n this.contexts = [];\n this.add(subscribeToResult(this, openings));\n }\n _next(value) {\n const contexts = this.contexts;\n const len = contexts.length;\n for (let i = 0; i < len; i++) {\n contexts[i].buffer.push(value);\n }\n }\n _error(err) {\n const contexts = this.contexts;\n while (contexts.length > 0) {\n const context = contexts.shift();\n context.subscription.unsubscribe();\n context.buffer = null;\n context.subscription = null;\n }\n this.contexts = null;\n super._error(err);\n }\n _complete() {\n const contexts = this.contexts;\n while (contexts.length > 0) {\n const context = contexts.shift();\n this.destination.next(context.buffer);\n context.subscription.unsubscribe();\n context.buffer = null;\n context.subscription = null;\n }\n this.contexts = null;\n super._complete();\n }\n notifyNext(outerValue, innerValue) {\n outerValue ? this.closeBuffer(outerValue) : this.openBuffer(innerValue);\n }\n notifyComplete(innerSub) {\n this.closeBuffer(innerSub.context);\n }\n openBuffer(value) {\n try {\n const closingSelector = this.closingSelector;\n const closingNotifier = closingSelector.call(this, value);\n if (closingNotifier) {\n this.trySubscribe(closingNotifier);\n }\n } catch (err) {\n this._error(err);\n }\n }\n closeBuffer(context) {\n const contexts = this.contexts;\n if (contexts && context) {\n const {\n buffer,\n subscription\n } = context;\n this.destination.next(buffer);\n contexts.splice(contexts.indexOf(context), 1);\n this.remove(subscription);\n subscription.unsubscribe();\n }\n }\n trySubscribe(closingNotifier) {\n const contexts = this.contexts;\n const buffer = [];\n const subscription = new Subscription();\n const context = {\n buffer,\n subscription\n };\n contexts.push(context);\n const innerSubscription = subscribeToResult(this, closingNotifier, context);\n if (!innerSubscription || innerSubscription.closed) {\n this.closeBuffer(context);\n } else {\n innerSubscription.context = context;\n this.add(innerSubscription);\n subscription.add(innerSubscription);\n }\n }\n}\n","import { Subscription } from '../Subscription';\nimport { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function bufferWhen(closingSelector) {\n return function (source) {\n return source.lift(new BufferWhenOperator(closingSelector));\n };\n}\nclass BufferWhenOperator {\n constructor(closingSelector) {\n this.closingSelector = closingSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new BufferWhenSubscriber(subscriber, this.closingSelector));\n }\n}\nclass BufferWhenSubscriber extends SimpleOuterSubscriber {\n constructor(destination, closingSelector) {\n super(destination);\n this.closingSelector = closingSelector;\n this.subscribing = false;\n this.openBuffer();\n }\n _next(value) {\n this.buffer.push(value);\n }\n _complete() {\n const buffer = this.buffer;\n if (buffer) {\n this.destination.next(buffer);\n }\n super._complete();\n }\n _unsubscribe() {\n this.buffer = undefined;\n this.subscribing = false;\n }\n notifyNext() {\n this.openBuffer();\n }\n notifyComplete() {\n if (this.subscribing) {\n this.complete();\n } else {\n this.openBuffer();\n }\n }\n openBuffer() {\n let {\n closingSubscription\n } = this;\n if (closingSubscription) {\n this.remove(closingSubscription);\n closingSubscription.unsubscribe();\n }\n const buffer = this.buffer;\n if (this.buffer) {\n this.destination.next(buffer);\n }\n this.buffer = [];\n let closingNotifier;\n try {\n const {\n closingSelector\n } = this;\n closingNotifier = closingSelector();\n } catch (err) {\n return this.error(err);\n }\n closingSubscription = new Subscription();\n this.closingSubscription = closingSubscription;\n this.add(closingSubscription);\n this.subscribing = true;\n closingSubscription.add(innerSubscribe(closingNotifier, new SimpleInnerSubscriber(this)));\n this.subscribing = false;\n }\n}\n","import { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function catchError(selector) {\n return function catchErrorOperatorFunction(source) {\n const operator = new CatchOperator(selector);\n const caught = source.lift(operator);\n return operator.caught = caught;\n };\n}\nclass CatchOperator {\n constructor(selector) {\n this.selector = selector;\n }\n call(subscriber, source) {\n return source.subscribe(new CatchSubscriber(subscriber, this.selector, this.caught));\n }\n}\nclass CatchSubscriber extends SimpleOuterSubscriber {\n constructor(destination, selector, caught) {\n super(destination);\n this.selector = selector;\n this.caught = caught;\n }\n error(err) {\n if (!this.isStopped) {\n let result;\n try {\n result = this.selector(err, this.caught);\n } catch (err2) {\n super.error(err2);\n return;\n }\n this._unsubscribeAndRecycle();\n const innerSubscriber = new SimpleInnerSubscriber(this);\n this.add(innerSubscriber);\n const innerSubscription = innerSubscribe(result, innerSubscriber);\n if (innerSubscription !== innerSubscriber) {\n this.add(innerSubscription);\n }\n }\n }\n}\n","import { Observable } from '../Observable';\nimport { Subscription } from '../Subscription';\nexport function scheduleArray(input, scheduler) {\n return new Observable(subscriber => {\n const sub = new Subscription();\n let i = 0;\n sub.add(scheduler.schedule(function () {\n if (i === input.length) {\n subscriber.complete();\n return;\n }\n subscriber.next(input[i++]);\n if (!subscriber.closed) {\n sub.add(this.schedule());\n }\n }));\n return sub;\n });\n}\n","import { Observable } from '../Observable';\nimport { subscribeToArray } from '../util/subscribeToArray';\nimport { scheduleArray } from '../scheduled/scheduleArray';\nexport function fromArray(input, scheduler) {\n if (!scheduler) {\n return new Observable(subscribeToArray(input));\n } else {\n return scheduleArray(input, scheduler);\n }\n}\n","import { isScheduler } from '../util/isScheduler';\nimport { isArray } from '../util/isArray';\nimport { OuterSubscriber } from '../OuterSubscriber';\nimport { subscribeToResult } from '../util/subscribeToResult';\nimport { fromArray } from './fromArray';\nconst NONE = {};\nexport function combineLatest(...observables) {\n let resultSelector = undefined;\n let scheduler = undefined;\n if (isScheduler(observables[observables.length - 1])) {\n scheduler = observables.pop();\n }\n if (typeof observables[observables.length - 1] === 'function') {\n resultSelector = observables.pop();\n }\n if (observables.length === 1 && isArray(observables[0])) {\n observables = observables[0];\n }\n return fromArray(observables, scheduler).lift(new CombineLatestOperator(resultSelector));\n}\nexport class CombineLatestOperator {\n constructor(resultSelector) {\n this.resultSelector = resultSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new CombineLatestSubscriber(subscriber, this.resultSelector));\n }\n}\nexport class CombineLatestSubscriber extends OuterSubscriber {\n constructor(destination, resultSelector) {\n super(destination);\n this.resultSelector = resultSelector;\n this.active = 0;\n this.values = [];\n this.observables = [];\n }\n _next(observable) {\n this.values.push(NONE);\n this.observables.push(observable);\n }\n _complete() {\n const observables = this.observables;\n const len = observables.length;\n if (len === 0) {\n this.destination.complete();\n } else {\n this.active = len;\n this.toRespond = len;\n for (let i = 0; i < len; i++) {\n const observable = observables[i];\n this.add(subscribeToResult(this, observable, undefined, i));\n }\n }\n }\n notifyComplete(unused) {\n if ((this.active -= 1) === 0) {\n this.destination.complete();\n }\n }\n notifyNext(_outerValue, innerValue, outerIndex) {\n const values = this.values;\n const oldVal = values[outerIndex];\n const toRespond = !this.toRespond ? 0 : oldVal === NONE ? --this.toRespond : this.toRespond;\n values[outerIndex] = innerValue;\n if (toRespond === 0) {\n if (this.resultSelector) {\n this._tryResultSelector(values);\n } else {\n this.destination.next(values.slice());\n }\n }\n }\n _tryResultSelector(values) {\n let result;\n try {\n result = this.resultSelector.apply(this, values);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.destination.next(result);\n }\n}\n","import { CombineLatestOperator } from '../observable/combineLatest';\nexport function combineAll(project) {\n return source => source.lift(new CombineLatestOperator(project));\n}\n","import { Observable } from '../Observable';\nimport { Subscription } from '../Subscription';\nimport { observable as Symbol_observable } from '../symbol/observable';\nexport function scheduleObservable(input, scheduler) {\n return new Observable(subscriber => {\n const sub = new Subscription();\n sub.add(scheduler.schedule(() => {\n const observable = input[Symbol_observable]();\n sub.add(observable.subscribe({\n next(value) {\n sub.add(scheduler.schedule(() => subscriber.next(value)));\n },\n error(err) {\n sub.add(scheduler.schedule(() => subscriber.error(err)));\n },\n complete() {\n sub.add(scheduler.schedule(() => subscriber.complete()));\n }\n }));\n }));\n return sub;\n });\n}\n","import { Observable } from '../Observable';\nimport { Subscription } from '../Subscription';\nexport function schedulePromise(input, scheduler) {\n return new Observable(subscriber => {\n const sub = new Subscription();\n sub.add(scheduler.schedule(() => input.then(value => {\n sub.add(scheduler.schedule(() => {\n subscriber.next(value);\n sub.add(scheduler.schedule(() => subscriber.complete()));\n }));\n }, err => {\n sub.add(scheduler.schedule(() => subscriber.error(err)));\n })));\n return sub;\n });\n}\n","import { Observable } from '../Observable';\nimport { Subscription } from '../Subscription';\nimport { iterator as Symbol_iterator } from '../symbol/iterator';\nexport function scheduleIterable(input, scheduler) {\n if (!input) {\n throw new Error('Iterable cannot be null');\n }\n return new Observable(subscriber => {\n const sub = new Subscription();\n let iterator;\n sub.add(() => {\n if (iterator && typeof iterator.return === 'function') {\n iterator.return();\n }\n });\n sub.add(scheduler.schedule(() => {\n iterator = input[Symbol_iterator]();\n sub.add(scheduler.schedule(function () {\n if (subscriber.closed) {\n return;\n }\n let value;\n let done;\n try {\n const result = iterator.next();\n value = result.value;\n done = result.done;\n } catch (err) {\n subscriber.error(err);\n return;\n }\n if (done) {\n subscriber.complete();\n } else {\n subscriber.next(value);\n this.schedule();\n }\n }));\n }));\n return sub;\n });\n}\n","import { observable as Symbol_observable } from '../symbol/observable';\nexport function isInteropObservable(input) {\n return input && typeof input[Symbol_observable] === 'function';\n}\n","import { iterator as Symbol_iterator } from '../symbol/iterator';\nexport function isIterable(input) {\n return input && typeof input[Symbol_iterator] === 'function';\n}\n","import { scheduleObservable } from './scheduleObservable';\nimport { schedulePromise } from './schedulePromise';\nimport { scheduleArray } from './scheduleArray';\nimport { scheduleIterable } from './scheduleIterable';\nimport { isInteropObservable } from '../util/isInteropObservable';\nimport { isPromise } from '../util/isPromise';\nimport { isArrayLike } from '../util/isArrayLike';\nimport { isIterable } from '../util/isIterable';\nexport function scheduled(input, scheduler) {\n if (input != null) {\n if (isInteropObservable(input)) {\n return scheduleObservable(input, scheduler);\n } else if (isPromise(input)) {\n return schedulePromise(input, scheduler);\n } else if (isArrayLike(input)) {\n return scheduleArray(input, scheduler);\n } else if (isIterable(input) || typeof input === 'string') {\n return scheduleIterable(input, scheduler);\n }\n }\n throw new TypeError((input !== null && typeof input || input) + ' is not observable');\n}\n","import { Observable } from '../Observable';\nimport { subscribeTo } from '../util/subscribeTo';\nimport { scheduled } from '../scheduled/scheduled';\nexport function from(input, scheduler) {\n if (!scheduler) {\n if (input instanceof Observable) {\n return input;\n }\n return new Observable(subscribeTo(input));\n } else {\n return scheduled(input, scheduler);\n }\n}\n","import { isArray } from '../util/isArray';\nimport { CombineLatestOperator } from '../observable/combineLatest';\nimport { from } from '../observable/from';\nconst none = {};\nexport function combineLatest(...observables) {\n let project = null;\n if (typeof observables[observables.length - 1] === 'function') {\n project = observables.pop();\n }\n if (observables.length === 1 && isArray(observables[0])) {\n observables = observables[0].slice();\n }\n return source => source.lift.call(from([source, ...observables]), new CombineLatestOperator(project));\n}\n","import { isScheduler } from '../util/isScheduler';\nimport { fromArray } from './fromArray';\nimport { scheduleArray } from '../scheduled/scheduleArray';\nexport function of(...args) {\n let scheduler = args[args.length - 1];\n if (isScheduler(scheduler)) {\n args.pop();\n return scheduleArray(args, scheduler);\n } else {\n return fromArray(args);\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function map(project, thisArg) {\n return function mapOperation(source) {\n if (typeof project !== 'function') {\n throw new TypeError('argument is not a function. Are you looking for `mapTo()`?');\n }\n return source.lift(new MapOperator(project, thisArg));\n };\n}\nexport class MapOperator {\n constructor(project, thisArg) {\n this.project = project;\n this.thisArg = thisArg;\n }\n call(subscriber, source) {\n return source.subscribe(new MapSubscriber(subscriber, this.project, this.thisArg));\n }\n}\nclass MapSubscriber extends Subscriber {\n constructor(destination, project, thisArg) {\n super(destination);\n this.project = project;\n this.count = 0;\n this.thisArg = thisArg || this;\n }\n _next(value) {\n let result;\n try {\n result = this.project.call(this.thisArg, value, this.count++);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.destination.next(result);\n }\n}\n","import { map } from './map';\nimport { from } from '../observable/from';\nimport { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function mergeMap(project, resultSelector, concurrent = Number.POSITIVE_INFINITY) {\n if (typeof resultSelector === 'function') {\n return source => source.pipe(mergeMap((a, i) => from(project(a, i)).pipe(map((b, ii) => resultSelector(a, b, i, ii))), concurrent));\n } else if (typeof resultSelector === 'number') {\n concurrent = resultSelector;\n }\n return source => source.lift(new MergeMapOperator(project, concurrent));\n}\nexport class MergeMapOperator {\n constructor(project, concurrent = Number.POSITIVE_INFINITY) {\n this.project = project;\n this.concurrent = concurrent;\n }\n call(observer, source) {\n return source.subscribe(new MergeMapSubscriber(observer, this.project, this.concurrent));\n }\n}\nexport class MergeMapSubscriber extends SimpleOuterSubscriber {\n constructor(destination, project, concurrent = Number.POSITIVE_INFINITY) {\n super(destination);\n this.project = project;\n this.concurrent = concurrent;\n this.hasCompleted = false;\n this.buffer = [];\n this.active = 0;\n this.index = 0;\n }\n _next(value) {\n if (this.active < this.concurrent) {\n this._tryNext(value);\n } else {\n this.buffer.push(value);\n }\n }\n _tryNext(value) {\n let result;\n const index = this.index++;\n try {\n result = this.project(value, index);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.active++;\n this._innerSub(result);\n }\n _innerSub(ish) {\n const innerSubscriber = new SimpleInnerSubscriber(this);\n const destination = this.destination;\n destination.add(innerSubscriber);\n const innerSubscription = innerSubscribe(ish, innerSubscriber);\n if (innerSubscription !== innerSubscriber) {\n destination.add(innerSubscription);\n }\n }\n _complete() {\n this.hasCompleted = true;\n if (this.active === 0 && this.buffer.length === 0) {\n this.destination.complete();\n }\n this.unsubscribe();\n }\n notifyNext(innerValue) {\n this.destination.next(innerValue);\n }\n notifyComplete() {\n const buffer = this.buffer;\n this.active--;\n if (buffer.length > 0) {\n this._next(buffer.shift());\n } else if (this.active === 0 && this.hasCompleted) {\n this.destination.complete();\n }\n }\n}\nexport const flatMap = mergeMap;\n","import { mergeMap } from './mergeMap';\nimport { identity } from '../util/identity';\nexport function mergeAll(concurrent = Number.POSITIVE_INFINITY) {\n return mergeMap(identity, concurrent);\n}\n","import { mergeAll } from './mergeAll';\nexport function concatAll() {\n return mergeAll(1);\n}\n","import { of } from './of';\nimport { concatAll } from '../operators/concatAll';\nexport function concat(...observables) {\n return concatAll()(of(...observables));\n}\n","import { concat as concatStatic } from '../observable/concat';\nexport function concat(...observables) {\n return source => source.lift.call(concatStatic(source, ...observables));\n}\n","import { mergeMap } from './mergeMap';\nexport function concatMap(project, resultSelector) {\n return mergeMap(project, resultSelector, 1);\n}\n","import { concatMap } from './concatMap';\nexport function concatMapTo(innerObservable, resultSelector) {\n return concatMap(() => innerObservable, resultSelector);\n}\n","import { Subscriber } from '../Subscriber';\nexport function count(predicate) {\n return source => source.lift(new CountOperator(predicate, source));\n}\nclass CountOperator {\n constructor(predicate, source) {\n this.predicate = predicate;\n this.source = source;\n }\n call(subscriber, source) {\n return source.subscribe(new CountSubscriber(subscriber, this.predicate, this.source));\n }\n}\nclass CountSubscriber extends Subscriber {\n constructor(destination, predicate, source) {\n super(destination);\n this.predicate = predicate;\n this.source = source;\n this.count = 0;\n this.index = 0;\n }\n _next(value) {\n if (this.predicate) {\n this._tryPredicate(value);\n } else {\n this.count++;\n }\n }\n _tryPredicate(value) {\n let result;\n try {\n result = this.predicate(value, this.index++, this.source);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n if (result) {\n this.count++;\n }\n }\n _complete() {\n this.destination.next(this.count);\n this.destination.complete();\n }\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function debounce(durationSelector) {\n return source => source.lift(new DebounceOperator(durationSelector));\n}\nclass DebounceOperator {\n constructor(durationSelector) {\n this.durationSelector = durationSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new DebounceSubscriber(subscriber, this.durationSelector));\n }\n}\nclass DebounceSubscriber extends SimpleOuterSubscriber {\n constructor(destination, durationSelector) {\n super(destination);\n this.durationSelector = durationSelector;\n this.hasValue = false;\n }\n _next(value) {\n try {\n const result = this.durationSelector.call(this, value);\n if (result) {\n this._tryNext(value, result);\n }\n } catch (err) {\n this.destination.error(err);\n }\n }\n _complete() {\n this.emitValue();\n this.destination.complete();\n }\n _tryNext(value, duration) {\n let subscription = this.durationSubscription;\n this.value = value;\n this.hasValue = true;\n if (subscription) {\n subscription.unsubscribe();\n this.remove(subscription);\n }\n subscription = innerSubscribe(duration, new SimpleInnerSubscriber(this));\n if (subscription && !subscription.closed) {\n this.add(this.durationSubscription = subscription);\n }\n }\n notifyNext() {\n this.emitValue();\n }\n notifyComplete() {\n this.emitValue();\n }\n emitValue() {\n if (this.hasValue) {\n const value = this.value;\n const subscription = this.durationSubscription;\n if (subscription) {\n this.durationSubscription = undefined;\n subscription.unsubscribe();\n this.remove(subscription);\n }\n this.value = undefined;\n this.hasValue = false;\n super._next(value);\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { async } from '../scheduler/async';\nexport function debounceTime(dueTime, scheduler = async) {\n return source => source.lift(new DebounceTimeOperator(dueTime, scheduler));\n}\nclass DebounceTimeOperator {\n constructor(dueTime, scheduler) {\n this.dueTime = dueTime;\n this.scheduler = scheduler;\n }\n call(subscriber, source) {\n return source.subscribe(new DebounceTimeSubscriber(subscriber, this.dueTime, this.scheduler));\n }\n}\nclass DebounceTimeSubscriber extends Subscriber {\n constructor(destination, dueTime, scheduler) {\n super(destination);\n this.dueTime = dueTime;\n this.scheduler = scheduler;\n this.debouncedSubscription = null;\n this.lastValue = null;\n this.hasValue = false;\n }\n _next(value) {\n this.clearDebounce();\n this.lastValue = value;\n this.hasValue = true;\n this.add(this.debouncedSubscription = this.scheduler.schedule(dispatchNext, this.dueTime, this));\n }\n _complete() {\n this.debouncedNext();\n this.destination.complete();\n }\n debouncedNext() {\n this.clearDebounce();\n if (this.hasValue) {\n const {\n lastValue\n } = this;\n this.lastValue = null;\n this.hasValue = false;\n this.destination.next(lastValue);\n }\n }\n clearDebounce() {\n const debouncedSubscription = this.debouncedSubscription;\n if (debouncedSubscription !== null) {\n this.remove(debouncedSubscription);\n debouncedSubscription.unsubscribe();\n this.debouncedSubscription = null;\n }\n }\n}\nfunction dispatchNext(subscriber) {\n subscriber.debouncedNext();\n}\n","import { Subscriber } from '../Subscriber';\nexport function defaultIfEmpty(defaultValue = null) {\n return source => source.lift(new DefaultIfEmptyOperator(defaultValue));\n}\nclass DefaultIfEmptyOperator {\n constructor(defaultValue) {\n this.defaultValue = defaultValue;\n }\n call(subscriber, source) {\n return source.subscribe(new DefaultIfEmptySubscriber(subscriber, this.defaultValue));\n }\n}\nclass DefaultIfEmptySubscriber extends Subscriber {\n constructor(destination, defaultValue) {\n super(destination);\n this.defaultValue = defaultValue;\n this.isEmpty = true;\n }\n _next(value) {\n this.isEmpty = false;\n this.destination.next(value);\n }\n _complete() {\n if (this.isEmpty) {\n this.destination.next(this.defaultValue);\n }\n this.destination.complete();\n }\n}\n","export function isDate(value) {\n return value instanceof Date && !isNaN(+value);\n}\n","import { Observable } from '../Observable';\nexport const EMPTY = new Observable(subscriber => subscriber.complete());\nexport function empty(scheduler) {\n return scheduler ? emptyScheduled(scheduler) : EMPTY;\n}\nfunction emptyScheduled(scheduler) {\n return new Observable(subscriber => scheduler.schedule(() => subscriber.complete()));\n}\n","import { Observable } from '../Observable';\nexport function throwError(error, scheduler) {\n if (!scheduler) {\n return new Observable(subscriber => subscriber.error(error));\n } else {\n return new Observable(subscriber => scheduler.schedule(dispatch, 0, {\n error,\n subscriber\n }));\n }\n}\nfunction dispatch({\n error,\n subscriber\n}) {\n subscriber.error(error);\n}\n","import { empty } from './observable/empty';\nimport { of } from './observable/of';\nimport { throwError } from './observable/throwError';\nexport var NotificationKind = /*#__PURE__*/function (NotificationKind) {\n NotificationKind[\"NEXT\"] = \"N\";\n NotificationKind[\"ERROR\"] = \"E\";\n NotificationKind[\"COMPLETE\"] = \"C\";\n return NotificationKind;\n}(NotificationKind || {});\nexport class Notification {\n constructor(kind, value, error) {\n this.kind = kind;\n this.value = value;\n this.error = error;\n this.hasValue = kind === 'N';\n }\n observe(observer) {\n switch (this.kind) {\n case 'N':\n return observer.next && observer.next(this.value);\n case 'E':\n return observer.error && observer.error(this.error);\n case 'C':\n return observer.complete && observer.complete();\n }\n }\n do(next, error, complete) {\n const kind = this.kind;\n switch (kind) {\n case 'N':\n return next && next(this.value);\n case 'E':\n return error && error(this.error);\n case 'C':\n return complete && complete();\n }\n }\n accept(nextOrObserver, error, complete) {\n if (nextOrObserver && typeof nextOrObserver.next === 'function') {\n return this.observe(nextOrObserver);\n } else {\n return this.do(nextOrObserver, error, complete);\n }\n }\n toObservable() {\n const kind = this.kind;\n switch (kind) {\n case 'N':\n return of(this.value);\n case 'E':\n return throwError(this.error);\n case 'C':\n return empty();\n }\n throw new Error('unexpected notification kind value');\n }\n static createNext(value) {\n if (typeof value !== 'undefined') {\n return new Notification('N', value);\n }\n return Notification.undefinedValueNotification;\n }\n static createError(err) {\n return new Notification('E', undefined, err);\n }\n static createComplete() {\n return Notification.completeNotification;\n }\n}\nNotification.completeNotification = new Notification('C');\nNotification.undefinedValueNotification = new Notification('N', undefined);\n","import { async } from '../scheduler/async';\nimport { isDate } from '../util/isDate';\nimport { Subscriber } from '../Subscriber';\nimport { Notification } from '../Notification';\nexport function delay(delay, scheduler = async) {\n const absoluteDelay = isDate(delay);\n const delayFor = absoluteDelay ? +delay - scheduler.now() : Math.abs(delay);\n return source => source.lift(new DelayOperator(delayFor, scheduler));\n}\nclass DelayOperator {\n constructor(delay, scheduler) {\n this.delay = delay;\n this.scheduler = scheduler;\n }\n call(subscriber, source) {\n return source.subscribe(new DelaySubscriber(subscriber, this.delay, this.scheduler));\n }\n}\nclass DelaySubscriber extends Subscriber {\n constructor(destination, delay, scheduler) {\n super(destination);\n this.delay = delay;\n this.scheduler = scheduler;\n this.queue = [];\n this.active = false;\n this.errored = false;\n }\n static dispatch(state) {\n const source = state.source;\n const queue = source.queue;\n const scheduler = state.scheduler;\n const destination = state.destination;\n while (queue.length > 0 && queue[0].time - scheduler.now() <= 0) {\n queue.shift().notification.observe(destination);\n }\n if (queue.length > 0) {\n const delay = Math.max(0, queue[0].time - scheduler.now());\n this.schedule(state, delay);\n } else {\n this.unsubscribe();\n source.active = false;\n }\n }\n _schedule(scheduler) {\n this.active = true;\n const destination = this.destination;\n destination.add(scheduler.schedule(DelaySubscriber.dispatch, this.delay, {\n source: this,\n destination: this.destination,\n scheduler: scheduler\n }));\n }\n scheduleNotification(notification) {\n if (this.errored === true) {\n return;\n }\n const scheduler = this.scheduler;\n const message = new DelayMessage(scheduler.now() + this.delay, notification);\n this.queue.push(message);\n if (this.active === false) {\n this._schedule(scheduler);\n }\n }\n _next(value) {\n this.scheduleNotification(Notification.createNext(value));\n }\n _error(err) {\n this.errored = true;\n this.queue = [];\n this.destination.error(err);\n this.unsubscribe();\n }\n _complete() {\n this.scheduleNotification(Notification.createComplete());\n this.unsubscribe();\n }\n}\nclass DelayMessage {\n constructor(time, notification) {\n this.time = time;\n this.notification = notification;\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { Observable } from '../Observable';\nimport { OuterSubscriber } from '../OuterSubscriber';\nimport { subscribeToResult } from '../util/subscribeToResult';\nexport function delayWhen(delayDurationSelector, subscriptionDelay) {\n if (subscriptionDelay) {\n return source => new SubscriptionDelayObservable(source, subscriptionDelay).lift(new DelayWhenOperator(delayDurationSelector));\n }\n return source => source.lift(new DelayWhenOperator(delayDurationSelector));\n}\nclass DelayWhenOperator {\n constructor(delayDurationSelector) {\n this.delayDurationSelector = delayDurationSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new DelayWhenSubscriber(subscriber, this.delayDurationSelector));\n }\n}\nclass DelayWhenSubscriber extends OuterSubscriber {\n constructor(destination, delayDurationSelector) {\n super(destination);\n this.delayDurationSelector = delayDurationSelector;\n this.completed = false;\n this.delayNotifierSubscriptions = [];\n this.index = 0;\n }\n notifyNext(outerValue, _innerValue, _outerIndex, _innerIndex, innerSub) {\n this.destination.next(outerValue);\n this.removeSubscription(innerSub);\n this.tryComplete();\n }\n notifyError(error, innerSub) {\n this._error(error);\n }\n notifyComplete(innerSub) {\n const value = this.removeSubscription(innerSub);\n if (value) {\n this.destination.next(value);\n }\n this.tryComplete();\n }\n _next(value) {\n const index = this.index++;\n try {\n const delayNotifier = this.delayDurationSelector(value, index);\n if (delayNotifier) {\n this.tryDelay(delayNotifier, value);\n }\n } catch (err) {\n this.destination.error(err);\n }\n }\n _complete() {\n this.completed = true;\n this.tryComplete();\n this.unsubscribe();\n }\n removeSubscription(subscription) {\n subscription.unsubscribe();\n const subscriptionIdx = this.delayNotifierSubscriptions.indexOf(subscription);\n if (subscriptionIdx !== -1) {\n this.delayNotifierSubscriptions.splice(subscriptionIdx, 1);\n }\n return subscription.outerValue;\n }\n tryDelay(delayNotifier, value) {\n const notifierSubscription = subscribeToResult(this, delayNotifier, value);\n if (notifierSubscription && !notifierSubscription.closed) {\n const destination = this.destination;\n destination.add(notifierSubscription);\n this.delayNotifierSubscriptions.push(notifierSubscription);\n }\n }\n tryComplete() {\n if (this.completed && this.delayNotifierSubscriptions.length === 0) {\n this.destination.complete();\n }\n }\n}\nclass SubscriptionDelayObservable extends Observable {\n constructor(source, subscriptionDelay) {\n super();\n this.source = source;\n this.subscriptionDelay = subscriptionDelay;\n }\n _subscribe(subscriber) {\n this.subscriptionDelay.subscribe(new SubscriptionDelaySubscriber(subscriber, this.source));\n }\n}\nclass SubscriptionDelaySubscriber extends Subscriber {\n constructor(parent, source) {\n super();\n this.parent = parent;\n this.source = source;\n this.sourceSubscribed = false;\n }\n _next(unused) {\n this.subscribeToSource();\n }\n _error(err) {\n this.unsubscribe();\n this.parent.error(err);\n }\n _complete() {\n this.unsubscribe();\n this.subscribeToSource();\n }\n subscribeToSource() {\n if (!this.sourceSubscribed) {\n this.sourceSubscribed = true;\n this.unsubscribe();\n this.source.subscribe(this.parent);\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function dematerialize() {\n return function dematerializeOperatorFunction(source) {\n return source.lift(new DeMaterializeOperator());\n };\n}\nclass DeMaterializeOperator {\n call(subscriber, source) {\n return source.subscribe(new DeMaterializeSubscriber(subscriber));\n }\n}\nclass DeMaterializeSubscriber extends Subscriber {\n constructor(destination) {\n super(destination);\n }\n _next(value) {\n value.observe(this.destination);\n }\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function distinct(keySelector, flushes) {\n return source => source.lift(new DistinctOperator(keySelector, flushes));\n}\nclass DistinctOperator {\n constructor(keySelector, flushes) {\n this.keySelector = keySelector;\n this.flushes = flushes;\n }\n call(subscriber, source) {\n return source.subscribe(new DistinctSubscriber(subscriber, this.keySelector, this.flushes));\n }\n}\nexport class DistinctSubscriber extends SimpleOuterSubscriber {\n constructor(destination, keySelector, flushes) {\n super(destination);\n this.keySelector = keySelector;\n this.values = new Set();\n if (flushes) {\n this.add(innerSubscribe(flushes, new SimpleInnerSubscriber(this)));\n }\n }\n notifyNext() {\n this.values.clear();\n }\n notifyError(error) {\n this._error(error);\n }\n _next(value) {\n if (this.keySelector) {\n this._useKeySelector(value);\n } else {\n this._finalizeNext(value, value);\n }\n }\n _useKeySelector(value) {\n let key;\n const {\n destination\n } = this;\n try {\n key = this.keySelector(value);\n } catch (err) {\n destination.error(err);\n return;\n }\n this._finalizeNext(key, value);\n }\n _finalizeNext(key, value) {\n const {\n values\n } = this;\n if (!values.has(key)) {\n values.add(key);\n this.destination.next(value);\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function distinctUntilChanged(compare, keySelector) {\n return source => source.lift(new DistinctUntilChangedOperator(compare, keySelector));\n}\nclass DistinctUntilChangedOperator {\n constructor(compare, keySelector) {\n this.compare = compare;\n this.keySelector = keySelector;\n }\n call(subscriber, source) {\n return source.subscribe(new DistinctUntilChangedSubscriber(subscriber, this.compare, this.keySelector));\n }\n}\nclass DistinctUntilChangedSubscriber extends Subscriber {\n constructor(destination, compare, keySelector) {\n super(destination);\n this.keySelector = keySelector;\n this.hasKey = false;\n if (typeof compare === 'function') {\n this.compare = compare;\n }\n }\n compare(x, y) {\n return x === y;\n }\n _next(value) {\n let key;\n try {\n const {\n keySelector\n } = this;\n key = keySelector ? keySelector(value) : value;\n } catch (err) {\n return this.destination.error(err);\n }\n let result = false;\n if (this.hasKey) {\n try {\n const {\n compare\n } = this;\n result = compare(this.key, key);\n } catch (err) {\n return this.destination.error(err);\n }\n } else {\n this.hasKey = true;\n }\n if (!result) {\n this.key = key;\n this.destination.next(value);\n }\n }\n}\n","import { distinctUntilChanged } from './distinctUntilChanged';\nexport function distinctUntilKeyChanged(key, compare) {\n return distinctUntilChanged((x, y) => compare ? compare(x[key], y[key]) : x[key] === y[key]);\n}\n","const ArgumentOutOfRangeErrorImpl = (() => {\n function ArgumentOutOfRangeErrorImpl() {\n Error.call(this);\n this.message = 'argument out of range';\n this.name = 'ArgumentOutOfRangeError';\n return this;\n }\n ArgumentOutOfRangeErrorImpl.prototype = Object.create(Error.prototype);\n return ArgumentOutOfRangeErrorImpl;\n})();\nexport const ArgumentOutOfRangeError = ArgumentOutOfRangeErrorImpl;\n","import { Subscriber } from '../Subscriber';\nexport function filter(predicate, thisArg) {\n return function filterOperatorFunction(source) {\n return source.lift(new FilterOperator(predicate, thisArg));\n };\n}\nclass FilterOperator {\n constructor(predicate, thisArg) {\n this.predicate = predicate;\n this.thisArg = thisArg;\n }\n call(subscriber, source) {\n return source.subscribe(new FilterSubscriber(subscriber, this.predicate, this.thisArg));\n }\n}\nclass FilterSubscriber extends Subscriber {\n constructor(destination, predicate, thisArg) {\n super(destination);\n this.predicate = predicate;\n this.thisArg = thisArg;\n this.count = 0;\n }\n _next(value) {\n let result;\n try {\n result = this.predicate.call(this.thisArg, value, this.count++);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n if (result) {\n this.destination.next(value);\n }\n }\n}\n","const EmptyErrorImpl = (() => {\n function EmptyErrorImpl() {\n Error.call(this);\n this.message = 'no elements in sequence';\n this.name = 'EmptyError';\n return this;\n }\n EmptyErrorImpl.prototype = Object.create(Error.prototype);\n return EmptyErrorImpl;\n})();\nexport const EmptyError = EmptyErrorImpl;\n","import { EmptyError } from '../util/EmptyError';\nimport { Subscriber } from '../Subscriber';\nexport function throwIfEmpty(errorFactory = defaultErrorFactory) {\n return source => {\n return source.lift(new ThrowIfEmptyOperator(errorFactory));\n };\n}\nclass ThrowIfEmptyOperator {\n constructor(errorFactory) {\n this.errorFactory = errorFactory;\n }\n call(subscriber, source) {\n return source.subscribe(new ThrowIfEmptySubscriber(subscriber, this.errorFactory));\n }\n}\nclass ThrowIfEmptySubscriber extends Subscriber {\n constructor(destination, errorFactory) {\n super(destination);\n this.errorFactory = errorFactory;\n this.hasValue = false;\n }\n _next(value) {\n this.hasValue = true;\n this.destination.next(value);\n }\n _complete() {\n if (!this.hasValue) {\n let err;\n try {\n err = this.errorFactory();\n } catch (e) {\n err = e;\n }\n this.destination.error(err);\n } else {\n return this.destination.complete();\n }\n }\n}\nfunction defaultErrorFactory() {\n return new EmptyError();\n}\n","import { Subscriber } from '../Subscriber';\nimport { ArgumentOutOfRangeError } from '../util/ArgumentOutOfRangeError';\nimport { empty } from '../observable/empty';\nexport function take(count) {\n return source => {\n if (count === 0) {\n return empty();\n } else {\n return source.lift(new TakeOperator(count));\n }\n };\n}\nclass TakeOperator {\n constructor(total) {\n this.total = total;\n if (this.total < 0) {\n throw new ArgumentOutOfRangeError();\n }\n }\n call(subscriber, source) {\n return source.subscribe(new TakeSubscriber(subscriber, this.total));\n }\n}\nclass TakeSubscriber extends Subscriber {\n constructor(destination, total) {\n super(destination);\n this.total = total;\n this.count = 0;\n }\n _next(value) {\n const total = this.total;\n const count = ++this.count;\n if (count <= total) {\n this.destination.next(value);\n if (count === total) {\n this.destination.complete();\n this.unsubscribe();\n }\n }\n }\n}\n","import { ArgumentOutOfRangeError } from '../util/ArgumentOutOfRangeError';\nimport { filter } from './filter';\nimport { throwIfEmpty } from './throwIfEmpty';\nimport { defaultIfEmpty } from './defaultIfEmpty';\nimport { take } from './take';\nexport function elementAt(index, defaultValue) {\n if (index < 0) {\n throw new ArgumentOutOfRangeError();\n }\n const hasDefaultValue = arguments.length >= 2;\n return source => source.pipe(filter((v, i) => i === index), take(1), hasDefaultValue ? defaultIfEmpty(defaultValue) : throwIfEmpty(() => new ArgumentOutOfRangeError()));\n}\n","import { concat } from '../observable/concat';\nimport { of } from '../observable/of';\nexport function endWith(...array) {\n return source => concat(source, of(...array));\n}\n","import { Subscriber } from '../Subscriber';\nexport function every(predicate, thisArg) {\n return source => source.lift(new EveryOperator(predicate, thisArg, source));\n}\nclass EveryOperator {\n constructor(predicate, thisArg, source) {\n this.predicate = predicate;\n this.thisArg = thisArg;\n this.source = source;\n }\n call(observer, source) {\n return source.subscribe(new EverySubscriber(observer, this.predicate, this.thisArg, this.source));\n }\n}\nclass EverySubscriber extends Subscriber {\n constructor(destination, predicate, thisArg, source) {\n super(destination);\n this.predicate = predicate;\n this.thisArg = thisArg;\n this.source = source;\n this.index = 0;\n this.thisArg = thisArg || this;\n }\n notifyComplete(everyValueMatch) {\n this.destination.next(everyValueMatch);\n this.destination.complete();\n }\n _next(value) {\n let result = false;\n try {\n result = this.predicate.call(this.thisArg, value, this.index++, this.source);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n if (!result) {\n this.notifyComplete(false);\n }\n }\n _complete() {\n this.notifyComplete(true);\n }\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function exhaust() {\n return source => source.lift(new SwitchFirstOperator());\n}\nclass SwitchFirstOperator {\n call(subscriber, source) {\n return source.subscribe(new SwitchFirstSubscriber(subscriber));\n }\n}\nclass SwitchFirstSubscriber extends SimpleOuterSubscriber {\n constructor(destination) {\n super(destination);\n this.hasCompleted = false;\n this.hasSubscription = false;\n }\n _next(value) {\n if (!this.hasSubscription) {\n this.hasSubscription = true;\n this.add(innerSubscribe(value, new SimpleInnerSubscriber(this)));\n }\n }\n _complete() {\n this.hasCompleted = true;\n if (!this.hasSubscription) {\n this.destination.complete();\n }\n }\n notifyComplete() {\n this.hasSubscription = false;\n if (this.hasCompleted) {\n this.destination.complete();\n }\n }\n}\n","import { map } from './map';\nimport { from } from '../observable/from';\nimport { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function exhaustMap(project, resultSelector) {\n if (resultSelector) {\n return source => source.pipe(exhaustMap((a, i) => from(project(a, i)).pipe(map((b, ii) => resultSelector(a, b, i, ii)))));\n }\n return source => source.lift(new ExhaustMapOperator(project));\n}\nclass ExhaustMapOperator {\n constructor(project) {\n this.project = project;\n }\n call(subscriber, source) {\n return source.subscribe(new ExhaustMapSubscriber(subscriber, this.project));\n }\n}\nclass ExhaustMapSubscriber extends SimpleOuterSubscriber {\n constructor(destination, project) {\n super(destination);\n this.project = project;\n this.hasSubscription = false;\n this.hasCompleted = false;\n this.index = 0;\n }\n _next(value) {\n if (!this.hasSubscription) {\n this.tryNext(value);\n }\n }\n tryNext(value) {\n let result;\n const index = this.index++;\n try {\n result = this.project(value, index);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.hasSubscription = true;\n this._innerSub(result);\n }\n _innerSub(result) {\n const innerSubscriber = new SimpleInnerSubscriber(this);\n const destination = this.destination;\n destination.add(innerSubscriber);\n const innerSubscription = innerSubscribe(result, innerSubscriber);\n if (innerSubscription !== innerSubscriber) {\n destination.add(innerSubscription);\n }\n }\n _complete() {\n this.hasCompleted = true;\n if (!this.hasSubscription) {\n this.destination.complete();\n }\n this.unsubscribe();\n }\n notifyNext(innerValue) {\n this.destination.next(innerValue);\n }\n notifyError(err) {\n this.destination.error(err);\n }\n notifyComplete() {\n this.hasSubscription = false;\n if (this.hasCompleted) {\n this.destination.complete();\n }\n }\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function expand(project, concurrent = Number.POSITIVE_INFINITY, scheduler) {\n concurrent = (concurrent || 0) < 1 ? Number.POSITIVE_INFINITY : concurrent;\n return source => source.lift(new ExpandOperator(project, concurrent, scheduler));\n}\nexport class ExpandOperator {\n constructor(project, concurrent, scheduler) {\n this.project = project;\n this.concurrent = concurrent;\n this.scheduler = scheduler;\n }\n call(subscriber, source) {\n return source.subscribe(new ExpandSubscriber(subscriber, this.project, this.concurrent, this.scheduler));\n }\n}\nexport class ExpandSubscriber extends SimpleOuterSubscriber {\n constructor(destination, project, concurrent, scheduler) {\n super(destination);\n this.project = project;\n this.concurrent = concurrent;\n this.scheduler = scheduler;\n this.index = 0;\n this.active = 0;\n this.hasCompleted = false;\n if (concurrent < Number.POSITIVE_INFINITY) {\n this.buffer = [];\n }\n }\n static dispatch(arg) {\n const {\n subscriber,\n result,\n value,\n index\n } = arg;\n subscriber.subscribeToProjection(result, value, index);\n }\n _next(value) {\n const destination = this.destination;\n if (destination.closed) {\n this._complete();\n return;\n }\n const index = this.index++;\n if (this.active < this.concurrent) {\n destination.next(value);\n try {\n const {\n project\n } = this;\n const result = project(value, index);\n if (!this.scheduler) {\n this.subscribeToProjection(result, value, index);\n } else {\n const state = {\n subscriber: this,\n result,\n value,\n index\n };\n const destination = this.destination;\n destination.add(this.scheduler.schedule(ExpandSubscriber.dispatch, 0, state));\n }\n } catch (e) {\n destination.error(e);\n }\n } else {\n this.buffer.push(value);\n }\n }\n subscribeToProjection(result, value, index) {\n this.active++;\n const destination = this.destination;\n destination.add(innerSubscribe(result, new SimpleInnerSubscriber(this)));\n }\n _complete() {\n this.hasCompleted = true;\n if (this.hasCompleted && this.active === 0) {\n this.destination.complete();\n }\n this.unsubscribe();\n }\n notifyNext(innerValue) {\n this._next(innerValue);\n }\n notifyComplete() {\n const buffer = this.buffer;\n this.active--;\n if (buffer && buffer.length > 0) {\n this._next(buffer.shift());\n }\n if (this.hasCompleted && this.active === 0) {\n this.destination.complete();\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { Subscription } from '../Subscription';\nexport function finalize(callback) {\n return source => source.lift(new FinallyOperator(callback));\n}\nclass FinallyOperator {\n constructor(callback) {\n this.callback = callback;\n }\n call(subscriber, source) {\n return source.subscribe(new FinallySubscriber(subscriber, this.callback));\n }\n}\nclass FinallySubscriber extends Subscriber {\n constructor(destination, callback) {\n super(destination);\n this.add(new Subscription(callback));\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function find(predicate, thisArg) {\n if (typeof predicate !== 'function') {\n throw new TypeError('predicate is not a function');\n }\n return source => source.lift(new FindValueOperator(predicate, source, false, thisArg));\n}\nexport class FindValueOperator {\n constructor(predicate, source, yieldIndex, thisArg) {\n this.predicate = predicate;\n this.source = source;\n this.yieldIndex = yieldIndex;\n this.thisArg = thisArg;\n }\n call(observer, source) {\n return source.subscribe(new FindValueSubscriber(observer, this.predicate, this.source, this.yieldIndex, this.thisArg));\n }\n}\nexport class FindValueSubscriber extends Subscriber {\n constructor(destination, predicate, source, yieldIndex, thisArg) {\n super(destination);\n this.predicate = predicate;\n this.source = source;\n this.yieldIndex = yieldIndex;\n this.thisArg = thisArg;\n this.index = 0;\n }\n notifyComplete(value) {\n const destination = this.destination;\n destination.next(value);\n destination.complete();\n this.unsubscribe();\n }\n _next(value) {\n const {\n predicate,\n thisArg\n } = this;\n const index = this.index++;\n try {\n const result = predicate.call(thisArg || this, value, index, this.source);\n if (result) {\n this.notifyComplete(this.yieldIndex ? index : value);\n }\n } catch (err) {\n this.destination.error(err);\n }\n }\n _complete() {\n this.notifyComplete(this.yieldIndex ? -1 : undefined);\n }\n}\n","import { FindValueOperator } from '../operators/find';\nexport function findIndex(predicate, thisArg) {\n return source => source.lift(new FindValueOperator(predicate, source, true, thisArg));\n}\n","import { EmptyError } from '../util/EmptyError';\nimport { filter } from './filter';\nimport { take } from './take';\nimport { defaultIfEmpty } from './defaultIfEmpty';\nimport { throwIfEmpty } from './throwIfEmpty';\nimport { identity } from '../util/identity';\nexport function first(predicate, defaultValue) {\n const hasDefaultValue = arguments.length >= 2;\n return source => source.pipe(predicate ? filter((v, i) => predicate(v, i, source)) : identity, take(1), hasDefaultValue ? defaultIfEmpty(defaultValue) : throwIfEmpty(() => new EmptyError()));\n}\n","const ObjectUnsubscribedErrorImpl = (() => {\n function ObjectUnsubscribedErrorImpl() {\n Error.call(this);\n this.message = 'object unsubscribed';\n this.name = 'ObjectUnsubscribedError';\n return this;\n }\n ObjectUnsubscribedErrorImpl.prototype = Object.create(Error.prototype);\n return ObjectUnsubscribedErrorImpl;\n})();\nexport const ObjectUnsubscribedError = ObjectUnsubscribedErrorImpl;\n","import { Subscription } from './Subscription';\nexport class SubjectSubscription extends Subscription {\n constructor(subject, subscriber) {\n super();\n this.subject = subject;\n this.subscriber = subscriber;\n this.closed = false;\n }\n unsubscribe() {\n if (this.closed) {\n return;\n }\n this.closed = true;\n const subject = this.subject;\n const observers = subject.observers;\n this.subject = null;\n if (!observers || observers.length === 0 || subject.isStopped || subject.closed) {\n return;\n }\n const subscriberIndex = observers.indexOf(this.subscriber);\n if (subscriberIndex !== -1) {\n observers.splice(subscriberIndex, 1);\n }\n }\n}\n","import { Observable } from './Observable';\nimport { Subscriber } from './Subscriber';\nimport { Subscription } from './Subscription';\nimport { ObjectUnsubscribedError } from './util/ObjectUnsubscribedError';\nimport { SubjectSubscription } from './SubjectSubscription';\nimport { rxSubscriber as rxSubscriberSymbol } from '../internal/symbol/rxSubscriber';\nexport class SubjectSubscriber extends Subscriber {\n constructor(destination) {\n super(destination);\n this.destination = destination;\n }\n}\nexport let Subject = /*#__PURE__*/(() => {\n class Subject extends Observable {\n constructor() {\n super();\n this.observers = [];\n this.closed = false;\n this.isStopped = false;\n this.hasError = false;\n this.thrownError = null;\n }\n [rxSubscriberSymbol]() {\n return new SubjectSubscriber(this);\n }\n lift(operator) {\n const subject = new AnonymousSubject(this, this);\n subject.operator = operator;\n return subject;\n }\n next(value) {\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n }\n if (!this.isStopped) {\n const {\n observers\n } = this;\n const len = observers.length;\n const copy = observers.slice();\n for (let i = 0; i < len; i++) {\n copy[i].next(value);\n }\n }\n }\n error(err) {\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n }\n this.hasError = true;\n this.thrownError = err;\n this.isStopped = true;\n const {\n observers\n } = this;\n const len = observers.length;\n const copy = observers.slice();\n for (let i = 0; i < len; i++) {\n copy[i].error(err);\n }\n this.observers.length = 0;\n }\n complete() {\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n }\n this.isStopped = true;\n const {\n observers\n } = this;\n const len = observers.length;\n const copy = observers.slice();\n for (let i = 0; i < len; i++) {\n copy[i].complete();\n }\n this.observers.length = 0;\n }\n unsubscribe() {\n this.isStopped = true;\n this.closed = true;\n this.observers = null;\n }\n _trySubscribe(subscriber) {\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n } else {\n return super._trySubscribe(subscriber);\n }\n }\n _subscribe(subscriber) {\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n } else if (this.hasError) {\n subscriber.error(this.thrownError);\n return Subscription.EMPTY;\n } else if (this.isStopped) {\n subscriber.complete();\n return Subscription.EMPTY;\n } else {\n this.observers.push(subscriber);\n return new SubjectSubscription(this, subscriber);\n }\n }\n asObservable() {\n const observable = new Observable();\n observable.source = this;\n return observable;\n }\n }\n Subject.create = (destination, source) => {\n return new AnonymousSubject(destination, source);\n };\n return Subject;\n})();\nexport class AnonymousSubject extends Subject {\n constructor(destination, source) {\n super();\n this.destination = destination;\n this.source = source;\n }\n next(value) {\n const {\n destination\n } = this;\n if (destination && destination.next) {\n destination.next(value);\n }\n }\n error(err) {\n const {\n destination\n } = this;\n if (destination && destination.error) {\n this.destination.error(err);\n }\n }\n complete() {\n const {\n destination\n } = this;\n if (destination && destination.complete) {\n this.destination.complete();\n }\n }\n _subscribe(subscriber) {\n const {\n source\n } = this;\n if (source) {\n return this.source.subscribe(subscriber);\n } else {\n return Subscription.EMPTY;\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { Subscription } from '../Subscription';\nimport { Observable } from '../Observable';\nimport { Subject } from '../Subject';\nexport function groupBy(keySelector, elementSelector, durationSelector, subjectSelector) {\n return source => source.lift(new GroupByOperator(keySelector, elementSelector, durationSelector, subjectSelector));\n}\nclass GroupByOperator {\n constructor(keySelector, elementSelector, durationSelector, subjectSelector) {\n this.keySelector = keySelector;\n this.elementSelector = elementSelector;\n this.durationSelector = durationSelector;\n this.subjectSelector = subjectSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new GroupBySubscriber(subscriber, this.keySelector, this.elementSelector, this.durationSelector, this.subjectSelector));\n }\n}\nclass GroupBySubscriber extends Subscriber {\n constructor(destination, keySelector, elementSelector, durationSelector, subjectSelector) {\n super(destination);\n this.keySelector = keySelector;\n this.elementSelector = elementSelector;\n this.durationSelector = durationSelector;\n this.subjectSelector = subjectSelector;\n this.groups = null;\n this.attemptedToUnsubscribe = false;\n this.count = 0;\n }\n _next(value) {\n let key;\n try {\n key = this.keySelector(value);\n } catch (err) {\n this.error(err);\n return;\n }\n this._group(value, key);\n }\n _group(value, key) {\n let groups = this.groups;\n if (!groups) {\n groups = this.groups = new Map();\n }\n let group = groups.get(key);\n let element;\n if (this.elementSelector) {\n try {\n element = this.elementSelector(value);\n } catch (err) {\n this.error(err);\n }\n } else {\n element = value;\n }\n if (!group) {\n group = this.subjectSelector ? this.subjectSelector() : new Subject();\n groups.set(key, group);\n const groupedObservable = new GroupedObservable(key, group, this);\n this.destination.next(groupedObservable);\n if (this.durationSelector) {\n let duration;\n try {\n duration = this.durationSelector(new GroupedObservable(key, group));\n } catch (err) {\n this.error(err);\n return;\n }\n this.add(duration.subscribe(new GroupDurationSubscriber(key, group, this)));\n }\n }\n if (!group.closed) {\n group.next(element);\n }\n }\n _error(err) {\n const groups = this.groups;\n if (groups) {\n groups.forEach((group, key) => {\n group.error(err);\n });\n groups.clear();\n }\n this.destination.error(err);\n }\n _complete() {\n const groups = this.groups;\n if (groups) {\n groups.forEach((group, key) => {\n group.complete();\n });\n groups.clear();\n }\n this.destination.complete();\n }\n removeGroup(key) {\n this.groups.delete(key);\n }\n unsubscribe() {\n if (!this.closed) {\n this.attemptedToUnsubscribe = true;\n if (this.count === 0) {\n super.unsubscribe();\n }\n }\n }\n}\nclass GroupDurationSubscriber extends Subscriber {\n constructor(key, group, parent) {\n super(group);\n this.key = key;\n this.group = group;\n this.parent = parent;\n }\n _next(value) {\n this.complete();\n }\n _unsubscribe() {\n const {\n parent,\n key\n } = this;\n this.key = this.parent = null;\n if (parent) {\n parent.removeGroup(key);\n }\n }\n}\nexport class GroupedObservable extends Observable {\n constructor(key, groupSubject, refCountSubscription) {\n super();\n this.key = key;\n this.groupSubject = groupSubject;\n this.refCountSubscription = refCountSubscription;\n }\n _subscribe(subscriber) {\n const subscription = new Subscription();\n const {\n refCountSubscription,\n groupSubject\n } = this;\n if (refCountSubscription && !refCountSubscription.closed) {\n subscription.add(new InnerRefCountSubscription(refCountSubscription));\n }\n subscription.add(groupSubject.subscribe(subscriber));\n return subscription;\n }\n}\nclass InnerRefCountSubscription extends Subscription {\n constructor(parent) {\n super();\n this.parent = parent;\n parent.count++;\n }\n unsubscribe() {\n const parent = this.parent;\n if (!parent.closed && !this.closed) {\n super.unsubscribe();\n parent.count -= 1;\n if (parent.count === 0 && parent.attemptedToUnsubscribe) {\n parent.unsubscribe();\n }\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function ignoreElements() {\n return function ignoreElementsOperatorFunction(source) {\n return source.lift(new IgnoreElementsOperator());\n };\n}\nclass IgnoreElementsOperator {\n call(subscriber, source) {\n return source.subscribe(new IgnoreElementsSubscriber(subscriber));\n }\n}\nclass IgnoreElementsSubscriber extends Subscriber {\n _next(unused) {}\n}\n","import { Subscriber } from '../Subscriber';\nexport function isEmpty() {\n return source => source.lift(new IsEmptyOperator());\n}\nclass IsEmptyOperator {\n call(observer, source) {\n return source.subscribe(new IsEmptySubscriber(observer));\n }\n}\nclass IsEmptySubscriber extends Subscriber {\n constructor(destination) {\n super(destination);\n }\n notifyComplete(isEmpty) {\n const destination = this.destination;\n destination.next(isEmpty);\n destination.complete();\n }\n _next(value) {\n this.notifyComplete(false);\n }\n _complete() {\n this.notifyComplete(true);\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { ArgumentOutOfRangeError } from '../util/ArgumentOutOfRangeError';\nimport { empty } from '../observable/empty';\nexport function takeLast(count) {\n return function takeLastOperatorFunction(source) {\n if (count === 0) {\n return empty();\n } else {\n return source.lift(new TakeLastOperator(count));\n }\n };\n}\nclass TakeLastOperator {\n constructor(total) {\n this.total = total;\n if (this.total < 0) {\n throw new ArgumentOutOfRangeError();\n }\n }\n call(subscriber, source) {\n return source.subscribe(new TakeLastSubscriber(subscriber, this.total));\n }\n}\nclass TakeLastSubscriber extends Subscriber {\n constructor(destination, total) {\n super(destination);\n this.total = total;\n this.ring = new Array();\n this.count = 0;\n }\n _next(value) {\n const ring = this.ring;\n const total = this.total;\n const count = this.count++;\n if (ring.length < total) {\n ring.push(value);\n } else {\n const index = count % total;\n ring[index] = value;\n }\n }\n _complete() {\n const destination = this.destination;\n let count = this.count;\n if (count > 0) {\n const total = this.count >= this.total ? this.total : this.count;\n const ring = this.ring;\n for (let i = 0; i < total; i++) {\n const idx = count++ % total;\n destination.next(ring[idx]);\n }\n }\n destination.complete();\n }\n}\n","import { EmptyError } from '../util/EmptyError';\nimport { filter } from './filter';\nimport { takeLast } from './takeLast';\nimport { throwIfEmpty } from './throwIfEmpty';\nimport { defaultIfEmpty } from './defaultIfEmpty';\nimport { identity } from '../util/identity';\nexport function last(predicate, defaultValue) {\n const hasDefaultValue = arguments.length >= 2;\n return source => source.pipe(predicate ? filter((v, i) => predicate(v, i, source)) : identity, takeLast(1), hasDefaultValue ? defaultIfEmpty(defaultValue) : throwIfEmpty(() => new EmptyError()));\n}\n","import { Subscriber } from '../Subscriber';\nexport function mapTo(value) {\n return source => source.lift(new MapToOperator(value));\n}\nclass MapToOperator {\n constructor(value) {\n this.value = value;\n }\n call(subscriber, source) {\n return source.subscribe(new MapToSubscriber(subscriber, this.value));\n }\n}\nclass MapToSubscriber extends Subscriber {\n constructor(destination, value) {\n super(destination);\n this.value = value;\n }\n _next(x) {\n this.destination.next(this.value);\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { Notification } from '../Notification';\nexport function materialize() {\n return function materializeOperatorFunction(source) {\n return source.lift(new MaterializeOperator());\n };\n}\nclass MaterializeOperator {\n call(subscriber, source) {\n return source.subscribe(new MaterializeSubscriber(subscriber));\n }\n}\nclass MaterializeSubscriber extends Subscriber {\n constructor(destination) {\n super(destination);\n }\n _next(value) {\n this.destination.next(Notification.createNext(value));\n }\n _error(err) {\n const destination = this.destination;\n destination.next(Notification.createError(err));\n destination.complete();\n }\n _complete() {\n const destination = this.destination;\n destination.next(Notification.createComplete());\n destination.complete();\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function scan(accumulator, seed) {\n let hasSeed = false;\n if (arguments.length >= 2) {\n hasSeed = true;\n }\n return function scanOperatorFunction(source) {\n return source.lift(new ScanOperator(accumulator, seed, hasSeed));\n };\n}\nclass ScanOperator {\n constructor(accumulator, seed, hasSeed = false) {\n this.accumulator = accumulator;\n this.seed = seed;\n this.hasSeed = hasSeed;\n }\n call(subscriber, source) {\n return source.subscribe(new ScanSubscriber(subscriber, this.accumulator, this.seed, this.hasSeed));\n }\n}\nclass ScanSubscriber extends Subscriber {\n constructor(destination, accumulator, _seed, hasSeed) {\n super(destination);\n this.accumulator = accumulator;\n this._seed = _seed;\n this.hasSeed = hasSeed;\n this.index = 0;\n }\n get seed() {\n return this._seed;\n }\n set seed(value) {\n this.hasSeed = true;\n this._seed = value;\n }\n _next(value) {\n if (!this.hasSeed) {\n this.seed = value;\n this.destination.next(value);\n } else {\n return this._tryNext(value);\n }\n }\n _tryNext(value) {\n const index = this.index++;\n let result;\n try {\n result = this.accumulator(this.seed, value, index);\n } catch (err) {\n this.destination.error(err);\n }\n this.seed = result;\n this.destination.next(result);\n }\n}\n","import { scan } from './scan';\nimport { takeLast } from './takeLast';\nimport { defaultIfEmpty } from './defaultIfEmpty';\nimport { pipe } from '../util/pipe';\nexport function reduce(accumulator, seed) {\n if (arguments.length >= 2) {\n return function reduceOperatorFunctionWithSeed(source) {\n return pipe(scan(accumulator, seed), takeLast(1), defaultIfEmpty(seed))(source);\n };\n }\n return function reduceOperatorFunction(source) {\n return pipe(scan((acc, value, index) => accumulator(acc, value, index + 1)), takeLast(1))(source);\n };\n}\n","import { reduce } from './reduce';\nexport function max(comparer) {\n const max = typeof comparer === 'function' ? (x, y) => comparer(x, y) > 0 ? x : y : (x, y) => x > y ? x : y;\n return reduce(max);\n}\n","import { Observable } from '../Observable';\nimport { isScheduler } from '../util/isScheduler';\nimport { mergeAll } from '../operators/mergeAll';\nimport { fromArray } from './fromArray';\nexport function merge(...observables) {\n let concurrent = Number.POSITIVE_INFINITY;\n let scheduler = null;\n let last = observables[observables.length - 1];\n if (isScheduler(last)) {\n scheduler = observables.pop();\n if (observables.length > 1 && typeof observables[observables.length - 1] === 'number') {\n concurrent = observables.pop();\n }\n } else if (typeof last === 'number') {\n concurrent = observables.pop();\n }\n if (scheduler === null && observables.length === 1 && observables[0] instanceof Observable) {\n return observables[0];\n }\n return mergeAll(concurrent)(fromArray(observables, scheduler));\n}\n","import { merge as mergeStatic } from '../observable/merge';\nexport function merge(...observables) {\n return source => source.lift.call(mergeStatic(source, ...observables));\n}\n","import { mergeMap } from './mergeMap';\nexport function mergeMapTo(innerObservable, resultSelector, concurrent = Number.POSITIVE_INFINITY) {\n if (typeof resultSelector === 'function') {\n return mergeMap(() => innerObservable, resultSelector, concurrent);\n }\n if (typeof resultSelector === 'number') {\n concurrent = resultSelector;\n }\n return mergeMap(() => innerObservable, concurrent);\n}\n","import { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function mergeScan(accumulator, seed, concurrent = Number.POSITIVE_INFINITY) {\n return source => source.lift(new MergeScanOperator(accumulator, seed, concurrent));\n}\nexport class MergeScanOperator {\n constructor(accumulator, seed, concurrent) {\n this.accumulator = accumulator;\n this.seed = seed;\n this.concurrent = concurrent;\n }\n call(subscriber, source) {\n return source.subscribe(new MergeScanSubscriber(subscriber, this.accumulator, this.seed, this.concurrent));\n }\n}\nexport class MergeScanSubscriber extends SimpleOuterSubscriber {\n constructor(destination, accumulator, acc, concurrent) {\n super(destination);\n this.accumulator = accumulator;\n this.acc = acc;\n this.concurrent = concurrent;\n this.hasValue = false;\n this.hasCompleted = false;\n this.buffer = [];\n this.active = 0;\n this.index = 0;\n }\n _next(value) {\n if (this.active < this.concurrent) {\n const index = this.index++;\n const destination = this.destination;\n let ish;\n try {\n const {\n accumulator\n } = this;\n ish = accumulator(this.acc, value, index);\n } catch (e) {\n return destination.error(e);\n }\n this.active++;\n this._innerSub(ish);\n } else {\n this.buffer.push(value);\n }\n }\n _innerSub(ish) {\n const innerSubscriber = new SimpleInnerSubscriber(this);\n const destination = this.destination;\n destination.add(innerSubscriber);\n const innerSubscription = innerSubscribe(ish, innerSubscriber);\n if (innerSubscription !== innerSubscriber) {\n destination.add(innerSubscription);\n }\n }\n _complete() {\n this.hasCompleted = true;\n if (this.active === 0 && this.buffer.length === 0) {\n if (this.hasValue === false) {\n this.destination.next(this.acc);\n }\n this.destination.complete();\n }\n this.unsubscribe();\n }\n notifyNext(innerValue) {\n const {\n destination\n } = this;\n this.acc = innerValue;\n this.hasValue = true;\n destination.next(innerValue);\n }\n notifyComplete() {\n const buffer = this.buffer;\n this.active--;\n if (buffer.length > 0) {\n this._next(buffer.shift());\n } else if (this.active === 0 && this.hasCompleted) {\n if (this.hasValue === false) {\n this.destination.next(this.acc);\n }\n this.destination.complete();\n }\n }\n}\n","import { reduce } from './reduce';\nexport function min(comparer) {\n const min = typeof comparer === 'function' ? (x, y) => comparer(x, y) < 0 ? x : y : (x, y) => x < y ? x : y;\n return reduce(min);\n}\n","import { Subscriber } from '../Subscriber';\nexport function refCount() {\n return function refCountOperatorFunction(source) {\n return source.lift(new RefCountOperator(source));\n };\n}\nclass RefCountOperator {\n constructor(connectable) {\n this.connectable = connectable;\n }\n call(subscriber, source) {\n const {\n connectable\n } = this;\n connectable._refCount++;\n const refCounter = new RefCountSubscriber(subscriber, connectable);\n const subscription = source.subscribe(refCounter);\n if (!refCounter.closed) {\n refCounter.connection = connectable.connect();\n }\n return subscription;\n }\n}\nclass RefCountSubscriber extends Subscriber {\n constructor(destination, connectable) {\n super(destination);\n this.connectable = connectable;\n }\n _unsubscribe() {\n const {\n connectable\n } = this;\n if (!connectable) {\n this.connection = null;\n return;\n }\n this.connectable = null;\n const refCount = connectable._refCount;\n if (refCount <= 0) {\n this.connection = null;\n return;\n }\n connectable._refCount = refCount - 1;\n if (refCount > 1) {\n this.connection = null;\n return;\n }\n const {\n connection\n } = this;\n const sharedConnection = connectable._connection;\n this.connection = null;\n if (sharedConnection && (!connection || sharedConnection === connection)) {\n sharedConnection.unsubscribe();\n }\n }\n}\n","import { SubjectSubscriber } from '../Subject';\nimport { Observable } from '../Observable';\nimport { Subscriber } from '../Subscriber';\nimport { Subscription } from '../Subscription';\nimport { refCount as higherOrderRefCount } from '../operators/refCount';\nexport class ConnectableObservable extends Observable {\n constructor(source, subjectFactory) {\n super();\n this.source = source;\n this.subjectFactory = subjectFactory;\n this._refCount = 0;\n this._isComplete = false;\n }\n _subscribe(subscriber) {\n return this.getSubject().subscribe(subscriber);\n }\n getSubject() {\n const subject = this._subject;\n if (!subject || subject.isStopped) {\n this._subject = this.subjectFactory();\n }\n return this._subject;\n }\n connect() {\n let connection = this._connection;\n if (!connection) {\n this._isComplete = false;\n connection = this._connection = new Subscription();\n connection.add(this.source.subscribe(new ConnectableSubscriber(this.getSubject(), this)));\n if (connection.closed) {\n this._connection = null;\n connection = Subscription.EMPTY;\n }\n }\n return connection;\n }\n refCount() {\n return higherOrderRefCount()(this);\n }\n}\nexport const connectableObservableDescriptor = (() => {\n const connectableProto = ConnectableObservable.prototype;\n return {\n operator: {\n value: null\n },\n _refCount: {\n value: 0,\n writable: true\n },\n _subject: {\n value: null,\n writable: true\n },\n _connection: {\n value: null,\n writable: true\n },\n _subscribe: {\n value: connectableProto._subscribe\n },\n _isComplete: {\n value: connectableProto._isComplete,\n writable: true\n },\n getSubject: {\n value: connectableProto.getSubject\n },\n connect: {\n value: connectableProto.connect\n },\n refCount: {\n value: connectableProto.refCount\n }\n };\n})();\nclass ConnectableSubscriber extends SubjectSubscriber {\n constructor(destination, connectable) {\n super(destination);\n this.connectable = connectable;\n }\n _error(err) {\n this._unsubscribe();\n super._error(err);\n }\n _complete() {\n this.connectable._isComplete = true;\n this._unsubscribe();\n super._complete();\n }\n _unsubscribe() {\n const connectable = this.connectable;\n if (connectable) {\n this.connectable = null;\n const connection = connectable._connection;\n connectable._refCount = 0;\n connectable._subject = null;\n connectable._connection = null;\n if (connection) {\n connection.unsubscribe();\n }\n }\n }\n}\nclass RefCountOperator {\n constructor(connectable) {\n this.connectable = connectable;\n }\n call(subscriber, source) {\n const {\n connectable\n } = this;\n connectable._refCount++;\n const refCounter = new RefCountSubscriber(subscriber, connectable);\n const subscription = source.subscribe(refCounter);\n if (!refCounter.closed) {\n refCounter.connection = connectable.connect();\n }\n return subscription;\n }\n}\nclass RefCountSubscriber extends Subscriber {\n constructor(destination, connectable) {\n super(destination);\n this.connectable = connectable;\n }\n _unsubscribe() {\n const {\n connectable\n } = this;\n if (!connectable) {\n this.connection = null;\n return;\n }\n this.connectable = null;\n const refCount = connectable._refCount;\n if (refCount <= 0) {\n this.connection = null;\n return;\n }\n connectable._refCount = refCount - 1;\n if (refCount > 1) {\n this.connection = null;\n return;\n }\n const {\n connection\n } = this;\n const sharedConnection = connectable._connection;\n this.connection = null;\n if (sharedConnection && (!connection || sharedConnection === connection)) {\n sharedConnection.unsubscribe();\n }\n }\n}\n","import { connectableObservableDescriptor } from '../observable/ConnectableObservable';\nexport function multicast(subjectOrSubjectFactory, selector) {\n return function multicastOperatorFunction(source) {\n let subjectFactory;\n if (typeof subjectOrSubjectFactory === 'function') {\n subjectFactory = subjectOrSubjectFactory;\n } else {\n subjectFactory = function subjectFactory() {\n return subjectOrSubjectFactory;\n };\n }\n if (typeof selector === 'function') {\n return source.lift(new MulticastOperator(subjectFactory, selector));\n }\n const connectable = Object.create(source, connectableObservableDescriptor);\n connectable.source = source;\n connectable.subjectFactory = subjectFactory;\n return connectable;\n };\n}\nexport class MulticastOperator {\n constructor(subjectFactory, selector) {\n this.subjectFactory = subjectFactory;\n this.selector = selector;\n }\n call(subscriber, source) {\n const {\n selector\n } = this;\n const subject = this.subjectFactory();\n const subscription = selector(subject).subscribe(subscriber);\n subscription.add(source.subscribe(subject));\n return subscription;\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { Notification } from '../Notification';\nexport function observeOn(scheduler, delay = 0) {\n return function observeOnOperatorFunction(source) {\n return source.lift(new ObserveOnOperator(scheduler, delay));\n };\n}\nexport class ObserveOnOperator {\n constructor(scheduler, delay = 0) {\n this.scheduler = scheduler;\n this.delay = delay;\n }\n call(subscriber, source) {\n return source.subscribe(new ObserveOnSubscriber(subscriber, this.scheduler, this.delay));\n }\n}\nexport class ObserveOnSubscriber extends Subscriber {\n constructor(destination, scheduler, delay = 0) {\n super(destination);\n this.scheduler = scheduler;\n this.delay = delay;\n }\n static dispatch(arg) {\n const {\n notification,\n destination\n } = arg;\n notification.observe(destination);\n this.unsubscribe();\n }\n scheduleMessage(notification) {\n const destination = this.destination;\n destination.add(this.scheduler.schedule(ObserveOnSubscriber.dispatch, this.delay, new ObserveOnMessage(notification, this.destination)));\n }\n _next(value) {\n this.scheduleMessage(Notification.createNext(value));\n }\n _error(err) {\n this.scheduleMessage(Notification.createError(err));\n this.unsubscribe();\n }\n _complete() {\n this.scheduleMessage(Notification.createComplete());\n this.unsubscribe();\n }\n}\nexport class ObserveOnMessage {\n constructor(notification, destination) {\n this.notification = notification;\n this.destination = destination;\n }\n}\n","import { from } from '../observable/from';\nimport { isArray } from '../util/isArray';\nimport { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function onErrorResumeNext(...nextSources) {\n if (nextSources.length === 1 && isArray(nextSources[0])) {\n nextSources = nextSources[0];\n }\n return source => source.lift(new OnErrorResumeNextOperator(nextSources));\n}\nexport function onErrorResumeNextStatic(...nextSources) {\n let source = undefined;\n if (nextSources.length === 1 && isArray(nextSources[0])) {\n nextSources = nextSources[0];\n }\n source = nextSources.shift();\n return from(source).lift(new OnErrorResumeNextOperator(nextSources));\n}\nclass OnErrorResumeNextOperator {\n constructor(nextSources) {\n this.nextSources = nextSources;\n }\n call(subscriber, source) {\n return source.subscribe(new OnErrorResumeNextSubscriber(subscriber, this.nextSources));\n }\n}\nclass OnErrorResumeNextSubscriber extends SimpleOuterSubscriber {\n constructor(destination, nextSources) {\n super(destination);\n this.destination = destination;\n this.nextSources = nextSources;\n }\n notifyError() {\n this.subscribeToNextSource();\n }\n notifyComplete() {\n this.subscribeToNextSource();\n }\n _error(err) {\n this.subscribeToNextSource();\n this.unsubscribe();\n }\n _complete() {\n this.subscribeToNextSource();\n this.unsubscribe();\n }\n subscribeToNextSource() {\n const next = this.nextSources.shift();\n if (!!next) {\n const innerSubscriber = new SimpleInnerSubscriber(this);\n const destination = this.destination;\n destination.add(innerSubscriber);\n const innerSubscription = innerSubscribe(next, innerSubscriber);\n if (innerSubscription !== innerSubscriber) {\n destination.add(innerSubscription);\n }\n } else {\n this.destination.complete();\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function pairwise() {\n return source => source.lift(new PairwiseOperator());\n}\nclass PairwiseOperator {\n call(subscriber, source) {\n return source.subscribe(new PairwiseSubscriber(subscriber));\n }\n}\nclass PairwiseSubscriber extends Subscriber {\n constructor(destination) {\n super(destination);\n this.hasPrev = false;\n }\n _next(value) {\n let pair;\n if (this.hasPrev) {\n pair = [this.prev, value];\n } else {\n this.hasPrev = true;\n }\n this.prev = value;\n if (pair) {\n this.destination.next(pair);\n }\n }\n}\n","export function not(pred, thisArg) {\n function notPred() {\n return !notPred.pred.apply(notPred.thisArg, arguments);\n }\n notPred.pred = pred;\n notPred.thisArg = thisArg;\n return notPred;\n}\n","import { not } from '../util/not';\nimport { filter } from './filter';\nexport function partition(predicate, thisArg) {\n return source => [filter(predicate, thisArg)(source), filter(not(predicate, thisArg))(source)];\n}\n","import { map } from './map';\nexport function pluck(...properties) {\n const length = properties.length;\n if (length === 0) {\n throw new Error('list of properties cannot be empty.');\n }\n return source => map(plucker(properties, length))(source);\n}\nfunction plucker(props, length) {\n const mapper = x => {\n let currentProp = x;\n for (let i = 0; i < length; i++) {\n const p = currentProp != null ? currentProp[props[i]] : undefined;\n if (p !== void 0) {\n currentProp = p;\n } else {\n return undefined;\n }\n }\n return currentProp;\n };\n return mapper;\n}\n","import { Subject } from '../Subject';\nimport { multicast } from './multicast';\nexport function publish(selector) {\n return selector ? multicast(() => new Subject(), selector) : multicast(new Subject());\n}\n","import { Subject } from './Subject';\nimport { ObjectUnsubscribedError } from './util/ObjectUnsubscribedError';\nexport class BehaviorSubject extends Subject {\n constructor(_value) {\n super();\n this._value = _value;\n }\n get value() {\n return this.getValue();\n }\n _subscribe(subscriber) {\n const subscription = super._subscribe(subscriber);\n if (subscription && !subscription.closed) {\n subscriber.next(this._value);\n }\n return subscription;\n }\n getValue() {\n if (this.hasError) {\n throw this.thrownError;\n } else if (this.closed) {\n throw new ObjectUnsubscribedError();\n } else {\n return this._value;\n }\n }\n next(value) {\n super.next(this._value = value);\n }\n}\n","import { BehaviorSubject } from '../BehaviorSubject';\nimport { multicast } from './multicast';\nexport function publishBehavior(value) {\n return source => multicast(new BehaviorSubject(value))(source);\n}\n","import { Subject } from './Subject';\nimport { Subscription } from './Subscription';\nexport class AsyncSubject extends Subject {\n constructor() {\n super(...arguments);\n this.value = null;\n this.hasNext = false;\n this.hasCompleted = false;\n }\n _subscribe(subscriber) {\n if (this.hasError) {\n subscriber.error(this.thrownError);\n return Subscription.EMPTY;\n } else if (this.hasCompleted && this.hasNext) {\n subscriber.next(this.value);\n subscriber.complete();\n return Subscription.EMPTY;\n }\n return super._subscribe(subscriber);\n }\n next(value) {\n if (!this.hasCompleted) {\n this.value = value;\n this.hasNext = true;\n }\n }\n error(error) {\n if (!this.hasCompleted) {\n super.error(error);\n }\n }\n complete() {\n this.hasCompleted = true;\n if (this.hasNext) {\n super.next(this.value);\n }\n super.complete();\n }\n}\n","import { AsyncSubject } from '../AsyncSubject';\nimport { multicast } from './multicast';\nexport function publishLast() {\n return source => multicast(new AsyncSubject())(source);\n}\n","import { AsyncAction } from './AsyncAction';\nexport class QueueAction extends AsyncAction {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n }\n schedule(state, delay = 0) {\n if (delay > 0) {\n return super.schedule(state, delay);\n }\n this.delay = delay;\n this.state = state;\n this.scheduler.flush(this);\n return this;\n }\n execute(state, delay) {\n return delay > 0 || this.closed ? super.execute(state, delay) : this._execute(state, delay);\n }\n requestAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && delay > 0 || delay === null && this.delay > 0) {\n return super.requestAsyncId(scheduler, id, delay);\n }\n return scheduler.flush(this);\n }\n}\n","import { AsyncScheduler } from './AsyncScheduler';\nexport class QueueScheduler extends AsyncScheduler {}\n","import { QueueAction } from './QueueAction';\nimport { QueueScheduler } from './QueueScheduler';\nexport const queueScheduler = new QueueScheduler(QueueAction);\nexport const queue = queueScheduler;\n","import { Subject } from './Subject';\nimport { queue } from './scheduler/queue';\nimport { Subscription } from './Subscription';\nimport { ObserveOnSubscriber } from './operators/observeOn';\nimport { ObjectUnsubscribedError } from './util/ObjectUnsubscribedError';\nimport { SubjectSubscription } from './SubjectSubscription';\nexport class ReplaySubject extends Subject {\n constructor(bufferSize = Number.POSITIVE_INFINITY, windowTime = Number.POSITIVE_INFINITY, scheduler) {\n super();\n this.scheduler = scheduler;\n this._events = [];\n this._infiniteTimeWindow = false;\n this._bufferSize = bufferSize < 1 ? 1 : bufferSize;\n this._windowTime = windowTime < 1 ? 1 : windowTime;\n if (windowTime === Number.POSITIVE_INFINITY) {\n this._infiniteTimeWindow = true;\n this.next = this.nextInfiniteTimeWindow;\n } else {\n this.next = this.nextTimeWindow;\n }\n }\n nextInfiniteTimeWindow(value) {\n if (!this.isStopped) {\n const _events = this._events;\n _events.push(value);\n if (_events.length > this._bufferSize) {\n _events.shift();\n }\n }\n super.next(value);\n }\n nextTimeWindow(value) {\n if (!this.isStopped) {\n this._events.push(new ReplayEvent(this._getNow(), value));\n this._trimBufferThenGetEvents();\n }\n super.next(value);\n }\n _subscribe(subscriber) {\n const _infiniteTimeWindow = this._infiniteTimeWindow;\n const _events = _infiniteTimeWindow ? this._events : this._trimBufferThenGetEvents();\n const scheduler = this.scheduler;\n const len = _events.length;\n let subscription;\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n } else if (this.isStopped || this.hasError) {\n subscription = Subscription.EMPTY;\n } else {\n this.observers.push(subscriber);\n subscription = new SubjectSubscription(this, subscriber);\n }\n if (scheduler) {\n subscriber.add(subscriber = new ObserveOnSubscriber(subscriber, scheduler));\n }\n if (_infiniteTimeWindow) {\n for (let i = 0; i < len && !subscriber.closed; i++) {\n subscriber.next(_events[i]);\n }\n } else {\n for (let i = 0; i < len && !subscriber.closed; i++) {\n subscriber.next(_events[i].value);\n }\n }\n if (this.hasError) {\n subscriber.error(this.thrownError);\n } else if (this.isStopped) {\n subscriber.complete();\n }\n return subscription;\n }\n _getNow() {\n return (this.scheduler || queue).now();\n }\n _trimBufferThenGetEvents() {\n const now = this._getNow();\n const _bufferSize = this._bufferSize;\n const _windowTime = this._windowTime;\n const _events = this._events;\n const eventsCount = _events.length;\n let spliceCount = 0;\n while (spliceCount < eventsCount) {\n if (now - _events[spliceCount].time < _windowTime) {\n break;\n }\n spliceCount++;\n }\n if (eventsCount > _bufferSize) {\n spliceCount = Math.max(spliceCount, eventsCount - _bufferSize);\n }\n if (spliceCount > 0) {\n _events.splice(0, spliceCount);\n }\n return _events;\n }\n}\nclass ReplayEvent {\n constructor(time, value) {\n this.time = time;\n this.value = value;\n }\n}\n","import { ReplaySubject } from '../ReplaySubject';\nimport { multicast } from './multicast';\nexport function publishReplay(bufferSize, windowTime, selectorOrScheduler, scheduler) {\n if (selectorOrScheduler && typeof selectorOrScheduler !== 'function') {\n scheduler = selectorOrScheduler;\n }\n const selector = typeof selectorOrScheduler === 'function' ? selectorOrScheduler : undefined;\n const subject = new ReplaySubject(bufferSize, windowTime, scheduler);\n return source => multicast(() => subject, selector)(source);\n}\n","import { isArray } from '../util/isArray';\nimport { fromArray } from './fromArray';\nimport { OuterSubscriber } from '../OuterSubscriber';\nimport { subscribeToResult } from '../util/subscribeToResult';\nexport function race(...observables) {\n if (observables.length === 1) {\n if (isArray(observables[0])) {\n observables = observables[0];\n } else {\n return observables[0];\n }\n }\n return fromArray(observables, undefined).lift(new RaceOperator());\n}\nexport class RaceOperator {\n call(subscriber, source) {\n return source.subscribe(new RaceSubscriber(subscriber));\n }\n}\nexport class RaceSubscriber extends OuterSubscriber {\n constructor(destination) {\n super(destination);\n this.hasFirst = false;\n this.observables = [];\n this.subscriptions = [];\n }\n _next(observable) {\n this.observables.push(observable);\n }\n _complete() {\n const observables = this.observables;\n const len = observables.length;\n if (len === 0) {\n this.destination.complete();\n } else {\n for (let i = 0; i < len && !this.hasFirst; i++) {\n const observable = observables[i];\n const subscription = subscribeToResult(this, observable, undefined, i);\n if (this.subscriptions) {\n this.subscriptions.push(subscription);\n }\n this.add(subscription);\n }\n this.observables = null;\n }\n }\n notifyNext(_outerValue, innerValue, outerIndex) {\n if (!this.hasFirst) {\n this.hasFirst = true;\n for (let i = 0; i < this.subscriptions.length; i++) {\n if (i !== outerIndex) {\n let subscription = this.subscriptions[i];\n subscription.unsubscribe();\n this.remove(subscription);\n }\n }\n this.subscriptions = null;\n }\n this.destination.next(innerValue);\n }\n}\n","import { isArray } from '../util/isArray';\nimport { race as raceStatic } from '../observable/race';\nexport function race(...observables) {\n return function raceOperatorFunction(source) {\n if (observables.length === 1 && isArray(observables[0])) {\n observables = observables[0];\n }\n return source.lift.call(raceStatic(source, ...observables));\n };\n}\n","import { Subscriber } from '../Subscriber';\nimport { empty } from '../observable/empty';\nexport function repeat(count = -1) {\n return source => {\n if (count === 0) {\n return empty();\n } else if (count < 0) {\n return source.lift(new RepeatOperator(-1, source));\n } else {\n return source.lift(new RepeatOperator(count - 1, source));\n }\n };\n}\nclass RepeatOperator {\n constructor(count, source) {\n this.count = count;\n this.source = source;\n }\n call(subscriber, source) {\n return source.subscribe(new RepeatSubscriber(subscriber, this.count, this.source));\n }\n}\nclass RepeatSubscriber extends Subscriber {\n constructor(destination, count, source) {\n super(destination);\n this.count = count;\n this.source = source;\n }\n complete() {\n if (!this.isStopped) {\n const {\n source,\n count\n } = this;\n if (count === 0) {\n return super.complete();\n } else if (count > -1) {\n this.count = count - 1;\n }\n source.subscribe(this._unsubscribeAndRecycle());\n }\n }\n}\n","import { Subject } from '../Subject';\nimport { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function repeatWhen(notifier) {\n return source => source.lift(new RepeatWhenOperator(notifier));\n}\nclass RepeatWhenOperator {\n constructor(notifier) {\n this.notifier = notifier;\n }\n call(subscriber, source) {\n return source.subscribe(new RepeatWhenSubscriber(subscriber, this.notifier, source));\n }\n}\nclass RepeatWhenSubscriber extends SimpleOuterSubscriber {\n constructor(destination, notifier, source) {\n super(destination);\n this.notifier = notifier;\n this.source = source;\n this.sourceIsBeingSubscribedTo = true;\n }\n notifyNext() {\n this.sourceIsBeingSubscribedTo = true;\n this.source.subscribe(this);\n }\n notifyComplete() {\n if (this.sourceIsBeingSubscribedTo === false) {\n return super.complete();\n }\n }\n complete() {\n this.sourceIsBeingSubscribedTo = false;\n if (!this.isStopped) {\n if (!this.retries) {\n this.subscribeToRetries();\n }\n if (!this.retriesSubscription || this.retriesSubscription.closed) {\n return super.complete();\n }\n this._unsubscribeAndRecycle();\n this.notifications.next(undefined);\n }\n }\n _unsubscribe() {\n const {\n notifications,\n retriesSubscription\n } = this;\n if (notifications) {\n notifications.unsubscribe();\n this.notifications = undefined;\n }\n if (retriesSubscription) {\n retriesSubscription.unsubscribe();\n this.retriesSubscription = undefined;\n }\n this.retries = undefined;\n }\n _unsubscribeAndRecycle() {\n const {\n _unsubscribe\n } = this;\n this._unsubscribe = null;\n super._unsubscribeAndRecycle();\n this._unsubscribe = _unsubscribe;\n return this;\n }\n subscribeToRetries() {\n this.notifications = new Subject();\n let retries;\n try {\n const {\n notifier\n } = this;\n retries = notifier(this.notifications);\n } catch (e) {\n return super.complete();\n }\n this.retries = retries;\n this.retriesSubscription = innerSubscribe(retries, new SimpleInnerSubscriber(this));\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function retry(count = -1) {\n return source => source.lift(new RetryOperator(count, source));\n}\nclass RetryOperator {\n constructor(count, source) {\n this.count = count;\n this.source = source;\n }\n call(subscriber, source) {\n return source.subscribe(new RetrySubscriber(subscriber, this.count, this.source));\n }\n}\nclass RetrySubscriber extends Subscriber {\n constructor(destination, count, source) {\n super(destination);\n this.count = count;\n this.source = source;\n }\n error(err) {\n if (!this.isStopped) {\n const {\n source,\n count\n } = this;\n if (count === 0) {\n return super.error(err);\n } else if (count > -1) {\n this.count = count - 1;\n }\n source.subscribe(this._unsubscribeAndRecycle());\n }\n }\n}\n","import { Subject } from '../Subject';\nimport { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function retryWhen(notifier) {\n return source => source.lift(new RetryWhenOperator(notifier, source));\n}\nclass RetryWhenOperator {\n constructor(notifier, source) {\n this.notifier = notifier;\n this.source = source;\n }\n call(subscriber, source) {\n return source.subscribe(new RetryWhenSubscriber(subscriber, this.notifier, this.source));\n }\n}\nclass RetryWhenSubscriber extends SimpleOuterSubscriber {\n constructor(destination, notifier, source) {\n super(destination);\n this.notifier = notifier;\n this.source = source;\n }\n error(err) {\n if (!this.isStopped) {\n let errors = this.errors;\n let retries = this.retries;\n let retriesSubscription = this.retriesSubscription;\n if (!retries) {\n errors = new Subject();\n try {\n const {\n notifier\n } = this;\n retries = notifier(errors);\n } catch (e) {\n return super.error(e);\n }\n retriesSubscription = innerSubscribe(retries, new SimpleInnerSubscriber(this));\n } else {\n this.errors = undefined;\n this.retriesSubscription = undefined;\n }\n this._unsubscribeAndRecycle();\n this.errors = errors;\n this.retries = retries;\n this.retriesSubscription = retriesSubscription;\n errors.next(err);\n }\n }\n _unsubscribe() {\n const {\n errors,\n retriesSubscription\n } = this;\n if (errors) {\n errors.unsubscribe();\n this.errors = undefined;\n }\n if (retriesSubscription) {\n retriesSubscription.unsubscribe();\n this.retriesSubscription = undefined;\n }\n this.retries = undefined;\n }\n notifyNext() {\n const {\n _unsubscribe\n } = this;\n this._unsubscribe = null;\n this._unsubscribeAndRecycle();\n this._unsubscribe = _unsubscribe;\n this.source.subscribe(this);\n }\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function sample(notifier) {\n return source => source.lift(new SampleOperator(notifier));\n}\nclass SampleOperator {\n constructor(notifier) {\n this.notifier = notifier;\n }\n call(subscriber, source) {\n const sampleSubscriber = new SampleSubscriber(subscriber);\n const subscription = source.subscribe(sampleSubscriber);\n subscription.add(innerSubscribe(this.notifier, new SimpleInnerSubscriber(sampleSubscriber)));\n return subscription;\n }\n}\nclass SampleSubscriber extends SimpleOuterSubscriber {\n constructor() {\n super(...arguments);\n this.hasValue = false;\n }\n _next(value) {\n this.value = value;\n this.hasValue = true;\n }\n notifyNext() {\n this.emitValue();\n }\n notifyComplete() {\n this.emitValue();\n }\n emitValue() {\n if (this.hasValue) {\n this.hasValue = false;\n this.destination.next(this.value);\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { async } from '../scheduler/async';\nexport function sampleTime(period, scheduler = async) {\n return source => source.lift(new SampleTimeOperator(period, scheduler));\n}\nclass SampleTimeOperator {\n constructor(period, scheduler) {\n this.period = period;\n this.scheduler = scheduler;\n }\n call(subscriber, source) {\n return source.subscribe(new SampleTimeSubscriber(subscriber, this.period, this.scheduler));\n }\n}\nclass SampleTimeSubscriber extends Subscriber {\n constructor(destination, period, scheduler) {\n super(destination);\n this.period = period;\n this.scheduler = scheduler;\n this.hasValue = false;\n this.add(scheduler.schedule(dispatchNotification, period, {\n subscriber: this,\n period\n }));\n }\n _next(value) {\n this.lastValue = value;\n this.hasValue = true;\n }\n notifyNext() {\n if (this.hasValue) {\n this.hasValue = false;\n this.destination.next(this.lastValue);\n }\n }\n}\nfunction dispatchNotification(state) {\n let {\n subscriber,\n period\n } = state;\n subscriber.notifyNext();\n this.schedule(state, period);\n}\n","import { Subscriber } from '../Subscriber';\nexport function sequenceEqual(compareTo, comparator) {\n return source => source.lift(new SequenceEqualOperator(compareTo, comparator));\n}\nexport class SequenceEqualOperator {\n constructor(compareTo, comparator) {\n this.compareTo = compareTo;\n this.comparator = comparator;\n }\n call(subscriber, source) {\n return source.subscribe(new SequenceEqualSubscriber(subscriber, this.compareTo, this.comparator));\n }\n}\nexport class SequenceEqualSubscriber extends Subscriber {\n constructor(destination, compareTo, comparator) {\n super(destination);\n this.compareTo = compareTo;\n this.comparator = comparator;\n this._a = [];\n this._b = [];\n this._oneComplete = false;\n this.destination.add(compareTo.subscribe(new SequenceEqualCompareToSubscriber(destination, this)));\n }\n _next(value) {\n if (this._oneComplete && this._b.length === 0) {\n this.emit(false);\n } else {\n this._a.push(value);\n this.checkValues();\n }\n }\n _complete() {\n if (this._oneComplete) {\n this.emit(this._a.length === 0 && this._b.length === 0);\n } else {\n this._oneComplete = true;\n }\n this.unsubscribe();\n }\n checkValues() {\n const {\n _a,\n _b,\n comparator\n } = this;\n while (_a.length > 0 && _b.length > 0) {\n let a = _a.shift();\n let b = _b.shift();\n let areEqual = false;\n try {\n areEqual = comparator ? comparator(a, b) : a === b;\n } catch (e) {\n this.destination.error(e);\n }\n if (!areEqual) {\n this.emit(false);\n }\n }\n }\n emit(value) {\n const {\n destination\n } = this;\n destination.next(value);\n destination.complete();\n }\n nextB(value) {\n if (this._oneComplete && this._a.length === 0) {\n this.emit(false);\n } else {\n this._b.push(value);\n this.checkValues();\n }\n }\n completeB() {\n if (this._oneComplete) {\n this.emit(this._a.length === 0 && this._b.length === 0);\n } else {\n this._oneComplete = true;\n }\n }\n}\nclass SequenceEqualCompareToSubscriber extends Subscriber {\n constructor(destination, parent) {\n super(destination);\n this.parent = parent;\n }\n _next(value) {\n this.parent.nextB(value);\n }\n _error(err) {\n this.parent.error(err);\n this.unsubscribe();\n }\n _complete() {\n this.parent.completeB();\n this.unsubscribe();\n }\n}\n","import { multicast } from './multicast';\nimport { refCount } from './refCount';\nimport { Subject } from '../Subject';\nfunction shareSubjectFactory() {\n return new Subject();\n}\nexport function share() {\n return source => refCount()(multicast(shareSubjectFactory)(source));\n}\n","import { ReplaySubject } from '../ReplaySubject';\nexport function shareReplay(configOrBufferSize, windowTime, scheduler) {\n let config;\n if (configOrBufferSize && typeof configOrBufferSize === 'object') {\n config = configOrBufferSize;\n } else {\n config = {\n bufferSize: configOrBufferSize,\n windowTime,\n refCount: false,\n scheduler\n };\n }\n return source => source.lift(shareReplayOperator(config));\n}\nfunction shareReplayOperator({\n bufferSize = Number.POSITIVE_INFINITY,\n windowTime = Number.POSITIVE_INFINITY,\n refCount: useRefCount,\n scheduler\n}) {\n let subject;\n let refCount = 0;\n let subscription;\n let hasError = false;\n let isComplete = false;\n return function shareReplayOperation(source) {\n refCount++;\n let innerSub;\n if (!subject || hasError) {\n hasError = false;\n subject = new ReplaySubject(bufferSize, windowTime, scheduler);\n innerSub = subject.subscribe(this);\n subscription = source.subscribe({\n next(value) {\n subject.next(value);\n },\n error(err) {\n hasError = true;\n subject.error(err);\n },\n complete() {\n isComplete = true;\n subscription = undefined;\n subject.complete();\n }\n });\n if (isComplete) {\n subscription = undefined;\n }\n } else {\n innerSub = subject.subscribe(this);\n }\n this.add(() => {\n refCount--;\n innerSub.unsubscribe();\n innerSub = undefined;\n if (subscription && !isComplete && useRefCount && refCount === 0) {\n subscription.unsubscribe();\n subscription = undefined;\n subject = undefined;\n }\n });\n };\n}\n","import { Subscriber } from '../Subscriber';\nimport { EmptyError } from '../util/EmptyError';\nexport function single(predicate) {\n return source => source.lift(new SingleOperator(predicate, source));\n}\nclass SingleOperator {\n constructor(predicate, source) {\n this.predicate = predicate;\n this.source = source;\n }\n call(subscriber, source) {\n return source.subscribe(new SingleSubscriber(subscriber, this.predicate, this.source));\n }\n}\nclass SingleSubscriber extends Subscriber {\n constructor(destination, predicate, source) {\n super(destination);\n this.predicate = predicate;\n this.source = source;\n this.seenValue = false;\n this.index = 0;\n }\n applySingleValue(value) {\n if (this.seenValue) {\n this.destination.error('Sequence contains more than one element');\n } else {\n this.seenValue = true;\n this.singleValue = value;\n }\n }\n _next(value) {\n const index = this.index++;\n if (this.predicate) {\n this.tryNext(value, index);\n } else {\n this.applySingleValue(value);\n }\n }\n tryNext(value, index) {\n try {\n if (this.predicate(value, index, this.source)) {\n this.applySingleValue(value);\n }\n } catch (err) {\n this.destination.error(err);\n }\n }\n _complete() {\n const destination = this.destination;\n if (this.index > 0) {\n destination.next(this.seenValue ? this.singleValue : undefined);\n destination.complete();\n } else {\n destination.error(new EmptyError());\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nexport function skip(count) {\n return source => source.lift(new SkipOperator(count));\n}\nclass SkipOperator {\n constructor(total) {\n this.total = total;\n }\n call(subscriber, source) {\n return source.subscribe(new SkipSubscriber(subscriber, this.total));\n }\n}\nclass SkipSubscriber extends Subscriber {\n constructor(destination, total) {\n super(destination);\n this.total = total;\n this.count = 0;\n }\n _next(x) {\n if (++this.count > this.total) {\n this.destination.next(x);\n }\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { ArgumentOutOfRangeError } from '../util/ArgumentOutOfRangeError';\nexport function skipLast(count) {\n return source => source.lift(new SkipLastOperator(count));\n}\nclass SkipLastOperator {\n constructor(_skipCount) {\n this._skipCount = _skipCount;\n if (this._skipCount < 0) {\n throw new ArgumentOutOfRangeError();\n }\n }\n call(subscriber, source) {\n if (this._skipCount === 0) {\n return source.subscribe(new Subscriber(subscriber));\n } else {\n return source.subscribe(new SkipLastSubscriber(subscriber, this._skipCount));\n }\n }\n}\nclass SkipLastSubscriber extends Subscriber {\n constructor(destination, _skipCount) {\n super(destination);\n this._skipCount = _skipCount;\n this._count = 0;\n this._ring = new Array(_skipCount);\n }\n _next(value) {\n const skipCount = this._skipCount;\n const count = this._count++;\n if (count < skipCount) {\n this._ring[count] = value;\n } else {\n const currentIndex = count % skipCount;\n const ring = this._ring;\n const oldValue = ring[currentIndex];\n ring[currentIndex] = value;\n this.destination.next(oldValue);\n }\n }\n}\n","import { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function skipUntil(notifier) {\n return source => source.lift(new SkipUntilOperator(notifier));\n}\nclass SkipUntilOperator {\n constructor(notifier) {\n this.notifier = notifier;\n }\n call(destination, source) {\n return source.subscribe(new SkipUntilSubscriber(destination, this.notifier));\n }\n}\nclass SkipUntilSubscriber extends SimpleOuterSubscriber {\n constructor(destination, notifier) {\n super(destination);\n this.hasValue = false;\n const innerSubscriber = new SimpleInnerSubscriber(this);\n this.add(innerSubscriber);\n this.innerSubscription = innerSubscriber;\n const innerSubscription = innerSubscribe(notifier, innerSubscriber);\n if (innerSubscription !== innerSubscriber) {\n this.add(innerSubscription);\n this.innerSubscription = innerSubscription;\n }\n }\n _next(value) {\n if (this.hasValue) {\n super._next(value);\n }\n }\n notifyNext() {\n this.hasValue = true;\n if (this.innerSubscription) {\n this.innerSubscription.unsubscribe();\n }\n }\n notifyComplete() {}\n}\n","import { Subscriber } from '../Subscriber';\nexport function skipWhile(predicate) {\n return source => source.lift(new SkipWhileOperator(predicate));\n}\nclass SkipWhileOperator {\n constructor(predicate) {\n this.predicate = predicate;\n }\n call(subscriber, source) {\n return source.subscribe(new SkipWhileSubscriber(subscriber, this.predicate));\n }\n}\nclass SkipWhileSubscriber extends Subscriber {\n constructor(destination, predicate) {\n super(destination);\n this.predicate = predicate;\n this.skipping = true;\n this.index = 0;\n }\n _next(value) {\n const destination = this.destination;\n if (this.skipping) {\n this.tryCallPredicate(value);\n }\n if (!this.skipping) {\n destination.next(value);\n }\n }\n tryCallPredicate(value) {\n try {\n const result = this.predicate(value, this.index++);\n this.skipping = Boolean(result);\n } catch (err) {\n this.destination.error(err);\n }\n }\n}\n","import { concat } from '../observable/concat';\nimport { isScheduler } from '../util/isScheduler';\nexport function startWith(...array) {\n const scheduler = array[array.length - 1];\n if (isScheduler(scheduler)) {\n array.pop();\n return source => concat(array, source, scheduler);\n } else {\n return source => concat(array, source);\n }\n}\n","let nextHandle = 1;\nconst RESOLVED = (() => Promise.resolve())();\nconst activeHandles = {};\nfunction findAndClearHandle(handle) {\n if (handle in activeHandles) {\n delete activeHandles[handle];\n return true;\n }\n return false;\n}\nexport const Immediate = {\n setImmediate(cb) {\n const handle = nextHandle++;\n activeHandles[handle] = true;\n RESOLVED.then(() => findAndClearHandle(handle) && cb());\n return handle;\n },\n clearImmediate(handle) {\n findAndClearHandle(handle);\n }\n};\nexport const TestTools = {\n pending() {\n return Object.keys(activeHandles).length;\n }\n};\n","import { Immediate } from '../util/Immediate';\nimport { AsyncAction } from './AsyncAction';\nexport class AsapAction extends AsyncAction {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n }\n requestAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && delay > 0) {\n return super.requestAsyncId(scheduler, id, delay);\n }\n scheduler.actions.push(this);\n return scheduler.scheduled || (scheduler.scheduled = Immediate.setImmediate(scheduler.flush.bind(scheduler, null)));\n }\n recycleAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && delay > 0 || delay === null && this.delay > 0) {\n return super.recycleAsyncId(scheduler, id, delay);\n }\n if (scheduler.actions.length === 0) {\n Immediate.clearImmediate(id);\n scheduler.scheduled = undefined;\n }\n return undefined;\n }\n}\n","import { AsyncScheduler } from './AsyncScheduler';\nexport class AsapScheduler extends AsyncScheduler {\n flush(action) {\n this.active = true;\n this.scheduled = undefined;\n const {\n actions\n } = this;\n let error;\n let index = -1;\n let count = actions.length;\n action = action || actions.shift();\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while (++index < count && (action = actions.shift()));\n this.active = false;\n if (error) {\n while (++index < count && (action = actions.shift())) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n","import { AsapAction } from './AsapAction';\nimport { AsapScheduler } from './AsapScheduler';\nexport const asapScheduler = new AsapScheduler(AsapAction);\nexport const asap = asapScheduler;\n","import { Observable } from '../Observable';\nimport { asap } from '../scheduler/asap';\nimport { isNumeric } from '../util/isNumeric';\nexport class SubscribeOnObservable extends Observable {\n constructor(source, delayTime = 0, scheduler = asap) {\n super();\n this.source = source;\n this.delayTime = delayTime;\n this.scheduler = scheduler;\n if (!isNumeric(delayTime) || delayTime < 0) {\n this.delayTime = 0;\n }\n if (!scheduler || typeof scheduler.schedule !== 'function') {\n this.scheduler = asap;\n }\n }\n static create(source, delay = 0, scheduler = asap) {\n return new SubscribeOnObservable(source, delay, scheduler);\n }\n static dispatch(arg) {\n const {\n source,\n subscriber\n } = arg;\n return this.add(source.subscribe(subscriber));\n }\n _subscribe(subscriber) {\n const delay = this.delayTime;\n const source = this.source;\n const scheduler = this.scheduler;\n return scheduler.schedule(SubscribeOnObservable.dispatch, delay, {\n source,\n subscriber\n });\n }\n}\n","import { SubscribeOnObservable } from '../observable/SubscribeOnObservable';\nexport function subscribeOn(scheduler, delay = 0) {\n return function subscribeOnOperatorFunction(source) {\n return source.lift(new SubscribeOnOperator(scheduler, delay));\n };\n}\nclass SubscribeOnOperator {\n constructor(scheduler, delay) {\n this.scheduler = scheduler;\n this.delay = delay;\n }\n call(subscriber, source) {\n return new SubscribeOnObservable(source, this.delay, this.scheduler).subscribe(subscriber);\n }\n}\n","import { map } from './map';\nimport { from } from '../observable/from';\nimport { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function switchMap(project, resultSelector) {\n if (typeof resultSelector === 'function') {\n return source => source.pipe(switchMap((a, i) => from(project(a, i)).pipe(map((b, ii) => resultSelector(a, b, i, ii)))));\n }\n return source => source.lift(new SwitchMapOperator(project));\n}\nclass SwitchMapOperator {\n constructor(project) {\n this.project = project;\n }\n call(subscriber, source) {\n return source.subscribe(new SwitchMapSubscriber(subscriber, this.project));\n }\n}\nclass SwitchMapSubscriber extends SimpleOuterSubscriber {\n constructor(destination, project) {\n super(destination);\n this.project = project;\n this.index = 0;\n }\n _next(value) {\n let result;\n const index = this.index++;\n try {\n result = this.project(value, index);\n } catch (error) {\n this.destination.error(error);\n return;\n }\n this._innerSub(result);\n }\n _innerSub(result) {\n const innerSubscription = this.innerSubscription;\n if (innerSubscription) {\n innerSubscription.unsubscribe();\n }\n const innerSubscriber = new SimpleInnerSubscriber(this);\n const destination = this.destination;\n destination.add(innerSubscriber);\n this.innerSubscription = innerSubscribe(result, innerSubscriber);\n if (this.innerSubscription !== innerSubscriber) {\n destination.add(this.innerSubscription);\n }\n }\n _complete() {\n const {\n innerSubscription\n } = this;\n if (!innerSubscription || innerSubscription.closed) {\n super._complete();\n }\n this.unsubscribe();\n }\n _unsubscribe() {\n this.innerSubscription = undefined;\n }\n notifyComplete() {\n this.innerSubscription = undefined;\n if (this.isStopped) {\n super._complete();\n }\n }\n notifyNext(innerValue) {\n this.destination.next(innerValue);\n }\n}\n","import { switchMap } from './switchMap';\nimport { identity } from '../util/identity';\nexport function switchAll() {\n return switchMap(identity);\n}\n","import { switchMap } from './switchMap';\nexport function switchMapTo(innerObservable, resultSelector) {\n return resultSelector ? switchMap(() => innerObservable, resultSelector) : switchMap(() => innerObservable);\n}\n","import { innerSubscribe, SimpleInnerSubscriber, SimpleOuterSubscriber } from '../innerSubscribe';\nexport function takeUntil(notifier) {\n return source => source.lift(new TakeUntilOperator(notifier));\n}\nclass TakeUntilOperator {\n constructor(notifier) {\n this.notifier = notifier;\n }\n call(subscriber, source) {\n const takeUntilSubscriber = new TakeUntilSubscriber(subscriber);\n const notifierSubscription = innerSubscribe(this.notifier, new SimpleInnerSubscriber(takeUntilSubscriber));\n if (notifierSubscription && !takeUntilSubscriber.seenValue) {\n takeUntilSubscriber.add(notifierSubscription);\n return source.subscribe(takeUntilSubscriber);\n }\n return takeUntilSubscriber;\n }\n}\nclass TakeUntilSubscriber extends SimpleOuterSubscriber {\n constructor(destination) {\n super(destination);\n this.seenValue = false;\n }\n notifyNext() {\n this.seenValue = true;\n this.complete();\n }\n notifyComplete() {}\n}\n","import { Subscriber } from '../Subscriber';\nexport function takeWhile(predicate, inclusive = false) {\n return source => source.lift(new TakeWhileOperator(predicate, inclusive));\n}\nclass TakeWhileOperator {\n constructor(predicate, inclusive) {\n this.predicate = predicate;\n this.inclusive = inclusive;\n }\n call(subscriber, source) {\n return source.subscribe(new TakeWhileSubscriber(subscriber, this.predicate, this.inclusive));\n }\n}\nclass TakeWhileSubscriber extends Subscriber {\n constructor(destination, predicate, inclusive) {\n super(destination);\n this.predicate = predicate;\n this.inclusive = inclusive;\n this.index = 0;\n }\n _next(value) {\n const destination = this.destination;\n let result;\n try {\n result = this.predicate(value, this.index++);\n } catch (err) {\n destination.error(err);\n return;\n }\n this.nextOrComplete(value, result);\n }\n nextOrComplete(value, predicateResult) {\n const destination = this.destination;\n if (Boolean(predicateResult)) {\n destination.next(value);\n } else {\n if (this.inclusive) {\n destination.next(value);\n }\n destination.complete();\n }\n }\n}\n","export function noop() {}\n","import { Subscriber } from '../Subscriber';\nimport { noop } from '../util/noop';\nimport { isFunction } from '../util/isFunction';\nexport function tap(nextOrObserver, error, complete) {\n return function tapOperatorFunction(source) {\n return source.lift(new DoOperator(nextOrObserver, error, complete));\n };\n}\nclass DoOperator {\n constructor(nextOrObserver, error, complete) {\n this.nextOrObserver = nextOrObserver;\n this.error = error;\n this.complete = complete;\n }\n call(subscriber, source) {\n return source.subscribe(new TapSubscriber(subscriber, this.nextOrObserver, this.error, this.complete));\n }\n}\nclass TapSubscriber extends Subscriber {\n constructor(destination, observerOrNext, error, complete) {\n super(destination);\n this._tapNext = noop;\n this._tapError = noop;\n this._tapComplete = noop;\n this._tapError = error || noop;\n this._tapComplete = complete || noop;\n if (isFunction(observerOrNext)) {\n this._context = this;\n this._tapNext = observerOrNext;\n } else if (observerOrNext) {\n this._context = observerOrNext;\n this._tapNext = observerOrNext.next || noop;\n this._tapError = observerOrNext.error || noop;\n this._tapComplete = observerOrNext.complete || noop;\n }\n }\n _next(value) {\n try {\n this._tapNext.call(this._context, value);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.destination.next(value);\n }\n _error(err) {\n try {\n this._tapError.call(this._context, err);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.destination.error(err);\n }\n _complete() {\n try {\n this._tapComplete.call(this._context);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n return this.destination.complete();\n }\n}\n","import { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport const defaultThrottleConfig = {\n leading: true,\n trailing: false\n};\nexport function throttle(durationSelector, config = defaultThrottleConfig) {\n return source => source.lift(new ThrottleOperator(durationSelector, !!config.leading, !!config.trailing));\n}\nclass ThrottleOperator {\n constructor(durationSelector, leading, trailing) {\n this.durationSelector = durationSelector;\n this.leading = leading;\n this.trailing = trailing;\n }\n call(subscriber, source) {\n return source.subscribe(new ThrottleSubscriber(subscriber, this.durationSelector, this.leading, this.trailing));\n }\n}\nclass ThrottleSubscriber extends SimpleOuterSubscriber {\n constructor(destination, durationSelector, _leading, _trailing) {\n super(destination);\n this.destination = destination;\n this.durationSelector = durationSelector;\n this._leading = _leading;\n this._trailing = _trailing;\n this._hasValue = false;\n }\n _next(value) {\n this._hasValue = true;\n this._sendValue = value;\n if (!this._throttled) {\n if (this._leading) {\n this.send();\n } else {\n this.throttle(value);\n }\n }\n }\n send() {\n const {\n _hasValue,\n _sendValue\n } = this;\n if (_hasValue) {\n this.destination.next(_sendValue);\n this.throttle(_sendValue);\n }\n this._hasValue = false;\n this._sendValue = undefined;\n }\n throttle(value) {\n const duration = this.tryDurationSelector(value);\n if (!!duration) {\n this.add(this._throttled = innerSubscribe(duration, new SimpleInnerSubscriber(this)));\n }\n }\n tryDurationSelector(value) {\n try {\n return this.durationSelector(value);\n } catch (err) {\n this.destination.error(err);\n return null;\n }\n }\n throttlingDone() {\n const {\n _throttled,\n _trailing\n } = this;\n if (_throttled) {\n _throttled.unsubscribe();\n }\n this._throttled = undefined;\n if (_trailing) {\n this.send();\n }\n }\n notifyNext() {\n this.throttlingDone();\n }\n notifyComplete() {\n this.throttlingDone();\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { async } from '../scheduler/async';\nimport { defaultThrottleConfig } from './throttle';\nexport function throttleTime(duration, scheduler = async, config = defaultThrottleConfig) {\n return source => source.lift(new ThrottleTimeOperator(duration, scheduler, config.leading, config.trailing));\n}\nclass ThrottleTimeOperator {\n constructor(duration, scheduler, leading, trailing) {\n this.duration = duration;\n this.scheduler = scheduler;\n this.leading = leading;\n this.trailing = trailing;\n }\n call(subscriber, source) {\n return source.subscribe(new ThrottleTimeSubscriber(subscriber, this.duration, this.scheduler, this.leading, this.trailing));\n }\n}\nclass ThrottleTimeSubscriber extends Subscriber {\n constructor(destination, duration, scheduler, leading, trailing) {\n super(destination);\n this.duration = duration;\n this.scheduler = scheduler;\n this.leading = leading;\n this.trailing = trailing;\n this._hasTrailingValue = false;\n this._trailingValue = null;\n }\n _next(value) {\n if (this.throttled) {\n if (this.trailing) {\n this._trailingValue = value;\n this._hasTrailingValue = true;\n }\n } else {\n this.add(this.throttled = this.scheduler.schedule(dispatchNext, this.duration, {\n subscriber: this\n }));\n if (this.leading) {\n this.destination.next(value);\n } else if (this.trailing) {\n this._trailingValue = value;\n this._hasTrailingValue = true;\n }\n }\n }\n _complete() {\n if (this._hasTrailingValue) {\n this.destination.next(this._trailingValue);\n this.destination.complete();\n } else {\n this.destination.complete();\n }\n }\n clearThrottle() {\n const throttled = this.throttled;\n if (throttled) {\n if (this.trailing && this._hasTrailingValue) {\n this.destination.next(this._trailingValue);\n this._trailingValue = null;\n this._hasTrailingValue = false;\n }\n throttled.unsubscribe();\n this.remove(throttled);\n this.throttled = null;\n }\n }\n}\nfunction dispatchNext(arg) {\n const {\n subscriber\n } = arg;\n subscriber.clearThrottle();\n}\n","import { Observable } from '../Observable';\nimport { from } from './from';\nimport { empty } from './empty';\nexport function defer(observableFactory) {\n return new Observable(subscriber => {\n let input;\n try {\n input = observableFactory();\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n const source = input ? from(input) : empty();\n return source.subscribe(subscriber);\n });\n}\n","import { async } from '../scheduler/async';\nimport { scan } from './scan';\nimport { defer } from '../observable/defer';\nimport { map } from './map';\nexport function timeInterval(scheduler = async) {\n return source => defer(() => {\n return source.pipe(scan(({\n current\n }, value) => ({\n value,\n current: scheduler.now(),\n last: current\n }), {\n current: scheduler.now(),\n value: undefined,\n last: undefined\n }), map(({\n current,\n last,\n value\n }) => new TimeInterval(value, current - last)));\n });\n}\nexport class TimeInterval {\n constructor(value, interval) {\n this.value = value;\n this.interval = interval;\n }\n}\n","const TimeoutErrorImpl = (() => {\n function TimeoutErrorImpl() {\n Error.call(this);\n this.message = 'Timeout has occurred';\n this.name = 'TimeoutError';\n return this;\n }\n TimeoutErrorImpl.prototype = Object.create(Error.prototype);\n return TimeoutErrorImpl;\n})();\nexport const TimeoutError = TimeoutErrorImpl;\n","import { async } from '../scheduler/async';\nimport { isDate } from '../util/isDate';\nimport { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function timeoutWith(due, withObservable, scheduler = async) {\n return source => {\n let absoluteTimeout = isDate(due);\n let waitFor = absoluteTimeout ? +due - scheduler.now() : Math.abs(due);\n return source.lift(new TimeoutWithOperator(waitFor, absoluteTimeout, withObservable, scheduler));\n };\n}\nclass TimeoutWithOperator {\n constructor(waitFor, absoluteTimeout, withObservable, scheduler) {\n this.waitFor = waitFor;\n this.absoluteTimeout = absoluteTimeout;\n this.withObservable = withObservable;\n this.scheduler = scheduler;\n }\n call(subscriber, source) {\n return source.subscribe(new TimeoutWithSubscriber(subscriber, this.absoluteTimeout, this.waitFor, this.withObservable, this.scheduler));\n }\n}\nclass TimeoutWithSubscriber extends SimpleOuterSubscriber {\n constructor(destination, absoluteTimeout, waitFor, withObservable, scheduler) {\n super(destination);\n this.absoluteTimeout = absoluteTimeout;\n this.waitFor = waitFor;\n this.withObservable = withObservable;\n this.scheduler = scheduler;\n this.scheduleTimeout();\n }\n static dispatchTimeout(subscriber) {\n const {\n withObservable\n } = subscriber;\n subscriber._unsubscribeAndRecycle();\n subscriber.add(innerSubscribe(withObservable, new SimpleInnerSubscriber(subscriber)));\n }\n scheduleTimeout() {\n const {\n action\n } = this;\n if (action) {\n this.action = action.schedule(this, this.waitFor);\n } else {\n this.add(this.action = this.scheduler.schedule(TimeoutWithSubscriber.dispatchTimeout, this.waitFor, this));\n }\n }\n _next(value) {\n if (!this.absoluteTimeout) {\n this.scheduleTimeout();\n }\n super._next(value);\n }\n _unsubscribe() {\n this.action = undefined;\n this.scheduler = null;\n this.withObservable = null;\n }\n}\n","import { async } from '../scheduler/async';\nimport { TimeoutError } from '../util/TimeoutError';\nimport { timeoutWith } from './timeoutWith';\nimport { throwError } from '../observable/throwError';\nexport function timeout(due, scheduler = async) {\n return timeoutWith(due, throwError(new TimeoutError()), scheduler);\n}\n","import { async } from '../scheduler/async';\nimport { map } from './map';\nexport function timestamp(scheduler = async) {\n return map(value => new Timestamp(value, scheduler.now()));\n}\nexport class Timestamp {\n constructor(value, timestamp) {\n this.value = value;\n this.timestamp = timestamp;\n }\n}\n","import { reduce } from './reduce';\nfunction toArrayReducer(arr, item, index) {\n if (index === 0) {\n return [item];\n }\n arr.push(item);\n return arr;\n}\nexport function toArray() {\n return reduce(toArrayReducer, []);\n}\n","import { Subject } from '../Subject';\nimport { SimpleOuterSubscriber, innerSubscribe, SimpleInnerSubscriber } from '../innerSubscribe';\nexport function window(windowBoundaries) {\n return function windowOperatorFunction(source) {\n return source.lift(new WindowOperator(windowBoundaries));\n };\n}\nclass WindowOperator {\n constructor(windowBoundaries) {\n this.windowBoundaries = windowBoundaries;\n }\n call(subscriber, source) {\n const windowSubscriber = new WindowSubscriber(subscriber);\n const sourceSubscription = source.subscribe(windowSubscriber);\n if (!sourceSubscription.closed) {\n windowSubscriber.add(innerSubscribe(this.windowBoundaries, new SimpleInnerSubscriber(windowSubscriber)));\n }\n return sourceSubscription;\n }\n}\nclass WindowSubscriber extends SimpleOuterSubscriber {\n constructor(destination) {\n super(destination);\n this.window = new Subject();\n destination.next(this.window);\n }\n notifyNext() {\n this.openWindow();\n }\n notifyError(error) {\n this._error(error);\n }\n notifyComplete() {\n this._complete();\n }\n _next(value) {\n this.window.next(value);\n }\n _error(err) {\n this.window.error(err);\n this.destination.error(err);\n }\n _complete() {\n this.window.complete();\n this.destination.complete();\n }\n _unsubscribe() {\n this.window = null;\n }\n openWindow() {\n const prevWindow = this.window;\n if (prevWindow) {\n prevWindow.complete();\n }\n const destination = this.destination;\n const newWindow = this.window = new Subject();\n destination.next(newWindow);\n }\n}\n","import { Subscriber } from '../Subscriber';\nimport { Subject } from '../Subject';\nexport function windowCount(windowSize, startWindowEvery = 0) {\n return function windowCountOperatorFunction(source) {\n return source.lift(new WindowCountOperator(windowSize, startWindowEvery));\n };\n}\nclass WindowCountOperator {\n constructor(windowSize, startWindowEvery) {\n this.windowSize = windowSize;\n this.startWindowEvery = startWindowEvery;\n }\n call(subscriber, source) {\n return source.subscribe(new WindowCountSubscriber(subscriber, this.windowSize, this.startWindowEvery));\n }\n}\nclass WindowCountSubscriber extends Subscriber {\n constructor(destination, windowSize, startWindowEvery) {\n super(destination);\n this.destination = destination;\n this.windowSize = windowSize;\n this.startWindowEvery = startWindowEvery;\n this.windows = [new Subject()];\n this.count = 0;\n destination.next(this.windows[0]);\n }\n _next(value) {\n const startWindowEvery = this.startWindowEvery > 0 ? this.startWindowEvery : this.windowSize;\n const destination = this.destination;\n const windowSize = this.windowSize;\n const windows = this.windows;\n const len = windows.length;\n for (let i = 0; i < len && !this.closed; i++) {\n windows[i].next(value);\n }\n const c = this.count - windowSize + 1;\n if (c >= 0 && c % startWindowEvery === 0 && !this.closed) {\n windows.shift().complete();\n }\n if (++this.count % startWindowEvery === 0 && !this.closed) {\n const window = new Subject();\n windows.push(window);\n destination.next(window);\n }\n }\n _error(err) {\n const windows = this.windows;\n if (windows) {\n while (windows.length > 0 && !this.closed) {\n windows.shift().error(err);\n }\n }\n this.destination.error(err);\n }\n _complete() {\n const windows = this.windows;\n if (windows) {\n while (windows.length > 0 && !this.closed) {\n windows.shift().complete();\n }\n }\n this.destination.complete();\n }\n _unsubscribe() {\n this.count = 0;\n this.windows = null;\n }\n}\n","import { Subject } from '../Subject';\nimport { async } from '../scheduler/async';\nimport { Subscriber } from '../Subscriber';\nimport { isNumeric } from '../util/isNumeric';\nimport { isScheduler } from '../util/isScheduler';\nexport function windowTime(windowTimeSpan) {\n let scheduler = async;\n let windowCreationInterval = null;\n let maxWindowSize = Number.POSITIVE_INFINITY;\n if (isScheduler(arguments[3])) {\n scheduler = arguments[3];\n }\n if (isScheduler(arguments[2])) {\n scheduler = arguments[2];\n } else if (isNumeric(arguments[2])) {\n maxWindowSize = Number(arguments[2]);\n }\n if (isScheduler(arguments[1])) {\n scheduler = arguments[1];\n } else if (isNumeric(arguments[1])) {\n windowCreationInterval = Number(arguments[1]);\n }\n return function windowTimeOperatorFunction(source) {\n return source.lift(new WindowTimeOperator(windowTimeSpan, windowCreationInterval, maxWindowSize, scheduler));\n };\n}\nclass WindowTimeOperator {\n constructor(windowTimeSpan, windowCreationInterval, maxWindowSize, scheduler) {\n this.windowTimeSpan = windowTimeSpan;\n this.windowCreationInterval = windowCreationInterval;\n this.maxWindowSize = maxWindowSize;\n this.scheduler = scheduler;\n }\n call(subscriber, source) {\n return source.subscribe(new WindowTimeSubscriber(subscriber, this.windowTimeSpan, this.windowCreationInterval, this.maxWindowSize, this.scheduler));\n }\n}\nclass CountedSubject extends Subject {\n constructor() {\n super(...arguments);\n this._numberOfNextedValues = 0;\n }\n next(value) {\n this._numberOfNextedValues++;\n super.next(value);\n }\n get numberOfNextedValues() {\n return this._numberOfNextedValues;\n }\n}\nclass WindowTimeSubscriber extends Subscriber {\n constructor(destination, windowTimeSpan, windowCreationInterval, maxWindowSize, scheduler) {\n super(destination);\n this.destination = destination;\n this.windowTimeSpan = windowTimeSpan;\n this.windowCreationInterval = windowCreationInterval;\n this.maxWindowSize = maxWindowSize;\n this.scheduler = scheduler;\n this.windows = [];\n const window = this.openWindow();\n if (windowCreationInterval !== null && windowCreationInterval >= 0) {\n const closeState = {\n subscriber: this,\n window,\n context: null\n };\n const creationState = {\n windowTimeSpan,\n windowCreationInterval,\n subscriber: this,\n scheduler\n };\n this.add(scheduler.schedule(dispatchWindowClose, windowTimeSpan, closeState));\n this.add(scheduler.schedule(dispatchWindowCreation, windowCreationInterval, creationState));\n } else {\n const timeSpanOnlyState = {\n subscriber: this,\n window,\n windowTimeSpan\n };\n this.add(scheduler.schedule(dispatchWindowTimeSpanOnly, windowTimeSpan, timeSpanOnlyState));\n }\n }\n _next(value) {\n const windows = this.windows;\n const len = windows.length;\n for (let i = 0; i < len; i++) {\n const window = windows[i];\n if (!window.closed) {\n window.next(value);\n if (window.numberOfNextedValues >= this.maxWindowSize) {\n this.closeWindow(window);\n }\n }\n }\n }\n _error(err) {\n const windows = this.windows;\n while (windows.length > 0) {\n windows.shift().error(err);\n }\n this.destination.error(err);\n }\n _complete() {\n const windows = this.windows;\n while (windows.length > 0) {\n const window = windows.shift();\n if (!window.closed) {\n window.complete();\n }\n }\n this.destination.complete();\n }\n openWindow() {\n const window = new CountedSubject();\n this.windows.push(window);\n const destination = this.destination;\n destination.next(window);\n return window;\n }\n closeWindow(window) {\n window.complete();\n const windows = this.windows;\n windows.splice(windows.indexOf(window), 1);\n }\n}\nfunction dispatchWindowTimeSpanOnly(state) {\n const {\n subscriber,\n windowTimeSpan,\n window\n } = state;\n if (window) {\n subscriber.closeWindow(window);\n }\n state.window = subscriber.openWindow();\n this.schedule(state, windowTimeSpan);\n}\nfunction dispatchWindowCreation(state) {\n const {\n windowTimeSpan,\n subscriber,\n scheduler,\n windowCreationInterval\n } = state;\n const window = subscriber.openWindow();\n const action = this;\n let context = {\n action,\n subscription: null\n };\n const timeSpanState = {\n subscriber,\n window,\n context\n };\n context.subscription = scheduler.schedule(dispatchWindowClose, windowTimeSpan, timeSpanState);\n action.add(context.subscription);\n action.schedule(state, windowCreationInterval);\n}\nfunction dispatchWindowClose(state) {\n const {\n subscriber,\n window,\n context\n } = state;\n if (context && context.action && context.subscription) {\n context.action.remove(context.subscription);\n }\n subscriber.closeWindow(window);\n}\n","import { Subject } from '../Subject';\nimport { Subscription } from '../Subscription';\nimport { OuterSubscriber } from '../OuterSubscriber';\nimport { subscribeToResult } from '../util/subscribeToResult';\nexport function windowToggle(openings, closingSelector) {\n return source => source.lift(new WindowToggleOperator(openings, closingSelector));\n}\nclass WindowToggleOperator {\n constructor(openings, closingSelector) {\n this.openings = openings;\n this.closingSelector = closingSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new WindowToggleSubscriber(subscriber, this.openings, this.closingSelector));\n }\n}\nclass WindowToggleSubscriber extends OuterSubscriber {\n constructor(destination, openings, closingSelector) {\n super(destination);\n this.openings = openings;\n this.closingSelector = closingSelector;\n this.contexts = [];\n this.add(this.openSubscription = subscribeToResult(this, openings, openings));\n }\n _next(value) {\n const {\n contexts\n } = this;\n if (contexts) {\n const len = contexts.length;\n for (let i = 0; i < len; i++) {\n contexts[i].window.next(value);\n }\n }\n }\n _error(err) {\n const {\n contexts\n } = this;\n this.contexts = null;\n if (contexts) {\n const len = contexts.length;\n let index = -1;\n while (++index < len) {\n const context = contexts[index];\n context.window.error(err);\n context.subscription.unsubscribe();\n }\n }\n super._error(err);\n }\n _complete() {\n const {\n contexts\n } = this;\n this.contexts = null;\n if (contexts) {\n const len = contexts.length;\n let index = -1;\n while (++index < len) {\n const context = contexts[index];\n context.window.complete();\n context.subscription.unsubscribe();\n }\n }\n super._complete();\n }\n _unsubscribe() {\n const {\n contexts\n } = this;\n this.contexts = null;\n if (contexts) {\n const len = contexts.length;\n let index = -1;\n while (++index < len) {\n const context = contexts[index];\n context.window.unsubscribe();\n context.subscription.unsubscribe();\n }\n }\n }\n notifyNext(outerValue, innerValue, outerIndex, innerIndex, innerSub) {\n if (outerValue === this.openings) {\n let closingNotifier;\n try {\n const {\n closingSelector\n } = this;\n closingNotifier = closingSelector(innerValue);\n } catch (e) {\n return this.error(e);\n }\n const window = new Subject();\n const subscription = new Subscription();\n const context = {\n window,\n subscription\n };\n this.contexts.push(context);\n const innerSubscription = subscribeToResult(this, closingNotifier, context);\n if (innerSubscription.closed) {\n this.closeWindow(this.contexts.length - 1);\n } else {\n innerSubscription.context = context;\n subscription.add(innerSubscription);\n }\n this.destination.next(window);\n } else {\n this.closeWindow(this.contexts.indexOf(outerValue));\n }\n }\n notifyError(err) {\n this.error(err);\n }\n notifyComplete(inner) {\n if (inner !== this.openSubscription) {\n this.closeWindow(this.contexts.indexOf(inner.context));\n }\n }\n closeWindow(index) {\n if (index === -1) {\n return;\n }\n const {\n contexts\n } = this;\n const context = contexts[index];\n const {\n window,\n subscription\n } = context;\n contexts.splice(index, 1);\n window.complete();\n subscription.unsubscribe();\n }\n}\n","import { Subject } from '../Subject';\nimport { OuterSubscriber } from '../OuterSubscriber';\nimport { subscribeToResult } from '../util/subscribeToResult';\nexport function windowWhen(closingSelector) {\n return function windowWhenOperatorFunction(source) {\n return source.lift(new WindowOperator(closingSelector));\n };\n}\nclass WindowOperator {\n constructor(closingSelector) {\n this.closingSelector = closingSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new WindowSubscriber(subscriber, this.closingSelector));\n }\n}\nclass WindowSubscriber extends OuterSubscriber {\n constructor(destination, closingSelector) {\n super(destination);\n this.destination = destination;\n this.closingSelector = closingSelector;\n this.openWindow();\n }\n notifyNext(_outerValue, _innerValue, _outerIndex, _innerIndex, innerSub) {\n this.openWindow(innerSub);\n }\n notifyError(error) {\n this._error(error);\n }\n notifyComplete(innerSub) {\n this.openWindow(innerSub);\n }\n _next(value) {\n this.window.next(value);\n }\n _error(err) {\n this.window.error(err);\n this.destination.error(err);\n this.unsubscribeClosingNotification();\n }\n _complete() {\n this.window.complete();\n this.destination.complete();\n this.unsubscribeClosingNotification();\n }\n unsubscribeClosingNotification() {\n if (this.closingNotification) {\n this.closingNotification.unsubscribe();\n }\n }\n openWindow(innerSub = null) {\n if (innerSub) {\n this.remove(innerSub);\n innerSub.unsubscribe();\n }\n const prevWindow = this.window;\n if (prevWindow) {\n prevWindow.complete();\n }\n const window = this.window = new Subject();\n this.destination.next(window);\n let closingNotifier;\n try {\n const {\n closingSelector\n } = this;\n closingNotifier = closingSelector();\n } catch (e) {\n this.destination.error(e);\n this.window.error(e);\n return;\n }\n this.add(this.closingNotification = subscribeToResult(this, closingNotifier));\n }\n}\n","import { OuterSubscriber } from '../OuterSubscriber';\nimport { subscribeToResult } from '../util/subscribeToResult';\nexport function withLatestFrom(...args) {\n return source => {\n let project;\n if (typeof args[args.length - 1] === 'function') {\n project = args.pop();\n }\n const observables = args;\n return source.lift(new WithLatestFromOperator(observables, project));\n };\n}\nclass WithLatestFromOperator {\n constructor(observables, project) {\n this.observables = observables;\n this.project = project;\n }\n call(subscriber, source) {\n return source.subscribe(new WithLatestFromSubscriber(subscriber, this.observables, this.project));\n }\n}\nclass WithLatestFromSubscriber extends OuterSubscriber {\n constructor(destination, observables, project) {\n super(destination);\n this.observables = observables;\n this.project = project;\n this.toRespond = [];\n const len = observables.length;\n this.values = new Array(len);\n for (let i = 0; i < len; i++) {\n this.toRespond.push(i);\n }\n for (let i = 0; i < len; i++) {\n let observable = observables[i];\n this.add(subscribeToResult(this, observable, undefined, i));\n }\n }\n notifyNext(_outerValue, innerValue, outerIndex) {\n this.values[outerIndex] = innerValue;\n const toRespond = this.toRespond;\n if (toRespond.length > 0) {\n const found = toRespond.indexOf(outerIndex);\n if (found !== -1) {\n toRespond.splice(found, 1);\n }\n }\n }\n notifyComplete() {}\n _next(value) {\n if (this.toRespond.length === 0) {\n const args = [value, ...this.values];\n if (this.project) {\n this._tryProject(args);\n } else {\n this.destination.next(args);\n }\n }\n }\n _tryProject(args) {\n let result;\n try {\n result = this.project.apply(this, args);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.destination.next(result);\n }\n}\n","import { fromArray } from './fromArray';\nimport { isArray } from '../util/isArray';\nimport { Subscriber } from '../Subscriber';\nimport { iterator as Symbol_iterator } from '../../internal/symbol/iterator';\nimport { SimpleOuterSubscriber, SimpleInnerSubscriber, innerSubscribe } from '../innerSubscribe';\nexport function zip(...observables) {\n const resultSelector = observables[observables.length - 1];\n if (typeof resultSelector === 'function') {\n observables.pop();\n }\n return fromArray(observables, undefined).lift(new ZipOperator(resultSelector));\n}\nexport class ZipOperator {\n constructor(resultSelector) {\n this.resultSelector = resultSelector;\n }\n call(subscriber, source) {\n return source.subscribe(new ZipSubscriber(subscriber, this.resultSelector));\n }\n}\nexport class ZipSubscriber extends Subscriber {\n constructor(destination, resultSelector, values = Object.create(null)) {\n super(destination);\n this.resultSelector = resultSelector;\n this.iterators = [];\n this.active = 0;\n this.resultSelector = typeof resultSelector === 'function' ? resultSelector : undefined;\n }\n _next(value) {\n const iterators = this.iterators;\n if (isArray(value)) {\n iterators.push(new StaticArrayIterator(value));\n } else if (typeof value[Symbol_iterator] === 'function') {\n iterators.push(new StaticIterator(value[Symbol_iterator]()));\n } else {\n iterators.push(new ZipBufferIterator(this.destination, this, value));\n }\n }\n _complete() {\n const iterators = this.iterators;\n const len = iterators.length;\n this.unsubscribe();\n if (len === 0) {\n this.destination.complete();\n return;\n }\n this.active = len;\n for (let i = 0; i < len; i++) {\n let iterator = iterators[i];\n if (iterator.stillUnsubscribed) {\n const destination = this.destination;\n destination.add(iterator.subscribe());\n } else {\n this.active--;\n }\n }\n }\n notifyInactive() {\n this.active--;\n if (this.active === 0) {\n this.destination.complete();\n }\n }\n checkIterators() {\n const iterators = this.iterators;\n const len = iterators.length;\n const destination = this.destination;\n for (let i = 0; i < len; i++) {\n let iterator = iterators[i];\n if (typeof iterator.hasValue === 'function' && !iterator.hasValue()) {\n return;\n }\n }\n let shouldComplete = false;\n const args = [];\n for (let i = 0; i < len; i++) {\n let iterator = iterators[i];\n let result = iterator.next();\n if (iterator.hasCompleted()) {\n shouldComplete = true;\n }\n if (result.done) {\n destination.complete();\n return;\n }\n args.push(result.value);\n }\n if (this.resultSelector) {\n this._tryresultSelector(args);\n } else {\n destination.next(args);\n }\n if (shouldComplete) {\n destination.complete();\n }\n }\n _tryresultSelector(args) {\n let result;\n try {\n result = this.resultSelector.apply(this, args);\n } catch (err) {\n this.destination.error(err);\n return;\n }\n this.destination.next(result);\n }\n}\nclass StaticIterator {\n constructor(iterator) {\n this.iterator = iterator;\n this.nextResult = iterator.next();\n }\n hasValue() {\n return true;\n }\n next() {\n const result = this.nextResult;\n this.nextResult = this.iterator.next();\n return result;\n }\n hasCompleted() {\n const nextResult = this.nextResult;\n return Boolean(nextResult && nextResult.done);\n }\n}\nclass StaticArrayIterator {\n constructor(array) {\n this.array = array;\n this.index = 0;\n this.length = 0;\n this.length = array.length;\n }\n [Symbol_iterator]() {\n return this;\n }\n next(value) {\n const i = this.index++;\n const array = this.array;\n return i < this.length ? {\n value: array[i],\n done: false\n } : {\n value: null,\n done: true\n };\n }\n hasValue() {\n return this.array.length > this.index;\n }\n hasCompleted() {\n return this.array.length === this.index;\n }\n}\nclass ZipBufferIterator extends SimpleOuterSubscriber {\n constructor(destination, parent, observable) {\n super(destination);\n this.parent = parent;\n this.observable = observable;\n this.stillUnsubscribed = true;\n this.buffer = [];\n this.isComplete = false;\n }\n [Symbol_iterator]() {\n return this;\n }\n next() {\n const buffer = this.buffer;\n if (buffer.length === 0 && this.isComplete) {\n return {\n value: null,\n done: true\n };\n } else {\n return {\n value: buffer.shift(),\n done: false\n };\n }\n }\n hasValue() {\n return this.buffer.length > 0;\n }\n hasCompleted() {\n return this.buffer.length === 0 && this.isComplete;\n }\n notifyComplete() {\n if (this.buffer.length > 0) {\n this.isComplete = true;\n this.parent.notifyInactive();\n } else {\n this.destination.complete();\n }\n }\n notifyNext(innerValue) {\n this.buffer.push(innerValue);\n this.parent.checkIterators();\n }\n subscribe() {\n return innerSubscribe(this.observable, new SimpleInnerSubscriber(this));\n }\n}\n","import { zip as zipStatic } from '../observable/zip';\nexport function zip(...observables) {\n return function zipOperatorFunction(source) {\n return source.lift.call(zipStatic(source, ...observables));\n };\n}\n","import { ZipOperator } from '../observable/zip';\nexport function zipAll(project) {\n return source => source.lift(new ZipOperator(project));\n}\n","export { audit } from '../internal/operators/audit';\nexport { auditTime } from '../internal/operators/auditTime';\nexport { buffer } from '../internal/operators/buffer';\nexport { bufferCount } from '../internal/operators/bufferCount';\nexport { bufferTime } from '../internal/operators/bufferTime';\nexport { bufferToggle } from '../internal/operators/bufferToggle';\nexport { bufferWhen } from '../internal/operators/bufferWhen';\nexport { catchError } from '../internal/operators/catchError';\nexport { combineAll } from '../internal/operators/combineAll';\nexport { combineLatest } from '../internal/operators/combineLatest';\nexport { concat } from '../internal/operators/concat';\nexport { concatAll } from '../internal/operators/concatAll';\nexport { concatMap } from '../internal/operators/concatMap';\nexport { concatMapTo } from '../internal/operators/concatMapTo';\nexport { count } from '../internal/operators/count';\nexport { debounce } from '../internal/operators/debounce';\nexport { debounceTime } from '../internal/operators/debounceTime';\nexport { defaultIfEmpty } from '../internal/operators/defaultIfEmpty';\nexport { delay } from '../internal/operators/delay';\nexport { delayWhen } from '../internal/operators/delayWhen';\nexport { dematerialize } from '../internal/operators/dematerialize';\nexport { distinct } from '../internal/operators/distinct';\nexport { distinctUntilChanged } from '../internal/operators/distinctUntilChanged';\nexport { distinctUntilKeyChanged } from '../internal/operators/distinctUntilKeyChanged';\nexport { elementAt } from '../internal/operators/elementAt';\nexport { endWith } from '../internal/operators/endWith';\nexport { every } from '../internal/operators/every';\nexport { exhaust } from '../internal/operators/exhaust';\nexport { exhaustMap } from '../internal/operators/exhaustMap';\nexport { expand } from '../internal/operators/expand';\nexport { filter } from '../internal/operators/filter';\nexport { finalize } from '../internal/operators/finalize';\nexport { find } from '../internal/operators/find';\nexport { findIndex } from '../internal/operators/findIndex';\nexport { first } from '../internal/operators/first';\nexport { groupBy } from '../internal/operators/groupBy';\nexport { ignoreElements } from '../internal/operators/ignoreElements';\nexport { isEmpty } from '../internal/operators/isEmpty';\nexport { last } from '../internal/operators/last';\nexport { map } from '../internal/operators/map';\nexport { mapTo } from '../internal/operators/mapTo';\nexport { materialize } from '../internal/operators/materialize';\nexport { max } from '../internal/operators/max';\nexport { merge } from '../internal/operators/merge';\nexport { mergeAll } from '../internal/operators/mergeAll';\nexport { mergeMap, flatMap } from '../internal/operators/mergeMap';\nexport { mergeMapTo } from '../internal/operators/mergeMapTo';\nexport { mergeScan } from '../internal/operators/mergeScan';\nexport { min } from '../internal/operators/min';\nexport { multicast } from '../internal/operators/multicast';\nexport { observeOn } from '../internal/operators/observeOn';\nexport { onErrorResumeNext } from '../internal/operators/onErrorResumeNext';\nexport { pairwise } from '../internal/operators/pairwise';\nexport { partition } from '../internal/operators/partition';\nexport { pluck } from '../internal/operators/pluck';\nexport { publish } from '../internal/operators/publish';\nexport { publishBehavior } from '../internal/operators/publishBehavior';\nexport { publishLast } from '../internal/operators/publishLast';\nexport { publishReplay } from '../internal/operators/publishReplay';\nexport { race } from '../internal/operators/race';\nexport { reduce } from '../internal/operators/reduce';\nexport { repeat } from '../internal/operators/repeat';\nexport { repeatWhen } from '../internal/operators/repeatWhen';\nexport { retry } from '../internal/operators/retry';\nexport { retryWhen } from '../internal/operators/retryWhen';\nexport { refCount } from '../internal/operators/refCount';\nexport { sample } from '../internal/operators/sample';\nexport { sampleTime } from '../internal/operators/sampleTime';\nexport { scan } from '../internal/operators/scan';\nexport { sequenceEqual } from '../internal/operators/sequenceEqual';\nexport { share } from '../internal/operators/share';\nexport { shareReplay } from '../internal/operators/shareReplay';\nexport { single } from '../internal/operators/single';\nexport { skip } from '../internal/operators/skip';\nexport { skipLast } from '../internal/operators/skipLast';\nexport { skipUntil } from '../internal/operators/skipUntil';\nexport { skipWhile } from '../internal/operators/skipWhile';\nexport { startWith } from '../internal/operators/startWith';\nexport { subscribeOn } from '../internal/operators/subscribeOn';\nexport { switchAll } from '../internal/operators/switchAll';\nexport { switchMap } from '../internal/operators/switchMap';\nexport { switchMapTo } from '../internal/operators/switchMapTo';\nexport { take } from '../internal/operators/take';\nexport { takeLast } from '../internal/operators/takeLast';\nexport { takeUntil } from '../internal/operators/takeUntil';\nexport { takeWhile } from '../internal/operators/takeWhile';\nexport { tap } from '../internal/operators/tap';\nexport { throttle } from '../internal/operators/throttle';\nexport { throttleTime } from '../internal/operators/throttleTime';\nexport { throwIfEmpty } from '../internal/operators/throwIfEmpty';\nexport { timeInterval } from '../internal/operators/timeInterval';\nexport { timeout } from '../internal/operators/timeout';\nexport { timeoutWith } from '../internal/operators/timeoutWith';\nexport { timestamp } from '../internal/operators/timestamp';\nexport { toArray } from '../internal/operators/toArray';\nexport { window } from '../internal/operators/window';\nexport { windowCount } from '../internal/operators/windowCount';\nexport { windowTime } from '../internal/operators/windowTime';\nexport { windowToggle } from '../internal/operators/windowToggle';\nexport { windowWhen } from '../internal/operators/windowWhen';\nexport { withLatestFrom } from '../internal/operators/withLatestFrom';\nexport { zip } from '../internal/operators/zip';\nexport { zipAll } from '../internal/operators/zipAll';\n","import { AsyncAction } from './AsyncAction';\nexport class AnimationFrameAction extends AsyncAction {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n }\n requestAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && delay > 0) {\n return super.requestAsyncId(scheduler, id, delay);\n }\n scheduler.actions.push(this);\n return scheduler.scheduled || (scheduler.scheduled = requestAnimationFrame(() => scheduler.flush(null)));\n }\n recycleAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && delay > 0 || delay === null && this.delay > 0) {\n return super.recycleAsyncId(scheduler, id, delay);\n }\n if (scheduler.actions.length === 0) {\n cancelAnimationFrame(id);\n scheduler.scheduled = undefined;\n }\n return undefined;\n }\n}\n","import { AsyncScheduler } from './AsyncScheduler';\nexport class AnimationFrameScheduler extends AsyncScheduler {\n flush(action) {\n this.active = true;\n this.scheduled = undefined;\n const {\n actions\n } = this;\n let error;\n let index = -1;\n let count = actions.length;\n action = action || actions.shift();\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while (++index < count && (action = actions.shift()));\n this.active = false;\n if (error) {\n while (++index < count && (action = actions.shift())) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n","import { AnimationFrameAction } from './AnimationFrameAction';\nimport { AnimationFrameScheduler } from './AnimationFrameScheduler';\nexport const animationFrameScheduler = new AnimationFrameScheduler(AnimationFrameAction);\nexport const animationFrame = animationFrameScheduler;\n","import { AsyncAction } from './AsyncAction';\nimport { AsyncScheduler } from './AsyncScheduler';\nexport let VirtualTimeScheduler = /*#__PURE__*/(() => {\n class VirtualTimeScheduler extends AsyncScheduler {\n constructor(SchedulerAction = VirtualAction, maxFrames = Number.POSITIVE_INFINITY) {\n super(SchedulerAction, () => this.frame);\n this.maxFrames = maxFrames;\n this.frame = 0;\n this.index = -1;\n }\n flush() {\n const {\n actions,\n maxFrames\n } = this;\n let error, action;\n while ((action = actions[0]) && action.delay <= maxFrames) {\n actions.shift();\n this.frame = action.delay;\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n }\n if (error) {\n while (action = actions.shift()) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n }\n VirtualTimeScheduler.frameTimeFactor = 10;\n return VirtualTimeScheduler;\n})();\nexport class VirtualAction extends AsyncAction {\n constructor(scheduler, work, index = scheduler.index += 1) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n this.index = index;\n this.active = true;\n this.index = scheduler.index = index;\n }\n schedule(state, delay = 0) {\n if (!this.id) {\n return super.schedule(state, delay);\n }\n this.active = false;\n const action = new VirtualAction(this.scheduler, this.work);\n this.add(action);\n return action.schedule(state, delay);\n }\n requestAsyncId(scheduler, id, delay = 0) {\n this.delay = scheduler.frame + delay;\n const {\n actions\n } = scheduler;\n actions.push(this);\n actions.sort(VirtualAction.sortActions);\n return true;\n }\n recycleAsyncId(scheduler, id, delay = 0) {\n return undefined;\n }\n _execute(state, delay) {\n if (this.active === true) {\n return super._execute(state, delay);\n }\n }\n static sortActions(a, b) {\n if (a.delay === b.delay) {\n if (a.index === b.index) {\n return 0;\n } else if (a.index > b.index) {\n return 1;\n } else {\n return -1;\n }\n } else if (a.delay > b.delay) {\n return 1;\n } else {\n return -1;\n }\n }\n}\n","import { Observable } from '../Observable';\nexport function isObservable(obj) {\n return !!obj && (obj instanceof Observable || typeof obj.lift === 'function' && typeof obj.subscribe === 'function');\n}\n","import { Observable } from '../Observable';\nimport { AsyncSubject } from '../AsyncSubject';\nimport { map } from '../operators/map';\nimport { canReportError } from '../util/canReportError';\nimport { isArray } from '../util/isArray';\nimport { isScheduler } from '../util/isScheduler';\nexport function bindCallback(callbackFunc, resultSelector, scheduler) {\n if (resultSelector) {\n if (isScheduler(resultSelector)) {\n scheduler = resultSelector;\n } else {\n return (...args) => bindCallback(callbackFunc, scheduler)(...args).pipe(map(args => isArray(args) ? resultSelector(...args) : resultSelector(args)));\n }\n }\n return function (...args) {\n const context = this;\n let subject;\n const params = {\n context,\n subject,\n callbackFunc,\n scheduler\n };\n return new Observable(subscriber => {\n if (!scheduler) {\n if (!subject) {\n subject = new AsyncSubject();\n const handler = (...innerArgs) => {\n subject.next(innerArgs.length <= 1 ? innerArgs[0] : innerArgs);\n subject.complete();\n };\n try {\n callbackFunc.apply(context, [...args, handler]);\n } catch (err) {\n if (canReportError(subject)) {\n subject.error(err);\n } else {\n console.warn(err);\n }\n }\n }\n return subject.subscribe(subscriber);\n } else {\n const state = {\n args,\n subscriber,\n params\n };\n return scheduler.schedule(dispatch, 0, state);\n }\n });\n };\n}\nfunction dispatch(state) {\n const self = this;\n const {\n args,\n subscriber,\n params\n } = state;\n const {\n callbackFunc,\n context,\n scheduler\n } = params;\n let {\n subject\n } = params;\n if (!subject) {\n subject = params.subject = new AsyncSubject();\n const handler = (...innerArgs) => {\n const value = innerArgs.length <= 1 ? innerArgs[0] : innerArgs;\n this.add(scheduler.schedule(dispatchNext, 0, {\n value,\n subject\n }));\n };\n try {\n callbackFunc.apply(context, [...args, handler]);\n } catch (err) {\n subject.error(err);\n }\n }\n this.add(subject.subscribe(subscriber));\n}\nfunction dispatchNext(state) {\n const {\n value,\n subject\n } = state;\n subject.next(value);\n subject.complete();\n}\nfunction dispatchError(state) {\n const {\n err,\n subject\n } = state;\n subject.error(err);\n}\n","import { Observable } from '../Observable';\nimport { AsyncSubject } from '../AsyncSubject';\nimport { map } from '../operators/map';\nimport { canReportError } from '../util/canReportError';\nimport { isScheduler } from '../util/isScheduler';\nimport { isArray } from '../util/isArray';\nexport function bindNodeCallback(callbackFunc, resultSelector, scheduler) {\n if (resultSelector) {\n if (isScheduler(resultSelector)) {\n scheduler = resultSelector;\n } else {\n return (...args) => bindNodeCallback(callbackFunc, scheduler)(...args).pipe(map(args => isArray(args) ? resultSelector(...args) : resultSelector(args)));\n }\n }\n return function (...args) {\n const params = {\n subject: undefined,\n args,\n callbackFunc,\n scheduler,\n context: this\n };\n return new Observable(subscriber => {\n const {\n context\n } = params;\n let {\n subject\n } = params;\n if (!scheduler) {\n if (!subject) {\n subject = params.subject = new AsyncSubject();\n const handler = (...innerArgs) => {\n const err = innerArgs.shift();\n if (err) {\n subject.error(err);\n return;\n }\n subject.next(innerArgs.length <= 1 ? innerArgs[0] : innerArgs);\n subject.complete();\n };\n try {\n callbackFunc.apply(context, [...args, handler]);\n } catch (err) {\n if (canReportError(subject)) {\n subject.error(err);\n } else {\n console.warn(err);\n }\n }\n }\n return subject.subscribe(subscriber);\n } else {\n return scheduler.schedule(dispatch, 0, {\n params,\n subscriber,\n context\n });\n }\n });\n };\n}\nfunction dispatch(state) {\n const {\n params,\n subscriber,\n context\n } = state;\n const {\n callbackFunc,\n args,\n scheduler\n } = params;\n let subject = params.subject;\n if (!subject) {\n subject = params.subject = new AsyncSubject();\n const handler = (...innerArgs) => {\n const err = innerArgs.shift();\n if (err) {\n this.add(scheduler.schedule(dispatchError, 0, {\n err,\n subject\n }));\n } else {\n const value = innerArgs.length <= 1 ? innerArgs[0] : innerArgs;\n this.add(scheduler.schedule(dispatchNext, 0, {\n value,\n subject\n }));\n }\n };\n try {\n callbackFunc.apply(context, [...args, handler]);\n } catch (err) {\n this.add(scheduler.schedule(dispatchError, 0, {\n err,\n subject\n }));\n }\n }\n this.add(subject.subscribe(subscriber));\n}\nfunction dispatchNext(arg) {\n const {\n value,\n subject\n } = arg;\n subject.next(value);\n subject.complete();\n}\nfunction dispatchError(arg) {\n const {\n err,\n subject\n } = arg;\n subject.error(err);\n}\n","import { Observable } from '../Observable';\nimport { isArray } from '../util/isArray';\nimport { map } from '../operators/map';\nimport { isObject } from '../util/isObject';\nimport { from } from './from';\nexport function forkJoin(...sources) {\n if (sources.length === 1) {\n const first = sources[0];\n if (isArray(first)) {\n return forkJoinInternal(first, null);\n }\n if (isObject(first) && Object.getPrototypeOf(first) === Object.prototype) {\n const keys = Object.keys(first);\n return forkJoinInternal(keys.map(key => first[key]), keys);\n }\n }\n if (typeof sources[sources.length - 1] === 'function') {\n const resultSelector = sources.pop();\n sources = sources.length === 1 && isArray(sources[0]) ? sources[0] : sources;\n return forkJoinInternal(sources, null).pipe(map(args => resultSelector(...args)));\n }\n return forkJoinInternal(sources, null);\n}\nfunction forkJoinInternal(sources, keys) {\n return new Observable(subscriber => {\n const len = sources.length;\n if (len === 0) {\n subscriber.complete();\n return;\n }\n const values = new Array(len);\n let completed = 0;\n let emitted = 0;\n for (let i = 0; i < len; i++) {\n const source = from(sources[i]);\n let hasValue = false;\n subscriber.add(source.subscribe({\n next: value => {\n if (!hasValue) {\n hasValue = true;\n emitted++;\n }\n values[i] = value;\n },\n error: err => subscriber.error(err),\n complete: () => {\n completed++;\n if (completed === len || !hasValue) {\n if (emitted === len) {\n subscriber.next(keys ? keys.reduce((result, key, i) => (result[key] = values[i], result), {}) : values);\n }\n subscriber.complete();\n }\n }\n }));\n }\n });\n}\n","import { Observable } from '../Observable';\nimport { isArray } from '../util/isArray';\nimport { isFunction } from '../util/isFunction';\nimport { map } from '../operators/map';\nconst toString = (() => Object.prototype.toString)();\nexport function fromEvent(target, eventName, options, resultSelector) {\n if (isFunction(options)) {\n resultSelector = options;\n options = undefined;\n }\n if (resultSelector) {\n return fromEvent(target, eventName, options).pipe(map(args => isArray(args) ? resultSelector(...args) : resultSelector(args)));\n }\n return new Observable(subscriber => {\n function handler(e) {\n if (arguments.length > 1) {\n subscriber.next(Array.prototype.slice.call(arguments));\n } else {\n subscriber.next(e);\n }\n }\n setupSubscription(target, eventName, handler, subscriber, options);\n });\n}\nfunction setupSubscription(sourceObj, eventName, handler, subscriber, options) {\n let unsubscribe;\n if (isEventTarget(sourceObj)) {\n const source = sourceObj;\n sourceObj.addEventListener(eventName, handler, options);\n unsubscribe = () => source.removeEventListener(eventName, handler, options);\n } else if (isJQueryStyleEventEmitter(sourceObj)) {\n const source = sourceObj;\n sourceObj.on(eventName, handler);\n unsubscribe = () => source.off(eventName, handler);\n } else if (isNodeStyleEventEmitter(sourceObj)) {\n const source = sourceObj;\n sourceObj.addListener(eventName, handler);\n unsubscribe = () => source.removeListener(eventName, handler);\n } else if (sourceObj && sourceObj.length) {\n for (let i = 0, len = sourceObj.length; i < len; i++) {\n setupSubscription(sourceObj[i], eventName, handler, subscriber, options);\n }\n } else {\n throw new TypeError('Invalid event target');\n }\n subscriber.add(unsubscribe);\n}\nfunction isNodeStyleEventEmitter(sourceObj) {\n return sourceObj && typeof sourceObj.addListener === 'function' && typeof sourceObj.removeListener === 'function';\n}\nfunction isJQueryStyleEventEmitter(sourceObj) {\n return sourceObj && typeof sourceObj.on === 'function' && typeof sourceObj.off === 'function';\n}\nfunction isEventTarget(sourceObj) {\n return sourceObj && typeof sourceObj.addEventListener === 'function' && typeof sourceObj.removeEventListener === 'function';\n}\n","import { Observable } from '../Observable';\nimport { isArray } from '../util/isArray';\nimport { isFunction } from '../util/isFunction';\nimport { map } from '../operators/map';\nexport function fromEventPattern(addHandler, removeHandler, resultSelector) {\n if (resultSelector) {\n return fromEventPattern(addHandler, removeHandler).pipe(map(args => isArray(args) ? resultSelector(...args) : resultSelector(args)));\n }\n return new Observable(subscriber => {\n const handler = (...e) => subscriber.next(e.length === 1 ? e[0] : e);\n let retValue;\n try {\n retValue = addHandler(handler);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n if (!isFunction(removeHandler)) {\n return undefined;\n }\n return () => removeHandler(handler, retValue);\n });\n}\n","import { Observable } from '../Observable';\nimport { identity } from '../util/identity';\nimport { isScheduler } from '../util/isScheduler';\nexport function generate(initialStateOrOptions, condition, iterate, resultSelectorOrObservable, scheduler) {\n let resultSelector;\n let initialState;\n if (arguments.length == 1) {\n const options = initialStateOrOptions;\n initialState = options.initialState;\n condition = options.condition;\n iterate = options.iterate;\n resultSelector = options.resultSelector || identity;\n scheduler = options.scheduler;\n } else if (resultSelectorOrObservable === undefined || isScheduler(resultSelectorOrObservable)) {\n initialState = initialStateOrOptions;\n resultSelector = identity;\n scheduler = resultSelectorOrObservable;\n } else {\n initialState = initialStateOrOptions;\n resultSelector = resultSelectorOrObservable;\n }\n return new Observable(subscriber => {\n let state = initialState;\n if (scheduler) {\n return scheduler.schedule(dispatch, 0, {\n subscriber,\n iterate,\n condition,\n resultSelector,\n state\n });\n }\n do {\n if (condition) {\n let conditionResult;\n try {\n conditionResult = condition(state);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n if (!conditionResult) {\n subscriber.complete();\n break;\n }\n }\n let value;\n try {\n value = resultSelector(state);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n subscriber.next(value);\n if (subscriber.closed) {\n break;\n }\n try {\n state = iterate(state);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n } while (true);\n return undefined;\n });\n}\nfunction dispatch(state) {\n const {\n subscriber,\n condition\n } = state;\n if (subscriber.closed) {\n return undefined;\n }\n if (state.needIterate) {\n try {\n state.state = state.iterate(state.state);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n } else {\n state.needIterate = true;\n }\n if (condition) {\n let conditionResult;\n try {\n conditionResult = condition(state.state);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n if (!conditionResult) {\n subscriber.complete();\n return undefined;\n }\n if (subscriber.closed) {\n return undefined;\n }\n }\n let value;\n try {\n value = state.resultSelector(state.state);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n if (subscriber.closed) {\n return undefined;\n }\n subscriber.next(value);\n if (subscriber.closed) {\n return undefined;\n }\n return this.schedule(state);\n}\n","import { defer } from './defer';\nimport { EMPTY } from './empty';\nexport function iif(condition, trueResult = EMPTY, falseResult = EMPTY) {\n return defer(() => condition() ? trueResult : falseResult);\n}\n","import { Observable } from '../Observable';\nimport { async } from '../scheduler/async';\nimport { isNumeric } from '../util/isNumeric';\nexport function interval(period = 0, scheduler = async) {\n if (!isNumeric(period) || period < 0) {\n period = 0;\n }\n if (!scheduler || typeof scheduler.schedule !== 'function') {\n scheduler = async;\n }\n return new Observable(subscriber => {\n subscriber.add(scheduler.schedule(dispatch, period, {\n subscriber,\n counter: 0,\n period\n }));\n return subscriber;\n });\n}\nfunction dispatch(state) {\n const {\n subscriber,\n counter,\n period\n } = state;\n subscriber.next(counter);\n this.schedule({\n subscriber,\n counter: counter + 1,\n period\n }, period);\n}\n","import { Observable } from '../Observable';\nimport { noop } from '../util/noop';\nexport const NEVER = new Observable(noop);\nexport function never() {\n return NEVER;\n}\n","import { Observable } from '../Observable';\nimport { from } from './from';\nimport { isArray } from '../util/isArray';\nimport { EMPTY } from './empty';\nexport function onErrorResumeNext(...sources) {\n if (sources.length === 0) {\n return EMPTY;\n }\n const [first, ...remainder] = sources;\n if (sources.length === 1 && isArray(first)) {\n return onErrorResumeNext(...first);\n }\n return new Observable(subscriber => {\n const subNext = () => subscriber.add(onErrorResumeNext(...remainder).subscribe(subscriber));\n return from(first).subscribe({\n next(value) {\n subscriber.next(value);\n },\n error: subNext,\n complete: subNext\n });\n });\n}\n","import { Observable } from '../Observable';\nimport { Subscription } from '../Subscription';\nexport function pairs(obj, scheduler) {\n if (!scheduler) {\n return new Observable(subscriber => {\n const keys = Object.keys(obj);\n for (let i = 0; i < keys.length && !subscriber.closed; i++) {\n const key = keys[i];\n if (obj.hasOwnProperty(key)) {\n subscriber.next([key, obj[key]]);\n }\n }\n subscriber.complete();\n });\n } else {\n return new Observable(subscriber => {\n const keys = Object.keys(obj);\n const subscription = new Subscription();\n subscription.add(scheduler.schedule(dispatch, 0, {\n keys,\n index: 0,\n subscriber,\n subscription,\n obj\n }));\n return subscription;\n });\n }\n}\nexport function dispatch(state) {\n const {\n keys,\n index,\n subscriber,\n subscription,\n obj\n } = state;\n if (!subscriber.closed) {\n if (index < keys.length) {\n const key = keys[index];\n subscriber.next([key, obj[key]]);\n subscription.add(this.schedule({\n keys,\n index: index + 1,\n subscriber,\n subscription,\n obj\n }));\n } else {\n subscriber.complete();\n }\n }\n}\n","import { not } from '../util/not';\nimport { subscribeTo } from '../util/subscribeTo';\nimport { filter } from '../operators/filter';\nimport { Observable } from '../Observable';\nexport function partition(source, predicate, thisArg) {\n return [filter(predicate, thisArg)(new Observable(subscribeTo(source))), filter(not(predicate, thisArg))(new Observable(subscribeTo(source)))];\n}\n","import { Observable } from '../Observable';\nexport function range(start = 0, count, scheduler) {\n return new Observable(subscriber => {\n if (count === undefined) {\n count = start;\n start = 0;\n }\n let index = 0;\n let current = start;\n if (scheduler) {\n return scheduler.schedule(dispatch, 0, {\n index,\n count,\n start,\n subscriber\n });\n } else {\n do {\n if (index++ >= count) {\n subscriber.complete();\n break;\n }\n subscriber.next(current++);\n if (subscriber.closed) {\n break;\n }\n } while (true);\n }\n return undefined;\n });\n}\nexport function dispatch(state) {\n const {\n start,\n index,\n count,\n subscriber\n } = state;\n if (index >= count) {\n subscriber.complete();\n return;\n }\n subscriber.next(start);\n if (subscriber.closed) {\n return;\n }\n state.index = index + 1;\n state.start = start + 1;\n this.schedule(state);\n}\n","import { Observable } from '../Observable';\nimport { from } from './from';\nimport { EMPTY } from './empty';\nexport function using(resourceFactory, observableFactory) {\n return new Observable(subscriber => {\n let resource;\n try {\n resource = resourceFactory();\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n let result;\n try {\n result = observableFactory(resource);\n } catch (err) {\n subscriber.error(err);\n return undefined;\n }\n const source = result ? from(result) : EMPTY;\n const subscription = source.subscribe(subscriber);\n return () => {\n subscription.unsubscribe();\n if (resource) {\n resource.unsubscribe();\n }\n };\n });\n}\n","export { Observable } from './internal/Observable';\nexport { ConnectableObservable } from './internal/observable/ConnectableObservable';\nexport { GroupedObservable } from './internal/operators/groupBy';\nexport { observable } from './internal/symbol/observable';\nexport { Subject } from './internal/Subject';\nexport { BehaviorSubject } from './internal/BehaviorSubject';\nexport { ReplaySubject } from './internal/ReplaySubject';\nexport { AsyncSubject } from './internal/AsyncSubject';\nexport { asap, asapScheduler } from './internal/scheduler/asap';\nexport { async, asyncScheduler } from './internal/scheduler/async';\nexport { queue, queueScheduler } from './internal/scheduler/queue';\nexport { animationFrame, animationFrameScheduler } from './internal/scheduler/animationFrame';\nexport { VirtualTimeScheduler, VirtualAction } from './internal/scheduler/VirtualTimeScheduler';\nexport { Scheduler } from './internal/Scheduler';\nexport { Subscription } from './internal/Subscription';\nexport { Subscriber } from './internal/Subscriber';\nexport { Notification, NotificationKind } from './internal/Notification';\nexport { pipe } from './internal/util/pipe';\nexport { noop } from './internal/util/noop';\nexport { identity } from './internal/util/identity';\nexport { isObservable } from './internal/util/isObservable';\nexport { ArgumentOutOfRangeError } from './internal/util/ArgumentOutOfRangeError';\nexport { EmptyError } from './internal/util/EmptyError';\nexport { ObjectUnsubscribedError } from './internal/util/ObjectUnsubscribedError';\nexport { UnsubscriptionError } from './internal/util/UnsubscriptionError';\nexport { TimeoutError } from './internal/util/TimeoutError';\nexport { bindCallback } from './internal/observable/bindCallback';\nexport { bindNodeCallback } from './internal/observable/bindNodeCallback';\nexport { combineLatest } from './internal/observable/combineLatest';\nexport { concat } from './internal/observable/concat';\nexport { defer } from './internal/observable/defer';\nexport { empty } from './internal/observable/empty';\nexport { forkJoin } from './internal/observable/forkJoin';\nexport { from } from './internal/observable/from';\nexport { fromEvent } from './internal/observable/fromEvent';\nexport { fromEventPattern } from './internal/observable/fromEventPattern';\nexport { generate } from './internal/observable/generate';\nexport { iif } from './internal/observable/iif';\nexport { interval } from './internal/observable/interval';\nexport { merge } from './internal/observable/merge';\nexport { never } from './internal/observable/never';\nexport { of } from './internal/observable/of';\nexport { onErrorResumeNext } from './internal/observable/onErrorResumeNext';\nexport { pairs } from './internal/observable/pairs';\nexport { partition } from './internal/observable/partition';\nexport { race } from './internal/observable/race';\nexport { range } from './internal/observable/range';\nexport { throwError } from './internal/observable/throwError';\nexport { timer } from './internal/observable/timer';\nexport { using } from './internal/observable/using';\nexport { zip } from './internal/observable/zip';\nexport { scheduled } from './internal/scheduled/scheduled';\nexport { EMPTY } from './internal/observable/empty';\nexport { NEVER } from './internal/observable/never';\nexport { config } from './internal/config';\n","'use strict';\n\nmodule.exports = {\n \"aliceblue\": [240, 248, 255],\n \"antiquewhite\": [250, 235, 215],\n \"aqua\": [0, 255, 255],\n \"aquamarine\": [127, 255, 212],\n \"azure\": [240, 255, 255],\n \"beige\": [245, 245, 220],\n \"bisque\": [255, 228, 196],\n \"black\": [0, 0, 0],\n \"blanchedalmond\": [255, 235, 205],\n \"blue\": [0, 0, 255],\n \"blueviolet\": [138, 43, 226],\n \"brown\": [165, 42, 42],\n \"burlywood\": [222, 184, 135],\n \"cadetblue\": [95, 158, 160],\n \"chartreuse\": [127, 255, 0],\n \"chocolate\": [210, 105, 30],\n \"coral\": [255, 127, 80],\n \"cornflowerblue\": [100, 149, 237],\n \"cornsilk\": [255, 248, 220],\n \"crimson\": [220, 20, 60],\n \"cyan\": [0, 255, 255],\n \"darkblue\": [0, 0, 139],\n \"darkcyan\": [0, 139, 139],\n \"darkgoldenrod\": [184, 134, 11],\n \"darkgray\": [169, 169, 169],\n \"darkgreen\": [0, 100, 0],\n \"darkgrey\": [169, 169, 169],\n \"darkkhaki\": [189, 183, 107],\n \"darkmagenta\": [139, 0, 139],\n \"darkolivegreen\": [85, 107, 47],\n \"darkorange\": [255, 140, 0],\n \"darkorchid\": [153, 50, 204],\n \"darkred\": [139, 0, 0],\n \"darksalmon\": [233, 150, 122],\n \"darkseagreen\": [143, 188, 143],\n \"darkslateblue\": [72, 61, 139],\n \"darkslategray\": [47, 79, 79],\n \"darkslategrey\": [47, 79, 79],\n \"darkturquoise\": [0, 206, 209],\n \"darkviolet\": [148, 0, 211],\n \"deeppink\": [255, 20, 147],\n \"deepskyblue\": [0, 191, 255],\n \"dimgray\": [105, 105, 105],\n \"dimgrey\": [105, 105, 105],\n \"dodgerblue\": [30, 144, 255],\n \"firebrick\": [178, 34, 34],\n \"floralwhite\": [255, 250, 240],\n \"forestgreen\": [34, 139, 34],\n \"fuchsia\": [255, 0, 255],\n \"gainsboro\": [220, 220, 220],\n \"ghostwhite\": [248, 248, 255],\n \"gold\": [255, 215, 0],\n \"goldenrod\": [218, 165, 32],\n \"gray\": [128, 128, 128],\n \"green\": [0, 128, 0],\n \"greenyellow\": [173, 255, 47],\n \"grey\": [128, 128, 128],\n \"honeydew\": [240, 255, 240],\n \"hotpink\": [255, 105, 180],\n \"indianred\": [205, 92, 92],\n \"indigo\": [75, 0, 130],\n \"ivory\": [255, 255, 240],\n \"khaki\": [240, 230, 140],\n \"lavender\": [230, 230, 250],\n \"lavenderblush\": [255, 240, 245],\n \"lawngreen\": [124, 252, 0],\n \"lemonchiffon\": [255, 250, 205],\n \"lightblue\": [173, 216, 230],\n \"lightcoral\": [240, 128, 128],\n \"lightcyan\": [224, 255, 255],\n \"lightgoldenrodyellow\": [250, 250, 210],\n \"lightgray\": [211, 211, 211],\n \"lightgreen\": [144, 238, 144],\n \"lightgrey\": [211, 211, 211],\n \"lightpink\": [255, 182, 193],\n \"lightsalmon\": [255, 160, 122],\n \"lightseagreen\": [32, 178, 170],\n \"lightskyblue\": [135, 206, 250],\n \"lightslategray\": [119, 136, 153],\n \"lightslategrey\": [119, 136, 153],\n \"lightsteelblue\": [176, 196, 222],\n \"lightyellow\": [255, 255, 224],\n \"lime\": [0, 255, 0],\n \"limegreen\": [50, 205, 50],\n \"linen\": [250, 240, 230],\n \"magenta\": [255, 0, 255],\n \"maroon\": [128, 0, 0],\n \"mediumaquamarine\": [102, 205, 170],\n \"mediumblue\": [0, 0, 205],\n \"mediumorchid\": [186, 85, 211],\n \"mediumpurple\": [147, 112, 219],\n \"mediumseagreen\": [60, 179, 113],\n \"mediumslateblue\": [123, 104, 238],\n \"mediumspringgreen\": [0, 250, 154],\n \"mediumturquoise\": [72, 209, 204],\n \"mediumvioletred\": [199, 21, 133],\n \"midnightblue\": [25, 25, 112],\n \"mintcream\": [245, 255, 250],\n \"mistyrose\": [255, 228, 225],\n \"moccasin\": [255, 228, 181],\n \"navajowhite\": [255, 222, 173],\n \"navy\": [0, 0, 128],\n \"oldlace\": [253, 245, 230],\n \"olive\": [128, 128, 0],\n \"olivedrab\": [107, 142, 35],\n \"orange\": [255, 165, 0],\n \"orangered\": [255, 69, 0],\n \"orchid\": [218, 112, 214],\n \"palegoldenrod\": [238, 232, 170],\n \"palegreen\": [152, 251, 152],\n \"paleturquoise\": [175, 238, 238],\n \"palevioletred\": [219, 112, 147],\n \"papayawhip\": [255, 239, 213],\n \"peachpuff\": [255, 218, 185],\n \"peru\": [205, 133, 63],\n \"pink\": [255, 192, 203],\n \"plum\": [221, 160, 221],\n \"powderblue\": [176, 224, 230],\n \"purple\": [128, 0, 128],\n \"rebeccapurple\": [102, 51, 153],\n \"red\": [255, 0, 0],\n \"rosybrown\": [188, 143, 143],\n \"royalblue\": [65, 105, 225],\n \"saddlebrown\": [139, 69, 19],\n \"salmon\": [250, 128, 114],\n \"sandybrown\": [244, 164, 96],\n \"seagreen\": [46, 139, 87],\n \"seashell\": [255, 245, 238],\n \"sienna\": [160, 82, 45],\n \"silver\": [192, 192, 192],\n \"skyblue\": [135, 206, 235],\n \"slateblue\": [106, 90, 205],\n \"slategray\": [112, 128, 144],\n \"slategrey\": [112, 128, 144],\n \"snow\": [255, 250, 250],\n \"springgreen\": [0, 255, 127],\n \"steelblue\": [70, 130, 180],\n \"tan\": [210, 180, 140],\n \"teal\": [0, 128, 128],\n \"thistle\": [216, 191, 216],\n \"tomato\": [255, 99, 71],\n \"turquoise\": [64, 224, 208],\n \"violet\": [238, 130, 238],\n \"wheat\": [245, 222, 179],\n \"white\": [255, 255, 255],\n \"whitesmoke\": [245, 245, 245],\n \"yellow\": [255, 255, 0],\n \"yellowgreen\": [154, 205, 50]\n};","/* MIT license */\n/* eslint-disable no-mixed-operators */\nconst cssKeywords = require('color-name');\n\n// NOTE: conversions should only return primitive values (i.e. arrays, or\n// values that give correct `typeof` results).\n// do not use box values types (i.e. Number(), String(), etc.)\n\nconst reverseKeywords = {};\nfor (const key of Object.keys(cssKeywords)) {\n reverseKeywords[cssKeywords[key]] = key;\n}\nconst convert = {\n rgb: {\n channels: 3,\n labels: 'rgb'\n },\n hsl: {\n channels: 3,\n labels: 'hsl'\n },\n hsv: {\n channels: 3,\n labels: 'hsv'\n },\n hwb: {\n channels: 3,\n labels: 'hwb'\n },\n cmyk: {\n channels: 4,\n labels: 'cmyk'\n },\n xyz: {\n channels: 3,\n labels: 'xyz'\n },\n lab: {\n channels: 3,\n labels: 'lab'\n },\n lch: {\n channels: 3,\n labels: 'lch'\n },\n hex: {\n channels: 1,\n labels: ['hex']\n },\n keyword: {\n channels: 1,\n labels: ['keyword']\n },\n ansi16: {\n channels: 1,\n labels: ['ansi16']\n },\n ansi256: {\n channels: 1,\n labels: ['ansi256']\n },\n hcg: {\n channels: 3,\n labels: ['h', 'c', 'g']\n },\n apple: {\n channels: 3,\n labels: ['r16', 'g16', 'b16']\n },\n gray: {\n channels: 1,\n labels: ['gray']\n }\n};\nmodule.exports = convert;\n\n// Hide .channels and .labels properties\nfor (const model of Object.keys(convert)) {\n if (!('channels' in convert[model])) {\n throw new Error('missing channels property: ' + model);\n }\n if (!('labels' in convert[model])) {\n throw new Error('missing channel labels property: ' + model);\n }\n if (convert[model].labels.length !== convert[model].channels) {\n throw new Error('channel and label counts mismatch: ' + model);\n }\n const {\n channels,\n labels\n } = convert[model];\n delete convert[model].channels;\n delete convert[model].labels;\n Object.defineProperty(convert[model], 'channels', {\n value: channels\n });\n Object.defineProperty(convert[model], 'labels', {\n value: labels\n });\n}\nconvert.rgb.hsl = function (rgb) {\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n const min = Math.min(r, g, b);\n const max = Math.max(r, g, b);\n const delta = max - min;\n let h;\n let s;\n if (max === min) {\n h = 0;\n } else if (r === max) {\n h = (g - b) / delta;\n } else if (g === max) {\n h = 2 + (b - r) / delta;\n } else if (b === max) {\n h = 4 + (r - g) / delta;\n }\n h = Math.min(h * 60, 360);\n if (h < 0) {\n h += 360;\n }\n const l = (min + max) / 2;\n if (max === min) {\n s = 0;\n } else if (l <= 0.5) {\n s = delta / (max + min);\n } else {\n s = delta / (2 - max - min);\n }\n return [h, s * 100, l * 100];\n};\nconvert.rgb.hsv = function (rgb) {\n let rdif;\n let gdif;\n let bdif;\n let h;\n let s;\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n const v = Math.max(r, g, b);\n const diff = v - Math.min(r, g, b);\n const diffc = function (c) {\n return (v - c) / 6 / diff + 1 / 2;\n };\n if (diff === 0) {\n h = 0;\n s = 0;\n } else {\n s = diff / v;\n rdif = diffc(r);\n gdif = diffc(g);\n bdif = diffc(b);\n if (r === v) {\n h = bdif - gdif;\n } else if (g === v) {\n h = 1 / 3 + rdif - bdif;\n } else if (b === v) {\n h = 2 / 3 + gdif - rdif;\n }\n if (h < 0) {\n h += 1;\n } else if (h > 1) {\n h -= 1;\n }\n }\n return [h * 360, s * 100, v * 100];\n};\nconvert.rgb.hwb = function (rgb) {\n const r = rgb[0];\n const g = rgb[1];\n let b = rgb[2];\n const h = convert.rgb.hsl(rgb)[0];\n const w = 1 / 255 * Math.min(r, Math.min(g, b));\n b = 1 - 1 / 255 * Math.max(r, Math.max(g, b));\n return [h, w * 100, b * 100];\n};\nconvert.rgb.cmyk = function (rgb) {\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n const k = Math.min(1 - r, 1 - g, 1 - b);\n const c = (1 - r - k) / (1 - k) || 0;\n const m = (1 - g - k) / (1 - k) || 0;\n const y = (1 - b - k) / (1 - k) || 0;\n return [c * 100, m * 100, y * 100, k * 100];\n};\nfunction comparativeDistance(x, y) {\n /*\n \tSee https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance\n */\n return (x[0] - y[0]) ** 2 + (x[1] - y[1]) ** 2 + (x[2] - y[2]) ** 2;\n}\nconvert.rgb.keyword = function (rgb) {\n const reversed = reverseKeywords[rgb];\n if (reversed) {\n return reversed;\n }\n let currentClosestDistance = Infinity;\n let currentClosestKeyword;\n for (const keyword of Object.keys(cssKeywords)) {\n const value = cssKeywords[keyword];\n\n // Compute comparative distance\n const distance = comparativeDistance(rgb, value);\n\n // Check if its less, if so set as closest\n if (distance < currentClosestDistance) {\n currentClosestDistance = distance;\n currentClosestKeyword = keyword;\n }\n }\n return currentClosestKeyword;\n};\nconvert.keyword.rgb = function (keyword) {\n return cssKeywords[keyword];\n};\nconvert.rgb.xyz = function (rgb) {\n let r = rgb[0] / 255;\n let g = rgb[1] / 255;\n let b = rgb[2] / 255;\n\n // Assume sRGB\n r = r > 0.04045 ? ((r + 0.055) / 1.055) ** 2.4 : r / 12.92;\n g = g > 0.04045 ? ((g + 0.055) / 1.055) ** 2.4 : g / 12.92;\n b = b > 0.04045 ? ((b + 0.055) / 1.055) ** 2.4 : b / 12.92;\n const x = r * 0.4124 + g * 0.3576 + b * 0.1805;\n const y = r * 0.2126 + g * 0.7152 + b * 0.0722;\n const z = r * 0.0193 + g * 0.1192 + b * 0.9505;\n return [x * 100, y * 100, z * 100];\n};\nconvert.rgb.lab = function (rgb) {\n const xyz = convert.rgb.xyz(rgb);\n let x = xyz[0];\n let y = xyz[1];\n let z = xyz[2];\n x /= 95.047;\n y /= 100;\n z /= 108.883;\n x = x > 0.008856 ? x ** (1 / 3) : 7.787 * x + 16 / 116;\n y = y > 0.008856 ? y ** (1 / 3) : 7.787 * y + 16 / 116;\n z = z > 0.008856 ? z ** (1 / 3) : 7.787 * z + 16 / 116;\n const l = 116 * y - 16;\n const a = 500 * (x - y);\n const b = 200 * (y - z);\n return [l, a, b];\n};\nconvert.hsl.rgb = function (hsl) {\n const h = hsl[0] / 360;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n let t2;\n let t3;\n let val;\n if (s === 0) {\n val = l * 255;\n return [val, val, val];\n }\n if (l < 0.5) {\n t2 = l * (1 + s);\n } else {\n t2 = l + s - l * s;\n }\n const t1 = 2 * l - t2;\n const rgb = [0, 0, 0];\n for (let i = 0; i < 3; i++) {\n t3 = h + 1 / 3 * -(i - 1);\n if (t3 < 0) {\n t3++;\n }\n if (t3 > 1) {\n t3--;\n }\n if (6 * t3 < 1) {\n val = t1 + (t2 - t1) * 6 * t3;\n } else if (2 * t3 < 1) {\n val = t2;\n } else if (3 * t3 < 2) {\n val = t1 + (t2 - t1) * (2 / 3 - t3) * 6;\n } else {\n val = t1;\n }\n rgb[i] = val * 255;\n }\n return rgb;\n};\nconvert.hsl.hsv = function (hsl) {\n const h = hsl[0];\n let s = hsl[1] / 100;\n let l = hsl[2] / 100;\n let smin = s;\n const lmin = Math.max(l, 0.01);\n l *= 2;\n s *= l <= 1 ? l : 2 - l;\n smin *= lmin <= 1 ? lmin : 2 - lmin;\n const v = (l + s) / 2;\n const sv = l === 0 ? 2 * smin / (lmin + smin) : 2 * s / (l + s);\n return [h, sv * 100, v * 100];\n};\nconvert.hsv.rgb = function (hsv) {\n const h = hsv[0] / 60;\n const s = hsv[1] / 100;\n let v = hsv[2] / 100;\n const hi = Math.floor(h) % 6;\n const f = h - Math.floor(h);\n const p = 255 * v * (1 - s);\n const q = 255 * v * (1 - s * f);\n const t = 255 * v * (1 - s * (1 - f));\n v *= 255;\n switch (hi) {\n case 0:\n return [v, t, p];\n case 1:\n return [q, v, p];\n case 2:\n return [p, v, t];\n case 3:\n return [p, q, v];\n case 4:\n return [t, p, v];\n case 5:\n return [v, p, q];\n }\n};\nconvert.hsv.hsl = function (hsv) {\n const h = hsv[0];\n const s = hsv[1] / 100;\n const v = hsv[2] / 100;\n const vmin = Math.max(v, 0.01);\n let sl;\n let l;\n l = (2 - s) * v;\n const lmin = (2 - s) * vmin;\n sl = s * vmin;\n sl /= lmin <= 1 ? lmin : 2 - lmin;\n sl = sl || 0;\n l /= 2;\n return [h, sl * 100, l * 100];\n};\n\n// http://dev.w3.org/csswg/css-color/#hwb-to-rgb\nconvert.hwb.rgb = function (hwb) {\n const h = hwb[0] / 360;\n let wh = hwb[1] / 100;\n let bl = hwb[2] / 100;\n const ratio = wh + bl;\n let f;\n\n // Wh + bl cant be > 1\n if (ratio > 1) {\n wh /= ratio;\n bl /= ratio;\n }\n const i = Math.floor(6 * h);\n const v = 1 - bl;\n f = 6 * h - i;\n if ((i & 0x01) !== 0) {\n f = 1 - f;\n }\n const n = wh + f * (v - wh); // Linear interpolation\n\n let r;\n let g;\n let b;\n /* eslint-disable max-statements-per-line,no-multi-spaces */\n switch (i) {\n default:\n case 6:\n case 0:\n r = v;\n g = n;\n b = wh;\n break;\n case 1:\n r = n;\n g = v;\n b = wh;\n break;\n case 2:\n r = wh;\n g = v;\n b = n;\n break;\n case 3:\n r = wh;\n g = n;\n b = v;\n break;\n case 4:\n r = n;\n g = wh;\n b = v;\n break;\n case 5:\n r = v;\n g = wh;\n b = n;\n break;\n }\n /* eslint-enable max-statements-per-line,no-multi-spaces */\n\n return [r * 255, g * 255, b * 255];\n};\nconvert.cmyk.rgb = function (cmyk) {\n const c = cmyk[0] / 100;\n const m = cmyk[1] / 100;\n const y = cmyk[2] / 100;\n const k = cmyk[3] / 100;\n const r = 1 - Math.min(1, c * (1 - k) + k);\n const g = 1 - Math.min(1, m * (1 - k) + k);\n const b = 1 - Math.min(1, y * (1 - k) + k);\n return [r * 255, g * 255, b * 255];\n};\nconvert.xyz.rgb = function (xyz) {\n const x = xyz[0] / 100;\n const y = xyz[1] / 100;\n const z = xyz[2] / 100;\n let r;\n let g;\n let b;\n r = x * 3.2406 + y * -1.5372 + z * -0.4986;\n g = x * -0.9689 + y * 1.8758 + z * 0.0415;\n b = x * 0.0557 + y * -0.2040 + z * 1.0570;\n\n // Assume sRGB\n r = r > 0.0031308 ? 1.055 * r ** (1.0 / 2.4) - 0.055 : r * 12.92;\n g = g > 0.0031308 ? 1.055 * g ** (1.0 / 2.4) - 0.055 : g * 12.92;\n b = b > 0.0031308 ? 1.055 * b ** (1.0 / 2.4) - 0.055 : b * 12.92;\n r = Math.min(Math.max(0, r), 1);\n g = Math.min(Math.max(0, g), 1);\n b = Math.min(Math.max(0, b), 1);\n return [r * 255, g * 255, b * 255];\n};\nconvert.xyz.lab = function (xyz) {\n let x = xyz[0];\n let y = xyz[1];\n let z = xyz[2];\n x /= 95.047;\n y /= 100;\n z /= 108.883;\n x = x > 0.008856 ? x ** (1 / 3) : 7.787 * x + 16 / 116;\n y = y > 0.008856 ? y ** (1 / 3) : 7.787 * y + 16 / 116;\n z = z > 0.008856 ? z ** (1 / 3) : 7.787 * z + 16 / 116;\n const l = 116 * y - 16;\n const a = 500 * (x - y);\n const b = 200 * (y - z);\n return [l, a, b];\n};\nconvert.lab.xyz = function (lab) {\n const l = lab[0];\n const a = lab[1];\n const b = lab[2];\n let x;\n let y;\n let z;\n y = (l + 16) / 116;\n x = a / 500 + y;\n z = y - b / 200;\n const y2 = y ** 3;\n const x2 = x ** 3;\n const z2 = z ** 3;\n y = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;\n x = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;\n z = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787;\n x *= 95.047;\n y *= 100;\n z *= 108.883;\n return [x, y, z];\n};\nconvert.lab.lch = function (lab) {\n const l = lab[0];\n const a = lab[1];\n const b = lab[2];\n let h;\n const hr = Math.atan2(b, a);\n h = hr * 360 / 2 / Math.PI;\n if (h < 0) {\n h += 360;\n }\n const c = Math.sqrt(a * a + b * b);\n return [l, c, h];\n};\nconvert.lch.lab = function (lch) {\n const l = lch[0];\n const c = lch[1];\n const h = lch[2];\n const hr = h / 360 * 2 * Math.PI;\n const a = c * Math.cos(hr);\n const b = c * Math.sin(hr);\n return [l, a, b];\n};\nconvert.rgb.ansi16 = function (args, saturation = null) {\n const [r, g, b] = args;\n let value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization\n\n value = Math.round(value / 50);\n if (value === 0) {\n return 30;\n }\n let ansi = 30 + (Math.round(b / 255) << 2 | Math.round(g / 255) << 1 | Math.round(r / 255));\n if (value === 2) {\n ansi += 60;\n }\n return ansi;\n};\nconvert.hsv.ansi16 = function (args) {\n // Optimization here; we already know the value and don't need to get\n // it converted for us.\n return convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);\n};\nconvert.rgb.ansi256 = function (args) {\n const r = args[0];\n const g = args[1];\n const b = args[2];\n\n // We use the extended greyscale palette here, with the exception of\n // black and white. normal palette only has 4 greyscale shades.\n if (r === g && g === b) {\n if (r < 8) {\n return 16;\n }\n if (r > 248) {\n return 231;\n }\n return Math.round((r - 8) / 247 * 24) + 232;\n }\n const ansi = 16 + 36 * Math.round(r / 255 * 5) + 6 * Math.round(g / 255 * 5) + Math.round(b / 255 * 5);\n return ansi;\n};\nconvert.ansi16.rgb = function (args) {\n let color = args % 10;\n\n // Handle greyscale\n if (color === 0 || color === 7) {\n if (args > 50) {\n color += 3.5;\n }\n color = color / 10.5 * 255;\n return [color, color, color];\n }\n const mult = (~~(args > 50) + 1) * 0.5;\n const r = (color & 1) * mult * 255;\n const g = (color >> 1 & 1) * mult * 255;\n const b = (color >> 2 & 1) * mult * 255;\n return [r, g, b];\n};\nconvert.ansi256.rgb = function (args) {\n // Handle greyscale\n if (args >= 232) {\n const c = (args - 232) * 10 + 8;\n return [c, c, c];\n }\n args -= 16;\n let rem;\n const r = Math.floor(args / 36) / 5 * 255;\n const g = Math.floor((rem = args % 36) / 6) / 5 * 255;\n const b = rem % 6 / 5 * 255;\n return [r, g, b];\n};\nconvert.rgb.hex = function (args) {\n const integer = ((Math.round(args[0]) & 0xFF) << 16) + ((Math.round(args[1]) & 0xFF) << 8) + (Math.round(args[2]) & 0xFF);\n const string = integer.toString(16).toUpperCase();\n return '000000'.substring(string.length) + string;\n};\nconvert.hex.rgb = function (args) {\n const match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);\n if (!match) {\n return [0, 0, 0];\n }\n let colorString = match[0];\n if (match[0].length === 3) {\n colorString = colorString.split('').map(char => {\n return char + char;\n }).join('');\n }\n const integer = parseInt(colorString, 16);\n const r = integer >> 16 & 0xFF;\n const g = integer >> 8 & 0xFF;\n const b = integer & 0xFF;\n return [r, g, b];\n};\nconvert.rgb.hcg = function (rgb) {\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n const max = Math.max(Math.max(r, g), b);\n const min = Math.min(Math.min(r, g), b);\n const chroma = max - min;\n let grayscale;\n let hue;\n if (chroma < 1) {\n grayscale = min / (1 - chroma);\n } else {\n grayscale = 0;\n }\n if (chroma <= 0) {\n hue = 0;\n } else if (max === r) {\n hue = (g - b) / chroma % 6;\n } else if (max === g) {\n hue = 2 + (b - r) / chroma;\n } else {\n hue = 4 + (r - g) / chroma;\n }\n hue /= 6;\n hue %= 1;\n return [hue * 360, chroma * 100, grayscale * 100];\n};\nconvert.hsl.hcg = function (hsl) {\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n const c = l < 0.5 ? 2.0 * s * l : 2.0 * s * (1.0 - l);\n let f = 0;\n if (c < 1.0) {\n f = (l - 0.5 * c) / (1.0 - c);\n }\n return [hsl[0], c * 100, f * 100];\n};\nconvert.hsv.hcg = function (hsv) {\n const s = hsv[1] / 100;\n const v = hsv[2] / 100;\n const c = s * v;\n let f = 0;\n if (c < 1.0) {\n f = (v - c) / (1 - c);\n }\n return [hsv[0], c * 100, f * 100];\n};\nconvert.hcg.rgb = function (hcg) {\n const h = hcg[0] / 360;\n const c = hcg[1] / 100;\n const g = hcg[2] / 100;\n if (c === 0.0) {\n return [g * 255, g * 255, g * 255];\n }\n const pure = [0, 0, 0];\n const hi = h % 1 * 6;\n const v = hi % 1;\n const w = 1 - v;\n let mg = 0;\n\n /* eslint-disable max-statements-per-line */\n switch (Math.floor(hi)) {\n case 0:\n pure[0] = 1;\n pure[1] = v;\n pure[2] = 0;\n break;\n case 1:\n pure[0] = w;\n pure[1] = 1;\n pure[2] = 0;\n break;\n case 2:\n pure[0] = 0;\n pure[1] = 1;\n pure[2] = v;\n break;\n case 3:\n pure[0] = 0;\n pure[1] = w;\n pure[2] = 1;\n break;\n case 4:\n pure[0] = v;\n pure[1] = 0;\n pure[2] = 1;\n break;\n default:\n pure[0] = 1;\n pure[1] = 0;\n pure[2] = w;\n }\n /* eslint-enable max-statements-per-line */\n\n mg = (1.0 - c) * g;\n return [(c * pure[0] + mg) * 255, (c * pure[1] + mg) * 255, (c * pure[2] + mg) * 255];\n};\nconvert.hcg.hsv = function (hcg) {\n const c = hcg[1] / 100;\n const g = hcg[2] / 100;\n const v = c + g * (1.0 - c);\n let f = 0;\n if (v > 0.0) {\n f = c / v;\n }\n return [hcg[0], f * 100, v * 100];\n};\nconvert.hcg.hsl = function (hcg) {\n const c = hcg[1] / 100;\n const g = hcg[2] / 100;\n const l = g * (1.0 - c) + 0.5 * c;\n let s = 0;\n if (l > 0.0 && l < 0.5) {\n s = c / (2 * l);\n } else if (l >= 0.5 && l < 1.0) {\n s = c / (2 * (1 - l));\n }\n return [hcg[0], s * 100, l * 100];\n};\nconvert.hcg.hwb = function (hcg) {\n const c = hcg[1] / 100;\n const g = hcg[2] / 100;\n const v = c + g * (1.0 - c);\n return [hcg[0], (v - c) * 100, (1 - v) * 100];\n};\nconvert.hwb.hcg = function (hwb) {\n const w = hwb[1] / 100;\n const b = hwb[2] / 100;\n const v = 1 - b;\n const c = v - w;\n let g = 0;\n if (c < 1) {\n g = (v - c) / (1 - c);\n }\n return [hwb[0], c * 100, g * 100];\n};\nconvert.apple.rgb = function (apple) {\n return [apple[0] / 65535 * 255, apple[1] / 65535 * 255, apple[2] / 65535 * 255];\n};\nconvert.rgb.apple = function (rgb) {\n return [rgb[0] / 255 * 65535, rgb[1] / 255 * 65535, rgb[2] / 255 * 65535];\n};\nconvert.gray.rgb = function (args) {\n return [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];\n};\nconvert.gray.hsl = function (args) {\n return [0, 0, args[0]];\n};\nconvert.gray.hsv = convert.gray.hsl;\nconvert.gray.hwb = function (gray) {\n return [0, 100, gray[0]];\n};\nconvert.gray.cmyk = function (gray) {\n return [0, 0, 0, gray[0]];\n};\nconvert.gray.lab = function (gray) {\n return [gray[0], 0, 0];\n};\nconvert.gray.hex = function (gray) {\n const val = Math.round(gray[0] / 100 * 255) & 0xFF;\n const integer = (val << 16) + (val << 8) + val;\n const string = integer.toString(16).toUpperCase();\n return '000000'.substring(string.length) + string;\n};\nconvert.rgb.gray = function (rgb) {\n const val = (rgb[0] + rgb[1] + rgb[2]) / 3;\n return [val / 255 * 100];\n};","const conversions = require('./conversions');\n\n/*\n\tThis function routes a model to all other models.\n\n\tall functions that are routed have a property `.conversion` attached\n\tto the returned synthetic function. This property is an array\n\tof strings, each with the steps in between the 'from' and 'to'\n\tcolor models (inclusive).\n\n\tconversions that are not possible simply are not included.\n*/\n\nfunction buildGraph() {\n const graph = {};\n // https://jsperf.com/object-keys-vs-for-in-with-closure/3\n const models = Object.keys(conversions);\n for (let len = models.length, i = 0; i < len; i++) {\n graph[models[i]] = {\n // http://jsperf.com/1-vs-infinity\n // micro-opt, but this is simple.\n distance: -1,\n parent: null\n };\n }\n return graph;\n}\n\n// https://en.wikipedia.org/wiki/Breadth-first_search\nfunction deriveBFS(fromModel) {\n const graph = buildGraph();\n const queue = [fromModel]; // Unshift -> queue -> pop\n\n graph[fromModel].distance = 0;\n while (queue.length) {\n const current = queue.pop();\n const adjacents = Object.keys(conversions[current]);\n for (let len = adjacents.length, i = 0; i < len; i++) {\n const adjacent = adjacents[i];\n const node = graph[adjacent];\n if (node.distance === -1) {\n node.distance = graph[current].distance + 1;\n node.parent = current;\n queue.unshift(adjacent);\n }\n }\n }\n return graph;\n}\nfunction link(from, to) {\n return function (args) {\n return to(from(args));\n };\n}\nfunction wrapConversion(toModel, graph) {\n const path = [graph[toModel].parent, toModel];\n let fn = conversions[graph[toModel].parent][toModel];\n let cur = graph[toModel].parent;\n while (graph[cur].parent) {\n path.unshift(graph[cur].parent);\n fn = link(conversions[graph[cur].parent][cur], fn);\n cur = graph[cur].parent;\n }\n fn.conversion = path;\n return fn;\n}\nmodule.exports = function (fromModel) {\n const graph = deriveBFS(fromModel);\n const conversion = {};\n const models = Object.keys(graph);\n for (let len = models.length, i = 0; i < len; i++) {\n const toModel = models[i];\n const node = graph[toModel];\n if (node.parent === null) {\n // No possible conversion, or this node is the source model.\n continue;\n }\n conversion[toModel] = wrapConversion(toModel, graph);\n }\n return conversion;\n};","const conversions = require('./conversions');\nconst route = require('./route');\nconst convert = {};\nconst models = Object.keys(conversions);\nfunction wrapRaw(fn) {\n const wrappedFn = function (...args) {\n const arg0 = args[0];\n if (arg0 === undefined || arg0 === null) {\n return arg0;\n }\n if (arg0.length > 1) {\n args = arg0;\n }\n return fn(args);\n };\n\n // Preserve .conversion property if there is one\n if ('conversion' in fn) {\n wrappedFn.conversion = fn.conversion;\n }\n return wrappedFn;\n}\nfunction wrapRounded(fn) {\n const wrappedFn = function (...args) {\n const arg0 = args[0];\n if (arg0 === undefined || arg0 === null) {\n return arg0;\n }\n if (arg0.length > 1) {\n args = arg0;\n }\n const result = fn(args);\n\n // We're assuming the result is an array here.\n // see notice in conversions.js; don't use box types\n // in conversion functions.\n if (typeof result === 'object') {\n for (let len = result.length, i = 0; i < len; i++) {\n result[i] = Math.round(result[i]);\n }\n }\n return result;\n };\n\n // Preserve .conversion property if there is one\n if ('conversion' in fn) {\n wrappedFn.conversion = fn.conversion;\n }\n return wrappedFn;\n}\nmodels.forEach(fromModel => {\n convert[fromModel] = {};\n Object.defineProperty(convert[fromModel], 'channels', {\n value: conversions[fromModel].channels\n });\n Object.defineProperty(convert[fromModel], 'labels', {\n value: conversions[fromModel].labels\n });\n const routes = route(fromModel);\n const routeModels = Object.keys(routes);\n routeModels.forEach(toModel => {\n const fn = routes[toModel];\n convert[fromModel][toModel] = wrapRounded(fn);\n convert[fromModel][toModel].raw = wrapRaw(fn);\n });\n});\nmodule.exports = convert;","'use strict';\n\nconst wrapAnsi16 = (fn, offset) => (...args) => {\n const code = fn(...args);\n return `\\u001B[${code + offset}m`;\n};\nconst wrapAnsi256 = (fn, offset) => (...args) => {\n const code = fn(...args);\n return `\\u001B[${38 + offset};5;${code}m`;\n};\nconst wrapAnsi16m = (fn, offset) => (...args) => {\n const rgb = fn(...args);\n return `\\u001B[${38 + offset};2;${rgb[0]};${rgb[1]};${rgb[2]}m`;\n};\nconst ansi2ansi = n => n;\nconst rgb2rgb = (r, g, b) => [r, g, b];\nconst setLazyProperty = (object, property, get) => {\n Object.defineProperty(object, property, {\n get: () => {\n const value = get();\n Object.defineProperty(object, property, {\n value,\n enumerable: true,\n configurable: true\n });\n return value;\n },\n enumerable: true,\n configurable: true\n });\n};\n\n/** @type {typeof import('color-convert')} */\nlet colorConvert;\nconst makeDynamicStyles = (wrap, targetSpace, identity, isBackground) => {\n if (colorConvert === undefined) {\n colorConvert = require('color-convert');\n }\n const offset = isBackground ? 10 : 0;\n const styles = {};\n for (const [sourceSpace, suite] of Object.entries(colorConvert)) {\n const name = sourceSpace === 'ansi16' ? 'ansi' : sourceSpace;\n if (sourceSpace === targetSpace) {\n styles[name] = wrap(identity, offset);\n } else if (typeof suite === 'object') {\n styles[name] = wrap(suite[targetSpace], offset);\n }\n }\n return styles;\n};\nfunction assembleStyles() {\n const codes = new Map();\n const styles = {\n modifier: {\n reset: [0, 0],\n // 21 isn't widely supported and 22 does the same thing\n bold: [1, 22],\n dim: [2, 22],\n italic: [3, 23],\n underline: [4, 24],\n inverse: [7, 27],\n hidden: [8, 28],\n strikethrough: [9, 29]\n },\n color: {\n black: [30, 39],\n red: [31, 39],\n green: [32, 39],\n yellow: [33, 39],\n blue: [34, 39],\n magenta: [35, 39],\n cyan: [36, 39],\n white: [37, 39],\n // Bright color\n blackBright: [90, 39],\n redBright: [91, 39],\n greenBright: [92, 39],\n yellowBright: [93, 39],\n blueBright: [94, 39],\n magentaBright: [95, 39],\n cyanBright: [96, 39],\n whiteBright: [97, 39]\n },\n bgColor: {\n bgBlack: [40, 49],\n bgRed: [41, 49],\n bgGreen: [42, 49],\n bgYellow: [43, 49],\n bgBlue: [44, 49],\n bgMagenta: [45, 49],\n bgCyan: [46, 49],\n bgWhite: [47, 49],\n // Bright color\n bgBlackBright: [100, 49],\n bgRedBright: [101, 49],\n bgGreenBright: [102, 49],\n bgYellowBright: [103, 49],\n bgBlueBright: [104, 49],\n bgMagentaBright: [105, 49],\n bgCyanBright: [106, 49],\n bgWhiteBright: [107, 49]\n }\n };\n\n // Alias bright black as gray (and grey)\n styles.color.gray = styles.color.blackBright;\n styles.bgColor.bgGray = styles.bgColor.bgBlackBright;\n styles.color.grey = styles.color.blackBright;\n styles.bgColor.bgGrey = styles.bgColor.bgBlackBright;\n for (const [groupName, group] of Object.entries(styles)) {\n for (const [styleName, style] of Object.entries(group)) {\n styles[styleName] = {\n open: `\\u001B[${style[0]}m`,\n close: `\\u001B[${style[1]}m`\n };\n group[styleName] = styles[styleName];\n codes.set(style[0], style[1]);\n }\n Object.defineProperty(styles, groupName, {\n value: group,\n enumerable: false\n });\n }\n Object.defineProperty(styles, 'codes', {\n value: codes,\n enumerable: false\n });\n styles.color.close = '\\u001B[39m';\n styles.bgColor.close = '\\u001B[49m';\n setLazyProperty(styles.color, 'ansi', () => makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, false));\n setLazyProperty(styles.color, 'ansi256', () => makeDynamicStyles(wrapAnsi256, 'ansi256', ansi2ansi, false));\n setLazyProperty(styles.color, 'ansi16m', () => makeDynamicStyles(wrapAnsi16m, 'rgb', rgb2rgb, false));\n setLazyProperty(styles.bgColor, 'ansi', () => makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, true));\n setLazyProperty(styles.bgColor, 'ansi256', () => makeDynamicStyles(wrapAnsi256, 'ansi256', ansi2ansi, true));\n setLazyProperty(styles.bgColor, 'ansi16m', () => makeDynamicStyles(wrapAnsi16m, 'rgb', rgb2rgb, true));\n return styles;\n}\n\n// Make the export immutable\nObject.defineProperty(module, 'exports', {\n enumerable: true,\n get: assembleStyles\n});","'use strict';\n\nmodule.exports = {\n stdout: false,\n stderr: false\n};","'use strict';\n\nconst stringReplaceAll = (string, substring, replacer) => {\n let index = string.indexOf(substring);\n if (index === -1) {\n return string;\n }\n const substringLength = substring.length;\n let endIndex = 0;\n let returnValue = '';\n do {\n returnValue += string.substr(endIndex, index - endIndex) + substring + replacer;\n endIndex = index + substringLength;\n index = string.indexOf(substring, endIndex);\n } while (index !== -1);\n returnValue += string.substr(endIndex);\n return returnValue;\n};\nconst stringEncaseCRLFWithFirstIndex = (string, prefix, postfix, index) => {\n let endIndex = 0;\n let returnValue = '';\n do {\n const gotCR = string[index - 1] === '\\r';\n returnValue += string.substr(endIndex, (gotCR ? index - 1 : index) - endIndex) + prefix + (gotCR ? '\\r\\n' : '\\n') + postfix;\n endIndex = index + 1;\n index = string.indexOf('\\n', endIndex);\n } while (index !== -1);\n returnValue += string.substr(endIndex);\n return returnValue;\n};\nmodule.exports = {\n stringReplaceAll,\n stringEncaseCRLFWithFirstIndex\n};","'use strict';\n\nconst TEMPLATE_REGEX = /(?:\\\\(u(?:[a-f\\d]{4}|\\{[a-f\\d]{1,6}\\})|x[a-f\\d]{2}|.))|(?:\\{(~)?(\\w+(?:\\([^)]*\\))?(?:\\.\\w+(?:\\([^)]*\\))?)*)(?:[ \\t]|(?=\\r?\\n)))|(\\})|((?:.|[\\r\\n\\f])+?)/gi;\nconst STYLE_REGEX = /(?:^|\\.)(\\w+)(?:\\(([^)]*)\\))?/g;\nconst STRING_REGEX = /^(['\"])((?:\\\\.|(?!\\1)[^\\\\])*)\\1$/;\nconst ESCAPE_REGEX = /\\\\(u(?:[a-f\\d]{4}|{[a-f\\d]{1,6}})|x[a-f\\d]{2}|.)|([^\\\\])/gi;\nconst ESCAPES = new Map([['n', '\\n'], ['r', '\\r'], ['t', '\\t'], ['b', '\\b'], ['f', '\\f'], ['v', '\\v'], ['0', '\\0'], ['\\\\', '\\\\'], ['e', '\\u001B'], ['a', '\\u0007']]);\nfunction unescape(c) {\n const u = c[0] === 'u';\n const bracket = c[1] === '{';\n if (u && !bracket && c.length === 5 || c[0] === 'x' && c.length === 3) {\n return String.fromCharCode(parseInt(c.slice(1), 16));\n }\n if (u && bracket) {\n return String.fromCodePoint(parseInt(c.slice(2, -1), 16));\n }\n return ESCAPES.get(c) || c;\n}\nfunction parseArguments(name, arguments_) {\n const results = [];\n const chunks = arguments_.trim().split(/\\s*,\\s*/g);\n let matches;\n for (const chunk of chunks) {\n const number = Number(chunk);\n if (!Number.isNaN(number)) {\n results.push(number);\n } else if (matches = chunk.match(STRING_REGEX)) {\n results.push(matches[2].replace(ESCAPE_REGEX, (m, escape, character) => escape ? unescape(escape) : character));\n } else {\n throw new Error(`Invalid Chalk template style argument: ${chunk} (in style '${name}')`);\n }\n }\n return results;\n}\nfunction parseStyle(style) {\n STYLE_REGEX.lastIndex = 0;\n const results = [];\n let matches;\n while ((matches = STYLE_REGEX.exec(style)) !== null) {\n const name = matches[1];\n if (matches[2]) {\n const args = parseArguments(name, matches[2]);\n results.push([name].concat(args));\n } else {\n results.push([name]);\n }\n }\n return results;\n}\nfunction buildStyle(chalk, styles) {\n const enabled = {};\n for (const layer of styles) {\n for (const style of layer.styles) {\n enabled[style[0]] = layer.inverse ? null : style.slice(1);\n }\n }\n let current = chalk;\n for (const [styleName, styles] of Object.entries(enabled)) {\n if (!Array.isArray(styles)) {\n continue;\n }\n if (!(styleName in current)) {\n throw new Error(`Unknown Chalk style: ${styleName}`);\n }\n current = styles.length > 0 ? current[styleName](...styles) : current[styleName];\n }\n return current;\n}\nmodule.exports = (chalk, temporary) => {\n const styles = [];\n const chunks = [];\n let chunk = [];\n\n // eslint-disable-next-line max-params\n temporary.replace(TEMPLATE_REGEX, (m, escapeCharacter, inverse, style, close, character) => {\n if (escapeCharacter) {\n chunk.push(unescape(escapeCharacter));\n } else if (style) {\n const string = chunk.join('');\n chunk = [];\n chunks.push(styles.length === 0 ? string : buildStyle(chalk, styles)(string));\n styles.push({\n inverse,\n styles: parseStyle(style)\n });\n } else if (close) {\n if (styles.length === 0) {\n throw new Error('Found extraneous } in Chalk template literal');\n }\n chunks.push(buildStyle(chalk, styles)(chunk.join('')));\n chunk = [];\n styles.pop();\n } else {\n chunk.push(character);\n }\n });\n chunks.push(chunk.join(''));\n if (styles.length > 0) {\n const errMessage = `Chalk template literal is missing ${styles.length} closing bracket${styles.length === 1 ? '' : 's'} (\\`}\\`)`;\n throw new Error(errMessage);\n }\n return chunks.join('');\n};","'use strict';\n\nconst ansiStyles = require('ansi-styles');\nconst {\n stdout: stdoutColor,\n stderr: stderrColor\n} = require('supports-color');\nconst {\n stringReplaceAll,\n stringEncaseCRLFWithFirstIndex\n} = require('./util');\nconst {\n isArray\n} = Array;\n\n// `supportsColor.level` → `ansiStyles.color[name]` mapping\nconst levelMapping = ['ansi', 'ansi', 'ansi256', 'ansi16m'];\nconst styles = Object.create(null);\nconst applyOptions = (object, options = {}) => {\n if (options.level && !(Number.isInteger(options.level) && options.level >= 0 && options.level <= 3)) {\n throw new Error('The `level` option should be an integer from 0 to 3');\n }\n\n // Detect level if not set manually\n const colorLevel = stdoutColor ? stdoutColor.level : 0;\n object.level = options.level === undefined ? colorLevel : options.level;\n};\nclass ChalkClass {\n constructor(options) {\n // eslint-disable-next-line no-constructor-return\n return chalkFactory(options);\n }\n}\nconst chalkFactory = options => {\n const chalk = {};\n applyOptions(chalk, options);\n chalk.template = (...arguments_) => chalkTag(chalk.template, ...arguments_);\n Object.setPrototypeOf(chalk, Chalk.prototype);\n Object.setPrototypeOf(chalk.template, chalk);\n chalk.template.constructor = () => {\n throw new Error('`chalk.constructor()` is deprecated. Use `new chalk.Instance()` instead.');\n };\n chalk.template.Instance = ChalkClass;\n return chalk.template;\n};\nfunction Chalk(options) {\n return chalkFactory(options);\n}\nfor (const [styleName, style] of Object.entries(ansiStyles)) {\n styles[styleName] = {\n get() {\n const builder = createBuilder(this, createStyler(style.open, style.close, this._styler), this._isEmpty);\n Object.defineProperty(this, styleName, {\n value: builder\n });\n return builder;\n }\n };\n}\nstyles.visible = {\n get() {\n const builder = createBuilder(this, this._styler, true);\n Object.defineProperty(this, 'visible', {\n value: builder\n });\n return builder;\n }\n};\nconst usedModels = ['rgb', 'hex', 'keyword', 'hsl', 'hsv', 'hwb', 'ansi', 'ansi256'];\nfor (const model of usedModels) {\n styles[model] = {\n get() {\n const {\n level\n } = this;\n return function (...arguments_) {\n const styler = createStyler(ansiStyles.color[levelMapping[level]][model](...arguments_), ansiStyles.color.close, this._styler);\n return createBuilder(this, styler, this._isEmpty);\n };\n }\n };\n}\nfor (const model of usedModels) {\n const bgModel = 'bg' + model[0].toUpperCase() + model.slice(1);\n styles[bgModel] = {\n get() {\n const {\n level\n } = this;\n return function (...arguments_) {\n const styler = createStyler(ansiStyles.bgColor[levelMapping[level]][model](...arguments_), ansiStyles.bgColor.close, this._styler);\n return createBuilder(this, styler, this._isEmpty);\n };\n }\n };\n}\nconst proto = Object.defineProperties(() => {}, {\n ...styles,\n level: {\n enumerable: true,\n get() {\n return this._generator.level;\n },\n set(level) {\n this._generator.level = level;\n }\n }\n});\nconst createStyler = (open, close, parent) => {\n let openAll;\n let closeAll;\n if (parent === undefined) {\n openAll = open;\n closeAll = close;\n } else {\n openAll = parent.openAll + open;\n closeAll = close + parent.closeAll;\n }\n return {\n open,\n close,\n openAll,\n closeAll,\n parent\n };\n};\nconst createBuilder = (self, _styler, _isEmpty) => {\n const builder = (...arguments_) => {\n if (isArray(arguments_[0]) && isArray(arguments_[0].raw)) {\n // Called as a template literal, for example: chalk.red`2 + 3 = {bold ${2+3}}`\n return applyStyle(builder, chalkTag(builder, ...arguments_));\n }\n\n // Single argument is hot path, implicit coercion is faster than anything\n // eslint-disable-next-line no-implicit-coercion\n return applyStyle(builder, arguments_.length === 1 ? '' + arguments_[0] : arguments_.join(' '));\n };\n\n // We alter the prototype because we must return a function, but there is\n // no way to create a function with a different prototype\n Object.setPrototypeOf(builder, proto);\n builder._generator = self;\n builder._styler = _styler;\n builder._isEmpty = _isEmpty;\n return builder;\n};\nconst applyStyle = (self, string) => {\n if (self.level <= 0 || !string) {\n return self._isEmpty ? '' : string;\n }\n let styler = self._styler;\n if (styler === undefined) {\n return string;\n }\n const {\n openAll,\n closeAll\n } = styler;\n if (string.indexOf('\\u001B') !== -1) {\n while (styler !== undefined) {\n // Replace any instances already present with a re-opening code\n // otherwise only the part of the string until said closing code\n // will be colored, and the rest will simply be 'plain'.\n string = stringReplaceAll(string, styler.close, styler.open);\n styler = styler.parent;\n }\n }\n\n // We can move both next actions out of loop, because remaining actions in loop won't have\n // any/visible effect on parts we add here. Close the styling before a linebreak and reopen\n // after next line to fix a bleed issue on macOS: https://github.com/chalk/chalk/pull/92\n const lfIndex = string.indexOf('\\n');\n if (lfIndex !== -1) {\n string = stringEncaseCRLFWithFirstIndex(string, closeAll, openAll, lfIndex);\n }\n return openAll + string + closeAll;\n};\nlet template;\nconst chalkTag = (chalk, ...strings) => {\n const [firstString] = strings;\n if (!isArray(firstString) || !isArray(firstString.raw)) {\n // If chalk() was called by itself or with a string,\n // return the string itself as a string.\n return strings.join(' ');\n }\n const arguments_ = strings.slice(1);\n const parts = [firstString.raw[0]];\n for (let i = 1; i < firstString.length; i++) {\n parts.push(String(arguments_[i - 1]).replace(/[{}\\\\]/g, '\\\\$&'), String(firstString.raw[i]));\n }\n if (template === undefined) {\n template = require('./templates');\n }\n return template(chalk, parts.join(''));\n};\nObject.defineProperties(Chalk.prototype, styles);\nconst chalk = Chalk(); // eslint-disable-line new-cap\nchalk.supportsColor = stdoutColor;\nchalk.stderr = Chalk({\n level: stderrColor ? stderrColor.level : 0\n}); // eslint-disable-line new-cap\nchalk.stderr.supportsColor = stderrColor;\nmodule.exports = chalk;","export const version = \"abstract-provider/5.7.0\";\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { isHexString } from \"@ethersproject/bytes\";\nimport { Description, defineReadOnly, resolveProperties } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n;\n;\n//export type CallTransactionable = {\n// call(transaction: TransactionRequest): Promise;\n//};\nexport class ForkEvent extends Description {\n static isForkEvent(value) {\n return !!(value && value._isForkEvent);\n }\n}\nexport class BlockForkEvent extends ForkEvent {\n constructor(blockHash, expiry) {\n if (!isHexString(blockHash, 32)) {\n logger.throwArgumentError(\"invalid blockHash\", \"blockHash\", blockHash);\n }\n super({\n _isForkEvent: true,\n _isBlockForkEvent: true,\n expiry: expiry || 0,\n blockHash: blockHash\n });\n }\n}\nexport class TransactionForkEvent extends ForkEvent {\n constructor(hash, expiry) {\n if (!isHexString(hash, 32)) {\n logger.throwArgumentError(\"invalid transaction hash\", \"hash\", hash);\n }\n super({\n _isForkEvent: true,\n _isTransactionForkEvent: true,\n expiry: expiry || 0,\n hash: hash\n });\n }\n}\nexport class TransactionOrderForkEvent extends ForkEvent {\n constructor(beforeHash, afterHash, expiry) {\n if (!isHexString(beforeHash, 32)) {\n logger.throwArgumentError(\"invalid transaction hash\", \"beforeHash\", beforeHash);\n }\n if (!isHexString(afterHash, 32)) {\n logger.throwArgumentError(\"invalid transaction hash\", \"afterHash\", afterHash);\n }\n super({\n _isForkEvent: true,\n _isTransactionOrderForkEvent: true,\n expiry: expiry || 0,\n beforeHash: beforeHash,\n afterHash: afterHash\n });\n }\n}\n///////////////////////////////\n// Exported Abstracts\nexport class Provider {\n constructor() {\n logger.checkAbstract(new.target, Provider);\n defineReadOnly(this, \"_isProvider\", true);\n }\n getFeeData() {\n return __awaiter(this, void 0, void 0, function* () {\n const {\n block,\n gasPrice\n } = yield resolveProperties({\n block: this.getBlock(\"latest\"),\n gasPrice: this.getGasPrice().catch(error => {\n // @TODO: Why is this now failing on Calaveras?\n //console.log(error);\n return null;\n })\n });\n let lastBaseFeePerGas = null,\n maxFeePerGas = null,\n maxPriorityFeePerGas = null;\n if (block && block.baseFeePerGas) {\n // We may want to compute this more accurately in the future,\n // using the formula \"check if the base fee is correct\".\n // See: https://eips.ethereum.org/EIPS/eip-1559\n lastBaseFeePerGas = block.baseFeePerGas;\n maxPriorityFeePerGas = BigNumber.from(\"1500000000\");\n maxFeePerGas = block.baseFeePerGas.mul(2).add(maxPriorityFeePerGas);\n }\n return {\n lastBaseFeePerGas,\n maxFeePerGas,\n maxPriorityFeePerGas,\n gasPrice\n };\n });\n }\n // Alias for \"on\"\n addListener(eventName, listener) {\n return this.on(eventName, listener);\n }\n // Alias for \"off\"\n removeListener(eventName, listener) {\n return this.off(eventName, listener);\n }\n static isProvider(value) {\n return !!(value && value._isProvider);\n }\n}\n","export const version = \"networks/5.7.1\";\n","\"use strict\";\n\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n;\nfunction isRenetworkable(value) {\n return value && typeof value.renetwork === \"function\";\n}\nfunction ethDefaultProvider(network) {\n const func = function (providers, options) {\n if (options == null) {\n options = {};\n }\n const providerList = [];\n if (providers.InfuraProvider && options.infura !== \"-\") {\n try {\n providerList.push(new providers.InfuraProvider(network, options.infura));\n } catch (error) {}\n }\n if (providers.EtherscanProvider && options.etherscan !== \"-\") {\n try {\n providerList.push(new providers.EtherscanProvider(network, options.etherscan));\n } catch (error) {}\n }\n if (providers.AlchemyProvider && options.alchemy !== \"-\") {\n try {\n providerList.push(new providers.AlchemyProvider(network, options.alchemy));\n } catch (error) {}\n }\n if (providers.PocketProvider && options.pocket !== \"-\") {\n // These networks are currently faulty on Pocket as their\n // network does not handle the Berlin hardfork, which is\n // live on these ones.\n // @TODO: This goes away once Pocket has upgraded their nodes\n const skip = [\"goerli\", \"ropsten\", \"rinkeby\", \"sepolia\"];\n try {\n const provider = new providers.PocketProvider(network, options.pocket);\n if (provider.network && skip.indexOf(provider.network.name) === -1) {\n providerList.push(provider);\n }\n } catch (error) {}\n }\n if (providers.CloudflareProvider && options.cloudflare !== \"-\") {\n try {\n providerList.push(new providers.CloudflareProvider(network));\n } catch (error) {}\n }\n if (providers.AnkrProvider && options.ankr !== \"-\") {\n try {\n const skip = [\"ropsten\"];\n const provider = new providers.AnkrProvider(network, options.ankr);\n if (provider.network && skip.indexOf(provider.network.name) === -1) {\n providerList.push(provider);\n }\n } catch (error) {}\n }\n if (providerList.length === 0) {\n return null;\n }\n if (providers.FallbackProvider) {\n let quorum = 1;\n if (options.quorum != null) {\n quorum = options.quorum;\n } else if (network === \"homestead\") {\n quorum = 2;\n }\n return new providers.FallbackProvider(providerList, quorum);\n }\n return providerList[0];\n };\n func.renetwork = function (network) {\n return ethDefaultProvider(network);\n };\n return func;\n}\nfunction etcDefaultProvider(url, network) {\n const func = function (providers, options) {\n if (providers.JsonRpcProvider) {\n return new providers.JsonRpcProvider(url, network);\n }\n return null;\n };\n func.renetwork = function (network) {\n return etcDefaultProvider(url, network);\n };\n return func;\n}\nconst homestead = {\n chainId: 1,\n ensAddress: \"0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e\",\n name: \"homestead\",\n _defaultProvider: ethDefaultProvider(\"homestead\")\n};\nconst ropsten = {\n chainId: 3,\n ensAddress: \"0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e\",\n name: \"ropsten\",\n _defaultProvider: ethDefaultProvider(\"ropsten\")\n};\nconst classicMordor = {\n chainId: 63,\n name: \"classicMordor\",\n _defaultProvider: etcDefaultProvider(\"https://www.ethercluster.com/mordor\", \"classicMordor\")\n};\n// See: https://chainlist.org\nconst networks = {\n unspecified: {\n chainId: 0,\n name: \"unspecified\"\n },\n homestead: homestead,\n mainnet: homestead,\n morden: {\n chainId: 2,\n name: \"morden\"\n },\n ropsten: ropsten,\n testnet: ropsten,\n rinkeby: {\n chainId: 4,\n ensAddress: \"0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e\",\n name: \"rinkeby\",\n _defaultProvider: ethDefaultProvider(\"rinkeby\")\n },\n kovan: {\n chainId: 42,\n name: \"kovan\",\n _defaultProvider: ethDefaultProvider(\"kovan\")\n },\n goerli: {\n chainId: 5,\n ensAddress: \"0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e\",\n name: \"goerli\",\n _defaultProvider: ethDefaultProvider(\"goerli\")\n },\n kintsugi: {\n chainId: 1337702,\n name: \"kintsugi\"\n },\n sepolia: {\n chainId: 11155111,\n name: \"sepolia\",\n _defaultProvider: ethDefaultProvider(\"sepolia\")\n },\n // ETC (See: #351)\n classic: {\n chainId: 61,\n name: \"classic\",\n _defaultProvider: etcDefaultProvider(\"https:/\\/www.ethercluster.com/etc\", \"classic\")\n },\n classicMorden: {\n chainId: 62,\n name: \"classicMorden\"\n },\n classicMordor: classicMordor,\n classicTestnet: classicMordor,\n classicKotti: {\n chainId: 6,\n name: \"classicKotti\",\n _defaultProvider: etcDefaultProvider(\"https:/\\/www.ethercluster.com/kotti\", \"classicKotti\")\n },\n xdai: {\n chainId: 100,\n name: \"xdai\"\n },\n matic: {\n chainId: 137,\n name: \"matic\",\n _defaultProvider: ethDefaultProvider(\"matic\")\n },\n maticmum: {\n chainId: 80001,\n name: \"maticmum\"\n },\n optimism: {\n chainId: 10,\n name: \"optimism\",\n _defaultProvider: ethDefaultProvider(\"optimism\")\n },\n \"optimism-kovan\": {\n chainId: 69,\n name: \"optimism-kovan\"\n },\n \"optimism-goerli\": {\n chainId: 420,\n name: \"optimism-goerli\"\n },\n arbitrum: {\n chainId: 42161,\n name: \"arbitrum\"\n },\n \"arbitrum-rinkeby\": {\n chainId: 421611,\n name: \"arbitrum-rinkeby\"\n },\n \"arbitrum-goerli\": {\n chainId: 421613,\n name: \"arbitrum-goerli\"\n },\n bnb: {\n chainId: 56,\n name: \"bnb\"\n },\n bnbt: {\n chainId: 97,\n name: \"bnbt\"\n }\n};\n/**\n * getNetwork\n *\n * Converts a named common networks or chain ID (network ID) to a Network\n * and verifies a network is a valid Network..\n */\nexport function getNetwork(network) {\n // No network (null)\n if (network == null) {\n return null;\n }\n if (typeof network === \"number\") {\n for (const name in networks) {\n const standard = networks[name];\n if (standard.chainId === network) {\n return {\n name: standard.name,\n chainId: standard.chainId,\n ensAddress: standard.ensAddress || null,\n _defaultProvider: standard._defaultProvider || null\n };\n }\n }\n return {\n chainId: network,\n name: \"unknown\"\n };\n }\n if (typeof network === \"string\") {\n const standard = networks[network];\n if (standard == null) {\n return null;\n }\n return {\n name: standard.name,\n chainId: standard.chainId,\n ensAddress: standard.ensAddress,\n _defaultProvider: standard._defaultProvider || null\n };\n }\n const standard = networks[network.name];\n // Not a standard network; check that it is a valid network in general\n if (!standard) {\n if (typeof network.chainId !== \"number\") {\n logger.throwArgumentError(\"invalid network chainId\", \"network\", network);\n }\n return network;\n }\n // Make sure the chainId matches the expected network chainId (or is 0; disable EIP-155)\n if (network.chainId !== 0 && network.chainId !== standard.chainId) {\n logger.throwArgumentError(\"network chainId mismatch\", \"network\", network);\n }\n // @TODO: In the next major version add an attach function to a defaultProvider\n // class and move the _defaultProvider internal to this file (extend Network)\n let defaultProvider = network._defaultProvider || null;\n if (defaultProvider == null && standard._defaultProvider) {\n if (isRenetworkable(standard._defaultProvider)) {\n defaultProvider = standard._defaultProvider.renetwork(network);\n } else {\n defaultProvider = standard._defaultProvider;\n }\n }\n // Standard Network (allow overriding the ENS address)\n return {\n name: network.name,\n chainId: standard.chainId,\n ensAddress: network.ensAddress || standard.ensAddress || null,\n _defaultProvider: defaultProvider\n };\n}\n","/**\n * var basex = require(\"base-x\");\n *\n * This implementation is heavily based on base-x. The main reason to\n * deviate was to prevent the dependency of Buffer.\n *\n * Contributors:\n *\n * base-x encoding\n * Forked from https://github.com/cryptocoinjs/bs58\n * Originally written by Mike Hearn for BitcoinJ\n * Copyright (c) 2011 Google Inc\n * Ported to JavaScript by Stefan Thomas\n * Merged Buffer refactorings from base58-native by Stephen Pair\n * Copyright (c) 2013 BitPay Inc\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\n * copy of this software and associated documentation files (the \"Software\"),\n * to deal in the Software without restriction, including without limitation\n * the rights to use, copy, modify, merge, publish, distribute, sublicense,\n * and/or sell copies of the Software, and to permit persons to whom the\n * Software is 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 DEALINGS\n * IN THE SOFTWARE.\n *\n */\nimport { arrayify } from \"@ethersproject/bytes\";\nimport { defineReadOnly } from \"@ethersproject/properties\";\nexport class BaseX {\n constructor(alphabet) {\n defineReadOnly(this, \"alphabet\", alphabet);\n defineReadOnly(this, \"base\", alphabet.length);\n defineReadOnly(this, \"_alphabetMap\", {});\n defineReadOnly(this, \"_leader\", alphabet.charAt(0));\n // pre-compute lookup table\n for (let i = 0; i < alphabet.length; i++) {\n this._alphabetMap[alphabet.charAt(i)] = i;\n }\n }\n encode(value) {\n let source = arrayify(value);\n if (source.length === 0) {\n return \"\";\n }\n let digits = [0];\n for (let i = 0; i < source.length; ++i) {\n let carry = source[i];\n for (let j = 0; j < digits.length; ++j) {\n carry += digits[j] << 8;\n digits[j] = carry % this.base;\n carry = carry / this.base | 0;\n }\n while (carry > 0) {\n digits.push(carry % this.base);\n carry = carry / this.base | 0;\n }\n }\n let string = \"\";\n // deal with leading zeros\n for (let k = 0; source[k] === 0 && k < source.length - 1; ++k) {\n string += this._leader;\n }\n // convert digits to a string\n for (let q = digits.length - 1; q >= 0; --q) {\n string += this.alphabet[digits[q]];\n }\n return string;\n }\n decode(value) {\n if (typeof value !== \"string\") {\n throw new TypeError(\"Expected String\");\n }\n let bytes = [];\n if (value.length === 0) {\n return new Uint8Array(bytes);\n }\n bytes.push(0);\n for (let i = 0; i < value.length; i++) {\n let byte = this._alphabetMap[value[i]];\n if (byte === undefined) {\n throw new Error(\"Non-base\" + this.base + \" character\");\n }\n let carry = byte;\n for (let j = 0; j < bytes.length; ++j) {\n carry += bytes[j] * this.base;\n bytes[j] = carry & 0xff;\n carry >>= 8;\n }\n while (carry > 0) {\n bytes.push(carry & 0xff);\n carry >>= 8;\n }\n }\n // deal with leading zeros\n for (let k = 0; value[k] === this._leader && k < value.length - 1; ++k) {\n bytes.push(0);\n }\n return arrayify(new Uint8Array(bytes.reverse()));\n }\n}\nconst Base32 = new BaseX(\"abcdefghijklmnopqrstuvwxyz234567\");\nconst Base58 = new BaseX(\"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\");\nexport { Base32, Base58 };\n//console.log(Base58.decode(\"Qmd2V777o5XvJbYMeMb8k2nU5f8d3ciUQ5YpYuWhzv8iDj\"))\n//console.log(Base58.encode(Base58.decode(\"Qmd2V777o5XvJbYMeMb8k2nU5f8d3ciUQ5YpYuWhzv8iDj\")))\n","export var SupportedAlgorithm = /*#__PURE__*/function (SupportedAlgorithm) {\n SupportedAlgorithm[\"sha256\"] = \"sha256\";\n SupportedAlgorithm[\"sha512\"] = \"sha512\";\n return SupportedAlgorithm;\n}(SupportedAlgorithm || {});\n;\n","export const version = \"sha2/5.7.0\";\n","\"use strict\";\n\nimport hash from \"hash.js\";\n//const _ripemd160 = _hash.ripemd160;\nimport { arrayify } from \"@ethersproject/bytes\";\nimport { SupportedAlgorithm } from \"./types\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nexport function ripemd160(data) {\n return \"0x\" + hash.ripemd160().update(arrayify(data)).digest(\"hex\");\n}\nexport function sha256(data) {\n return \"0x\" + hash.sha256().update(arrayify(data)).digest(\"hex\");\n}\nexport function sha512(data) {\n return \"0x\" + hash.sha512().update(arrayify(data)).digest(\"hex\");\n}\nexport function computeHmac(algorithm, key, data) {\n if (!SupportedAlgorithm[algorithm]) {\n logger.throwError(\"unsupported algorithm \" + algorithm, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"hmac\",\n algorithm: algorithm\n });\n }\n return \"0x\" + hash.hmac(hash[algorithm], arrayify(key)).update(arrayify(data)).digest(\"hex\");\n}\n","import { computeHmac, ripemd160, sha256, sha512 } from \"./sha2\";\nimport { SupportedAlgorithm } from \"./types\";\nexport { computeHmac, ripemd160, sha256, sha512, SupportedAlgorithm };\n","export const version = \"web/5.7.1\";\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { arrayify } from \"@ethersproject/bytes\";\nexport function getUrl(href, options) {\n return __awaiter(this, void 0, void 0, function* () {\n if (options == null) {\n options = {};\n }\n const request = {\n method: options.method || \"GET\",\n headers: options.headers || {},\n body: options.body || undefined\n };\n if (options.skipFetchSetup !== true) {\n request.mode = \"cors\"; // no-cors, cors, *same-origin\n request.cache = \"no-cache\"; // *default, no-cache, reload, force-cache, only-if-cached\n request.credentials = \"same-origin\"; // include, *same-origin, omit\n request.redirect = \"follow\"; // manual, *follow, error\n request.referrer = \"client\"; // no-referrer, *client\n }\n ;\n if (options.fetchOptions != null) {\n const opts = options.fetchOptions;\n if (opts.mode) {\n request.mode = opts.mode;\n }\n if (opts.cache) {\n request.cache = opts.cache;\n }\n if (opts.credentials) {\n request.credentials = opts.credentials;\n }\n if (opts.redirect) {\n request.redirect = opts.redirect;\n }\n if (opts.referrer) {\n request.referrer = opts.referrer;\n }\n }\n const response = yield fetch(href, request);\n const body = yield response.arrayBuffer();\n const headers = {};\n if (response.headers.forEach) {\n response.headers.forEach((value, key) => {\n headers[key.toLowerCase()] = value;\n });\n } else {\n response.headers.keys().forEach(key => {\n headers[key.toLowerCase()] = response.headers.get(key);\n });\n }\n return {\n headers: headers,\n statusCode: response.status,\n statusMessage: response.statusText,\n body: arrayify(new Uint8Array(body))\n };\n });\n}\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { decode as base64Decode, encode as base64Encode } from \"@ethersproject/base64\";\nimport { hexlify, isBytesLike } from \"@ethersproject/bytes\";\nimport { shallowCopy } from \"@ethersproject/properties\";\nimport { toUtf8Bytes, toUtf8String } from \"@ethersproject/strings\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { getUrl } from \"./geturl\";\nfunction staller(duration) {\n return new Promise(resolve => {\n setTimeout(resolve, duration);\n });\n}\nfunction bodyify(value, type) {\n if (value == null) {\n return null;\n }\n if (typeof value === \"string\") {\n return value;\n }\n if (isBytesLike(value)) {\n if (type && (type.split(\"/\")[0] === \"text\" || type.split(\";\")[0].trim() === \"application/json\")) {\n try {\n return toUtf8String(value);\n } catch (error) {}\n ;\n }\n return hexlify(value);\n }\n return value;\n}\nfunction unpercent(value) {\n return toUtf8Bytes(value.replace(/%([0-9a-f][0-9a-f])/gi, (all, code) => {\n return String.fromCharCode(parseInt(code, 16));\n }));\n}\n// This API is still a work in progress; the future changes will likely be:\n// - ConnectionInfo => FetchDataRequest\n// - FetchDataRequest.body? = string | Uint8Array | { contentType: string, data: string | Uint8Array }\n// - If string => text/plain, Uint8Array => application/octet-stream (if content-type unspecified)\n// - FetchDataRequest.processFunc = (body: Uint8Array, response: FetchDataResponse) => T\n// For this reason, it should be considered internal until the API is finalized\nexport function _fetchData(connection, body, processFunc) {\n // How many times to retry in the event of a throttle\n const attemptLimit = typeof connection === \"object\" && connection.throttleLimit != null ? connection.throttleLimit : 12;\n logger.assertArgument(attemptLimit > 0 && attemptLimit % 1 === 0, \"invalid connection throttle limit\", \"connection.throttleLimit\", attemptLimit);\n const throttleCallback = typeof connection === \"object\" ? connection.throttleCallback : null;\n const throttleSlotInterval = typeof connection === \"object\" && typeof connection.throttleSlotInterval === \"number\" ? connection.throttleSlotInterval : 100;\n logger.assertArgument(throttleSlotInterval > 0 && throttleSlotInterval % 1 === 0, \"invalid connection throttle slot interval\", \"connection.throttleSlotInterval\", throttleSlotInterval);\n const errorPassThrough = typeof connection === \"object\" ? !!connection.errorPassThrough : false;\n const headers = {};\n let url = null;\n // @TODO: Allow ConnectionInfo to override some of these values\n const options = {\n method: \"GET\"\n };\n let allow304 = false;\n let timeout = 2 * 60 * 1000;\n if (typeof connection === \"string\") {\n url = connection;\n } else if (typeof connection === \"object\") {\n if (connection == null || connection.url == null) {\n logger.throwArgumentError(\"missing URL\", \"connection.url\", connection);\n }\n url = connection.url;\n if (typeof connection.timeout === \"number\" && connection.timeout > 0) {\n timeout = connection.timeout;\n }\n if (connection.headers) {\n for (const key in connection.headers) {\n headers[key.toLowerCase()] = {\n key: key,\n value: String(connection.headers[key])\n };\n if ([\"if-none-match\", \"if-modified-since\"].indexOf(key.toLowerCase()) >= 0) {\n allow304 = true;\n }\n }\n }\n options.allowGzip = !!connection.allowGzip;\n if (connection.user != null && connection.password != null) {\n if (url.substring(0, 6) !== \"https:\" && connection.allowInsecureAuthentication !== true) {\n logger.throwError(\"basic authentication requires a secure https url\", Logger.errors.INVALID_ARGUMENT, {\n argument: \"url\",\n url: url,\n user: connection.user,\n password: \"[REDACTED]\"\n });\n }\n const authorization = connection.user + \":\" + connection.password;\n headers[\"authorization\"] = {\n key: \"Authorization\",\n value: \"Basic \" + base64Encode(toUtf8Bytes(authorization))\n };\n }\n if (connection.skipFetchSetup != null) {\n options.skipFetchSetup = !!connection.skipFetchSetup;\n }\n if (connection.fetchOptions != null) {\n options.fetchOptions = shallowCopy(connection.fetchOptions);\n }\n }\n const reData = new RegExp(\"^data:([^;:]*)?(;base64)?,(.*)$\", \"i\");\n const dataMatch = url ? url.match(reData) : null;\n if (dataMatch) {\n try {\n const response = {\n statusCode: 200,\n statusMessage: \"OK\",\n headers: {\n \"content-type\": dataMatch[1] || \"text/plain\"\n },\n body: dataMatch[2] ? base64Decode(dataMatch[3]) : unpercent(dataMatch[3])\n };\n let result = response.body;\n if (processFunc) {\n result = processFunc(response.body, response);\n }\n return Promise.resolve(result);\n } catch (error) {\n logger.throwError(\"processing response error\", Logger.errors.SERVER_ERROR, {\n body: bodyify(dataMatch[1], dataMatch[2]),\n error: error,\n requestBody: null,\n requestMethod: \"GET\",\n url: url\n });\n }\n }\n if (body) {\n options.method = \"POST\";\n options.body = body;\n if (headers[\"content-type\"] == null) {\n headers[\"content-type\"] = {\n key: \"Content-Type\",\n value: \"application/octet-stream\"\n };\n }\n if (headers[\"content-length\"] == null) {\n headers[\"content-length\"] = {\n key: \"Content-Length\",\n value: String(body.length)\n };\n }\n }\n const flatHeaders = {};\n Object.keys(headers).forEach(key => {\n const header = headers[key];\n flatHeaders[header.key] = header.value;\n });\n options.headers = flatHeaders;\n const runningTimeout = function () {\n let timer = null;\n const promise = new Promise(function (resolve, reject) {\n if (timeout) {\n timer = setTimeout(() => {\n if (timer == null) {\n return;\n }\n timer = null;\n reject(logger.makeError(\"timeout\", Logger.errors.TIMEOUT, {\n requestBody: bodyify(options.body, flatHeaders[\"content-type\"]),\n requestMethod: options.method,\n timeout: timeout,\n url: url\n }));\n }, timeout);\n }\n });\n const cancel = function () {\n if (timer == null) {\n return;\n }\n clearTimeout(timer);\n timer = null;\n };\n return {\n promise,\n cancel\n };\n }();\n const runningFetch = function () {\n return __awaiter(this, void 0, void 0, function* () {\n for (let attempt = 0; attempt < attemptLimit; attempt++) {\n let response = null;\n try {\n response = yield getUrl(url, options);\n if (attempt < attemptLimit) {\n if (response.statusCode === 301 || response.statusCode === 302) {\n // Redirection; for now we only support absolute locataions\n const location = response.headers.location || \"\";\n if (options.method === \"GET\" && location.match(/^https:/)) {\n url = response.headers.location;\n continue;\n }\n } else if (response.statusCode === 429) {\n // Exponential back-off throttling\n let tryAgain = true;\n if (throttleCallback) {\n tryAgain = yield throttleCallback(attempt, url);\n }\n if (tryAgain) {\n let stall = 0;\n const retryAfter = response.headers[\"retry-after\"];\n if (typeof retryAfter === \"string\" && retryAfter.match(/^[1-9][0-9]*$/)) {\n stall = parseInt(retryAfter) * 1000;\n } else {\n stall = throttleSlotInterval * parseInt(String(Math.random() * Math.pow(2, attempt)));\n }\n //console.log(\"Stalling 429\");\n yield staller(stall);\n continue;\n }\n }\n }\n } catch (error) {\n response = error.response;\n if (response == null) {\n runningTimeout.cancel();\n logger.throwError(\"missing response\", Logger.errors.SERVER_ERROR, {\n requestBody: bodyify(options.body, flatHeaders[\"content-type\"]),\n requestMethod: options.method,\n serverError: error,\n url: url\n });\n }\n }\n let body = response.body;\n if (allow304 && response.statusCode === 304) {\n body = null;\n } else if (!errorPassThrough && (response.statusCode < 200 || response.statusCode >= 300)) {\n runningTimeout.cancel();\n logger.throwError(\"bad response\", Logger.errors.SERVER_ERROR, {\n status: response.statusCode,\n headers: response.headers,\n body: bodyify(body, response.headers ? response.headers[\"content-type\"] : null),\n requestBody: bodyify(options.body, flatHeaders[\"content-type\"]),\n requestMethod: options.method,\n url: url\n });\n }\n if (processFunc) {\n try {\n const result = yield processFunc(body, response);\n runningTimeout.cancel();\n return result;\n } catch (error) {\n // Allow the processFunc to trigger a throttle\n if (error.throttleRetry && attempt < attemptLimit) {\n let tryAgain = true;\n if (throttleCallback) {\n tryAgain = yield throttleCallback(attempt, url);\n }\n if (tryAgain) {\n const timeout = throttleSlotInterval * parseInt(String(Math.random() * Math.pow(2, attempt)));\n //console.log(\"Stalling callback\");\n yield staller(timeout);\n continue;\n }\n }\n runningTimeout.cancel();\n logger.throwError(\"processing response error\", Logger.errors.SERVER_ERROR, {\n body: bodyify(body, response.headers ? response.headers[\"content-type\"] : null),\n error: error,\n requestBody: bodyify(options.body, flatHeaders[\"content-type\"]),\n requestMethod: options.method,\n url: url\n });\n }\n }\n runningTimeout.cancel();\n // If we had a processFunc, it either returned a T or threw above.\n // The \"body\" is now a Uint8Array.\n return body;\n }\n return logger.throwError(\"failed response\", Logger.errors.SERVER_ERROR, {\n requestBody: bodyify(options.body, flatHeaders[\"content-type\"]),\n requestMethod: options.method,\n url: url\n });\n });\n }();\n return Promise.race([runningTimeout.promise, runningFetch]);\n}\nexport function fetchJson(connection, json, processFunc) {\n let processJsonFunc = (value, response) => {\n let result = null;\n if (value != null) {\n try {\n result = JSON.parse(toUtf8String(value));\n } catch (error) {\n logger.throwError(\"invalid JSON\", Logger.errors.SERVER_ERROR, {\n body: value,\n error: error\n });\n }\n }\n if (processFunc) {\n result = processFunc(result, response);\n }\n return result;\n };\n // If we have json to send, we must\n // - add content-type of application/json (unless already overridden)\n // - convert the json to bytes\n let body = null;\n if (json != null) {\n body = toUtf8Bytes(json);\n // Create a connection with the content-type set for JSON\n const updated = typeof connection === \"string\" ? {\n url: connection\n } : shallowCopy(connection);\n if (updated.headers) {\n const hasContentType = Object.keys(updated.headers).filter(k => k.toLowerCase() === \"content-type\").length !== 0;\n if (!hasContentType) {\n updated.headers = shallowCopy(updated.headers);\n updated.headers[\"content-type\"] = \"application/json\";\n }\n } else {\n updated.headers = {\n \"content-type\": \"application/json\"\n };\n }\n connection = updated;\n }\n return _fetchData(connection, body, processJsonFunc);\n}\nexport function poll(func, options) {\n if (!options) {\n options = {};\n }\n options = shallowCopy(options);\n if (options.floor == null) {\n options.floor = 0;\n }\n if (options.ceiling == null) {\n options.ceiling = 10000;\n }\n if (options.interval == null) {\n options.interval = 250;\n }\n return new Promise(function (resolve, reject) {\n let timer = null;\n let done = false;\n // Returns true if cancel was successful. Unsuccessful cancel means we're already done.\n const cancel = () => {\n if (done) {\n return false;\n }\n done = true;\n if (timer) {\n clearTimeout(timer);\n }\n return true;\n };\n if (options.timeout) {\n timer = setTimeout(() => {\n if (cancel()) {\n reject(new Error(\"timeout\"));\n }\n }, options.timeout);\n }\n const retryLimit = options.retryLimit;\n let attempt = 0;\n function check() {\n return func().then(function (result) {\n // If we have a result, or are allowed null then we're done\n if (result !== undefined) {\n if (cancel()) {\n resolve(result);\n }\n } else if (options.oncePoll) {\n options.oncePoll.once(\"poll\", check);\n } else if (options.onceBlock) {\n options.onceBlock.once(\"block\", check);\n // Otherwise, exponential back-off (up to 10s) our next request\n } else if (!done) {\n attempt++;\n if (attempt > retryLimit) {\n if (cancel()) {\n reject(new Error(\"retry limit reached\"));\n }\n return;\n }\n let timeout = options.interval * parseInt(String(Math.random() * Math.pow(2, attempt)));\n if (timeout < options.floor) {\n timeout = options.floor;\n }\n if (timeout > options.ceiling) {\n timeout = options.ceiling;\n }\n setTimeout(check, timeout);\n }\n return null;\n }, function (error) {\n if (cancel()) {\n reject(error);\n }\n });\n }\n check();\n });\n}\n","export const version = \"providers/5.7.2\";\n","\"use strict\";\n\nimport { getAddress, getContractAddress } from \"@ethersproject/address\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { hexDataLength, hexDataSlice, hexValue, hexZeroPad, isHexString } from \"@ethersproject/bytes\";\nimport { AddressZero } from \"@ethersproject/constants\";\nimport { shallowCopy } from \"@ethersproject/properties\";\nimport { accessListify, parse as parseTransaction } from \"@ethersproject/transactions\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nexport class Formatter {\n constructor() {\n this.formats = this.getDefaultFormats();\n }\n getDefaultFormats() {\n const formats = {};\n const address = this.address.bind(this);\n const bigNumber = this.bigNumber.bind(this);\n const blockTag = this.blockTag.bind(this);\n const data = this.data.bind(this);\n const hash = this.hash.bind(this);\n const hex = this.hex.bind(this);\n const number = this.number.bind(this);\n const type = this.type.bind(this);\n const strictData = v => {\n return this.data(v, true);\n };\n formats.transaction = {\n hash: hash,\n type: type,\n accessList: Formatter.allowNull(this.accessList.bind(this), null),\n blockHash: Formatter.allowNull(hash, null),\n blockNumber: Formatter.allowNull(number, null),\n transactionIndex: Formatter.allowNull(number, null),\n confirmations: Formatter.allowNull(number, null),\n from: address,\n // either (gasPrice) or (maxPriorityFeePerGas + maxFeePerGas)\n // must be set\n gasPrice: Formatter.allowNull(bigNumber),\n maxPriorityFeePerGas: Formatter.allowNull(bigNumber),\n maxFeePerGas: Formatter.allowNull(bigNumber),\n gasLimit: bigNumber,\n to: Formatter.allowNull(address, null),\n value: bigNumber,\n nonce: number,\n data: data,\n r: Formatter.allowNull(this.uint256),\n s: Formatter.allowNull(this.uint256),\n v: Formatter.allowNull(number),\n creates: Formatter.allowNull(address, null),\n raw: Formatter.allowNull(data)\n };\n formats.transactionRequest = {\n from: Formatter.allowNull(address),\n nonce: Formatter.allowNull(number),\n gasLimit: Formatter.allowNull(bigNumber),\n gasPrice: Formatter.allowNull(bigNumber),\n maxPriorityFeePerGas: Formatter.allowNull(bigNumber),\n maxFeePerGas: Formatter.allowNull(bigNumber),\n to: Formatter.allowNull(address),\n value: Formatter.allowNull(bigNumber),\n data: Formatter.allowNull(strictData),\n type: Formatter.allowNull(number),\n accessList: Formatter.allowNull(this.accessList.bind(this), null)\n };\n formats.receiptLog = {\n transactionIndex: number,\n blockNumber: number,\n transactionHash: hash,\n address: address,\n topics: Formatter.arrayOf(hash),\n data: data,\n logIndex: number,\n blockHash: hash\n };\n formats.receipt = {\n to: Formatter.allowNull(this.address, null),\n from: Formatter.allowNull(this.address, null),\n contractAddress: Formatter.allowNull(address, null),\n transactionIndex: number,\n // should be allowNull(hash), but broken-EIP-658 support is handled in receipt\n root: Formatter.allowNull(hex),\n gasUsed: bigNumber,\n logsBloom: Formatter.allowNull(data),\n blockHash: hash,\n transactionHash: hash,\n logs: Formatter.arrayOf(this.receiptLog.bind(this)),\n blockNumber: number,\n confirmations: Formatter.allowNull(number, null),\n cumulativeGasUsed: bigNumber,\n effectiveGasPrice: Formatter.allowNull(bigNumber),\n status: Formatter.allowNull(number),\n type: type\n };\n formats.block = {\n hash: Formatter.allowNull(hash),\n parentHash: hash,\n number: number,\n timestamp: number,\n nonce: Formatter.allowNull(hex),\n difficulty: this.difficulty.bind(this),\n gasLimit: bigNumber,\n gasUsed: bigNumber,\n miner: Formatter.allowNull(address),\n extraData: data,\n transactions: Formatter.allowNull(Formatter.arrayOf(hash)),\n baseFeePerGas: Formatter.allowNull(bigNumber)\n };\n formats.blockWithTransactions = shallowCopy(formats.block);\n formats.blockWithTransactions.transactions = Formatter.allowNull(Formatter.arrayOf(this.transactionResponse.bind(this)));\n formats.filter = {\n fromBlock: Formatter.allowNull(blockTag, undefined),\n toBlock: Formatter.allowNull(blockTag, undefined),\n blockHash: Formatter.allowNull(hash, undefined),\n address: Formatter.allowNull(address, undefined),\n topics: Formatter.allowNull(this.topics.bind(this), undefined)\n };\n formats.filterLog = {\n blockNumber: Formatter.allowNull(number),\n blockHash: Formatter.allowNull(hash),\n transactionIndex: number,\n removed: Formatter.allowNull(this.boolean.bind(this)),\n address: address,\n data: Formatter.allowFalsish(data, \"0x\"),\n topics: Formatter.arrayOf(hash),\n transactionHash: hash,\n logIndex: number\n };\n return formats;\n }\n accessList(accessList) {\n return accessListify(accessList || []);\n }\n // Requires a BigNumberish that is within the IEEE754 safe integer range; returns a number\n // Strict! Used on input.\n number(number) {\n if (number === \"0x\") {\n return 0;\n }\n return BigNumber.from(number).toNumber();\n }\n type(number) {\n if (number === \"0x\" || number == null) {\n return 0;\n }\n return BigNumber.from(number).toNumber();\n }\n // Strict! Used on input.\n bigNumber(value) {\n return BigNumber.from(value);\n }\n // Requires a boolean, \"true\" or \"false\"; returns a boolean\n boolean(value) {\n if (typeof value === \"boolean\") {\n return value;\n }\n if (typeof value === \"string\") {\n value = value.toLowerCase();\n if (value === \"true\") {\n return true;\n }\n if (value === \"false\") {\n return false;\n }\n }\n throw new Error(\"invalid boolean - \" + value);\n }\n hex(value, strict) {\n if (typeof value === \"string\") {\n if (!strict && value.substring(0, 2) !== \"0x\") {\n value = \"0x\" + value;\n }\n if (isHexString(value)) {\n return value.toLowerCase();\n }\n }\n return logger.throwArgumentError(\"invalid hash\", \"value\", value);\n }\n data(value, strict) {\n const result = this.hex(value, strict);\n if (result.length % 2 !== 0) {\n throw new Error(\"invalid data; odd-length - \" + value);\n }\n return result;\n }\n // Requires an address\n // Strict! Used on input.\n address(value) {\n return getAddress(value);\n }\n callAddress(value) {\n if (!isHexString(value, 32)) {\n return null;\n }\n const address = getAddress(hexDataSlice(value, 12));\n return address === AddressZero ? null : address;\n }\n contractAddress(value) {\n return getContractAddress(value);\n }\n // Strict! Used on input.\n blockTag(blockTag) {\n if (blockTag == null) {\n return \"latest\";\n }\n if (blockTag === \"earliest\") {\n return \"0x0\";\n }\n switch (blockTag) {\n case \"earliest\":\n return \"0x0\";\n case \"latest\":\n case \"pending\":\n case \"safe\":\n case \"finalized\":\n return blockTag;\n }\n if (typeof blockTag === \"number\" || isHexString(blockTag)) {\n return hexValue(blockTag);\n }\n throw new Error(\"invalid blockTag\");\n }\n // Requires a hash, optionally requires 0x prefix; returns prefixed lowercase hash.\n hash(value, strict) {\n const result = this.hex(value, strict);\n if (hexDataLength(result) !== 32) {\n return logger.throwArgumentError(\"invalid hash\", \"value\", value);\n }\n return result;\n }\n // Returns the difficulty as a number, or if too large (i.e. PoA network) null\n difficulty(value) {\n if (value == null) {\n return null;\n }\n const v = BigNumber.from(value);\n try {\n return v.toNumber();\n } catch (error) {}\n return null;\n }\n uint256(value) {\n if (!isHexString(value)) {\n throw new Error(\"invalid uint256\");\n }\n return hexZeroPad(value, 32);\n }\n _block(value, format) {\n if (value.author != null && value.miner == null) {\n value.miner = value.author;\n }\n // The difficulty may need to come from _difficulty in recursed blocks\n const difficulty = value._difficulty != null ? value._difficulty : value.difficulty;\n const result = Formatter.check(format, value);\n result._difficulty = difficulty == null ? null : BigNumber.from(difficulty);\n return result;\n }\n block(value) {\n return this._block(value, this.formats.block);\n }\n blockWithTransactions(value) {\n return this._block(value, this.formats.blockWithTransactions);\n }\n // Strict! Used on input.\n transactionRequest(value) {\n return Formatter.check(this.formats.transactionRequest, value);\n }\n transactionResponse(transaction) {\n // Rename gas to gasLimit\n if (transaction.gas != null && transaction.gasLimit == null) {\n transaction.gasLimit = transaction.gas;\n }\n // Some clients (TestRPC) do strange things like return 0x0 for the\n // 0 address; correct this to be a real address\n if (transaction.to && BigNumber.from(transaction.to).isZero()) {\n transaction.to = \"0x0000000000000000000000000000000000000000\";\n }\n // Rename input to data\n if (transaction.input != null && transaction.data == null) {\n transaction.data = transaction.input;\n }\n // If to and creates are empty, populate the creates from the transaction\n if (transaction.to == null && transaction.creates == null) {\n transaction.creates = this.contractAddress(transaction);\n }\n if ((transaction.type === 1 || transaction.type === 2) && transaction.accessList == null) {\n transaction.accessList = [];\n }\n const result = Formatter.check(this.formats.transaction, transaction);\n if (transaction.chainId != null) {\n let chainId = transaction.chainId;\n if (isHexString(chainId)) {\n chainId = BigNumber.from(chainId).toNumber();\n }\n result.chainId = chainId;\n } else {\n let chainId = transaction.networkId;\n // geth-etc returns chainId\n if (chainId == null && result.v == null) {\n chainId = transaction.chainId;\n }\n if (isHexString(chainId)) {\n chainId = BigNumber.from(chainId).toNumber();\n }\n if (typeof chainId !== \"number\" && result.v != null) {\n chainId = (result.v - 35) / 2;\n if (chainId < 0) {\n chainId = 0;\n }\n chainId = parseInt(chainId);\n }\n if (typeof chainId !== \"number\") {\n chainId = 0;\n }\n result.chainId = chainId;\n }\n // 0x0000... should actually be null\n if (result.blockHash && result.blockHash.replace(/0/g, \"\") === \"x\") {\n result.blockHash = null;\n }\n return result;\n }\n transaction(value) {\n return parseTransaction(value);\n }\n receiptLog(value) {\n return Formatter.check(this.formats.receiptLog, value);\n }\n receipt(value) {\n const result = Formatter.check(this.formats.receipt, value);\n // RSK incorrectly implemented EIP-658, so we munge things a bit here for it\n if (result.root != null) {\n if (result.root.length <= 4) {\n // Could be 0x00, 0x0, 0x01 or 0x1\n const value = BigNumber.from(result.root).toNumber();\n if (value === 0 || value === 1) {\n // Make sure if both are specified, they match\n if (result.status != null && result.status !== value) {\n logger.throwArgumentError(\"alt-root-status/status mismatch\", \"value\", {\n root: result.root,\n status: result.status\n });\n }\n result.status = value;\n delete result.root;\n } else {\n logger.throwArgumentError(\"invalid alt-root-status\", \"value.root\", result.root);\n }\n } else if (result.root.length !== 66) {\n // Must be a valid bytes32\n logger.throwArgumentError(\"invalid root hash\", \"value.root\", result.root);\n }\n }\n if (result.status != null) {\n result.byzantium = true;\n }\n return result;\n }\n topics(value) {\n if (Array.isArray(value)) {\n return value.map(v => this.topics(v));\n } else if (value != null) {\n return this.hash(value, true);\n }\n return null;\n }\n filter(value) {\n return Formatter.check(this.formats.filter, value);\n }\n filterLog(value) {\n return Formatter.check(this.formats.filterLog, value);\n }\n static check(format, object) {\n const result = {};\n for (const key in format) {\n try {\n const value = format[key](object[key]);\n if (value !== undefined) {\n result[key] = value;\n }\n } catch (error) {\n error.checkKey = key;\n error.checkValue = object[key];\n throw error;\n }\n }\n return result;\n }\n // if value is null-ish, nullValue is returned\n static allowNull(format, nullValue) {\n return function (value) {\n if (value == null) {\n return nullValue;\n }\n return format(value);\n };\n }\n // If value is false-ish, replaceValue is returned\n static allowFalsish(format, replaceValue) {\n return function (value) {\n if (!value) {\n return replaceValue;\n }\n return format(value);\n };\n }\n // Requires an Array satisfying check\n static arrayOf(format) {\n return function (array) {\n if (!Array.isArray(array)) {\n throw new Error(\"not an array\");\n }\n const result = [];\n array.forEach(function (value) {\n result.push(format(value));\n });\n return result;\n };\n }\n}\nexport function isCommunityResourcable(value) {\n return value && typeof value.isCommunityResource === \"function\";\n}\nexport function isCommunityResource(value) {\n return isCommunityResourcable(value) && value.isCommunityResource();\n}\n// Show the throttle message only once\nlet throttleMessage = false;\nexport function showThrottleMessage() {\n if (throttleMessage) {\n return;\n }\n throttleMessage = true;\n console.log(\"========= NOTICE =========\");\n console.log(\"Request-Rate Exceeded (this message will not be repeated)\");\n console.log(\"\");\n console.log(\"The default API keys for each service are provided as a highly-throttled,\");\n console.log(\"community resource for low-traffic projects and early prototyping.\");\n console.log(\"\");\n console.log(\"While your application will continue to function, we highly recommended\");\n console.log(\"signing up for your own API keys to improve performance, increase your\");\n console.log(\"request rate/limit and enable other perks, such as metrics and advanced APIs.\");\n console.log(\"\");\n console.log(\"For more details: https:/\\/docs.ethers.io/api-keys/\");\n console.log(\"==========================\");\n}\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { ForkEvent, Provider } from \"@ethersproject/abstract-provider\";\nimport { encode as base64Encode } from \"@ethersproject/base64\";\nimport { Base58 } from \"@ethersproject/basex\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { arrayify, concat, hexConcat, hexDataLength, hexDataSlice, hexlify, hexValue, hexZeroPad, isHexString } from \"@ethersproject/bytes\";\nimport { HashZero } from \"@ethersproject/constants\";\nimport { dnsEncode, namehash } from \"@ethersproject/hash\";\nimport { getNetwork } from \"@ethersproject/networks\";\nimport { defineReadOnly, getStatic, resolveProperties } from \"@ethersproject/properties\";\nimport { sha256 } from \"@ethersproject/sha2\";\nimport { toUtf8Bytes, toUtf8String } from \"@ethersproject/strings\";\nimport { fetchJson, poll } from \"@ethersproject/web\";\nimport bech32 from \"bech32\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { Formatter } from \"./formatter\";\nconst MAX_CCIP_REDIRECTS = 10;\n//////////////////////////////\n// Event Serializeing\nfunction checkTopic(topic) {\n if (topic == null) {\n return \"null\";\n }\n if (hexDataLength(topic) !== 32) {\n logger.throwArgumentError(\"invalid topic\", \"topic\", topic);\n }\n return topic.toLowerCase();\n}\nfunction serializeTopics(topics) {\n // Remove trailing null AND-topics; they are redundant\n topics = topics.slice();\n while (topics.length > 0 && topics[topics.length - 1] == null) {\n topics.pop();\n }\n return topics.map(topic => {\n if (Array.isArray(topic)) {\n // Only track unique OR-topics\n const unique = {};\n topic.forEach(topic => {\n unique[checkTopic(topic)] = true;\n });\n // The order of OR-topics does not matter\n const sorted = Object.keys(unique);\n sorted.sort();\n return sorted.join(\"|\");\n } else {\n return checkTopic(topic);\n }\n }).join(\"&\");\n}\nfunction deserializeTopics(data) {\n if (data === \"\") {\n return [];\n }\n return data.split(/&/g).map(topic => {\n if (topic === \"\") {\n return [];\n }\n const comps = topic.split(\"|\").map(topic => {\n return topic === \"null\" ? null : topic;\n });\n return comps.length === 1 ? comps[0] : comps;\n });\n}\nfunction getEventTag(eventName) {\n if (typeof eventName === \"string\") {\n eventName = eventName.toLowerCase();\n if (hexDataLength(eventName) === 32) {\n return \"tx:\" + eventName;\n }\n if (eventName.indexOf(\":\") === -1) {\n return eventName;\n }\n } else if (Array.isArray(eventName)) {\n return \"filter:*:\" + serializeTopics(eventName);\n } else if (ForkEvent.isForkEvent(eventName)) {\n logger.warn(\"not implemented\");\n throw new Error(\"not implemented\");\n } else if (eventName && typeof eventName === \"object\") {\n return \"filter:\" + (eventName.address || \"*\") + \":\" + serializeTopics(eventName.topics || []);\n }\n throw new Error(\"invalid event - \" + eventName);\n}\n//////////////////////////////\n// Helper Object\nfunction getTime() {\n return new Date().getTime();\n}\nfunction stall(duration) {\n return new Promise(resolve => {\n setTimeout(resolve, duration);\n });\n}\n//////////////////////////////\n// Provider Object\n/**\n * EventType\n * - \"block\"\n * - \"poll\"\n * - \"didPoll\"\n * - \"pending\"\n * - \"error\"\n * - \"network\"\n * - filter\n * - topics array\n * - transaction hash\n */\nconst PollableEvents = [\"block\", \"network\", \"pending\", \"poll\"];\nexport class Event {\n constructor(tag, listener, once) {\n defineReadOnly(this, \"tag\", tag);\n defineReadOnly(this, \"listener\", listener);\n defineReadOnly(this, \"once\", once);\n this._lastBlockNumber = -2;\n this._inflight = false;\n }\n get event() {\n switch (this.type) {\n case \"tx\":\n return this.hash;\n case \"filter\":\n return this.filter;\n }\n return this.tag;\n }\n get type() {\n return this.tag.split(\":\")[0];\n }\n get hash() {\n const comps = this.tag.split(\":\");\n if (comps[0] !== \"tx\") {\n return null;\n }\n return comps[1];\n }\n get filter() {\n const comps = this.tag.split(\":\");\n if (comps[0] !== \"filter\") {\n return null;\n }\n const address = comps[1];\n const topics = deserializeTopics(comps[2]);\n const filter = {};\n if (topics.length > 0) {\n filter.topics = topics;\n }\n if (address && address !== \"*\") {\n filter.address = address;\n }\n return filter;\n }\n pollable() {\n return this.tag.indexOf(\":\") >= 0 || PollableEvents.indexOf(this.tag) >= 0;\n }\n}\n;\n// https://github.com/satoshilabs/slips/blob/master/slip-0044.md\nconst coinInfos = {\n \"0\": {\n symbol: \"btc\",\n p2pkh: 0x00,\n p2sh: 0x05,\n prefix: \"bc\"\n },\n \"2\": {\n symbol: \"ltc\",\n p2pkh: 0x30,\n p2sh: 0x32,\n prefix: \"ltc\"\n },\n \"3\": {\n symbol: \"doge\",\n p2pkh: 0x1e,\n p2sh: 0x16\n },\n \"60\": {\n symbol: \"eth\",\n ilk: \"eth\"\n },\n \"61\": {\n symbol: \"etc\",\n ilk: \"eth\"\n },\n \"700\": {\n symbol: \"xdai\",\n ilk: \"eth\"\n }\n};\nfunction bytes32ify(value) {\n return hexZeroPad(BigNumber.from(value).toHexString(), 32);\n}\n// Compute the Base58Check encoded data (checksum is first 4 bytes of sha256d)\nfunction base58Encode(data) {\n return Base58.encode(concat([data, hexDataSlice(sha256(sha256(data)), 0, 4)]));\n}\nconst matcherIpfs = new RegExp(\"^(ipfs):/\\/(.*)$\", \"i\");\nconst matchers = [new RegExp(\"^(https):/\\/(.*)$\", \"i\"), new RegExp(\"^(data):(.*)$\", \"i\"), matcherIpfs, new RegExp(\"^eip155:[0-9]+/(erc[0-9]+):(.*)$\", \"i\")];\nfunction _parseString(result, start) {\n try {\n return toUtf8String(_parseBytes(result, start));\n } catch (error) {}\n return null;\n}\nfunction _parseBytes(result, start) {\n if (result === \"0x\") {\n return null;\n }\n const offset = BigNumber.from(hexDataSlice(result, start, start + 32)).toNumber();\n const length = BigNumber.from(hexDataSlice(result, offset, offset + 32)).toNumber();\n return hexDataSlice(result, offset + 32, offset + 32 + length);\n}\n// Trim off the ipfs:// prefix and return the default gateway URL\nfunction getIpfsLink(link) {\n if (link.match(/^ipfs:\\/\\/ipfs\\//i)) {\n link = link.substring(12);\n } else if (link.match(/^ipfs:\\/\\//i)) {\n link = link.substring(7);\n } else {\n logger.throwArgumentError(\"unsupported IPFS format\", \"link\", link);\n }\n return `https:/\\/gateway.ipfs.io/ipfs/${link}`;\n}\nfunction numPad(value) {\n const result = arrayify(value);\n if (result.length > 32) {\n throw new Error(\"internal; should not happen\");\n }\n const padded = new Uint8Array(32);\n padded.set(result, 32 - result.length);\n return padded;\n}\nfunction bytesPad(value) {\n if (value.length % 32 === 0) {\n return value;\n }\n const result = new Uint8Array(Math.ceil(value.length / 32) * 32);\n result.set(value);\n return result;\n}\n// ABI Encodes a series of (bytes, bytes, ...)\nfunction encodeBytes(datas) {\n const result = [];\n let byteCount = 0;\n // Add place-holders for pointers as we add items\n for (let i = 0; i < datas.length; i++) {\n result.push(null);\n byteCount += 32;\n }\n for (let i = 0; i < datas.length; i++) {\n const data = arrayify(datas[i]);\n // Update the bytes offset\n result[i] = numPad(byteCount);\n // The length and padded value of data\n result.push(numPad(data.length));\n result.push(bytesPad(data));\n byteCount += 32 + Math.ceil(data.length / 32) * 32;\n }\n return hexConcat(result);\n}\nexport class Resolver {\n // The resolvedAddress is only for creating a ReverseLookup resolver\n constructor(provider, address, name, resolvedAddress) {\n defineReadOnly(this, \"provider\", provider);\n defineReadOnly(this, \"name\", name);\n defineReadOnly(this, \"address\", provider.formatter.address(address));\n defineReadOnly(this, \"_resolvedAddress\", resolvedAddress);\n }\n supportsWildcard() {\n if (!this._supportsEip2544) {\n // supportsInterface(bytes4 = selector(\"resolve(bytes,bytes)\"))\n this._supportsEip2544 = this.provider.call({\n to: this.address,\n data: \"0x01ffc9a79061b92300000000000000000000000000000000000000000000000000000000\"\n }).then(result => {\n return BigNumber.from(result).eq(1);\n }).catch(error => {\n if (error.code === Logger.errors.CALL_EXCEPTION) {\n return false;\n }\n // Rethrow the error: link is down, etc. Let future attempts retry.\n this._supportsEip2544 = null;\n throw error;\n });\n }\n return this._supportsEip2544;\n }\n _fetch(selector, parameters) {\n return __awaiter(this, void 0, void 0, function* () {\n // e.g. keccak256(\"addr(bytes32,uint256)\")\n const tx = {\n to: this.address,\n ccipReadEnabled: true,\n data: hexConcat([selector, namehash(this.name), parameters || \"0x\"])\n };\n // Wildcard support; use EIP-2544 to resolve the request\n let parseBytes = false;\n if (yield this.supportsWildcard()) {\n parseBytes = true;\n // selector(\"resolve(bytes,bytes)\")\n tx.data = hexConcat([\"0x9061b923\", encodeBytes([dnsEncode(this.name), tx.data])]);\n }\n try {\n let result = yield this.provider.call(tx);\n if (arrayify(result).length % 32 === 4) {\n logger.throwError(\"resolver threw error\", Logger.errors.CALL_EXCEPTION, {\n transaction: tx,\n data: result\n });\n }\n if (parseBytes) {\n result = _parseBytes(result, 0);\n }\n return result;\n } catch (error) {\n if (error.code === Logger.errors.CALL_EXCEPTION) {\n return null;\n }\n throw error;\n }\n });\n }\n _fetchBytes(selector, parameters) {\n return __awaiter(this, void 0, void 0, function* () {\n const result = yield this._fetch(selector, parameters);\n if (result != null) {\n return _parseBytes(result, 0);\n }\n return null;\n });\n }\n _getAddress(coinType, hexBytes) {\n const coinInfo = coinInfos[String(coinType)];\n if (coinInfo == null) {\n logger.throwError(`unsupported coin type: ${coinType}`, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: `getAddress(${coinType})`\n });\n }\n if (coinInfo.ilk === \"eth\") {\n return this.provider.formatter.address(hexBytes);\n }\n const bytes = arrayify(hexBytes);\n // P2PKH: OP_DUP OP_HASH160 OP_EQUALVERIFY OP_CHECKSIG\n if (coinInfo.p2pkh != null) {\n const p2pkh = hexBytes.match(/^0x76a9([0-9a-f][0-9a-f])([0-9a-f]*)88ac$/);\n if (p2pkh) {\n const length = parseInt(p2pkh[1], 16);\n if (p2pkh[2].length === length * 2 && length >= 1 && length <= 75) {\n return base58Encode(concat([[coinInfo.p2pkh], \"0x\" + p2pkh[2]]));\n }\n }\n }\n // P2SH: OP_HASH160 OP_EQUAL\n if (coinInfo.p2sh != null) {\n const p2sh = hexBytes.match(/^0xa9([0-9a-f][0-9a-f])([0-9a-f]*)87$/);\n if (p2sh) {\n const length = parseInt(p2sh[1], 16);\n if (p2sh[2].length === length * 2 && length >= 1 && length <= 75) {\n return base58Encode(concat([[coinInfo.p2sh], \"0x\" + p2sh[2]]));\n }\n }\n }\n // Bech32\n if (coinInfo.prefix != null) {\n const length = bytes[1];\n // https://github.com/bitcoin/bips/blob/master/bip-0141.mediawiki#witness-program\n let version = bytes[0];\n if (version === 0x00) {\n if (length !== 20 && length !== 32) {\n version = -1;\n }\n } else {\n version = -1;\n }\n if (version >= 0 && bytes.length === 2 + length && length >= 1 && length <= 75) {\n const words = bech32.toWords(bytes.slice(2));\n words.unshift(version);\n return bech32.encode(coinInfo.prefix, words);\n }\n }\n return null;\n }\n getAddress(coinType) {\n return __awaiter(this, void 0, void 0, function* () {\n if (coinType == null) {\n coinType = 60;\n }\n // If Ethereum, use the standard `addr(bytes32)`\n if (coinType === 60) {\n try {\n // keccak256(\"addr(bytes32)\")\n const result = yield this._fetch(\"0x3b3b57de\");\n // No address\n if (result === \"0x\" || result === HashZero) {\n return null;\n }\n return this.provider.formatter.callAddress(result);\n } catch (error) {\n if (error.code === Logger.errors.CALL_EXCEPTION) {\n return null;\n }\n throw error;\n }\n }\n // keccak256(\"addr(bytes32,uint256\")\n const hexBytes = yield this._fetchBytes(\"0xf1cb7e06\", bytes32ify(coinType));\n // No address\n if (hexBytes == null || hexBytes === \"0x\") {\n return null;\n }\n // Compute the address\n const address = this._getAddress(coinType, hexBytes);\n if (address == null) {\n logger.throwError(`invalid or unsupported coin data`, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: `getAddress(${coinType})`,\n coinType: coinType,\n data: hexBytes\n });\n }\n return address;\n });\n }\n getAvatar() {\n return __awaiter(this, void 0, void 0, function* () {\n const linkage = [{\n type: \"name\",\n content: this.name\n }];\n try {\n // test data for ricmoo.eth\n //const avatar = \"eip155:1/erc721:0x265385c7f4132228A0d54EB1A9e7460b91c0cC68/29233\";\n const avatar = yield this.getText(\"avatar\");\n if (avatar == null) {\n return null;\n }\n for (let i = 0; i < matchers.length; i++) {\n const match = avatar.match(matchers[i]);\n if (match == null) {\n continue;\n }\n const scheme = match[1].toLowerCase();\n switch (scheme) {\n case \"https\":\n linkage.push({\n type: \"url\",\n content: avatar\n });\n return {\n linkage,\n url: avatar\n };\n case \"data\":\n linkage.push({\n type: \"data\",\n content: avatar\n });\n return {\n linkage,\n url: avatar\n };\n case \"ipfs\":\n linkage.push({\n type: \"ipfs\",\n content: avatar\n });\n return {\n linkage,\n url: getIpfsLink(avatar)\n };\n case \"erc721\":\n case \"erc1155\":\n {\n // Depending on the ERC type, use tokenURI(uint256) or url(uint256)\n const selector = scheme === \"erc721\" ? \"0xc87b56dd\" : \"0x0e89341c\";\n linkage.push({\n type: scheme,\n content: avatar\n });\n // The owner of this name\n const owner = this._resolvedAddress || (yield this.getAddress());\n const comps = (match[2] || \"\").split(\"/\");\n if (comps.length !== 2) {\n return null;\n }\n const addr = yield this.provider.formatter.address(comps[0]);\n const tokenId = hexZeroPad(BigNumber.from(comps[1]).toHexString(), 32);\n // Check that this account owns the token\n if (scheme === \"erc721\") {\n // ownerOf(uint256 tokenId)\n const tokenOwner = this.provider.formatter.callAddress(yield this.provider.call({\n to: addr,\n data: hexConcat([\"0x6352211e\", tokenId])\n }));\n if (owner !== tokenOwner) {\n return null;\n }\n linkage.push({\n type: \"owner\",\n content: tokenOwner\n });\n } else if (scheme === \"erc1155\") {\n // balanceOf(address owner, uint256 tokenId)\n const balance = BigNumber.from(yield this.provider.call({\n to: addr,\n data: hexConcat([\"0x00fdd58e\", hexZeroPad(owner, 32), tokenId])\n }));\n if (balance.isZero()) {\n return null;\n }\n linkage.push({\n type: \"balance\",\n content: balance.toString()\n });\n }\n // Call the token contract for the metadata URL\n const tx = {\n to: this.provider.formatter.address(comps[0]),\n data: hexConcat([selector, tokenId])\n };\n let metadataUrl = _parseString(yield this.provider.call(tx), 0);\n if (metadataUrl == null) {\n return null;\n }\n linkage.push({\n type: \"metadata-url-base\",\n content: metadataUrl\n });\n // ERC-1155 allows a generic {id} in the URL\n if (scheme === \"erc1155\") {\n metadataUrl = metadataUrl.replace(\"{id}\", tokenId.substring(2));\n linkage.push({\n type: \"metadata-url-expanded\",\n content: metadataUrl\n });\n }\n // Transform IPFS metadata links\n if (metadataUrl.match(/^ipfs:/i)) {\n metadataUrl = getIpfsLink(metadataUrl);\n }\n linkage.push({\n type: \"metadata-url\",\n content: metadataUrl\n });\n // Get the token metadata\n const metadata = yield fetchJson(metadataUrl);\n if (!metadata) {\n return null;\n }\n linkage.push({\n type: \"metadata\",\n content: JSON.stringify(metadata)\n });\n // Pull the image URL out\n let imageUrl = metadata.image;\n if (typeof imageUrl !== \"string\") {\n return null;\n }\n if (imageUrl.match(/^(https:\\/\\/|data:)/i)) {\n // Allow\n } else {\n // Transform IPFS link to gateway\n const ipfs = imageUrl.match(matcherIpfs);\n if (ipfs == null) {\n return null;\n }\n linkage.push({\n type: \"url-ipfs\",\n content: imageUrl\n });\n imageUrl = getIpfsLink(imageUrl);\n }\n linkage.push({\n type: \"url\",\n content: imageUrl\n });\n return {\n linkage,\n url: imageUrl\n };\n }\n }\n }\n } catch (error) {}\n return null;\n });\n }\n getContentHash() {\n return __awaiter(this, void 0, void 0, function* () {\n // keccak256(\"contenthash()\")\n const hexBytes = yield this._fetchBytes(\"0xbc1c58d1\");\n // No contenthash\n if (hexBytes == null || hexBytes === \"0x\") {\n return null;\n }\n // IPFS (CID: 1, Type: DAG-PB)\n const ipfs = hexBytes.match(/^0xe3010170(([0-9a-f][0-9a-f])([0-9a-f][0-9a-f])([0-9a-f]*))$/);\n if (ipfs) {\n const length = parseInt(ipfs[3], 16);\n if (ipfs[4].length === length * 2) {\n return \"ipfs:/\\/\" + Base58.encode(\"0x\" + ipfs[1]);\n }\n }\n // IPNS (CID: 1, Type: libp2p-key)\n const ipns = hexBytes.match(/^0xe5010172(([0-9a-f][0-9a-f])([0-9a-f][0-9a-f])([0-9a-f]*))$/);\n if (ipns) {\n const length = parseInt(ipns[3], 16);\n if (ipns[4].length === length * 2) {\n return \"ipns:/\\/\" + Base58.encode(\"0x\" + ipns[1]);\n }\n }\n // Swarm (CID: 1, Type: swarm-manifest; hash/length hard-coded to keccak256/32)\n const swarm = hexBytes.match(/^0xe40101fa011b20([0-9a-f]*)$/);\n if (swarm) {\n if (swarm[1].length === 32 * 2) {\n return \"bzz:/\\/\" + swarm[1];\n }\n }\n const skynet = hexBytes.match(/^0x90b2c605([0-9a-f]*)$/);\n if (skynet) {\n if (skynet[1].length === 34 * 2) {\n // URL Safe base64; https://datatracker.ietf.org/doc/html/rfc4648#section-5\n const urlSafe = {\n \"=\": \"\",\n \"+\": \"-\",\n \"/\": \"_\"\n };\n const hash = base64Encode(\"0x\" + skynet[1]).replace(/[=+\\/]/g, a => urlSafe[a]);\n return \"sia:/\\/\" + hash;\n }\n }\n return logger.throwError(`invalid or unsupported content hash data`, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"getContentHash()\",\n data: hexBytes\n });\n });\n }\n getText(key) {\n return __awaiter(this, void 0, void 0, function* () {\n // The key encoded as parameter to fetchBytes\n let keyBytes = toUtf8Bytes(key);\n // The nodehash consumes the first slot, so the string pointer targets\n // offset 64, with the length at offset 64 and data starting at offset 96\n keyBytes = concat([bytes32ify(64), bytes32ify(keyBytes.length), keyBytes]);\n // Pad to word-size (32 bytes)\n if (keyBytes.length % 32 !== 0) {\n keyBytes = concat([keyBytes, hexZeroPad(\"0x\", 32 - key.length % 32)]);\n }\n const hexBytes = yield this._fetchBytes(\"0x59d1d43c\", hexlify(keyBytes));\n if (hexBytes == null || hexBytes === \"0x\") {\n return null;\n }\n return toUtf8String(hexBytes);\n });\n }\n}\nlet defaultFormatter = null;\nlet nextPollId = 1;\nexport class BaseProvider extends Provider {\n /**\n * ready\n *\n * A Promise that resolves only once the provider is ready.\n *\n * Sub-classes that call the super with a network without a chainId\n * MUST set this. Standard named networks have a known chainId.\n *\n */\n constructor(network) {\n super();\n // Events being listened to\n this._events = [];\n this._emitted = {\n block: -2\n };\n this.disableCcipRead = false;\n this.formatter = new.target.getFormatter();\n // If network is any, this Provider allows the underlying\n // network to change dynamically, and we auto-detect the\n // current network\n defineReadOnly(this, \"anyNetwork\", network === \"any\");\n if (this.anyNetwork) {\n network = this.detectNetwork();\n }\n if (network instanceof Promise) {\n this._networkPromise = network;\n // Squash any \"unhandled promise\" errors; that do not need to be handled\n network.catch(error => {});\n // Trigger initial network setting (async)\n this._ready().catch(error => {});\n } else {\n const knownNetwork = getStatic(new.target, \"getNetwork\")(network);\n if (knownNetwork) {\n defineReadOnly(this, \"_network\", knownNetwork);\n this.emit(\"network\", knownNetwork, null);\n } else {\n logger.throwArgumentError(\"invalid network\", \"network\", network);\n }\n }\n this._maxInternalBlockNumber = -1024;\n this._lastBlockNumber = -2;\n this._maxFilterBlockRange = 10;\n this._pollingInterval = 4000;\n this._fastQueryDate = 0;\n }\n _ready() {\n return __awaiter(this, void 0, void 0, function* () {\n if (this._network == null) {\n let network = null;\n if (this._networkPromise) {\n try {\n network = yield this._networkPromise;\n } catch (error) {}\n }\n // Try the Provider's network detection (this MUST throw if it cannot)\n if (network == null) {\n network = yield this.detectNetwork();\n }\n // This should never happen; every Provider sub-class should have\n // suggested a network by here (or have thrown).\n if (!network) {\n logger.throwError(\"no network detected\", Logger.errors.UNKNOWN_ERROR, {});\n }\n // Possible this call stacked so do not call defineReadOnly again\n if (this._network == null) {\n if (this.anyNetwork) {\n this._network = network;\n } else {\n defineReadOnly(this, \"_network\", network);\n }\n this.emit(\"network\", network, null);\n }\n }\n return this._network;\n });\n }\n // This will always return the most recently established network.\n // For \"any\", this can change (a \"network\" event is emitted before\n // any change is reflected); otherwise this cannot change\n get ready() {\n return poll(() => {\n return this._ready().then(network => {\n return network;\n }, error => {\n // If the network isn't running yet, we will wait\n if (error.code === Logger.errors.NETWORK_ERROR && error.event === \"noNetwork\") {\n return undefined;\n }\n throw error;\n });\n });\n }\n // @TODO: Remove this and just create a singleton formatter\n static getFormatter() {\n if (defaultFormatter == null) {\n defaultFormatter = new Formatter();\n }\n return defaultFormatter;\n }\n // @TODO: Remove this and just use getNetwork\n static getNetwork(network) {\n return getNetwork(network == null ? \"homestead\" : network);\n }\n ccipReadFetch(tx, calldata, urls) {\n return __awaiter(this, void 0, void 0, function* () {\n if (this.disableCcipRead || urls.length === 0) {\n return null;\n }\n const sender = tx.to.toLowerCase();\n const data = calldata.toLowerCase();\n const errorMessages = [];\n for (let i = 0; i < urls.length; i++) {\n const url = urls[i];\n // URL expansion\n const href = url.replace(\"{sender}\", sender).replace(\"{data}\", data);\n // If no {data} is present, use POST; otherwise GET\n const json = url.indexOf(\"{data}\") >= 0 ? null : JSON.stringify({\n data,\n sender\n });\n const result = yield fetchJson({\n url: href,\n errorPassThrough: true\n }, json, (value, response) => {\n value.status = response.statusCode;\n return value;\n });\n if (result.data) {\n return result.data;\n }\n const errorMessage = result.message || \"unknown error\";\n // 4xx indicates the result is not present; stop\n if (result.status >= 400 && result.status < 500) {\n return logger.throwError(`response not found during CCIP fetch: ${errorMessage}`, Logger.errors.SERVER_ERROR, {\n url,\n errorMessage\n });\n }\n // 5xx indicates server issue; try the next url\n errorMessages.push(errorMessage);\n }\n return logger.throwError(`error encountered during CCIP fetch: ${errorMessages.map(m => JSON.stringify(m)).join(\", \")}`, Logger.errors.SERVER_ERROR, {\n urls,\n errorMessages\n });\n });\n }\n // Fetches the blockNumber, but will reuse any result that is less\n // than maxAge old or has been requested since the last request\n _getInternalBlockNumber(maxAge) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this._ready();\n // Allowing stale data up to maxAge old\n if (maxAge > 0) {\n // While there are pending internal block requests...\n while (this._internalBlockNumber) {\n // ...\"remember\" which fetch we started with\n const internalBlockNumber = this._internalBlockNumber;\n try {\n // Check the result is not too stale\n const result = yield internalBlockNumber;\n if (getTime() - result.respTime <= maxAge) {\n return result.blockNumber;\n }\n // Too old; fetch a new value\n break;\n } catch (error) {\n // The fetch rejected; if we are the first to get the\n // rejection, drop through so we replace it with a new\n // fetch; all others blocked will then get that fetch\n // which won't match the one they \"remembered\" and loop\n if (this._internalBlockNumber === internalBlockNumber) {\n break;\n }\n }\n }\n }\n const reqTime = getTime();\n const checkInternalBlockNumber = resolveProperties({\n blockNumber: this.perform(\"getBlockNumber\", {}),\n networkError: this.getNetwork().then(network => null, error => error)\n }).then(({\n blockNumber,\n networkError\n }) => {\n if (networkError) {\n // Unremember this bad internal block number\n if (this._internalBlockNumber === checkInternalBlockNumber) {\n this._internalBlockNumber = null;\n }\n throw networkError;\n }\n const respTime = getTime();\n blockNumber = BigNumber.from(blockNumber).toNumber();\n if (blockNumber < this._maxInternalBlockNumber) {\n blockNumber = this._maxInternalBlockNumber;\n }\n this._maxInternalBlockNumber = blockNumber;\n this._setFastBlockNumber(blockNumber); // @TODO: Still need this?\n return {\n blockNumber,\n reqTime,\n respTime\n };\n });\n this._internalBlockNumber = checkInternalBlockNumber;\n // Swallow unhandled exceptions; if needed they are handled else where\n checkInternalBlockNumber.catch(error => {\n // Don't null the dead (rejected) fetch, if it has already been updated\n if (this._internalBlockNumber === checkInternalBlockNumber) {\n this._internalBlockNumber = null;\n }\n });\n return (yield checkInternalBlockNumber).blockNumber;\n });\n }\n poll() {\n return __awaiter(this, void 0, void 0, function* () {\n const pollId = nextPollId++;\n // Track all running promises, so we can trigger a post-poll once they are complete\n const runners = [];\n let blockNumber = null;\n try {\n blockNumber = yield this._getInternalBlockNumber(100 + this.pollingInterval / 2);\n } catch (error) {\n this.emit(\"error\", error);\n return;\n }\n this._setFastBlockNumber(blockNumber);\n // Emit a poll event after we have the latest (fast) block number\n this.emit(\"poll\", pollId, blockNumber);\n // If the block has not changed, meh.\n if (blockNumber === this._lastBlockNumber) {\n this.emit(\"didPoll\", pollId);\n return;\n }\n // First polling cycle, trigger a \"block\" events\n if (this._emitted.block === -2) {\n this._emitted.block = blockNumber - 1;\n }\n if (Math.abs(this._emitted.block - blockNumber) > 1000) {\n logger.warn(`network block skew detected; skipping block events (emitted=${this._emitted.block} blockNumber${blockNumber})`);\n this.emit(\"error\", logger.makeError(\"network block skew detected\", Logger.errors.NETWORK_ERROR, {\n blockNumber: blockNumber,\n event: \"blockSkew\",\n previousBlockNumber: this._emitted.block\n }));\n this.emit(\"block\", blockNumber);\n } else {\n // Notify all listener for each block that has passed\n for (let i = this._emitted.block + 1; i <= blockNumber; i++) {\n this.emit(\"block\", i);\n }\n }\n // The emitted block was updated, check for obsolete events\n if (this._emitted.block !== blockNumber) {\n this._emitted.block = blockNumber;\n Object.keys(this._emitted).forEach(key => {\n // The block event does not expire\n if (key === \"block\") {\n return;\n }\n // The block we were at when we emitted this event\n const eventBlockNumber = this._emitted[key];\n // We cannot garbage collect pending transactions or blocks here\n // They should be garbage collected by the Provider when setting\n // \"pending\" events\n if (eventBlockNumber === \"pending\") {\n return;\n }\n // Evict any transaction hashes or block hashes over 12 blocks\n // old, since they should not return null anyways\n if (blockNumber - eventBlockNumber > 12) {\n delete this._emitted[key];\n }\n });\n }\n // First polling cycle\n if (this._lastBlockNumber === -2) {\n this._lastBlockNumber = blockNumber - 1;\n }\n // Find all transaction hashes we are waiting on\n this._events.forEach(event => {\n switch (event.type) {\n case \"tx\":\n {\n const hash = event.hash;\n let runner = this.getTransactionReceipt(hash).then(receipt => {\n if (!receipt || receipt.blockNumber == null) {\n return null;\n }\n this._emitted[\"t:\" + hash] = receipt.blockNumber;\n this.emit(hash, receipt);\n return null;\n }).catch(error => {\n this.emit(\"error\", error);\n });\n runners.push(runner);\n break;\n }\n case \"filter\":\n {\n // We only allow a single getLogs to be in-flight at a time\n if (!event._inflight) {\n event._inflight = true;\n // This is the first filter for this event, so we want to\n // restrict events to events that happened no earlier than now\n if (event._lastBlockNumber === -2) {\n event._lastBlockNumber = blockNumber - 1;\n }\n // Filter from the last *known* event; due to load-balancing\n // and some nodes returning updated block numbers before\n // indexing events, a logs result with 0 entries cannot be\n // trusted and we must retry a range which includes it again\n const filter = event.filter;\n filter.fromBlock = event._lastBlockNumber + 1;\n filter.toBlock = blockNumber;\n // Prevent fitler ranges from growing too wild, since it is quite\n // likely there just haven't been any events to move the lastBlockNumber.\n const minFromBlock = filter.toBlock - this._maxFilterBlockRange;\n if (minFromBlock > filter.fromBlock) {\n filter.fromBlock = minFromBlock;\n }\n if (filter.fromBlock < 0) {\n filter.fromBlock = 0;\n }\n const runner = this.getLogs(filter).then(logs => {\n // Allow the next getLogs\n event._inflight = false;\n if (logs.length === 0) {\n return;\n }\n logs.forEach(log => {\n // Only when we get an event for a given block number\n // can we trust the events are indexed\n if (log.blockNumber > event._lastBlockNumber) {\n event._lastBlockNumber = log.blockNumber;\n }\n // Make sure we stall requests to fetch blocks and txs\n this._emitted[\"b:\" + log.blockHash] = log.blockNumber;\n this._emitted[\"t:\" + log.transactionHash] = log.blockNumber;\n this.emit(filter, log);\n });\n }).catch(error => {\n this.emit(\"error\", error);\n // Allow another getLogs (the range was not updated)\n event._inflight = false;\n });\n runners.push(runner);\n }\n break;\n }\n }\n });\n this._lastBlockNumber = blockNumber;\n // Once all events for this loop have been processed, emit \"didPoll\"\n Promise.all(runners).then(() => {\n this.emit(\"didPoll\", pollId);\n }).catch(error => {\n this.emit(\"error\", error);\n });\n return;\n });\n }\n // Deprecated; do not use this\n resetEventsBlock(blockNumber) {\n this._lastBlockNumber = blockNumber - 1;\n if (this.polling) {\n this.poll();\n }\n }\n get network() {\n return this._network;\n }\n // This method should query the network if the underlying network\n // can change, such as when connected to a JSON-RPC backend\n detectNetwork() {\n return __awaiter(this, void 0, void 0, function* () {\n return logger.throwError(\"provider does not support network detection\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"provider.detectNetwork\"\n });\n });\n }\n getNetwork() {\n return __awaiter(this, void 0, void 0, function* () {\n const network = yield this._ready();\n // Make sure we are still connected to the same network; this is\n // only an external call for backends which can have the underlying\n // network change spontaneously\n const currentNetwork = yield this.detectNetwork();\n if (network.chainId !== currentNetwork.chainId) {\n // We are allowing network changes, things can get complex fast;\n // make sure you know what you are doing if you use \"any\"\n if (this.anyNetwork) {\n this._network = currentNetwork;\n // Reset all internal block number guards and caches\n this._lastBlockNumber = -2;\n this._fastBlockNumber = null;\n this._fastBlockNumberPromise = null;\n this._fastQueryDate = 0;\n this._emitted.block = -2;\n this._maxInternalBlockNumber = -1024;\n this._internalBlockNumber = null;\n // The \"network\" event MUST happen before this method resolves\n // so any events have a chance to unregister, so we stall an\n // additional event loop before returning from /this/ call\n this.emit(\"network\", currentNetwork, network);\n yield stall(0);\n return this._network;\n }\n const error = logger.makeError(\"underlying network changed\", Logger.errors.NETWORK_ERROR, {\n event: \"changed\",\n network: network,\n detectedNetwork: currentNetwork\n });\n this.emit(\"error\", error);\n throw error;\n }\n return network;\n });\n }\n get blockNumber() {\n this._getInternalBlockNumber(100 + this.pollingInterval / 2).then(blockNumber => {\n this._setFastBlockNumber(blockNumber);\n }, error => {});\n return this._fastBlockNumber != null ? this._fastBlockNumber : -1;\n }\n get polling() {\n return this._poller != null;\n }\n set polling(value) {\n if (value && !this._poller) {\n this._poller = setInterval(() => {\n this.poll();\n }, this.pollingInterval);\n if (!this._bootstrapPoll) {\n this._bootstrapPoll = setTimeout(() => {\n this.poll();\n // We block additional polls until the polling interval\n // is done, to prevent overwhelming the poll function\n this._bootstrapPoll = setTimeout(() => {\n // If polling was disabled, something may require a poke\n // since starting the bootstrap poll and it was disabled\n if (!this._poller) {\n this.poll();\n }\n // Clear out the bootstrap so we can do another\n this._bootstrapPoll = null;\n }, this.pollingInterval);\n }, 0);\n }\n } else if (!value && this._poller) {\n clearInterval(this._poller);\n this._poller = null;\n }\n }\n get pollingInterval() {\n return this._pollingInterval;\n }\n set pollingInterval(value) {\n if (typeof value !== \"number\" || value <= 0 || parseInt(String(value)) != value) {\n throw new Error(\"invalid polling interval\");\n }\n this._pollingInterval = value;\n if (this._poller) {\n clearInterval(this._poller);\n this._poller = setInterval(() => {\n this.poll();\n }, this._pollingInterval);\n }\n }\n _getFastBlockNumber() {\n const now = getTime();\n // Stale block number, request a newer value\n if (now - this._fastQueryDate > 2 * this._pollingInterval) {\n this._fastQueryDate = now;\n this._fastBlockNumberPromise = this.getBlockNumber().then(blockNumber => {\n if (this._fastBlockNumber == null || blockNumber > this._fastBlockNumber) {\n this._fastBlockNumber = blockNumber;\n }\n return this._fastBlockNumber;\n });\n }\n return this._fastBlockNumberPromise;\n }\n _setFastBlockNumber(blockNumber) {\n // Older block, maybe a stale request\n if (this._fastBlockNumber != null && blockNumber < this._fastBlockNumber) {\n return;\n }\n // Update the time we updated the blocknumber\n this._fastQueryDate = getTime();\n // Newer block number, use it\n if (this._fastBlockNumber == null || blockNumber > this._fastBlockNumber) {\n this._fastBlockNumber = blockNumber;\n this._fastBlockNumberPromise = Promise.resolve(blockNumber);\n }\n }\n waitForTransaction(transactionHash, confirmations, timeout) {\n return __awaiter(this, void 0, void 0, function* () {\n return this._waitForTransaction(transactionHash, confirmations == null ? 1 : confirmations, timeout || 0, null);\n });\n }\n _waitForTransaction(transactionHash, confirmations, timeout, replaceable) {\n return __awaiter(this, void 0, void 0, function* () {\n const receipt = yield this.getTransactionReceipt(transactionHash);\n // Receipt is already good\n if ((receipt ? receipt.confirmations : 0) >= confirmations) {\n return receipt;\n }\n // Poll until the receipt is good...\n return new Promise((resolve, reject) => {\n const cancelFuncs = [];\n let done = false;\n const alreadyDone = function () {\n if (done) {\n return true;\n }\n done = true;\n cancelFuncs.forEach(func => {\n func();\n });\n return false;\n };\n const minedHandler = receipt => {\n if (receipt.confirmations < confirmations) {\n return;\n }\n if (alreadyDone()) {\n return;\n }\n resolve(receipt);\n };\n this.on(transactionHash, minedHandler);\n cancelFuncs.push(() => {\n this.removeListener(transactionHash, minedHandler);\n });\n if (replaceable) {\n let lastBlockNumber = replaceable.startBlock;\n let scannedBlock = null;\n const replaceHandler = blockNumber => __awaiter(this, void 0, void 0, function* () {\n if (done) {\n return;\n }\n // Wait 1 second; this is only used in the case of a fault, so\n // we will trade off a little bit of latency for more consistent\n // results and fewer JSON-RPC calls\n yield stall(1000);\n this.getTransactionCount(replaceable.from).then(nonce => __awaiter(this, void 0, void 0, function* () {\n if (done) {\n return;\n }\n if (nonce <= replaceable.nonce) {\n lastBlockNumber = blockNumber;\n } else {\n // First check if the transaction was mined\n {\n const mined = yield this.getTransaction(transactionHash);\n if (mined && mined.blockNumber != null) {\n return;\n }\n }\n // First time scanning. We start a little earlier for some\n // wiggle room here to handle the eventually consistent nature\n // of blockchain (e.g. the getTransactionCount was for a\n // different block)\n if (scannedBlock == null) {\n scannedBlock = lastBlockNumber - 3;\n if (scannedBlock < replaceable.startBlock) {\n scannedBlock = replaceable.startBlock;\n }\n }\n while (scannedBlock <= blockNumber) {\n if (done) {\n return;\n }\n const block = yield this.getBlockWithTransactions(scannedBlock);\n for (let ti = 0; ti < block.transactions.length; ti++) {\n const tx = block.transactions[ti];\n // Successfully mined!\n if (tx.hash === transactionHash) {\n return;\n }\n // Matches our transaction from and nonce; its a replacement\n if (tx.from === replaceable.from && tx.nonce === replaceable.nonce) {\n if (done) {\n return;\n }\n // Get the receipt of the replacement\n const receipt = yield this.waitForTransaction(tx.hash, confirmations);\n // Already resolved or rejected (prolly a timeout)\n if (alreadyDone()) {\n return;\n }\n // The reason we were replaced\n let reason = \"replaced\";\n if (tx.data === replaceable.data && tx.to === replaceable.to && tx.value.eq(replaceable.value)) {\n reason = \"repriced\";\n } else if (tx.data === \"0x\" && tx.from === tx.to && tx.value.isZero()) {\n reason = \"cancelled\";\n }\n // Explain why we were replaced\n reject(logger.makeError(\"transaction was replaced\", Logger.errors.TRANSACTION_REPLACED, {\n cancelled: reason === \"replaced\" || reason === \"cancelled\",\n reason,\n replacement: this._wrapTransaction(tx),\n hash: transactionHash,\n receipt\n }));\n return;\n }\n }\n scannedBlock++;\n }\n }\n if (done) {\n return;\n }\n this.once(\"block\", replaceHandler);\n }), error => {\n if (done) {\n return;\n }\n this.once(\"block\", replaceHandler);\n });\n });\n if (done) {\n return;\n }\n this.once(\"block\", replaceHandler);\n cancelFuncs.push(() => {\n this.removeListener(\"block\", replaceHandler);\n });\n }\n if (typeof timeout === \"number\" && timeout > 0) {\n const timer = setTimeout(() => {\n if (alreadyDone()) {\n return;\n }\n reject(logger.makeError(\"timeout exceeded\", Logger.errors.TIMEOUT, {\n timeout: timeout\n }));\n }, timeout);\n if (timer.unref) {\n timer.unref();\n }\n cancelFuncs.push(() => {\n clearTimeout(timer);\n });\n }\n });\n });\n }\n getBlockNumber() {\n return __awaiter(this, void 0, void 0, function* () {\n return this._getInternalBlockNumber(0);\n });\n }\n getGasPrice() {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const result = yield this.perform(\"getGasPrice\", {});\n try {\n return BigNumber.from(result);\n } catch (error) {\n return logger.throwError(\"bad result from backend\", Logger.errors.SERVER_ERROR, {\n method: \"getGasPrice\",\n result,\n error\n });\n }\n });\n }\n getBalance(addressOrName, blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const params = yield resolveProperties({\n address: this._getAddress(addressOrName),\n blockTag: this._getBlockTag(blockTag)\n });\n const result = yield this.perform(\"getBalance\", params);\n try {\n return BigNumber.from(result);\n } catch (error) {\n return logger.throwError(\"bad result from backend\", Logger.errors.SERVER_ERROR, {\n method: \"getBalance\",\n params,\n result,\n error\n });\n }\n });\n }\n getTransactionCount(addressOrName, blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const params = yield resolveProperties({\n address: this._getAddress(addressOrName),\n blockTag: this._getBlockTag(blockTag)\n });\n const result = yield this.perform(\"getTransactionCount\", params);\n try {\n return BigNumber.from(result).toNumber();\n } catch (error) {\n return logger.throwError(\"bad result from backend\", Logger.errors.SERVER_ERROR, {\n method: \"getTransactionCount\",\n params,\n result,\n error\n });\n }\n });\n }\n getCode(addressOrName, blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const params = yield resolveProperties({\n address: this._getAddress(addressOrName),\n blockTag: this._getBlockTag(blockTag)\n });\n const result = yield this.perform(\"getCode\", params);\n try {\n return hexlify(result);\n } catch (error) {\n return logger.throwError(\"bad result from backend\", Logger.errors.SERVER_ERROR, {\n method: \"getCode\",\n params,\n result,\n error\n });\n }\n });\n }\n getStorageAt(addressOrName, position, blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const params = yield resolveProperties({\n address: this._getAddress(addressOrName),\n blockTag: this._getBlockTag(blockTag),\n position: Promise.resolve(position).then(p => hexValue(p))\n });\n const result = yield this.perform(\"getStorageAt\", params);\n try {\n return hexlify(result);\n } catch (error) {\n return logger.throwError(\"bad result from backend\", Logger.errors.SERVER_ERROR, {\n method: \"getStorageAt\",\n params,\n result,\n error\n });\n }\n });\n }\n // This should be called by any subclass wrapping a TransactionResponse\n _wrapTransaction(tx, hash, startBlock) {\n if (hash != null && hexDataLength(hash) !== 32) {\n throw new Error(\"invalid response - sendTransaction\");\n }\n const result = tx;\n // Check the hash we expect is the same as the hash the server reported\n if (hash != null && tx.hash !== hash) {\n logger.throwError(\"Transaction hash mismatch from Provider.sendTransaction.\", Logger.errors.UNKNOWN_ERROR, {\n expectedHash: tx.hash,\n returnedHash: hash\n });\n }\n result.wait = (confirms, timeout) => __awaiter(this, void 0, void 0, function* () {\n if (confirms == null) {\n confirms = 1;\n }\n if (timeout == null) {\n timeout = 0;\n }\n // Get the details to detect replacement\n let replacement = undefined;\n if (confirms !== 0 && startBlock != null) {\n replacement = {\n data: tx.data,\n from: tx.from,\n nonce: tx.nonce,\n to: tx.to,\n value: tx.value,\n startBlock\n };\n }\n const receipt = yield this._waitForTransaction(tx.hash, confirms, timeout, replacement);\n if (receipt == null && confirms === 0) {\n return null;\n }\n // No longer pending, allow the polling loop to garbage collect this\n this._emitted[\"t:\" + tx.hash] = receipt.blockNumber;\n if (receipt.status === 0) {\n logger.throwError(\"transaction failed\", Logger.errors.CALL_EXCEPTION, {\n transactionHash: tx.hash,\n transaction: tx,\n receipt: receipt\n });\n }\n return receipt;\n });\n return result;\n }\n sendTransaction(signedTransaction) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const hexTx = yield Promise.resolve(signedTransaction).then(t => hexlify(t));\n const tx = this.formatter.transaction(signedTransaction);\n if (tx.confirmations == null) {\n tx.confirmations = 0;\n }\n const blockNumber = yield this._getInternalBlockNumber(100 + 2 * this.pollingInterval);\n try {\n const hash = yield this.perform(\"sendTransaction\", {\n signedTransaction: hexTx\n });\n return this._wrapTransaction(tx, hash, blockNumber);\n } catch (error) {\n error.transaction = tx;\n error.transactionHash = tx.hash;\n throw error;\n }\n });\n }\n _getTransactionRequest(transaction) {\n return __awaiter(this, void 0, void 0, function* () {\n const values = yield transaction;\n const tx = {};\n [\"from\", \"to\"].forEach(key => {\n if (values[key] == null) {\n return;\n }\n tx[key] = Promise.resolve(values[key]).then(v => v ? this._getAddress(v) : null);\n });\n [\"gasLimit\", \"gasPrice\", \"maxFeePerGas\", \"maxPriorityFeePerGas\", \"value\"].forEach(key => {\n if (values[key] == null) {\n return;\n }\n tx[key] = Promise.resolve(values[key]).then(v => v ? BigNumber.from(v) : null);\n });\n [\"type\"].forEach(key => {\n if (values[key] == null) {\n return;\n }\n tx[key] = Promise.resolve(values[key]).then(v => v != null ? v : null);\n });\n if (values.accessList) {\n tx.accessList = this.formatter.accessList(values.accessList);\n }\n [\"data\"].forEach(key => {\n if (values[key] == null) {\n return;\n }\n tx[key] = Promise.resolve(values[key]).then(v => v ? hexlify(v) : null);\n });\n return this.formatter.transactionRequest(yield resolveProperties(tx));\n });\n }\n _getFilter(filter) {\n return __awaiter(this, void 0, void 0, function* () {\n filter = yield filter;\n const result = {};\n if (filter.address != null) {\n result.address = this._getAddress(filter.address);\n }\n [\"blockHash\", \"topics\"].forEach(key => {\n if (filter[key] == null) {\n return;\n }\n result[key] = filter[key];\n });\n [\"fromBlock\", \"toBlock\"].forEach(key => {\n if (filter[key] == null) {\n return;\n }\n result[key] = this._getBlockTag(filter[key]);\n });\n return this.formatter.filter(yield resolveProperties(result));\n });\n }\n _call(transaction, blockTag, attempt) {\n return __awaiter(this, void 0, void 0, function* () {\n if (attempt >= MAX_CCIP_REDIRECTS) {\n logger.throwError(\"CCIP read exceeded maximum redirections\", Logger.errors.SERVER_ERROR, {\n redirects: attempt,\n transaction\n });\n }\n const txSender = transaction.to;\n const result = yield this.perform(\"call\", {\n transaction,\n blockTag\n });\n // CCIP Read request via OffchainLookup(address,string[],bytes,bytes4,bytes)\n if (attempt >= 0 && blockTag === \"latest\" && txSender != null && result.substring(0, 10) === \"0x556f1830\" && hexDataLength(result) % 32 === 4) {\n try {\n const data = hexDataSlice(result, 4);\n // Check the sender of the OffchainLookup matches the transaction\n const sender = hexDataSlice(data, 0, 32);\n if (!BigNumber.from(sender).eq(txSender)) {\n logger.throwError(\"CCIP Read sender did not match\", Logger.errors.CALL_EXCEPTION, {\n name: \"OffchainLookup\",\n signature: \"OffchainLookup(address,string[],bytes,bytes4,bytes)\",\n transaction,\n data: result\n });\n }\n // Read the URLs from the response\n const urls = [];\n const urlsOffset = BigNumber.from(hexDataSlice(data, 32, 64)).toNumber();\n const urlsLength = BigNumber.from(hexDataSlice(data, urlsOffset, urlsOffset + 32)).toNumber();\n const urlsData = hexDataSlice(data, urlsOffset + 32);\n for (let u = 0; u < urlsLength; u++) {\n const url = _parseString(urlsData, u * 32);\n if (url == null) {\n logger.throwError(\"CCIP Read contained corrupt URL string\", Logger.errors.CALL_EXCEPTION, {\n name: \"OffchainLookup\",\n signature: \"OffchainLookup(address,string[],bytes,bytes4,bytes)\",\n transaction,\n data: result\n });\n }\n urls.push(url);\n }\n // Get the CCIP calldata to forward\n const calldata = _parseBytes(data, 64);\n // Get the callbackSelector (bytes4)\n if (!BigNumber.from(hexDataSlice(data, 100, 128)).isZero()) {\n logger.throwError(\"CCIP Read callback selector included junk\", Logger.errors.CALL_EXCEPTION, {\n name: \"OffchainLookup\",\n signature: \"OffchainLookup(address,string[],bytes,bytes4,bytes)\",\n transaction,\n data: result\n });\n }\n const callbackSelector = hexDataSlice(data, 96, 100);\n // Get the extra data to send back to the contract as context\n const extraData = _parseBytes(data, 128);\n const ccipResult = yield this.ccipReadFetch(transaction, calldata, urls);\n if (ccipResult == null) {\n logger.throwError(\"CCIP Read disabled or provided no URLs\", Logger.errors.CALL_EXCEPTION, {\n name: \"OffchainLookup\",\n signature: \"OffchainLookup(address,string[],bytes,bytes4,bytes)\",\n transaction,\n data: result\n });\n }\n const tx = {\n to: txSender,\n data: hexConcat([callbackSelector, encodeBytes([ccipResult, extraData])])\n };\n return this._call(tx, blockTag, attempt + 1);\n } catch (error) {\n if (error.code === Logger.errors.SERVER_ERROR) {\n throw error;\n }\n }\n }\n try {\n return hexlify(result);\n } catch (error) {\n return logger.throwError(\"bad result from backend\", Logger.errors.SERVER_ERROR, {\n method: \"call\",\n params: {\n transaction,\n blockTag\n },\n result,\n error\n });\n }\n });\n }\n call(transaction, blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const resolved = yield resolveProperties({\n transaction: this._getTransactionRequest(transaction),\n blockTag: this._getBlockTag(blockTag),\n ccipReadEnabled: Promise.resolve(transaction.ccipReadEnabled)\n });\n return this._call(resolved.transaction, resolved.blockTag, resolved.ccipReadEnabled ? 0 : -1);\n });\n }\n estimateGas(transaction) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const params = yield resolveProperties({\n transaction: this._getTransactionRequest(transaction)\n });\n const result = yield this.perform(\"estimateGas\", params);\n try {\n return BigNumber.from(result);\n } catch (error) {\n return logger.throwError(\"bad result from backend\", Logger.errors.SERVER_ERROR, {\n method: \"estimateGas\",\n params,\n result,\n error\n });\n }\n });\n }\n _getAddress(addressOrName) {\n return __awaiter(this, void 0, void 0, function* () {\n addressOrName = yield addressOrName;\n if (typeof addressOrName !== \"string\") {\n logger.throwArgumentError(\"invalid address or ENS name\", \"name\", addressOrName);\n }\n const address = yield this.resolveName(addressOrName);\n if (address == null) {\n logger.throwError(\"ENS name not configured\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: `resolveName(${JSON.stringify(addressOrName)})`\n });\n }\n return address;\n });\n }\n _getBlock(blockHashOrBlockTag, includeTransactions) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n blockHashOrBlockTag = yield blockHashOrBlockTag;\n // If blockTag is a number (not \"latest\", etc), this is the block number\n let blockNumber = -128;\n const params = {\n includeTransactions: !!includeTransactions\n };\n if (isHexString(blockHashOrBlockTag, 32)) {\n params.blockHash = blockHashOrBlockTag;\n } else {\n try {\n params.blockTag = yield this._getBlockTag(blockHashOrBlockTag);\n if (isHexString(params.blockTag)) {\n blockNumber = parseInt(params.blockTag.substring(2), 16);\n }\n } catch (error) {\n logger.throwArgumentError(\"invalid block hash or block tag\", \"blockHashOrBlockTag\", blockHashOrBlockTag);\n }\n }\n return poll(() => __awaiter(this, void 0, void 0, function* () {\n const block = yield this.perform(\"getBlock\", params);\n // Block was not found\n if (block == null) {\n // For blockhashes, if we didn't say it existed, that blockhash may\n // not exist. If we did see it though, perhaps from a log, we know\n // it exists, and this node is just not caught up yet.\n if (params.blockHash != null) {\n if (this._emitted[\"b:\" + params.blockHash] == null) {\n return null;\n }\n }\n // For block tags, if we are asking for a future block, we return null\n if (params.blockTag != null) {\n if (blockNumber > this._emitted.block) {\n return null;\n }\n }\n // Retry on the next block\n return undefined;\n }\n // Add transactions\n if (includeTransactions) {\n let blockNumber = null;\n for (let i = 0; i < block.transactions.length; i++) {\n const tx = block.transactions[i];\n if (tx.blockNumber == null) {\n tx.confirmations = 0;\n } else if (tx.confirmations == null) {\n if (blockNumber == null) {\n blockNumber = yield this._getInternalBlockNumber(100 + 2 * this.pollingInterval);\n }\n // Add the confirmations using the fast block number (pessimistic)\n let confirmations = blockNumber - tx.blockNumber + 1;\n if (confirmations <= 0) {\n confirmations = 1;\n }\n tx.confirmations = confirmations;\n }\n }\n const blockWithTxs = this.formatter.blockWithTransactions(block);\n blockWithTxs.transactions = blockWithTxs.transactions.map(tx => this._wrapTransaction(tx));\n return blockWithTxs;\n }\n return this.formatter.block(block);\n }), {\n oncePoll: this\n });\n });\n }\n getBlock(blockHashOrBlockTag) {\n return this._getBlock(blockHashOrBlockTag, false);\n }\n getBlockWithTransactions(blockHashOrBlockTag) {\n return this._getBlock(blockHashOrBlockTag, true);\n }\n getTransaction(transactionHash) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n transactionHash = yield transactionHash;\n const params = {\n transactionHash: this.formatter.hash(transactionHash, true)\n };\n return poll(() => __awaiter(this, void 0, void 0, function* () {\n const result = yield this.perform(\"getTransaction\", params);\n if (result == null) {\n if (this._emitted[\"t:\" + transactionHash] == null) {\n return null;\n }\n return undefined;\n }\n const tx = this.formatter.transactionResponse(result);\n if (tx.blockNumber == null) {\n tx.confirmations = 0;\n } else if (tx.confirmations == null) {\n const blockNumber = yield this._getInternalBlockNumber(100 + 2 * this.pollingInterval);\n // Add the confirmations using the fast block number (pessimistic)\n let confirmations = blockNumber - tx.blockNumber + 1;\n if (confirmations <= 0) {\n confirmations = 1;\n }\n tx.confirmations = confirmations;\n }\n return this._wrapTransaction(tx);\n }), {\n oncePoll: this\n });\n });\n }\n getTransactionReceipt(transactionHash) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n transactionHash = yield transactionHash;\n const params = {\n transactionHash: this.formatter.hash(transactionHash, true)\n };\n return poll(() => __awaiter(this, void 0, void 0, function* () {\n const result = yield this.perform(\"getTransactionReceipt\", params);\n if (result == null) {\n if (this._emitted[\"t:\" + transactionHash] == null) {\n return null;\n }\n return undefined;\n }\n // \"geth-etc\" returns receipts before they are ready\n if (result.blockHash == null) {\n return undefined;\n }\n const receipt = this.formatter.receipt(result);\n if (receipt.blockNumber == null) {\n receipt.confirmations = 0;\n } else if (receipt.confirmations == null) {\n const blockNumber = yield this._getInternalBlockNumber(100 + 2 * this.pollingInterval);\n // Add the confirmations using the fast block number (pessimistic)\n let confirmations = blockNumber - receipt.blockNumber + 1;\n if (confirmations <= 0) {\n confirmations = 1;\n }\n receipt.confirmations = confirmations;\n }\n return receipt;\n }), {\n oncePoll: this\n });\n });\n }\n getLogs(filter) {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n const params = yield resolveProperties({\n filter: this._getFilter(filter)\n });\n const logs = yield this.perform(\"getLogs\", params);\n logs.forEach(log => {\n if (log.removed == null) {\n log.removed = false;\n }\n });\n return Formatter.arrayOf(this.formatter.filterLog.bind(this.formatter))(logs);\n });\n }\n getEtherPrice() {\n return __awaiter(this, void 0, void 0, function* () {\n yield this.getNetwork();\n return this.perform(\"getEtherPrice\", {});\n });\n }\n _getBlockTag(blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n blockTag = yield blockTag;\n if (typeof blockTag === \"number\" && blockTag < 0) {\n if (blockTag % 1) {\n logger.throwArgumentError(\"invalid BlockTag\", \"blockTag\", blockTag);\n }\n let blockNumber = yield this._getInternalBlockNumber(100 + 2 * this.pollingInterval);\n blockNumber += blockTag;\n if (blockNumber < 0) {\n blockNumber = 0;\n }\n return this.formatter.blockTag(blockNumber);\n }\n return this.formatter.blockTag(blockTag);\n });\n }\n getResolver(name) {\n return __awaiter(this, void 0, void 0, function* () {\n let currentName = name;\n while (true) {\n if (currentName === \"\" || currentName === \".\") {\n return null;\n }\n // Optimization since the eth node cannot change and does\n // not have a wildcard resolver\n if (name !== \"eth\" && currentName === \"eth\") {\n return null;\n }\n // Check the current node for a resolver\n const addr = yield this._getResolver(currentName, \"getResolver\");\n // Found a resolver!\n if (addr != null) {\n const resolver = new Resolver(this, addr, name);\n // Legacy resolver found, using EIP-2544 so it isn't safe to use\n if (currentName !== name && !(yield resolver.supportsWildcard())) {\n return null;\n }\n return resolver;\n }\n // Get the parent node\n currentName = currentName.split(\".\").slice(1).join(\".\");\n }\n });\n }\n _getResolver(name, operation) {\n return __awaiter(this, void 0, void 0, function* () {\n if (operation == null) {\n operation = \"ENS\";\n }\n const network = yield this.getNetwork();\n // No ENS...\n if (!network.ensAddress) {\n logger.throwError(\"network does not support ENS\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation,\n network: network.name\n });\n }\n try {\n // keccak256(\"resolver(bytes32)\")\n const addrData = yield this.call({\n to: network.ensAddress,\n data: \"0x0178b8bf\" + namehash(name).substring(2)\n });\n return this.formatter.callAddress(addrData);\n } catch (error) {\n // ENS registry cannot throw errors on resolver(bytes32)\n }\n return null;\n });\n }\n resolveName(name) {\n return __awaiter(this, void 0, void 0, function* () {\n name = yield name;\n // If it is already an address, nothing to resolve\n try {\n return Promise.resolve(this.formatter.address(name));\n } catch (error) {\n // If is is a hexstring, the address is bad (See #694)\n if (isHexString(name)) {\n throw error;\n }\n }\n if (typeof name !== \"string\") {\n logger.throwArgumentError(\"invalid ENS name\", \"name\", name);\n }\n // Get the addr from the resolver\n const resolver = yield this.getResolver(name);\n if (!resolver) {\n return null;\n }\n return yield resolver.getAddress();\n });\n }\n lookupAddress(address) {\n return __awaiter(this, void 0, void 0, function* () {\n address = yield address;\n address = this.formatter.address(address);\n const node = address.substring(2).toLowerCase() + \".addr.reverse\";\n const resolverAddr = yield this._getResolver(node, \"lookupAddress\");\n if (resolverAddr == null) {\n return null;\n }\n // keccak(\"name(bytes32)\")\n const name = _parseString(yield this.call({\n to: resolverAddr,\n data: \"0x691f3431\" + namehash(node).substring(2)\n }), 0);\n const addr = yield this.resolveName(name);\n if (addr != address) {\n return null;\n }\n return name;\n });\n }\n getAvatar(nameOrAddress) {\n return __awaiter(this, void 0, void 0, function* () {\n let resolver = null;\n if (isHexString(nameOrAddress)) {\n // Address; reverse lookup\n const address = this.formatter.address(nameOrAddress);\n const node = address.substring(2).toLowerCase() + \".addr.reverse\";\n const resolverAddress = yield this._getResolver(node, \"getAvatar\");\n if (!resolverAddress) {\n return null;\n }\n // Try resolving the avatar against the addr.reverse resolver\n resolver = new Resolver(this, resolverAddress, node);\n try {\n const avatar = yield resolver.getAvatar();\n if (avatar) {\n return avatar.url;\n }\n } catch (error) {\n if (error.code !== Logger.errors.CALL_EXCEPTION) {\n throw error;\n }\n }\n // Try getting the name and performing forward lookup; allowing wildcards\n try {\n // keccak(\"name(bytes32)\")\n const name = _parseString(yield this.call({\n to: resolverAddress,\n data: \"0x691f3431\" + namehash(node).substring(2)\n }), 0);\n resolver = yield this.getResolver(name);\n } catch (error) {\n if (error.code !== Logger.errors.CALL_EXCEPTION) {\n throw error;\n }\n return null;\n }\n } else {\n // ENS name; forward lookup with wildcard\n resolver = yield this.getResolver(nameOrAddress);\n if (!resolver) {\n return null;\n }\n }\n const avatar = yield resolver.getAvatar();\n if (avatar == null) {\n return null;\n }\n return avatar.url;\n });\n }\n perform(method, params) {\n return logger.throwError(method + \" not implemented\", Logger.errors.NOT_IMPLEMENTED, {\n operation: method\n });\n }\n _startEvent(event) {\n this.polling = this._events.filter(e => e.pollable()).length > 0;\n }\n _stopEvent(event) {\n this.polling = this._events.filter(e => e.pollable()).length > 0;\n }\n _addEventListener(eventName, listener, once) {\n const event = new Event(getEventTag(eventName), listener, once);\n this._events.push(event);\n this._startEvent(event);\n return this;\n }\n on(eventName, listener) {\n return this._addEventListener(eventName, listener, false);\n }\n once(eventName, listener) {\n return this._addEventListener(eventName, listener, true);\n }\n emit(eventName, ...args) {\n let result = false;\n let stopped = [];\n let eventTag = getEventTag(eventName);\n this._events = this._events.filter(event => {\n if (event.tag !== eventTag) {\n return true;\n }\n setTimeout(() => {\n event.listener.apply(this, args);\n }, 0);\n result = true;\n if (event.once) {\n stopped.push(event);\n return false;\n }\n return true;\n });\n stopped.forEach(event => {\n this._stopEvent(event);\n });\n return result;\n }\n listenerCount(eventName) {\n if (!eventName) {\n return this._events.length;\n }\n let eventTag = getEventTag(eventName);\n return this._events.filter(event => {\n return event.tag === eventTag;\n }).length;\n }\n listeners(eventName) {\n if (eventName == null) {\n return this._events.map(event => event.listener);\n }\n let eventTag = getEventTag(eventName);\n return this._events.filter(event => event.tag === eventTag).map(event => event.listener);\n }\n off(eventName, listener) {\n if (listener == null) {\n return this.removeAllListeners(eventName);\n }\n const stopped = [];\n let found = false;\n let eventTag = getEventTag(eventName);\n this._events = this._events.filter(event => {\n if (event.tag !== eventTag || event.listener != listener) {\n return true;\n }\n if (found) {\n return true;\n }\n found = true;\n stopped.push(event);\n return false;\n });\n stopped.forEach(event => {\n this._stopEvent(event);\n });\n return this;\n }\n removeAllListeners(eventName) {\n let stopped = [];\n if (eventName == null) {\n stopped = this._events;\n this._events = [];\n } else {\n const eventTag = getEventTag(eventName);\n this._events = this._events.filter(event => {\n if (event.tag !== eventTag) {\n return true;\n }\n stopped.push(event);\n return false;\n });\n }\n stopped.forEach(event => {\n this._stopEvent(event);\n });\n return this;\n }\n}\n","export const version = \"abstract-signer/5.7.0\";\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { defineReadOnly, resolveProperties, shallowCopy } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nconst allowedTransactionKeys = [\"accessList\", \"ccipReadEnabled\", \"chainId\", \"customData\", \"data\", \"from\", \"gasLimit\", \"gasPrice\", \"maxFeePerGas\", \"maxPriorityFeePerGas\", \"nonce\", \"to\", \"type\", \"value\"];\nconst forwardErrors = [Logger.errors.INSUFFICIENT_FUNDS, Logger.errors.NONCE_EXPIRED, Logger.errors.REPLACEMENT_UNDERPRICED];\n;\n;\nexport class Signer {\n ///////////////////\n // Sub-classes MUST call super\n constructor() {\n logger.checkAbstract(new.target, Signer);\n defineReadOnly(this, \"_isSigner\", true);\n }\n ///////////////////\n // Sub-classes MAY override these\n getBalance(blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"getBalance\");\n return yield this.provider.getBalance(this.getAddress(), blockTag);\n });\n }\n getTransactionCount(blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"getTransactionCount\");\n return yield this.provider.getTransactionCount(this.getAddress(), blockTag);\n });\n }\n // Populates \"from\" if unspecified, and estimates the gas for the transaction\n estimateGas(transaction) {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"estimateGas\");\n const tx = yield resolveProperties(this.checkTransaction(transaction));\n return yield this.provider.estimateGas(tx);\n });\n }\n // Populates \"from\" if unspecified, and calls with the transaction\n call(transaction, blockTag) {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"call\");\n const tx = yield resolveProperties(this.checkTransaction(transaction));\n return yield this.provider.call(tx, blockTag);\n });\n }\n // Populates all fields in a transaction, signs it and sends it to the network\n sendTransaction(transaction) {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"sendTransaction\");\n const tx = yield this.populateTransaction(transaction);\n const signedTx = yield this.signTransaction(tx);\n return yield this.provider.sendTransaction(signedTx);\n });\n }\n getChainId() {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"getChainId\");\n const network = yield this.provider.getNetwork();\n return network.chainId;\n });\n }\n getGasPrice() {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"getGasPrice\");\n return yield this.provider.getGasPrice();\n });\n }\n getFeeData() {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"getFeeData\");\n return yield this.provider.getFeeData();\n });\n }\n resolveName(name) {\n return __awaiter(this, void 0, void 0, function* () {\n this._checkProvider(\"resolveName\");\n return yield this.provider.resolveName(name);\n });\n }\n // Checks a transaction does not contain invalid keys and if\n // no \"from\" is provided, populates it.\n // - does NOT require a provider\n // - adds \"from\" is not present\n // - returns a COPY (safe to mutate the result)\n // By default called from: (overriding these prevents it)\n // - call\n // - estimateGas\n // - populateTransaction (and therefor sendTransaction)\n checkTransaction(transaction) {\n for (const key in transaction) {\n if (allowedTransactionKeys.indexOf(key) === -1) {\n logger.throwArgumentError(\"invalid transaction key: \" + key, \"transaction\", transaction);\n }\n }\n const tx = shallowCopy(transaction);\n if (tx.from == null) {\n tx.from = this.getAddress();\n } else {\n // Make sure any provided address matches this signer\n tx.from = Promise.all([Promise.resolve(tx.from), this.getAddress()]).then(result => {\n if (result[0].toLowerCase() !== result[1].toLowerCase()) {\n logger.throwArgumentError(\"from address mismatch\", \"transaction\", transaction);\n }\n return result[0];\n });\n }\n return tx;\n }\n // Populates ALL keys for a transaction and checks that \"from\" matches\n // this Signer. Should be used by sendTransaction but NOT by signTransaction.\n // By default called from: (overriding these prevents it)\n // - sendTransaction\n //\n // Notes:\n // - We allow gasPrice for EIP-1559 as long as it matches maxFeePerGas\n populateTransaction(transaction) {\n return __awaiter(this, void 0, void 0, function* () {\n const tx = yield resolveProperties(this.checkTransaction(transaction));\n if (tx.to != null) {\n tx.to = Promise.resolve(tx.to).then(to => __awaiter(this, void 0, void 0, function* () {\n if (to == null) {\n return null;\n }\n const address = yield this.resolveName(to);\n if (address == null) {\n logger.throwArgumentError(\"provided ENS name resolves to null\", \"tx.to\", to);\n }\n return address;\n }));\n // Prevent this error from causing an UnhandledPromiseException\n tx.to.catch(error => {});\n }\n // Do not allow mixing pre-eip-1559 and eip-1559 properties\n const hasEip1559 = tx.maxFeePerGas != null || tx.maxPriorityFeePerGas != null;\n if (tx.gasPrice != null && (tx.type === 2 || hasEip1559)) {\n logger.throwArgumentError(\"eip-1559 transaction do not support gasPrice\", \"transaction\", transaction);\n } else if ((tx.type === 0 || tx.type === 1) && hasEip1559) {\n logger.throwArgumentError(\"pre-eip-1559 transaction do not support maxFeePerGas/maxPriorityFeePerGas\", \"transaction\", transaction);\n }\n if ((tx.type === 2 || tx.type == null) && tx.maxFeePerGas != null && tx.maxPriorityFeePerGas != null) {\n // Fully-formed EIP-1559 transaction (skip getFeeData)\n tx.type = 2;\n } else if (tx.type === 0 || tx.type === 1) {\n // Explicit Legacy or EIP-2930 transaction\n // Populate missing gasPrice\n if (tx.gasPrice == null) {\n tx.gasPrice = this.getGasPrice();\n }\n } else {\n // We need to get fee data to determine things\n const feeData = yield this.getFeeData();\n if (tx.type == null) {\n // We need to auto-detect the intended type of this transaction...\n if (feeData.maxFeePerGas != null && feeData.maxPriorityFeePerGas != null) {\n // The network supports EIP-1559!\n // Upgrade transaction from null to eip-1559\n tx.type = 2;\n if (tx.gasPrice != null) {\n // Using legacy gasPrice property on an eip-1559 network,\n // so use gasPrice as both fee properties\n const gasPrice = tx.gasPrice;\n delete tx.gasPrice;\n tx.maxFeePerGas = gasPrice;\n tx.maxPriorityFeePerGas = gasPrice;\n } else {\n // Populate missing fee data\n if (tx.maxFeePerGas == null) {\n tx.maxFeePerGas = feeData.maxFeePerGas;\n }\n if (tx.maxPriorityFeePerGas == null) {\n tx.maxPriorityFeePerGas = feeData.maxPriorityFeePerGas;\n }\n }\n } else if (feeData.gasPrice != null) {\n // Network doesn't support EIP-1559...\n // ...but they are trying to use EIP-1559 properties\n if (hasEip1559) {\n logger.throwError(\"network does not support EIP-1559\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"populateTransaction\"\n });\n }\n // Populate missing fee data\n if (tx.gasPrice == null) {\n tx.gasPrice = feeData.gasPrice;\n }\n // Explicitly set untyped transaction to legacy\n tx.type = 0;\n } else {\n // getFeeData has failed us.\n logger.throwError(\"failed to get consistent fee data\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"signer.getFeeData\"\n });\n }\n } else if (tx.type === 2) {\n // Explicitly using EIP-1559\n // Populate missing fee data\n if (tx.maxFeePerGas == null) {\n tx.maxFeePerGas = feeData.maxFeePerGas;\n }\n if (tx.maxPriorityFeePerGas == null) {\n tx.maxPriorityFeePerGas = feeData.maxPriorityFeePerGas;\n }\n }\n }\n if (tx.nonce == null) {\n tx.nonce = this.getTransactionCount(\"pending\");\n }\n if (tx.gasLimit == null) {\n tx.gasLimit = this.estimateGas(tx).catch(error => {\n if (forwardErrors.indexOf(error.code) >= 0) {\n throw error;\n }\n return logger.throwError(\"cannot estimate gas; transaction may fail or may require manual gas limit\", Logger.errors.UNPREDICTABLE_GAS_LIMIT, {\n error: error,\n tx: tx\n });\n });\n }\n if (tx.chainId == null) {\n tx.chainId = this.getChainId();\n } else {\n tx.chainId = Promise.all([Promise.resolve(tx.chainId), this.getChainId()]).then(results => {\n if (results[1] !== 0 && results[0] !== results[1]) {\n logger.throwArgumentError(\"chainId address mismatch\", \"transaction\", transaction);\n }\n return results[0];\n });\n }\n return yield resolveProperties(tx);\n });\n }\n ///////////////////\n // Sub-classes SHOULD leave these alone\n _checkProvider(operation) {\n if (!this.provider) {\n logger.throwError(\"missing provider\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: operation || \"_checkProvider\"\n });\n }\n }\n static isSigner(value) {\n return !!(value && value._isSigner);\n }\n}\nexport class VoidSigner extends Signer {\n constructor(address, provider) {\n super();\n defineReadOnly(this, \"address\", address);\n defineReadOnly(this, \"provider\", provider || null);\n }\n getAddress() {\n return Promise.resolve(this.address);\n }\n _fail(message, operation) {\n return Promise.resolve().then(() => {\n logger.throwError(message, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: operation\n });\n });\n }\n signMessage(message) {\n return this._fail(\"VoidSigner cannot sign messages\", \"signMessage\");\n }\n signTransaction(transaction) {\n return this._fail(\"VoidSigner cannot sign transactions\", \"signTransaction\");\n }\n _signTypedData(domain, types, value) {\n return this._fail(\"VoidSigner cannot sign typed data\", \"signTypedData\");\n }\n connect(provider) {\n return new VoidSigner(this.address, provider);\n }\n}\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { Signer } from \"@ethersproject/abstract-signer\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { hexlify, hexValue, hexZeroPad, isHexString } from \"@ethersproject/bytes\";\nimport { _TypedDataEncoder } from \"@ethersproject/hash\";\nimport { checkProperties, deepCopy, defineReadOnly, getStatic, resolveProperties, shallowCopy } from \"@ethersproject/properties\";\nimport { toUtf8Bytes } from \"@ethersproject/strings\";\nimport { accessListify } from \"@ethersproject/transactions\";\nimport { fetchJson, poll } from \"@ethersproject/web\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { BaseProvider } from \"./base-provider\";\nconst errorGas = [\"call\", \"estimateGas\"];\nfunction spelunk(value, requireData) {\n if (value == null) {\n return null;\n }\n // These *are* the droids we're looking for.\n if (typeof value.message === \"string\" && value.message.match(\"reverted\")) {\n const data = isHexString(value.data) ? value.data : null;\n if (!requireData || data) {\n return {\n message: value.message,\n data\n };\n }\n }\n // Spelunk further...\n if (typeof value === \"object\") {\n for (const key in value) {\n const result = spelunk(value[key], requireData);\n if (result) {\n return result;\n }\n }\n return null;\n }\n // Might be a JSON string we can further descend...\n if (typeof value === \"string\") {\n try {\n return spelunk(JSON.parse(value), requireData);\n } catch (error) {}\n }\n return null;\n}\nfunction checkError(method, error, params) {\n const transaction = params.transaction || params.signedTransaction;\n // Undo the \"convenience\" some nodes are attempting to prevent backwards\n // incompatibility; maybe for v6 consider forwarding reverts as errors\n if (method === \"call\") {\n const result = spelunk(error, true);\n if (result) {\n return result.data;\n }\n // Nothing descriptive..\n logger.throwError(\"missing revert data in call exception; Transaction reverted without a reason string\", Logger.errors.CALL_EXCEPTION, {\n data: \"0x\",\n transaction,\n error\n });\n }\n if (method === \"estimateGas\") {\n // Try to find something, with a preference on SERVER_ERROR body\n let result = spelunk(error.body, false);\n if (result == null) {\n result = spelunk(error, false);\n }\n // Found \"reverted\", this is a CALL_EXCEPTION\n if (result) {\n logger.throwError(\"cannot estimate gas; transaction may fail or may require manual gas limit\", Logger.errors.UNPREDICTABLE_GAS_LIMIT, {\n reason: result.message,\n method,\n transaction,\n error\n });\n }\n }\n // @TODO: Should we spelunk for message too?\n let message = error.message;\n if (error.code === Logger.errors.SERVER_ERROR && error.error && typeof error.error.message === \"string\") {\n message = error.error.message;\n } else if (typeof error.body === \"string\") {\n message = error.body;\n } else if (typeof error.responseText === \"string\") {\n message = error.responseText;\n }\n message = (message || \"\").toLowerCase();\n // \"insufficient funds for gas * price + value + cost(data)\"\n if (message.match(/insufficient funds|base fee exceeds gas limit|InsufficientFunds/i)) {\n logger.throwError(\"insufficient funds for intrinsic transaction cost\", Logger.errors.INSUFFICIENT_FUNDS, {\n error,\n method,\n transaction\n });\n }\n // \"nonce too low\"\n if (message.match(/nonce (is )?too low/i)) {\n logger.throwError(\"nonce has already been used\", Logger.errors.NONCE_EXPIRED, {\n error,\n method,\n transaction\n });\n }\n // \"replacement transaction underpriced\"\n if (message.match(/replacement transaction underpriced|transaction gas price.*too low/i)) {\n logger.throwError(\"replacement fee too low\", Logger.errors.REPLACEMENT_UNDERPRICED, {\n error,\n method,\n transaction\n });\n }\n // \"replacement transaction underpriced\"\n if (message.match(/only replay-protected/i)) {\n logger.throwError(\"legacy pre-eip-155 transactions not supported\", Logger.errors.UNSUPPORTED_OPERATION, {\n error,\n method,\n transaction\n });\n }\n if (errorGas.indexOf(method) >= 0 && message.match(/gas required exceeds allowance|always failing transaction|execution reverted|revert/)) {\n logger.throwError(\"cannot estimate gas; transaction may fail or may require manual gas limit\", Logger.errors.UNPREDICTABLE_GAS_LIMIT, {\n error,\n method,\n transaction\n });\n }\n throw error;\n}\nfunction timer(timeout) {\n return new Promise(function (resolve) {\n setTimeout(resolve, timeout);\n });\n}\nfunction getResult(payload) {\n if (payload.error) {\n // @TODO: not any\n const error = new Error(payload.error.message);\n error.code = payload.error.code;\n error.data = payload.error.data;\n throw error;\n }\n return payload.result;\n}\nfunction getLowerCase(value) {\n if (value) {\n return value.toLowerCase();\n }\n return value;\n}\nconst _constructorGuard = {};\nexport class JsonRpcSigner extends Signer {\n constructor(constructorGuard, provider, addressOrIndex) {\n super();\n if (constructorGuard !== _constructorGuard) {\n throw new Error(\"do not call the JsonRpcSigner constructor directly; use provider.getSigner\");\n }\n defineReadOnly(this, \"provider\", provider);\n if (addressOrIndex == null) {\n addressOrIndex = 0;\n }\n if (typeof addressOrIndex === \"string\") {\n defineReadOnly(this, \"_address\", this.provider.formatter.address(addressOrIndex));\n defineReadOnly(this, \"_index\", null);\n } else if (typeof addressOrIndex === \"number\") {\n defineReadOnly(this, \"_index\", addressOrIndex);\n defineReadOnly(this, \"_address\", null);\n } else {\n logger.throwArgumentError(\"invalid address or index\", \"addressOrIndex\", addressOrIndex);\n }\n }\n connect(provider) {\n return logger.throwError(\"cannot alter JSON-RPC Signer connection\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"connect\"\n });\n }\n connectUnchecked() {\n return new UncheckedJsonRpcSigner(_constructorGuard, this.provider, this._address || this._index);\n }\n getAddress() {\n if (this._address) {\n return Promise.resolve(this._address);\n }\n return this.provider.send(\"eth_accounts\", []).then(accounts => {\n if (accounts.length <= this._index) {\n logger.throwError(\"unknown account #\" + this._index, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"getAddress\"\n });\n }\n return this.provider.formatter.address(accounts[this._index]);\n });\n }\n sendUncheckedTransaction(transaction) {\n transaction = shallowCopy(transaction);\n const fromAddress = this.getAddress().then(address => {\n if (address) {\n address = address.toLowerCase();\n }\n return address;\n });\n // The JSON-RPC for eth_sendTransaction uses 90000 gas; if the user\n // wishes to use this, it is easy to specify explicitly, otherwise\n // we look it up for them.\n if (transaction.gasLimit == null) {\n const estimate = shallowCopy(transaction);\n estimate.from = fromAddress;\n transaction.gasLimit = this.provider.estimateGas(estimate);\n }\n if (transaction.to != null) {\n transaction.to = Promise.resolve(transaction.to).then(to => __awaiter(this, void 0, void 0, function* () {\n if (to == null) {\n return null;\n }\n const address = yield this.provider.resolveName(to);\n if (address == null) {\n logger.throwArgumentError(\"provided ENS name resolves to null\", \"tx.to\", to);\n }\n return address;\n }));\n }\n return resolveProperties({\n tx: resolveProperties(transaction),\n sender: fromAddress\n }).then(({\n tx,\n sender\n }) => {\n if (tx.from != null) {\n if (tx.from.toLowerCase() !== sender) {\n logger.throwArgumentError(\"from address mismatch\", \"transaction\", transaction);\n }\n } else {\n tx.from = sender;\n }\n const hexTx = this.provider.constructor.hexlifyTransaction(tx, {\n from: true\n });\n return this.provider.send(\"eth_sendTransaction\", [hexTx]).then(hash => {\n return hash;\n }, error => {\n if (typeof error.message === \"string\" && error.message.match(/user denied/i)) {\n logger.throwError(\"user rejected transaction\", Logger.errors.ACTION_REJECTED, {\n action: \"sendTransaction\",\n transaction: tx\n });\n }\n return checkError(\"sendTransaction\", error, hexTx);\n });\n });\n }\n signTransaction(transaction) {\n return logger.throwError(\"signing transactions is unsupported\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"signTransaction\"\n });\n }\n sendTransaction(transaction) {\n return __awaiter(this, void 0, void 0, function* () {\n // This cannot be mined any earlier than any recent block\n const blockNumber = yield this.provider._getInternalBlockNumber(100 + 2 * this.provider.pollingInterval);\n // Send the transaction\n const hash = yield this.sendUncheckedTransaction(transaction);\n try {\n // Unfortunately, JSON-RPC only provides and opaque transaction hash\n // for a response, and we need the actual transaction, so we poll\n // for it; it should show up very quickly\n return yield poll(() => __awaiter(this, void 0, void 0, function* () {\n const tx = yield this.provider.getTransaction(hash);\n if (tx === null) {\n return undefined;\n }\n return this.provider._wrapTransaction(tx, hash, blockNumber);\n }), {\n oncePoll: this.provider\n });\n } catch (error) {\n error.transactionHash = hash;\n throw error;\n }\n });\n }\n signMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = typeof message === \"string\" ? toUtf8Bytes(message) : message;\n const address = yield this.getAddress();\n try {\n return yield this.provider.send(\"personal_sign\", [hexlify(data), address.toLowerCase()]);\n } catch (error) {\n if (typeof error.message === \"string\" && error.message.match(/user denied/i)) {\n logger.throwError(\"user rejected signing\", Logger.errors.ACTION_REJECTED, {\n action: \"signMessage\",\n from: address,\n messageData: message\n });\n }\n throw error;\n }\n });\n }\n _legacySignMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = typeof message === \"string\" ? toUtf8Bytes(message) : message;\n const address = yield this.getAddress();\n try {\n // https://github.com/ethereum/wiki/wiki/JSON-RPC#eth_sign\n return yield this.provider.send(\"eth_sign\", [address.toLowerCase(), hexlify(data)]);\n } catch (error) {\n if (typeof error.message === \"string\" && error.message.match(/user denied/i)) {\n logger.throwError(\"user rejected signing\", Logger.errors.ACTION_REJECTED, {\n action: \"_legacySignMessage\",\n from: address,\n messageData: message\n });\n }\n throw error;\n }\n });\n }\n _signTypedData(domain, types, value) {\n return __awaiter(this, void 0, void 0, function* () {\n // Populate any ENS names (in-place)\n const populated = yield _TypedDataEncoder.resolveNames(domain, types, value, name => {\n return this.provider.resolveName(name);\n });\n const address = yield this.getAddress();\n try {\n return yield this.provider.send(\"eth_signTypedData_v4\", [address.toLowerCase(), JSON.stringify(_TypedDataEncoder.getPayload(populated.domain, types, populated.value))]);\n } catch (error) {\n if (typeof error.message === \"string\" && error.message.match(/user denied/i)) {\n logger.throwError(\"user rejected signing\", Logger.errors.ACTION_REJECTED, {\n action: \"_signTypedData\",\n from: address,\n messageData: {\n domain: populated.domain,\n types,\n value: populated.value\n }\n });\n }\n throw error;\n }\n });\n }\n unlock(password) {\n return __awaiter(this, void 0, void 0, function* () {\n const provider = this.provider;\n const address = yield this.getAddress();\n return provider.send(\"personal_unlockAccount\", [address.toLowerCase(), password, null]);\n });\n }\n}\nclass UncheckedJsonRpcSigner extends JsonRpcSigner {\n sendTransaction(transaction) {\n return this.sendUncheckedTransaction(transaction).then(hash => {\n return {\n hash: hash,\n nonce: null,\n gasLimit: null,\n gasPrice: null,\n data: null,\n value: null,\n chainId: null,\n confirmations: 0,\n from: null,\n wait: confirmations => {\n return this.provider.waitForTransaction(hash, confirmations);\n }\n };\n });\n }\n}\nconst allowedTransactionKeys = {\n chainId: true,\n data: true,\n gasLimit: true,\n gasPrice: true,\n nonce: true,\n to: true,\n value: true,\n type: true,\n accessList: true,\n maxFeePerGas: true,\n maxPriorityFeePerGas: true\n};\nexport class JsonRpcProvider extends BaseProvider {\n constructor(url, network) {\n let networkOrReady = network;\n // The network is unknown, query the JSON-RPC for it\n if (networkOrReady == null) {\n networkOrReady = new Promise((resolve, reject) => {\n setTimeout(() => {\n this.detectNetwork().then(network => {\n resolve(network);\n }, error => {\n reject(error);\n });\n }, 0);\n });\n }\n super(networkOrReady);\n // Default URL\n if (!url) {\n url = getStatic(this.constructor, \"defaultUrl\")();\n }\n if (typeof url === \"string\") {\n defineReadOnly(this, \"connection\", Object.freeze({\n url: url\n }));\n } else {\n defineReadOnly(this, \"connection\", Object.freeze(shallowCopy(url)));\n }\n this._nextId = 42;\n }\n get _cache() {\n if (this._eventLoopCache == null) {\n this._eventLoopCache = {};\n }\n return this._eventLoopCache;\n }\n static defaultUrl() {\n return \"http:/\\/localhost:8545\";\n }\n detectNetwork() {\n if (!this._cache[\"detectNetwork\"]) {\n this._cache[\"detectNetwork\"] = this._uncachedDetectNetwork();\n // Clear this cache at the beginning of the next event loop\n setTimeout(() => {\n this._cache[\"detectNetwork\"] = null;\n }, 0);\n }\n return this._cache[\"detectNetwork\"];\n }\n _uncachedDetectNetwork() {\n return __awaiter(this, void 0, void 0, function* () {\n yield timer(0);\n let chainId = null;\n try {\n chainId = yield this.send(\"eth_chainId\", []);\n } catch (error) {\n try {\n chainId = yield this.send(\"net_version\", []);\n } catch (error) {}\n }\n if (chainId != null) {\n const getNetwork = getStatic(this.constructor, \"getNetwork\");\n try {\n return getNetwork(BigNumber.from(chainId).toNumber());\n } catch (error) {\n return logger.throwError(\"could not detect network\", Logger.errors.NETWORK_ERROR, {\n chainId: chainId,\n event: \"invalidNetwork\",\n serverError: error\n });\n }\n }\n return logger.throwError(\"could not detect network\", Logger.errors.NETWORK_ERROR, {\n event: \"noNetwork\"\n });\n });\n }\n getSigner(addressOrIndex) {\n return new JsonRpcSigner(_constructorGuard, this, addressOrIndex);\n }\n getUncheckedSigner(addressOrIndex) {\n return this.getSigner(addressOrIndex).connectUnchecked();\n }\n listAccounts() {\n return this.send(\"eth_accounts\", []).then(accounts => {\n return accounts.map(a => this.formatter.address(a));\n });\n }\n send(method, params) {\n const request = {\n method: method,\n params: params,\n id: this._nextId++,\n jsonrpc: \"2.0\"\n };\n this.emit(\"debug\", {\n action: \"request\",\n request: deepCopy(request),\n provider: this\n });\n // We can expand this in the future to any call, but for now these\n // are the biggest wins and do not require any serializing parameters.\n const cache = [\"eth_chainId\", \"eth_blockNumber\"].indexOf(method) >= 0;\n if (cache && this._cache[method]) {\n return this._cache[method];\n }\n const result = fetchJson(this.connection, JSON.stringify(request), getResult).then(result => {\n this.emit(\"debug\", {\n action: \"response\",\n request: request,\n response: result,\n provider: this\n });\n return result;\n }, error => {\n this.emit(\"debug\", {\n action: \"response\",\n error: error,\n request: request,\n provider: this\n });\n throw error;\n });\n // Cache the fetch, but clear it on the next event loop\n if (cache) {\n this._cache[method] = result;\n setTimeout(() => {\n this._cache[method] = null;\n }, 0);\n }\n return result;\n }\n prepareRequest(method, params) {\n switch (method) {\n case \"getBlockNumber\":\n return [\"eth_blockNumber\", []];\n case \"getGasPrice\":\n return [\"eth_gasPrice\", []];\n case \"getBalance\":\n return [\"eth_getBalance\", [getLowerCase(params.address), params.blockTag]];\n case \"getTransactionCount\":\n return [\"eth_getTransactionCount\", [getLowerCase(params.address), params.blockTag]];\n case \"getCode\":\n return [\"eth_getCode\", [getLowerCase(params.address), params.blockTag]];\n case \"getStorageAt\":\n return [\"eth_getStorageAt\", [getLowerCase(params.address), hexZeroPad(params.position, 32), params.blockTag]];\n case \"sendTransaction\":\n return [\"eth_sendRawTransaction\", [params.signedTransaction]];\n case \"getBlock\":\n if (params.blockTag) {\n return [\"eth_getBlockByNumber\", [params.blockTag, !!params.includeTransactions]];\n } else if (params.blockHash) {\n return [\"eth_getBlockByHash\", [params.blockHash, !!params.includeTransactions]];\n }\n return null;\n case \"getTransaction\":\n return [\"eth_getTransactionByHash\", [params.transactionHash]];\n case \"getTransactionReceipt\":\n return [\"eth_getTransactionReceipt\", [params.transactionHash]];\n case \"call\":\n {\n const hexlifyTransaction = getStatic(this.constructor, \"hexlifyTransaction\");\n return [\"eth_call\", [hexlifyTransaction(params.transaction, {\n from: true\n }), params.blockTag]];\n }\n case \"estimateGas\":\n {\n const hexlifyTransaction = getStatic(this.constructor, \"hexlifyTransaction\");\n return [\"eth_estimateGas\", [hexlifyTransaction(params.transaction, {\n from: true\n })]];\n }\n case \"getLogs\":\n if (params.filter && params.filter.address != null) {\n params.filter.address = getLowerCase(params.filter.address);\n }\n return [\"eth_getLogs\", [params.filter]];\n default:\n break;\n }\n return null;\n }\n perform(method, params) {\n return __awaiter(this, void 0, void 0, function* () {\n // Legacy networks do not like the type field being passed along (which\n // is fair), so we delete type if it is 0 and a non-EIP-1559 network\n if (method === \"call\" || method === \"estimateGas\") {\n const tx = params.transaction;\n if (tx && tx.type != null && BigNumber.from(tx.type).isZero()) {\n // If there are no EIP-1559 properties, it might be non-EIP-1559\n if (tx.maxFeePerGas == null && tx.maxPriorityFeePerGas == null) {\n const feeData = yield this.getFeeData();\n if (feeData.maxFeePerGas == null && feeData.maxPriorityFeePerGas == null) {\n // Network doesn't know about EIP-1559 (and hence type)\n params = shallowCopy(params);\n params.transaction = shallowCopy(tx);\n delete params.transaction.type;\n }\n }\n }\n }\n const args = this.prepareRequest(method, params);\n if (args == null) {\n logger.throwError(method + \" not implemented\", Logger.errors.NOT_IMPLEMENTED, {\n operation: method\n });\n }\n try {\n return yield this.send(args[0], args[1]);\n } catch (error) {\n return checkError(method, error, params);\n }\n });\n }\n _startEvent(event) {\n if (event.tag === \"pending\") {\n this._startPending();\n }\n super._startEvent(event);\n }\n _startPending() {\n if (this._pendingFilter != null) {\n return;\n }\n const self = this;\n const pendingFilter = this.send(\"eth_newPendingTransactionFilter\", []);\n this._pendingFilter = pendingFilter;\n pendingFilter.then(function (filterId) {\n function poll() {\n self.send(\"eth_getFilterChanges\", [filterId]).then(function (hashes) {\n if (self._pendingFilter != pendingFilter) {\n return null;\n }\n let seq = Promise.resolve();\n hashes.forEach(function (hash) {\n // @TODO: This should be garbage collected at some point... How? When?\n self._emitted[\"t:\" + hash.toLowerCase()] = \"pending\";\n seq = seq.then(function () {\n return self.getTransaction(hash).then(function (tx) {\n self.emit(\"pending\", tx);\n return null;\n });\n });\n });\n return seq.then(function () {\n return timer(1000);\n });\n }).then(function () {\n if (self._pendingFilter != pendingFilter) {\n self.send(\"eth_uninstallFilter\", [filterId]);\n return;\n }\n setTimeout(function () {\n poll();\n }, 0);\n return null;\n }).catch(error => {});\n }\n poll();\n return filterId;\n }).catch(error => {});\n }\n _stopEvent(event) {\n if (event.tag === \"pending\" && this.listenerCount(\"pending\") === 0) {\n this._pendingFilter = null;\n }\n super._stopEvent(event);\n }\n // Convert an ethers.js transaction into a JSON-RPC transaction\n // - gasLimit => gas\n // - All values hexlified\n // - All numeric values zero-striped\n // - All addresses are lowercased\n // NOTE: This allows a TransactionRequest, but all values should be resolved\n // before this is called\n // @TODO: This will likely be removed in future versions and prepareRequest\n // will be the preferred method for this.\n static hexlifyTransaction(transaction, allowExtra) {\n // Check only allowed properties are given\n const allowed = shallowCopy(allowedTransactionKeys);\n if (allowExtra) {\n for (const key in allowExtra) {\n if (allowExtra[key]) {\n allowed[key] = true;\n }\n }\n }\n checkProperties(transaction, allowed);\n const result = {};\n // JSON-RPC now requires numeric values to be \"quantity\" values\n [\"chainId\", \"gasLimit\", \"gasPrice\", \"type\", \"maxFeePerGas\", \"maxPriorityFeePerGas\", \"nonce\", \"value\"].forEach(function (key) {\n if (transaction[key] == null) {\n return;\n }\n const value = hexValue(BigNumber.from(transaction[key]));\n if (key === \"gasLimit\") {\n key = \"gas\";\n }\n result[key] = value;\n });\n [\"from\", \"to\", \"data\"].forEach(function (key) {\n if (transaction[key] == null) {\n return;\n }\n result[key] = hexlify(transaction[key]);\n });\n if (transaction.accessList) {\n result[\"accessList\"] = accessListify(transaction.accessList);\n }\n return result;\n }\n}\n","\"use strict\";\n\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nlet WS = null;\ntry {\n WS = WebSocket;\n if (WS == null) {\n throw new Error(\"inject please\");\n }\n} catch (error) {\n const logger = new Logger(version);\n WS = function () {\n logger.throwError(\"WebSockets not supported in this environment\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"new WebSocket()\"\n });\n };\n}\n//export default WS;\n//module.exports = WS;\nexport { WS as WebSocket };\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { JsonRpcProvider } from \"./json-rpc-provider\";\nimport { WebSocket } from \"./ws\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n/**\n * Notes:\n *\n * This provider differs a bit from the polling providers. One main\n * difference is how it handles consistency. The polling providers\n * will stall responses to ensure a consistent state, while this\n * WebSocket provider assumes the connected backend will manage this.\n *\n * For example, if a polling provider emits an event which indicates\n * the event occurred in blockhash XXX, a call to fetch that block by\n * its hash XXX, if not present will retry until it is present. This\n * can occur when querying a pool of nodes that are mildly out of sync\n * with each other.\n */\nlet NextId = 1;\n// For more info about the Real-time Event API see:\n// https://geth.ethereum.org/docs/rpc/pubsub\nexport class WebSocketProvider extends JsonRpcProvider {\n constructor(url, network) {\n // This will be added in the future; please open an issue to expedite\n if (network === \"any\") {\n logger.throwError(\"WebSocketProvider does not support 'any' network yet\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"network:any\"\n });\n }\n if (typeof url === \"string\") {\n super(url, network);\n } else {\n super(\"_websocket\", network);\n }\n this._pollingInterval = -1;\n this._wsReady = false;\n if (typeof url === \"string\") {\n defineReadOnly(this, \"_websocket\", new WebSocket(this.connection.url));\n } else {\n defineReadOnly(this, \"_websocket\", url);\n }\n defineReadOnly(this, \"_requests\", {});\n defineReadOnly(this, \"_subs\", {});\n defineReadOnly(this, \"_subIds\", {});\n defineReadOnly(this, \"_detectNetwork\", super.detectNetwork());\n // Stall sending requests until the socket is open...\n this.websocket.onopen = () => {\n this._wsReady = true;\n Object.keys(this._requests).forEach(id => {\n this.websocket.send(this._requests[id].payload);\n });\n };\n this.websocket.onmessage = messageEvent => {\n const data = messageEvent.data;\n const result = JSON.parse(data);\n if (result.id != null) {\n const id = String(result.id);\n const request = this._requests[id];\n delete this._requests[id];\n if (result.result !== undefined) {\n request.callback(null, result.result);\n this.emit(\"debug\", {\n action: \"response\",\n request: JSON.parse(request.payload),\n response: result.result,\n provider: this\n });\n } else {\n let error = null;\n if (result.error) {\n error = new Error(result.error.message || \"unknown error\");\n defineReadOnly(error, \"code\", result.error.code || null);\n defineReadOnly(error, \"response\", data);\n } else {\n error = new Error(\"unknown error\");\n }\n request.callback(error, undefined);\n this.emit(\"debug\", {\n action: \"response\",\n error: error,\n request: JSON.parse(request.payload),\n provider: this\n });\n }\n } else if (result.method === \"eth_subscription\") {\n // Subscription...\n const sub = this._subs[result.params.subscription];\n if (sub) {\n //this.emit.apply(this, );\n sub.processFunc(result.params.result);\n }\n } else {\n console.warn(\"this should not happen\");\n }\n };\n // This Provider does not actually poll, but we want to trigger\n // poll events for things that depend on them (like stalling for\n // block and transaction lookups)\n const fauxPoll = setInterval(() => {\n this.emit(\"poll\");\n }, 1000);\n if (fauxPoll.unref) {\n fauxPoll.unref();\n }\n }\n // Cannot narrow the type of _websocket, as that is not backwards compatible\n // so we add a getter and let the WebSocket be a public API.\n get websocket() {\n return this._websocket;\n }\n detectNetwork() {\n return this._detectNetwork;\n }\n get pollingInterval() {\n return 0;\n }\n resetEventsBlock(blockNumber) {\n logger.throwError(\"cannot reset events block on WebSocketProvider\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"resetEventBlock\"\n });\n }\n set pollingInterval(value) {\n logger.throwError(\"cannot set polling interval on WebSocketProvider\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"setPollingInterval\"\n });\n }\n poll() {\n return __awaiter(this, void 0, void 0, function* () {\n return null;\n });\n }\n set polling(value) {\n if (!value) {\n return;\n }\n logger.throwError(\"cannot set polling on WebSocketProvider\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"setPolling\"\n });\n }\n send(method, params) {\n const rid = NextId++;\n return new Promise((resolve, reject) => {\n function callback(error, result) {\n if (error) {\n return reject(error);\n }\n return resolve(result);\n }\n const payload = JSON.stringify({\n method: method,\n params: params,\n id: rid,\n jsonrpc: \"2.0\"\n });\n this.emit(\"debug\", {\n action: \"request\",\n request: JSON.parse(payload),\n provider: this\n });\n this._requests[String(rid)] = {\n callback,\n payload\n };\n if (this._wsReady) {\n this.websocket.send(payload);\n }\n });\n }\n static defaultUrl() {\n return \"ws:/\\/localhost:8546\";\n }\n _subscribe(tag, param, processFunc) {\n return __awaiter(this, void 0, void 0, function* () {\n let subIdPromise = this._subIds[tag];\n if (subIdPromise == null) {\n subIdPromise = Promise.all(param).then(param => {\n return this.send(\"eth_subscribe\", param);\n });\n this._subIds[tag] = subIdPromise;\n }\n const subId = yield subIdPromise;\n this._subs[subId] = {\n tag,\n processFunc\n };\n });\n }\n _startEvent(event) {\n switch (event.type) {\n case \"block\":\n this._subscribe(\"block\", [\"newHeads\"], result => {\n const blockNumber = BigNumber.from(result.number).toNumber();\n this._emitted.block = blockNumber;\n this.emit(\"block\", blockNumber);\n });\n break;\n case \"pending\":\n this._subscribe(\"pending\", [\"newPendingTransactions\"], result => {\n this.emit(\"pending\", result);\n });\n break;\n case \"filter\":\n this._subscribe(event.tag, [\"logs\", this._getFilter(event.filter)], result => {\n if (result.removed == null) {\n result.removed = false;\n }\n this.emit(event.filter, this.formatter.filterLog(result));\n });\n break;\n case \"tx\":\n {\n const emitReceipt = event => {\n const hash = event.hash;\n this.getTransactionReceipt(hash).then(receipt => {\n if (!receipt) {\n return;\n }\n this.emit(hash, receipt);\n });\n };\n // In case it is already mined\n emitReceipt(event);\n // To keep things simple, we start up a single newHeads subscription\n // to keep an eye out for transactions we are watching for.\n // Starting a subscription for an event (i.e. \"tx\") that is already\n // running is (basically) a nop.\n this._subscribe(\"tx\", [\"newHeads\"], result => {\n this._events.filter(e => e.type === \"tx\").forEach(emitReceipt);\n });\n break;\n }\n // Nothing is needed\n case \"debug\":\n case \"poll\":\n case \"willPoll\":\n case \"didPoll\":\n case \"error\":\n break;\n default:\n console.log(\"unhandled:\", event);\n break;\n }\n }\n _stopEvent(event) {\n let tag = event.tag;\n if (event.type === \"tx\") {\n // There are remaining transaction event listeners\n if (this._events.filter(e => e.type === \"tx\").length) {\n return;\n }\n tag = \"tx\";\n } else if (this.listenerCount(event.event)) {\n // There are remaining event listeners\n return;\n }\n const subId = this._subIds[tag];\n if (!subId) {\n return;\n }\n delete this._subIds[tag];\n subId.then(subId => {\n if (!this._subs[subId]) {\n return;\n }\n delete this._subs[subId];\n this.send(\"eth_unsubscribe\", [subId]);\n });\n }\n destroy() {\n return __awaiter(this, void 0, void 0, function* () {\n // Wait until we have connected before trying to disconnect\n if (this.websocket.readyState === WebSocket.CONNECTING) {\n yield new Promise(resolve => {\n this.websocket.onopen = function () {\n resolve(true);\n };\n this.websocket.onerror = function () {\n resolve(false);\n };\n });\n }\n // Hangup\n // See: https://developer.mozilla.org/en-US/docs/Web/API/CloseEvent#Status_codes\n this.websocket.close(1000);\n });\n }\n}\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { defineReadOnly, getStatic } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { JsonRpcProvider } from \"./json-rpc-provider\";\n// A StaticJsonRpcProvider is useful when you *know* for certain that\n// the backend will never change, as it never calls eth_chainId to\n// verify its backend. However, if the backend does change, the effects\n// are undefined and may include:\n// - inconsistent results\n// - locking up the UI\n// - block skew warnings\n// - wrong results\n// If the network is not explicit (i.e. auto-detection is expected), the\n// node MUST be running and available to respond to requests BEFORE this\n// is instantiated.\nexport class StaticJsonRpcProvider extends JsonRpcProvider {\n detectNetwork() {\n const _super = Object.create(null, {\n detectNetwork: {\n get: () => super.detectNetwork\n }\n });\n return __awaiter(this, void 0, void 0, function* () {\n let network = this.network;\n if (network == null) {\n network = yield _super.detectNetwork.call(this);\n if (!network) {\n logger.throwError(\"no network detected\", Logger.errors.UNKNOWN_ERROR, {});\n }\n // If still not set, set it\n if (this._network == null) {\n // A static network does not support \"any\"\n defineReadOnly(this, \"_network\", network);\n this.emit(\"network\", network, null);\n }\n }\n return network;\n });\n }\n}\nexport class UrlJsonRpcProvider extends StaticJsonRpcProvider {\n constructor(network, apiKey) {\n logger.checkAbstract(new.target, UrlJsonRpcProvider);\n // Normalize the Network and API Key\n network = getStatic(new.target, \"getNetwork\")(network);\n apiKey = getStatic(new.target, \"getApiKey\")(apiKey);\n const connection = getStatic(new.target, \"getUrl\")(network, apiKey);\n super(connection, network);\n if (typeof apiKey === \"string\") {\n defineReadOnly(this, \"apiKey\", apiKey);\n } else if (apiKey != null) {\n Object.keys(apiKey).forEach(key => {\n defineReadOnly(this, key, apiKey[key]);\n });\n }\n }\n _startPending() {\n logger.warn(\"WARNING: API provider does not support pending filters\");\n }\n isCommunityResource() {\n return false;\n }\n getSigner(address) {\n return logger.throwError(\"API provider does not support signing\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"getSigner\"\n });\n }\n listAccounts() {\n return Promise.resolve([]);\n }\n // Return a defaultApiKey if null, otherwise validate the API key\n static getApiKey(apiKey) {\n return apiKey;\n }\n // Returns the url or connection for the given network and API key. The\n // API key will have been sanitized by the getApiKey first, so any validation\n // or transformations can be done there.\n static getUrl(network, apiKey) {\n return logger.throwError(\"not implemented; sub-classes must override getUrl\", Logger.errors.NOT_IMPLEMENTED, {\n operation: \"getUrl\"\n });\n }\n}\n","\"use strict\";\n\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { showThrottleMessage } from \"./formatter\";\nimport { WebSocketProvider } from \"./websocket-provider\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { UrlJsonRpcProvider } from \"./url-json-rpc-provider\";\n// This key was provided to ethers.js by Alchemy to be used by the\n// default provider, but it is recommended that for your own\n// production environments, that you acquire your own API key at:\n// https://dashboard.alchemyapi.io\nconst defaultApiKey = \"_gg7wSSi0KMBsdKnGVfHDueq6xMB9EkC\";\nexport class AlchemyWebSocketProvider extends WebSocketProvider {\n constructor(network, apiKey) {\n const provider = new AlchemyProvider(network, apiKey);\n const url = provider.connection.url.replace(/^http/i, \"ws\").replace(\".alchemyapi.\", \".ws.alchemyapi.\");\n super(url, provider.network);\n defineReadOnly(this, \"apiKey\", provider.apiKey);\n }\n isCommunityResource() {\n return this.apiKey === defaultApiKey;\n }\n}\nexport class AlchemyProvider extends UrlJsonRpcProvider {\n static getWebSocketProvider(network, apiKey) {\n return new AlchemyWebSocketProvider(network, apiKey);\n }\n static getApiKey(apiKey) {\n if (apiKey == null) {\n return defaultApiKey;\n }\n if (apiKey && typeof apiKey !== \"string\") {\n logger.throwArgumentError(\"invalid apiKey\", \"apiKey\", apiKey);\n }\n return apiKey;\n }\n static getUrl(network, apiKey) {\n let host = null;\n switch (network.name) {\n case \"homestead\":\n host = \"eth-mainnet.alchemyapi.io/v2/\";\n break;\n case \"goerli\":\n host = \"eth-goerli.g.alchemy.com/v2/\";\n break;\n case \"matic\":\n host = \"polygon-mainnet.g.alchemy.com/v2/\";\n break;\n case \"maticmum\":\n host = \"polygon-mumbai.g.alchemy.com/v2/\";\n break;\n case \"arbitrum\":\n host = \"arb-mainnet.g.alchemy.com/v2/\";\n break;\n case \"arbitrum-goerli\":\n host = \"arb-goerli.g.alchemy.com/v2/\";\n break;\n case \"optimism\":\n host = \"opt-mainnet.g.alchemy.com/v2/\";\n break;\n case \"optimism-goerli\":\n host = \"opt-goerli.g.alchemy.com/v2/\";\n break;\n default:\n logger.throwArgumentError(\"unsupported network\", \"network\", arguments[0]);\n }\n return {\n allowGzip: true,\n url: \"https:/\" + \"/\" + host + apiKey,\n throttleCallback: (attempt, url) => {\n if (apiKey === defaultApiKey) {\n showThrottleMessage();\n }\n return Promise.resolve(true);\n }\n };\n }\n isCommunityResource() {\n return this.apiKey === defaultApiKey;\n }\n}\n","import { showThrottleMessage } from \"./formatter\";\nimport { UrlJsonRpcProvider } from \"./url-json-rpc-provider\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nconst defaultApiKey = \"9f7d929b018cdffb338517efa06f58359e86ff1ffd350bc889738523659e7972\";\nfunction getHost(name) {\n switch (name) {\n case \"homestead\":\n return \"rpc.ankr.com/eth/\";\n case \"ropsten\":\n return \"rpc.ankr.com/eth_ropsten/\";\n case \"rinkeby\":\n return \"rpc.ankr.com/eth_rinkeby/\";\n case \"goerli\":\n return \"rpc.ankr.com/eth_goerli/\";\n case \"matic\":\n return \"rpc.ankr.com/polygon/\";\n case \"arbitrum\":\n return \"rpc.ankr.com/arbitrum/\";\n }\n return logger.throwArgumentError(\"unsupported network\", \"name\", name);\n}\nexport class AnkrProvider extends UrlJsonRpcProvider {\n isCommunityResource() {\n return this.apiKey === defaultApiKey;\n }\n static getApiKey(apiKey) {\n if (apiKey == null) {\n return defaultApiKey;\n }\n return apiKey;\n }\n static getUrl(network, apiKey) {\n if (apiKey == null) {\n apiKey = defaultApiKey;\n }\n const connection = {\n allowGzip: true,\n url: \"https:/\\/\" + getHost(network.name) + apiKey,\n throttleCallback: (attempt, url) => {\n if (apiKey.apiKey === defaultApiKey) {\n showThrottleMessage();\n }\n return Promise.resolve(true);\n }\n };\n if (apiKey.projectSecret != null) {\n connection.user = \"\";\n connection.password = apiKey.projectSecret;\n }\n return connection;\n }\n}\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { UrlJsonRpcProvider } from \"./url-json-rpc-provider\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nexport class CloudflareProvider extends UrlJsonRpcProvider {\n static getApiKey(apiKey) {\n if (apiKey != null) {\n logger.throwArgumentError(\"apiKey not supported for cloudflare\", \"apiKey\", apiKey);\n }\n return null;\n }\n static getUrl(network, apiKey) {\n let host = null;\n switch (network.name) {\n case \"homestead\":\n host = \"https://cloudflare-eth.com/\";\n break;\n default:\n logger.throwArgumentError(\"unsupported network\", \"network\", arguments[0]);\n }\n return host;\n }\n perform(method, params) {\n const _super = Object.create(null, {\n perform: {\n get: () => super.perform\n }\n });\n return __awaiter(this, void 0, void 0, function* () {\n // The Cloudflare provider does not support eth_blockNumber,\n // so we get the latest block and pull it from that\n if (method === \"getBlockNumber\") {\n const block = yield _super.perform.call(this, \"getBlock\", {\n blockTag: \"latest\"\n });\n return block.number;\n }\n return _super.perform.call(this, method, params);\n });\n }\n}\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { hexlify, hexValue, isHexString } from \"@ethersproject/bytes\";\nimport { deepCopy, defineReadOnly } from \"@ethersproject/properties\";\nimport { accessListify } from \"@ethersproject/transactions\";\nimport { fetchJson } from \"@ethersproject/web\";\nimport { showThrottleMessage } from \"./formatter\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { BaseProvider } from \"./base-provider\";\n// The transaction has already been sanitized by the calls in Provider\nfunction getTransactionPostData(transaction) {\n const result = {};\n for (let key in transaction) {\n if (transaction[key] == null) {\n continue;\n }\n let value = transaction[key];\n if (key === \"type\" && value === 0) {\n continue;\n }\n // Quantity-types require no leading zero, unless 0\n if ({\n type: true,\n gasLimit: true,\n gasPrice: true,\n maxFeePerGs: true,\n maxPriorityFeePerGas: true,\n nonce: true,\n value: true\n }[key]) {\n value = hexValue(hexlify(value));\n } else if (key === \"accessList\") {\n value = \"[\" + accessListify(value).map(set => {\n return `{address:\"${set.address}\",storageKeys:[\"${set.storageKeys.join('\",\"')}\"]}`;\n }).join(\",\") + \"]\";\n } else {\n value = hexlify(value);\n }\n result[key] = value;\n }\n return result;\n}\nfunction getResult(result) {\n // getLogs, getHistory have weird success responses\n if (result.status == 0 && (result.message === \"No records found\" || result.message === \"No transactions found\")) {\n return result.result;\n }\n if (result.status != 1 || typeof result.message !== \"string\" || !result.message.match(/^OK/)) {\n const error = new Error(\"invalid response\");\n error.result = JSON.stringify(result);\n if ((result.result || \"\").toLowerCase().indexOf(\"rate limit\") >= 0) {\n error.throttleRetry = true;\n }\n throw error;\n }\n return result.result;\n}\nfunction getJsonResult(result) {\n // This response indicates we are being throttled\n if (result && result.status == 0 && result.message == \"NOTOK\" && (result.result || \"\").toLowerCase().indexOf(\"rate limit\") >= 0) {\n const error = new Error(\"throttled response\");\n error.result = JSON.stringify(result);\n error.throttleRetry = true;\n throw error;\n }\n if (result.jsonrpc != \"2.0\") {\n // @TODO: not any\n const error = new Error(\"invalid response\");\n error.result = JSON.stringify(result);\n throw error;\n }\n if (result.error) {\n // @TODO: not any\n const error = new Error(result.error.message || \"unknown error\");\n if (result.error.code) {\n error.code = result.error.code;\n }\n if (result.error.data) {\n error.data = result.error.data;\n }\n throw error;\n }\n return result.result;\n}\n// The blockTag was normalized as a string by the Provider pre-perform operations\nfunction checkLogTag(blockTag) {\n if (blockTag === \"pending\") {\n throw new Error(\"pending not supported\");\n }\n if (blockTag === \"latest\") {\n return blockTag;\n }\n return parseInt(blockTag.substring(2), 16);\n}\nfunction checkError(method, error, transaction) {\n // Undo the \"convenience\" some nodes are attempting to prevent backwards\n // incompatibility; maybe for v6 consider forwarding reverts as errors\n if (method === \"call\" && error.code === Logger.errors.SERVER_ERROR) {\n const e = error.error;\n // Etherscan keeps changing their string\n if (e && (e.message.match(/reverted/i) || e.message.match(/VM execution error/i))) {\n // Etherscan prefixes the data like \"Reverted 0x1234\"\n let data = e.data;\n if (data) {\n data = \"0x\" + data.replace(/^.*0x/i, \"\");\n }\n if (isHexString(data)) {\n return data;\n }\n logger.throwError(\"missing revert data in call exception\", Logger.errors.CALL_EXCEPTION, {\n error,\n data: \"0x\"\n });\n }\n }\n // Get the message from any nested error structure\n let message = error.message;\n if (error.code === Logger.errors.SERVER_ERROR) {\n if (error.error && typeof error.error.message === \"string\") {\n message = error.error.message;\n } else if (typeof error.body === \"string\") {\n message = error.body;\n } else if (typeof error.responseText === \"string\") {\n message = error.responseText;\n }\n }\n message = (message || \"\").toLowerCase();\n // \"Insufficient funds. The account you tried to send transaction from does not have enough funds. Required 21464000000000 and got: 0\"\n if (message.match(/insufficient funds/)) {\n logger.throwError(\"insufficient funds for intrinsic transaction cost\", Logger.errors.INSUFFICIENT_FUNDS, {\n error,\n method,\n transaction\n });\n }\n // \"Transaction with the same hash was already imported.\"\n if (message.match(/same hash was already imported|transaction nonce is too low|nonce too low/)) {\n logger.throwError(\"nonce has already been used\", Logger.errors.NONCE_EXPIRED, {\n error,\n method,\n transaction\n });\n }\n // \"Transaction gas price is too low. There is another transaction with same nonce in the queue. Try increasing the gas price or incrementing the nonce.\"\n if (message.match(/another transaction with same nonce/)) {\n logger.throwError(\"replacement fee too low\", Logger.errors.REPLACEMENT_UNDERPRICED, {\n error,\n method,\n transaction\n });\n }\n if (message.match(/execution failed due to an exception|execution reverted/)) {\n logger.throwError(\"cannot estimate gas; transaction may fail or may require manual gas limit\", Logger.errors.UNPREDICTABLE_GAS_LIMIT, {\n error,\n method,\n transaction\n });\n }\n throw error;\n}\nexport class EtherscanProvider extends BaseProvider {\n constructor(network, apiKey) {\n super(network);\n defineReadOnly(this, \"baseUrl\", this.getBaseUrl());\n defineReadOnly(this, \"apiKey\", apiKey || null);\n }\n getBaseUrl() {\n switch (this.network ? this.network.name : \"invalid\") {\n case \"homestead\":\n return \"https:/\\/api.etherscan.io\";\n case \"goerli\":\n return \"https:/\\/api-goerli.etherscan.io\";\n case \"sepolia\":\n return \"https:/\\/api-sepolia.etherscan.io\";\n case \"matic\":\n return \"https:/\\/api.polygonscan.com\";\n case \"maticmum\":\n return \"https:/\\/api-testnet.polygonscan.com\";\n case \"arbitrum\":\n return \"https:/\\/api.arbiscan.io\";\n case \"arbitrum-goerli\":\n return \"https:/\\/api-goerli.arbiscan.io\";\n case \"optimism\":\n return \"https:/\\/api-optimistic.etherscan.io\";\n case \"optimism-goerli\":\n return \"https:/\\/api-goerli-optimistic.etherscan.io\";\n default:\n }\n return logger.throwArgumentError(\"unsupported network\", \"network\", this.network.name);\n }\n getUrl(module, params) {\n const query = Object.keys(params).reduce((accum, key) => {\n const value = params[key];\n if (value != null) {\n accum += `&${key}=${value}`;\n }\n return accum;\n }, \"\");\n const apiKey = this.apiKey ? `&apikey=${this.apiKey}` : \"\";\n return `${this.baseUrl}/api?module=${module}${query}${apiKey}`;\n }\n getPostUrl() {\n return `${this.baseUrl}/api`;\n }\n getPostData(module, params) {\n params.module = module;\n params.apikey = this.apiKey;\n return params;\n }\n fetch(module, params, post) {\n return __awaiter(this, void 0, void 0, function* () {\n const url = post ? this.getPostUrl() : this.getUrl(module, params);\n const payload = post ? this.getPostData(module, params) : null;\n const procFunc = module === \"proxy\" ? getJsonResult : getResult;\n this.emit(\"debug\", {\n action: \"request\",\n request: url,\n provider: this\n });\n const connection = {\n url: url,\n throttleSlotInterval: 1000,\n throttleCallback: (attempt, url) => {\n if (this.isCommunityResource()) {\n showThrottleMessage();\n }\n return Promise.resolve(true);\n }\n };\n let payloadStr = null;\n if (payload) {\n connection.headers = {\n \"content-type\": \"application/x-www-form-urlencoded; charset=UTF-8\"\n };\n payloadStr = Object.keys(payload).map(key => {\n return `${key}=${payload[key]}`;\n }).join(\"&\");\n }\n const result = yield fetchJson(connection, payloadStr, procFunc || getJsonResult);\n this.emit(\"debug\", {\n action: \"response\",\n request: url,\n response: deepCopy(result),\n provider: this\n });\n return result;\n });\n }\n detectNetwork() {\n return __awaiter(this, void 0, void 0, function* () {\n return this.network;\n });\n }\n perform(method, params) {\n const _super = Object.create(null, {\n perform: {\n get: () => super.perform\n }\n });\n return __awaiter(this, void 0, void 0, function* () {\n switch (method) {\n case \"getBlockNumber\":\n return this.fetch(\"proxy\", {\n action: \"eth_blockNumber\"\n });\n case \"getGasPrice\":\n return this.fetch(\"proxy\", {\n action: \"eth_gasPrice\"\n });\n case \"getBalance\":\n // Returns base-10 result\n return this.fetch(\"account\", {\n action: \"balance\",\n address: params.address,\n tag: params.blockTag\n });\n case \"getTransactionCount\":\n return this.fetch(\"proxy\", {\n action: \"eth_getTransactionCount\",\n address: params.address,\n tag: params.blockTag\n });\n case \"getCode\":\n return this.fetch(\"proxy\", {\n action: \"eth_getCode\",\n address: params.address,\n tag: params.blockTag\n });\n case \"getStorageAt\":\n return this.fetch(\"proxy\", {\n action: \"eth_getStorageAt\",\n address: params.address,\n position: params.position,\n tag: params.blockTag\n });\n case \"sendTransaction\":\n return this.fetch(\"proxy\", {\n action: \"eth_sendRawTransaction\",\n hex: params.signedTransaction\n }, true).catch(error => {\n return checkError(\"sendTransaction\", error, params.signedTransaction);\n });\n case \"getBlock\":\n if (params.blockTag) {\n return this.fetch(\"proxy\", {\n action: \"eth_getBlockByNumber\",\n tag: params.blockTag,\n boolean: params.includeTransactions ? \"true\" : \"false\"\n });\n }\n throw new Error(\"getBlock by blockHash not implemented\");\n case \"getTransaction\":\n return this.fetch(\"proxy\", {\n action: \"eth_getTransactionByHash\",\n txhash: params.transactionHash\n });\n case \"getTransactionReceipt\":\n return this.fetch(\"proxy\", {\n action: \"eth_getTransactionReceipt\",\n txhash: params.transactionHash\n });\n case \"call\":\n {\n if (params.blockTag !== \"latest\") {\n throw new Error(\"EtherscanProvider does not support blockTag for call\");\n }\n const postData = getTransactionPostData(params.transaction);\n postData.module = \"proxy\";\n postData.action = \"eth_call\";\n try {\n return yield this.fetch(\"proxy\", postData, true);\n } catch (error) {\n return checkError(\"call\", error, params.transaction);\n }\n }\n case \"estimateGas\":\n {\n const postData = getTransactionPostData(params.transaction);\n postData.module = \"proxy\";\n postData.action = \"eth_estimateGas\";\n try {\n return yield this.fetch(\"proxy\", postData, true);\n } catch (error) {\n return checkError(\"estimateGas\", error, params.transaction);\n }\n }\n case \"getLogs\":\n {\n const args = {\n action: \"getLogs\"\n };\n if (params.filter.fromBlock) {\n args.fromBlock = checkLogTag(params.filter.fromBlock);\n }\n if (params.filter.toBlock) {\n args.toBlock = checkLogTag(params.filter.toBlock);\n }\n if (params.filter.address) {\n args.address = params.filter.address;\n }\n // @TODO: We can handle slightly more complicated logs using the logs API\n if (params.filter.topics && params.filter.topics.length > 0) {\n if (params.filter.topics.length > 1) {\n logger.throwError(\"unsupported topic count\", Logger.errors.UNSUPPORTED_OPERATION, {\n topics: params.filter.topics\n });\n }\n if (params.filter.topics.length === 1) {\n const topic0 = params.filter.topics[0];\n if (typeof topic0 !== \"string\" || topic0.length !== 66) {\n logger.throwError(\"unsupported topic format\", Logger.errors.UNSUPPORTED_OPERATION, {\n topic0: topic0\n });\n }\n args.topic0 = topic0;\n }\n }\n const logs = yield this.fetch(\"logs\", args);\n // Cache txHash => blockHash\n let blocks = {};\n // Add any missing blockHash to the logs\n for (let i = 0; i < logs.length; i++) {\n const log = logs[i];\n if (log.blockHash != null) {\n continue;\n }\n if (blocks[log.blockNumber] == null) {\n const block = yield this.getBlock(log.blockNumber);\n if (block) {\n blocks[log.blockNumber] = block.hash;\n }\n }\n log.blockHash = blocks[log.blockNumber];\n }\n return logs;\n }\n case \"getEtherPrice\":\n if (this.network.name !== \"homestead\") {\n return 0.0;\n }\n return parseFloat((yield this.fetch(\"stats\", {\n action: \"ethprice\"\n })).ethusd);\n default:\n break;\n }\n return _super.perform.call(this, method, params);\n });\n }\n // Note: The `page` page parameter only allows pagination within the\n // 10,000 window available without a page and offset parameter\n // Error: Result window is too large, PageNo x Offset size must\n // be less than or equal to 10000\n getHistory(addressOrName, startBlock, endBlock) {\n return __awaiter(this, void 0, void 0, function* () {\n const params = {\n action: \"txlist\",\n address: yield this.resolveName(addressOrName),\n startblock: startBlock == null ? 0 : startBlock,\n endblock: endBlock == null ? 99999999 : endBlock,\n sort: \"asc\"\n };\n const result = yield this.fetch(\"account\", params);\n return result.map(tx => {\n [\"contractAddress\", \"to\"].forEach(function (key) {\n if (tx[key] == \"\") {\n delete tx[key];\n }\n });\n if (tx.creates == null && tx.contractAddress != null) {\n tx.creates = tx.contractAddress;\n }\n const item = this.formatter.transactionResponse(tx);\n if (tx.timeStamp) {\n item.timestamp = parseInt(tx.timeStamp);\n }\n return item;\n });\n });\n }\n isCommunityResource() {\n return this.apiKey == null;\n }\n}\n","export const version = \"random/5.7.0\";\n","\"use strict\";\n\nimport { arrayify } from \"@ethersproject/bytes\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n// Debugging line for testing browser lib in node\n//const window = { crypto: { getRandomValues: () => { } } };\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/globalThis\nfunction getGlobal() {\n if (typeof self !== 'undefined') {\n return self;\n }\n if (typeof window !== 'undefined') {\n return window;\n }\n if (typeof global !== 'undefined') {\n return global;\n }\n throw new Error('unable to locate global object');\n}\n;\nconst anyGlobal = getGlobal();\nlet crypto = anyGlobal.crypto || anyGlobal.msCrypto;\nif (!crypto || !crypto.getRandomValues) {\n logger.warn(\"WARNING: Missing strong random number source\");\n crypto = {\n getRandomValues: function (buffer) {\n return logger.throwError(\"no secure random source avaialble\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"crypto.getRandomValues\"\n });\n }\n };\n}\nexport function randomBytes(length) {\n if (length <= 0 || length > 1024 || length % 1 || length != length) {\n logger.throwArgumentError(\"invalid length\", \"length\", length);\n }\n const result = new Uint8Array(length);\n crypto.getRandomValues(result);\n return arrayify(result);\n}\n;\n","\"use strict\";\n\nexport function shuffled(array) {\n array = array.slice();\n for (let i = array.length - 1; i > 0; i--) {\n const j = Math.floor(Math.random() * (i + 1));\n const tmp = array[i];\n array[i] = array[j];\n array[j] = tmp;\n }\n return array;\n}\n","\"use strict\";\n\nexport { randomBytes } from \"./random\";\nexport { shuffled } from \"./shuffle\";\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { Provider } from \"@ethersproject/abstract-provider\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { isHexString } from \"@ethersproject/bytes\";\nimport { deepCopy, defineReadOnly, shallowCopy } from \"@ethersproject/properties\";\nimport { shuffled } from \"@ethersproject/random\";\nimport { poll } from \"@ethersproject/web\";\nimport { BaseProvider } from \"./base-provider\";\nimport { isCommunityResource } from \"./formatter\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nfunction now() {\n return new Date().getTime();\n}\n// Returns to network as long as all agree, or null if any is null.\n// Throws an error if any two networks do not match.\nfunction checkNetworks(networks) {\n let result = null;\n for (let i = 0; i < networks.length; i++) {\n const network = networks[i];\n // Null! We do not know our network; bail.\n if (network == null) {\n return null;\n }\n if (result) {\n // Make sure the network matches the previous networks\n if (!(result.name === network.name && result.chainId === network.chainId && (result.ensAddress === network.ensAddress || result.ensAddress == null && network.ensAddress == null))) {\n logger.throwArgumentError(\"provider mismatch\", \"networks\", networks);\n }\n } else {\n result = network;\n }\n }\n return result;\n}\nfunction median(values, maxDelta) {\n values = values.slice().sort();\n const middle = Math.floor(values.length / 2);\n // Odd length; take the middle\n if (values.length % 2) {\n return values[middle];\n }\n // Even length; take the average of the two middle\n const a = values[middle - 1],\n b = values[middle];\n if (maxDelta != null && Math.abs(a - b) > maxDelta) {\n return null;\n }\n return (a + b) / 2;\n}\nfunction serialize(value) {\n if (value === null) {\n return \"null\";\n } else if (typeof value === \"number\" || typeof value === \"boolean\") {\n return JSON.stringify(value);\n } else if (typeof value === \"string\") {\n return value;\n } else if (BigNumber.isBigNumber(value)) {\n return value.toString();\n } else if (Array.isArray(value)) {\n return JSON.stringify(value.map(i => serialize(i)));\n } else if (typeof value === \"object\") {\n const keys = Object.keys(value);\n keys.sort();\n return \"{\" + keys.map(key => {\n let v = value[key];\n if (typeof v === \"function\") {\n v = \"[function]\";\n } else {\n v = serialize(v);\n }\n return JSON.stringify(key) + \":\" + v;\n }).join(\",\") + \"}\";\n }\n throw new Error(\"unknown value type: \" + typeof value);\n}\n// Next request ID to use for emitting debug info\nlet nextRid = 1;\n;\nfunction stall(duration) {\n let cancel = null;\n let timer = null;\n let promise = new Promise(resolve => {\n cancel = function () {\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n resolve();\n };\n timer = setTimeout(cancel, duration);\n });\n const wait = func => {\n promise = promise.then(func);\n return promise;\n };\n function getPromise() {\n return promise;\n }\n return {\n cancel,\n getPromise,\n wait\n };\n}\nconst ForwardErrors = [Logger.errors.CALL_EXCEPTION, Logger.errors.INSUFFICIENT_FUNDS, Logger.errors.NONCE_EXPIRED, Logger.errors.REPLACEMENT_UNDERPRICED, Logger.errors.UNPREDICTABLE_GAS_LIMIT];\nconst ForwardProperties = [\"address\", \"args\", \"errorArgs\", \"errorSignature\", \"method\", \"transaction\"];\n;\nfunction exposeDebugConfig(config, now) {\n const result = {\n weight: config.weight\n };\n Object.defineProperty(result, \"provider\", {\n get: () => config.provider\n });\n if (config.start) {\n result.start = config.start;\n }\n if (now) {\n result.duration = now - config.start;\n }\n if (config.done) {\n if (config.error) {\n result.error = config.error;\n } else {\n result.result = config.result || null;\n }\n }\n return result;\n}\nfunction normalizedTally(normalize, quorum) {\n return function (configs) {\n // Count the votes for each result\n const tally = {};\n configs.forEach(c => {\n const value = normalize(c.result);\n if (!tally[value]) {\n tally[value] = {\n count: 0,\n result: c.result\n };\n }\n tally[value].count++;\n });\n // Check for a quorum on any given result\n const keys = Object.keys(tally);\n for (let i = 0; i < keys.length; i++) {\n const check = tally[keys[i]];\n if (check.count >= quorum) {\n return check.result;\n }\n }\n // No quroum\n return undefined;\n };\n}\nfunction getProcessFunc(provider, method, params) {\n let normalize = serialize;\n switch (method) {\n case \"getBlockNumber\":\n // Return the median value, unless there is (median + 1) is also\n // present, in which case that is probably true and the median\n // is going to be stale soon. In the event of a malicious node,\n // the lie will be true soon enough.\n return function (configs) {\n const values = configs.map(c => c.result);\n // Get the median block number\n let blockNumber = median(configs.map(c => c.result), 2);\n if (blockNumber == null) {\n return undefined;\n }\n blockNumber = Math.ceil(blockNumber);\n // If the next block height is present, its prolly safe to use\n if (values.indexOf(blockNumber + 1) >= 0) {\n blockNumber++;\n }\n // Don't ever roll back the blockNumber\n if (blockNumber >= provider._highestBlockNumber) {\n provider._highestBlockNumber = blockNumber;\n }\n return provider._highestBlockNumber;\n };\n case \"getGasPrice\":\n // Return the middle (round index up) value, similar to median\n // but do not average even entries and choose the higher.\n // Malicious actors must compromise 50% of the nodes to lie.\n return function (configs) {\n const values = configs.map(c => c.result);\n values.sort();\n return values[Math.floor(values.length / 2)];\n };\n case \"getEtherPrice\":\n // Returns the median price. Malicious actors must compromise at\n // least 50% of the nodes to lie (in a meaningful way).\n return function (configs) {\n return median(configs.map(c => c.result));\n };\n // No additional normalizing required; serialize is enough\n case \"getBalance\":\n case \"getTransactionCount\":\n case \"getCode\":\n case \"getStorageAt\":\n case \"call\":\n case \"estimateGas\":\n case \"getLogs\":\n break;\n // We drop the confirmations from transactions as it is approximate\n case \"getTransaction\":\n case \"getTransactionReceipt\":\n normalize = function (tx) {\n if (tx == null) {\n return null;\n }\n tx = shallowCopy(tx);\n tx.confirmations = -1;\n return serialize(tx);\n };\n break;\n // We drop the confirmations from transactions as it is approximate\n case \"getBlock\":\n // We drop the confirmations from transactions as it is approximate\n if (params.includeTransactions) {\n normalize = function (block) {\n if (block == null) {\n return null;\n }\n block = shallowCopy(block);\n block.transactions = block.transactions.map(tx => {\n tx = shallowCopy(tx);\n tx.confirmations = -1;\n return tx;\n });\n return serialize(block);\n };\n } else {\n normalize = function (block) {\n if (block == null) {\n return null;\n }\n return serialize(block);\n };\n }\n break;\n default:\n throw new Error(\"unknown method: \" + method);\n }\n // Return the result if and only if the expected quorum is\n // satisfied and agreed upon for the final result.\n return normalizedTally(normalize, provider.quorum);\n}\n// If we are doing a blockTag query, we need to make sure the backend is\n// caught up to the FallbackProvider, before sending a request to it.\nfunction waitForSync(config, blockNumber) {\n return __awaiter(this, void 0, void 0, function* () {\n const provider = config.provider;\n if (provider.blockNumber != null && provider.blockNumber >= blockNumber || blockNumber === -1) {\n return provider;\n }\n return poll(() => {\n return new Promise((resolve, reject) => {\n setTimeout(function () {\n // We are synced\n if (provider.blockNumber >= blockNumber) {\n return resolve(provider);\n }\n // We're done; just quit\n if (config.cancelled) {\n return resolve(null);\n }\n // Try again, next block\n return resolve(undefined);\n }, 0);\n });\n }, {\n oncePoll: provider\n });\n });\n}\nfunction getRunner(config, currentBlockNumber, method, params) {\n return __awaiter(this, void 0, void 0, function* () {\n let provider = config.provider;\n switch (method) {\n case \"getBlockNumber\":\n case \"getGasPrice\":\n return provider[method]();\n case \"getEtherPrice\":\n if (provider.getEtherPrice) {\n return provider.getEtherPrice();\n }\n break;\n case \"getBalance\":\n case \"getTransactionCount\":\n case \"getCode\":\n if (params.blockTag && isHexString(params.blockTag)) {\n provider = yield waitForSync(config, currentBlockNumber);\n }\n return provider[method](params.address, params.blockTag || \"latest\");\n case \"getStorageAt\":\n if (params.blockTag && isHexString(params.blockTag)) {\n provider = yield waitForSync(config, currentBlockNumber);\n }\n return provider.getStorageAt(params.address, params.position, params.blockTag || \"latest\");\n case \"getBlock\":\n if (params.blockTag && isHexString(params.blockTag)) {\n provider = yield waitForSync(config, currentBlockNumber);\n }\n return provider[params.includeTransactions ? \"getBlockWithTransactions\" : \"getBlock\"](params.blockTag || params.blockHash);\n case \"call\":\n case \"estimateGas\":\n if (params.blockTag && isHexString(params.blockTag)) {\n provider = yield waitForSync(config, currentBlockNumber);\n }\n if (method === \"call\" && params.blockTag) {\n return provider[method](params.transaction, params.blockTag);\n }\n return provider[method](params.transaction);\n case \"getTransaction\":\n case \"getTransactionReceipt\":\n return provider[method](params.transactionHash);\n case \"getLogs\":\n {\n let filter = params.filter;\n if (filter.fromBlock && isHexString(filter.fromBlock) || filter.toBlock && isHexString(filter.toBlock)) {\n provider = yield waitForSync(config, currentBlockNumber);\n }\n return provider.getLogs(filter);\n }\n }\n return logger.throwError(\"unknown method error\", Logger.errors.UNKNOWN_ERROR, {\n method: method,\n params: params\n });\n });\n}\nexport class FallbackProvider extends BaseProvider {\n constructor(providers, quorum) {\n if (providers.length === 0) {\n logger.throwArgumentError(\"missing providers\", \"providers\", providers);\n }\n const providerConfigs = providers.map((configOrProvider, index) => {\n if (Provider.isProvider(configOrProvider)) {\n const stallTimeout = isCommunityResource(configOrProvider) ? 2000 : 750;\n const priority = 1;\n return Object.freeze({\n provider: configOrProvider,\n weight: 1,\n stallTimeout,\n priority\n });\n }\n const config = shallowCopy(configOrProvider);\n if (config.priority == null) {\n config.priority = 1;\n }\n if (config.stallTimeout == null) {\n config.stallTimeout = isCommunityResource(configOrProvider) ? 2000 : 750;\n }\n if (config.weight == null) {\n config.weight = 1;\n }\n const weight = config.weight;\n if (weight % 1 || weight > 512 || weight < 1) {\n logger.throwArgumentError(\"invalid weight; must be integer in [1, 512]\", `providers[${index}].weight`, weight);\n }\n return Object.freeze(config);\n });\n const total = providerConfigs.reduce((accum, c) => accum + c.weight, 0);\n if (quorum == null) {\n quorum = total / 2;\n } else if (quorum > total) {\n logger.throwArgumentError(\"quorum will always fail; larger than total weight\", \"quorum\", quorum);\n }\n // Are all providers' networks are known\n let networkOrReady = checkNetworks(providerConfigs.map(c => c.provider.network));\n // Not all networks are known; we must stall\n if (networkOrReady == null) {\n networkOrReady = new Promise((resolve, reject) => {\n setTimeout(() => {\n this.detectNetwork().then(resolve, reject);\n }, 0);\n });\n }\n super(networkOrReady);\n // Preserve a copy, so we do not get mutated\n defineReadOnly(this, \"providerConfigs\", Object.freeze(providerConfigs));\n defineReadOnly(this, \"quorum\", quorum);\n this._highestBlockNumber = -1;\n }\n detectNetwork() {\n return __awaiter(this, void 0, void 0, function* () {\n const networks = yield Promise.all(this.providerConfigs.map(c => c.provider.getNetwork()));\n return checkNetworks(networks);\n });\n }\n perform(method, params) {\n return __awaiter(this, void 0, void 0, function* () {\n // Sending transactions is special; always broadcast it to all backends\n if (method === \"sendTransaction\") {\n const results = yield Promise.all(this.providerConfigs.map(c => {\n return c.provider.sendTransaction(params.signedTransaction).then(result => {\n return result.hash;\n }, error => {\n return error;\n });\n }));\n // Any success is good enough (other errors are likely \"already seen\" errors\n for (let i = 0; i < results.length; i++) {\n const result = results[i];\n if (typeof result === \"string\") {\n return result;\n }\n }\n // They were all an error; pick the first error\n throw results[0];\n }\n // We need to make sure we are in sync with our backends, so we need\n // to know this before we can make a lot of calls\n if (this._highestBlockNumber === -1 && method !== \"getBlockNumber\") {\n yield this.getBlockNumber();\n }\n const processFunc = getProcessFunc(this, method, params);\n // Shuffle the providers and then sort them by their priority; we\n // shallowCopy them since we will store the result in them too\n const configs = shuffled(this.providerConfigs.map(shallowCopy));\n configs.sort((a, b) => a.priority - b.priority);\n const currentBlockNumber = this._highestBlockNumber;\n let i = 0;\n let first = true;\n while (true) {\n const t0 = now();\n // Compute the inflight weight (exclude anything past)\n let inflightWeight = configs.filter(c => c.runner && t0 - c.start < c.stallTimeout).reduce((accum, c) => accum + c.weight, 0);\n // Start running enough to meet quorum\n while (inflightWeight < this.quorum && i < configs.length) {\n const config = configs[i++];\n const rid = nextRid++;\n config.start = now();\n config.staller = stall(config.stallTimeout);\n config.staller.wait(() => {\n config.staller = null;\n });\n config.runner = getRunner(config, currentBlockNumber, method, params).then(result => {\n config.done = true;\n config.result = result;\n if (this.listenerCount(\"debug\")) {\n this.emit(\"debug\", {\n action: \"request\",\n rid: rid,\n backend: exposeDebugConfig(config, now()),\n request: {\n method: method,\n params: deepCopy(params)\n },\n provider: this\n });\n }\n }, error => {\n config.done = true;\n config.error = error;\n if (this.listenerCount(\"debug\")) {\n this.emit(\"debug\", {\n action: \"request\",\n rid: rid,\n backend: exposeDebugConfig(config, now()),\n request: {\n method: method,\n params: deepCopy(params)\n },\n provider: this\n });\n }\n });\n if (this.listenerCount(\"debug\")) {\n this.emit(\"debug\", {\n action: \"request\",\n rid: rid,\n backend: exposeDebugConfig(config, null),\n request: {\n method: method,\n params: deepCopy(params)\n },\n provider: this\n });\n }\n inflightWeight += config.weight;\n }\n // Wait for anything meaningful to finish or stall out\n const waiting = [];\n configs.forEach(c => {\n if (c.done || !c.runner) {\n return;\n }\n waiting.push(c.runner);\n if (c.staller) {\n waiting.push(c.staller.getPromise());\n }\n });\n if (waiting.length) {\n yield Promise.race(waiting);\n }\n // Check the quorum and process the results; the process function\n // may additionally decide the quorum is not met\n const results = configs.filter(c => c.done && c.error == null);\n if (results.length >= this.quorum) {\n const result = processFunc(results);\n if (result !== undefined) {\n // Shut down any stallers\n configs.forEach(c => {\n if (c.staller) {\n c.staller.cancel();\n }\n c.cancelled = true;\n });\n return result;\n }\n if (!first) {\n yield stall(100).getPromise();\n }\n first = false;\n }\n // No result, check for errors that should be forwarded\n const errors = configs.reduce((accum, c) => {\n if (!c.done || c.error == null) {\n return accum;\n }\n const code = c.error.code;\n if (ForwardErrors.indexOf(code) >= 0) {\n if (!accum[code]) {\n accum[code] = {\n error: c.error,\n weight: 0\n };\n }\n accum[code].weight += c.weight;\n }\n return accum;\n }, {});\n Object.keys(errors).forEach(errorCode => {\n const tally = errors[errorCode];\n if (tally.weight < this.quorum) {\n return;\n }\n // Shut down any stallers\n configs.forEach(c => {\n if (c.staller) {\n c.staller.cancel();\n }\n c.cancelled = true;\n });\n const e = tally.error;\n const props = {};\n ForwardProperties.forEach(name => {\n if (e[name] == null) {\n return;\n }\n props[name] = e[name];\n });\n logger.throwError(e.reason || e.message, errorCode, props);\n });\n // All configs have run to completion; we will never get more data\n if (configs.filter(c => !c.done).length === 0) {\n break;\n }\n }\n // Shut down any stallers; shouldn't be any\n configs.forEach(c => {\n if (c.staller) {\n c.staller.cancel();\n }\n c.cancelled = true;\n });\n return logger.throwError(\"failed to meet quorum\", Logger.errors.SERVER_ERROR, {\n method: method,\n params: params,\n //results: configs.map((c) => c.result),\n //errors: configs.map((c) => c.error),\n results: configs.map(c => exposeDebugConfig(c)),\n provider: this\n });\n });\n }\n}\n","\"use strict\";\n\nconst IpcProvider = null;\nexport { IpcProvider };\n","\"use strict\";\n\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { WebSocketProvider } from \"./websocket-provider\";\nimport { showThrottleMessage } from \"./formatter\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { UrlJsonRpcProvider } from \"./url-json-rpc-provider\";\nconst defaultProjectId = \"84842078b09946638c03157f83405213\";\nexport class InfuraWebSocketProvider extends WebSocketProvider {\n constructor(network, apiKey) {\n const provider = new InfuraProvider(network, apiKey);\n const connection = provider.connection;\n if (connection.password) {\n logger.throwError(\"INFURA WebSocket project secrets unsupported\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"InfuraProvider.getWebSocketProvider()\"\n });\n }\n const url = connection.url.replace(/^http/i, \"ws\").replace(\"/v3/\", \"/ws/v3/\");\n super(url, network);\n defineReadOnly(this, \"apiKey\", provider.projectId);\n defineReadOnly(this, \"projectId\", provider.projectId);\n defineReadOnly(this, \"projectSecret\", provider.projectSecret);\n }\n isCommunityResource() {\n return this.projectId === defaultProjectId;\n }\n}\nexport class InfuraProvider extends UrlJsonRpcProvider {\n static getWebSocketProvider(network, apiKey) {\n return new InfuraWebSocketProvider(network, apiKey);\n }\n static getApiKey(apiKey) {\n const apiKeyObj = {\n apiKey: defaultProjectId,\n projectId: defaultProjectId,\n projectSecret: null\n };\n if (apiKey == null) {\n return apiKeyObj;\n }\n if (typeof apiKey === \"string\") {\n apiKeyObj.projectId = apiKey;\n } else if (apiKey.projectSecret != null) {\n logger.assertArgument(typeof apiKey.projectId === \"string\", \"projectSecret requires a projectId\", \"projectId\", apiKey.projectId);\n logger.assertArgument(typeof apiKey.projectSecret === \"string\", \"invalid projectSecret\", \"projectSecret\", \"[REDACTED]\");\n apiKeyObj.projectId = apiKey.projectId;\n apiKeyObj.projectSecret = apiKey.projectSecret;\n } else if (apiKey.projectId) {\n apiKeyObj.projectId = apiKey.projectId;\n }\n apiKeyObj.apiKey = apiKeyObj.projectId;\n return apiKeyObj;\n }\n static getUrl(network, apiKey) {\n let host = null;\n switch (network ? network.name : \"unknown\") {\n case \"homestead\":\n host = \"mainnet.infura.io\";\n break;\n case \"goerli\":\n host = \"goerli.infura.io\";\n break;\n case \"sepolia\":\n host = \"sepolia.infura.io\";\n break;\n case \"matic\":\n host = \"polygon-mainnet.infura.io\";\n break;\n case \"maticmum\":\n host = \"polygon-mumbai.infura.io\";\n break;\n case \"optimism\":\n host = \"optimism-mainnet.infura.io\";\n break;\n case \"optimism-goerli\":\n host = \"optimism-goerli.infura.io\";\n break;\n case \"arbitrum\":\n host = \"arbitrum-mainnet.infura.io\";\n break;\n case \"arbitrum-goerli\":\n host = \"arbitrum-goerli.infura.io\";\n break;\n default:\n logger.throwError(\"unsupported network\", Logger.errors.INVALID_ARGUMENT, {\n argument: \"network\",\n value: network\n });\n }\n const connection = {\n allowGzip: true,\n url: \"https:/\" + \"/\" + host + \"/v3/\" + apiKey.projectId,\n throttleCallback: (attempt, url) => {\n if (apiKey.projectId === defaultProjectId) {\n showThrottleMessage();\n }\n return Promise.resolve(true);\n }\n };\n if (apiKey.projectSecret != null) {\n connection.user = \"\";\n connection.password = apiKey.projectSecret;\n }\n return connection;\n }\n isCommunityResource() {\n return this.projectId === defaultProjectId;\n }\n}\n","import { deepCopy } from \"@ethersproject/properties\";\nimport { fetchJson } from \"@ethersproject/web\";\nimport { JsonRpcProvider } from \"./json-rpc-provider\";\n// Experimental\nexport class JsonRpcBatchProvider extends JsonRpcProvider {\n send(method, params) {\n const request = {\n method: method,\n params: params,\n id: this._nextId++,\n jsonrpc: \"2.0\"\n };\n if (this._pendingBatch == null) {\n this._pendingBatch = [];\n }\n const inflightRequest = {\n request,\n resolve: null,\n reject: null\n };\n const promise = new Promise((resolve, reject) => {\n inflightRequest.resolve = resolve;\n inflightRequest.reject = reject;\n });\n this._pendingBatch.push(inflightRequest);\n if (!this._pendingBatchAggregator) {\n // Schedule batch for next event loop + short duration\n this._pendingBatchAggregator = setTimeout(() => {\n // Get teh current batch and clear it, so new requests\n // go into the next batch\n const batch = this._pendingBatch;\n this._pendingBatch = null;\n this._pendingBatchAggregator = null;\n // Get the request as an array of requests\n const request = batch.map(inflight => inflight.request);\n this.emit(\"debug\", {\n action: \"requestBatch\",\n request: deepCopy(request),\n provider: this\n });\n return fetchJson(this.connection, JSON.stringify(request)).then(result => {\n this.emit(\"debug\", {\n action: \"response\",\n request: request,\n response: result,\n provider: this\n });\n // For each result, feed it to the correct Promise, depending\n // on whether it was a success or error\n batch.forEach((inflightRequest, index) => {\n const payload = result[index];\n if (payload.error) {\n const error = new Error(payload.error.message);\n error.code = payload.error.code;\n error.data = payload.error.data;\n inflightRequest.reject(error);\n } else {\n inflightRequest.resolve(payload.result);\n }\n });\n }, error => {\n this.emit(\"debug\", {\n action: \"response\",\n error: error,\n request: request,\n provider: this\n });\n batch.forEach(inflightRequest => {\n inflightRequest.reject(error);\n });\n });\n }, 10);\n }\n return promise;\n }\n}\n","/* istanbul ignore file */\n\"use strict\";\n\nimport { UrlJsonRpcProvider } from \"./url-json-rpc-provider\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n// Special API key provided by Nodesmith for ethers.js\nconst defaultApiKey = \"ETHERS_JS_SHARED\";\nexport class NodesmithProvider extends UrlJsonRpcProvider {\n static getApiKey(apiKey) {\n if (apiKey && typeof apiKey !== \"string\") {\n logger.throwArgumentError(\"invalid apiKey\", \"apiKey\", apiKey);\n }\n return apiKey || defaultApiKey;\n }\n static getUrl(network, apiKey) {\n logger.warn(\"NodeSmith will be discontinued on 2019-12-20; please migrate to another platform.\");\n let host = null;\n switch (network.name) {\n case \"homestead\":\n host = \"https://ethereum.api.nodesmith.io/v1/mainnet/jsonrpc\";\n break;\n case \"ropsten\":\n host = \"https://ethereum.api.nodesmith.io/v1/ropsten/jsonrpc\";\n break;\n case \"rinkeby\":\n host = \"https://ethereum.api.nodesmith.io/v1/rinkeby/jsonrpc\";\n break;\n case \"goerli\":\n host = \"https://ethereum.api.nodesmith.io/v1/goerli/jsonrpc\";\n break;\n case \"kovan\":\n host = \"https://ethereum.api.nodesmith.io/v1/kovan/jsonrpc\";\n break;\n default:\n logger.throwArgumentError(\"unsupported network\", \"network\", arguments[0]);\n }\n return host + \"?apiKey=\" + apiKey;\n }\n}\n","\"use strict\";\n\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { UrlJsonRpcProvider } from \"./url-json-rpc-provider\";\nconst defaultApplicationId = \"62e1ad51b37b8e00394bda3b\";\nexport class PocketProvider extends UrlJsonRpcProvider {\n static getApiKey(apiKey) {\n const apiKeyObj = {\n applicationId: null,\n loadBalancer: true,\n applicationSecretKey: null\n };\n // Parse applicationId and applicationSecretKey\n if (apiKey == null) {\n apiKeyObj.applicationId = defaultApplicationId;\n } else if (typeof apiKey === \"string\") {\n apiKeyObj.applicationId = apiKey;\n } else if (apiKey.applicationSecretKey != null) {\n apiKeyObj.applicationId = apiKey.applicationId;\n apiKeyObj.applicationSecretKey = apiKey.applicationSecretKey;\n } else if (apiKey.applicationId) {\n apiKeyObj.applicationId = apiKey.applicationId;\n } else {\n logger.throwArgumentError(\"unsupported PocketProvider apiKey\", \"apiKey\", apiKey);\n }\n return apiKeyObj;\n }\n static getUrl(network, apiKey) {\n let host = null;\n switch (network ? network.name : \"unknown\") {\n case \"goerli\":\n host = \"eth-goerli.gateway.pokt.network\";\n break;\n case \"homestead\":\n host = \"eth-mainnet.gateway.pokt.network\";\n break;\n case \"kovan\":\n host = \"poa-kovan.gateway.pokt.network\";\n break;\n case \"matic\":\n host = \"poly-mainnet.gateway.pokt.network\";\n break;\n case \"maticmum\":\n host = \"polygon-mumbai-rpc.gateway.pokt.network\";\n break;\n case \"rinkeby\":\n host = \"eth-rinkeby.gateway.pokt.network\";\n break;\n case \"ropsten\":\n host = \"eth-ropsten.gateway.pokt.network\";\n break;\n default:\n logger.throwError(\"unsupported network\", Logger.errors.INVALID_ARGUMENT, {\n argument: \"network\",\n value: network\n });\n }\n const url = `https:/\\/${host}/v1/lb/${apiKey.applicationId}`;\n const connection = {\n headers: {},\n url\n };\n if (apiKey.applicationSecretKey != null) {\n connection.user = \"\";\n connection.password = apiKey.applicationSecretKey;\n }\n return connection;\n }\n isCommunityResource() {\n return this.applicationId === defaultApplicationId;\n }\n}\n","\"use strict\";\n\nimport { deepCopy, defineReadOnly } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { JsonRpcProvider } from \"./json-rpc-provider\";\nlet _nextId = 1;\nfunction buildWeb3LegacyFetcher(provider, sendFunc) {\n const fetcher = \"Web3LegacyFetcher\";\n return function (method, params) {\n const request = {\n method: method,\n params: params,\n id: _nextId++,\n jsonrpc: \"2.0\"\n };\n return new Promise((resolve, reject) => {\n this.emit(\"debug\", {\n action: \"request\",\n fetcher,\n request: deepCopy(request),\n provider: this\n });\n sendFunc(request, (error, response) => {\n if (error) {\n this.emit(\"debug\", {\n action: \"response\",\n fetcher,\n error,\n request,\n provider: this\n });\n return reject(error);\n }\n this.emit(\"debug\", {\n action: \"response\",\n fetcher,\n request,\n response,\n provider: this\n });\n if (response.error) {\n const error = new Error(response.error.message);\n error.code = response.error.code;\n error.data = response.error.data;\n return reject(error);\n }\n resolve(response.result);\n });\n });\n };\n}\nfunction buildEip1193Fetcher(provider) {\n return function (method, params) {\n if (params == null) {\n params = [];\n }\n const request = {\n method,\n params\n };\n this.emit(\"debug\", {\n action: \"request\",\n fetcher: \"Eip1193Fetcher\",\n request: deepCopy(request),\n provider: this\n });\n return provider.request(request).then(response => {\n this.emit(\"debug\", {\n action: \"response\",\n fetcher: \"Eip1193Fetcher\",\n request,\n response,\n provider: this\n });\n return response;\n }, error => {\n this.emit(\"debug\", {\n action: \"response\",\n fetcher: \"Eip1193Fetcher\",\n request,\n error,\n provider: this\n });\n throw error;\n });\n };\n}\nexport class Web3Provider extends JsonRpcProvider {\n constructor(provider, network) {\n if (provider == null) {\n logger.throwArgumentError(\"missing provider\", \"provider\", provider);\n }\n let path = null;\n let jsonRpcFetchFunc = null;\n let subprovider = null;\n if (typeof provider === \"function\") {\n path = \"unknown:\";\n jsonRpcFetchFunc = provider;\n } else {\n path = provider.host || provider.path || \"\";\n if (!path && provider.isMetaMask) {\n path = \"metamask\";\n }\n subprovider = provider;\n if (provider.request) {\n if (path === \"\") {\n path = \"eip-1193:\";\n }\n jsonRpcFetchFunc = buildEip1193Fetcher(provider);\n } else if (provider.sendAsync) {\n jsonRpcFetchFunc = buildWeb3LegacyFetcher(provider, provider.sendAsync.bind(provider));\n } else if (provider.send) {\n jsonRpcFetchFunc = buildWeb3LegacyFetcher(provider, provider.send.bind(provider));\n } else {\n logger.throwArgumentError(\"unsupported provider\", \"provider\", provider);\n }\n if (!path) {\n path = \"unknown:\";\n }\n }\n super(path, network);\n defineReadOnly(this, \"jsonRpcFetchFunc\", jsonRpcFetchFunc);\n defineReadOnly(this, \"provider\", subprovider);\n }\n send(method, params) {\n return this.jsonRpcFetchFunc(method, params);\n }\n}\n","\"use strict\";\n\nimport { Provider } from \"@ethersproject/abstract-provider\";\nimport { getNetwork } from \"@ethersproject/networks\";\nimport { BaseProvider, Resolver } from \"./base-provider\";\nimport { AlchemyProvider, AlchemyWebSocketProvider } from \"./alchemy-provider\";\nimport { AnkrProvider } from \"./ankr-provider\";\nimport { CloudflareProvider } from \"./cloudflare-provider\";\nimport { EtherscanProvider } from \"./etherscan-provider\";\nimport { FallbackProvider } from \"./fallback-provider\";\nimport { IpcProvider } from \"./ipc-provider\";\nimport { InfuraProvider, InfuraWebSocketProvider } from \"./infura-provider\";\nimport { JsonRpcProvider, JsonRpcSigner } from \"./json-rpc-provider\";\nimport { JsonRpcBatchProvider } from \"./json-rpc-batch-provider\";\nimport { NodesmithProvider } from \"./nodesmith-provider\";\nimport { PocketProvider } from \"./pocket-provider\";\nimport { StaticJsonRpcProvider, UrlJsonRpcProvider } from \"./url-json-rpc-provider\";\nimport { Web3Provider } from \"./web3-provider\";\nimport { WebSocketProvider } from \"./websocket-provider\";\nimport { Formatter, isCommunityResourcable, isCommunityResource, showThrottleMessage } from \"./formatter\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n////////////////////////\n// Helper Functions\nfunction getDefaultProvider(network, options) {\n if (network == null) {\n network = \"homestead\";\n }\n // If passed a URL, figure out the right type of provider based on the scheme\n if (typeof network === \"string\") {\n // @TODO: Add support for IpcProvider; maybe if it ends in \".ipc\"?\n // Handle http and ws (and their secure variants)\n const match = network.match(/^(ws|http)s?:/i);\n if (match) {\n switch (match[1].toLowerCase()) {\n case \"http\":\n case \"https\":\n return new JsonRpcProvider(network);\n case \"ws\":\n case \"wss\":\n return new WebSocketProvider(network);\n default:\n logger.throwArgumentError(\"unsupported URL scheme\", \"network\", network);\n }\n }\n }\n const n = getNetwork(network);\n if (!n || !n._defaultProvider) {\n logger.throwError(\"unsupported getDefaultProvider network\", Logger.errors.NETWORK_ERROR, {\n operation: \"getDefaultProvider\",\n network: network\n });\n }\n return n._defaultProvider({\n FallbackProvider,\n AlchemyProvider,\n AnkrProvider,\n CloudflareProvider,\n EtherscanProvider,\n InfuraProvider,\n JsonRpcProvider,\n NodesmithProvider,\n PocketProvider,\n Web3Provider,\n IpcProvider\n }, options);\n}\n////////////////////////\n// Exports\nexport {\n// Abstract Providers (or Abstract-ish)\nProvider, BaseProvider, Resolver, UrlJsonRpcProvider,\n///////////////////////\n// Concrete Providers\nFallbackProvider, AlchemyProvider, AlchemyWebSocketProvider, AnkrProvider, CloudflareProvider, EtherscanProvider, InfuraProvider, InfuraWebSocketProvider, JsonRpcProvider, JsonRpcBatchProvider, NodesmithProvider, PocketProvider, StaticJsonRpcProvider, Web3Provider, WebSocketProvider, IpcProvider,\n///////////////////////\n// Signer\nJsonRpcSigner,\n///////////////////////\n// Functions\ngetDefaultProvider, getNetwork, isCommunityResource, isCommunityResourcable, showThrottleMessage,\n///////////////////////\n// Objects\nFormatter };\n","export const version = \"abi/5.7.0\";\n","\"use strict\";\n\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n;\nconst _constructorGuard = {};\nlet ModifiersBytes = {\n calldata: true,\n memory: true,\n storage: true\n};\nlet ModifiersNest = {\n calldata: true,\n memory: true\n};\nfunction checkModifier(type, name) {\n if (type === \"bytes\" || type === \"string\") {\n if (ModifiersBytes[name]) {\n return true;\n }\n } else if (type === \"address\") {\n if (name === \"payable\") {\n return true;\n }\n } else if (type.indexOf(\"[\") >= 0 || type === \"tuple\") {\n if (ModifiersNest[name]) {\n return true;\n }\n }\n if (ModifiersBytes[name] || name === \"payable\") {\n logger.throwArgumentError(\"invalid modifier\", \"name\", name);\n }\n return false;\n}\n// @TODO: Make sure that children of an indexed tuple are marked with a null indexed\nfunction parseParamType(param, allowIndexed) {\n let originalParam = param;\n function throwError(i) {\n logger.throwArgumentError(`unexpected character at position ${i}`, \"param\", param);\n }\n param = param.replace(/\\s/g, \" \");\n function newNode(parent) {\n let node = {\n type: \"\",\n name: \"\",\n parent: parent,\n state: {\n allowType: true\n }\n };\n if (allowIndexed) {\n node.indexed = false;\n }\n return node;\n }\n let parent = {\n type: \"\",\n name: \"\",\n state: {\n allowType: true\n }\n };\n let node = parent;\n for (let i = 0; i < param.length; i++) {\n let c = param[i];\n switch (c) {\n case \"(\":\n if (node.state.allowType && node.type === \"\") {\n node.type = \"tuple\";\n } else if (!node.state.allowParams) {\n throwError(i);\n }\n node.state.allowType = false;\n node.type = verifyType(node.type);\n node.components = [newNode(node)];\n node = node.components[0];\n break;\n case \")\":\n delete node.state;\n if (node.name === \"indexed\") {\n if (!allowIndexed) {\n throwError(i);\n }\n node.indexed = true;\n node.name = \"\";\n }\n if (checkModifier(node.type, node.name)) {\n node.name = \"\";\n }\n node.type = verifyType(node.type);\n let child = node;\n node = node.parent;\n if (!node) {\n throwError(i);\n }\n delete child.parent;\n node.state.allowParams = false;\n node.state.allowName = true;\n node.state.allowArray = true;\n break;\n case \",\":\n delete node.state;\n if (node.name === \"indexed\") {\n if (!allowIndexed) {\n throwError(i);\n }\n node.indexed = true;\n node.name = \"\";\n }\n if (checkModifier(node.type, node.name)) {\n node.name = \"\";\n }\n node.type = verifyType(node.type);\n let sibling = newNode(node.parent);\n //{ type: \"\", name: \"\", parent: node.parent, state: { allowType: true } };\n node.parent.components.push(sibling);\n delete node.parent;\n node = sibling;\n break;\n // Hit a space...\n case \" \":\n // If reading type, the type is done and may read a param or name\n if (node.state.allowType) {\n if (node.type !== \"\") {\n node.type = verifyType(node.type);\n delete node.state.allowType;\n node.state.allowName = true;\n node.state.allowParams = true;\n }\n }\n // If reading name, the name is done\n if (node.state.allowName) {\n if (node.name !== \"\") {\n if (node.name === \"indexed\") {\n if (!allowIndexed) {\n throwError(i);\n }\n if (node.indexed) {\n throwError(i);\n }\n node.indexed = true;\n node.name = \"\";\n } else if (checkModifier(node.type, node.name)) {\n node.name = \"\";\n } else {\n node.state.allowName = false;\n }\n }\n }\n break;\n case \"[\":\n if (!node.state.allowArray) {\n throwError(i);\n }\n node.type += c;\n node.state.allowArray = false;\n node.state.allowName = false;\n node.state.readArray = true;\n break;\n case \"]\":\n if (!node.state.readArray) {\n throwError(i);\n }\n node.type += c;\n node.state.readArray = false;\n node.state.allowArray = true;\n node.state.allowName = true;\n break;\n default:\n if (node.state.allowType) {\n node.type += c;\n node.state.allowParams = true;\n node.state.allowArray = true;\n } else if (node.state.allowName) {\n node.name += c;\n delete node.state.allowArray;\n } else if (node.state.readArray) {\n node.type += c;\n } else {\n throwError(i);\n }\n }\n }\n if (node.parent) {\n logger.throwArgumentError(\"unexpected eof\", \"param\", param);\n }\n delete parent.state;\n if (node.name === \"indexed\") {\n if (!allowIndexed) {\n throwError(originalParam.length - 7);\n }\n if (node.indexed) {\n throwError(originalParam.length - 7);\n }\n node.indexed = true;\n node.name = \"\";\n } else if (checkModifier(node.type, node.name)) {\n node.name = \"\";\n }\n parent.type = verifyType(parent.type);\n return parent;\n}\nfunction populate(object, params) {\n for (let key in params) {\n defineReadOnly(object, key, params[key]);\n }\n}\nexport const FormatTypes = Object.freeze({\n // Bare formatting, as is needed for computing a sighash of an event or function\n sighash: \"sighash\",\n // Human-Readable with Minimal spacing and without names (compact human-readable)\n minimal: \"minimal\",\n // Human-Readable with nice spacing, including all names\n full: \"full\",\n // JSON-format a la Solidity\n json: \"json\"\n});\nconst paramTypeArray = new RegExp(/^(.*)\\[([0-9]*)\\]$/);\nexport class ParamType {\n constructor(constructorGuard, params) {\n if (constructorGuard !== _constructorGuard) {\n logger.throwError(\"use fromString\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"new ParamType()\"\n });\n }\n populate(this, params);\n let match = this.type.match(paramTypeArray);\n if (match) {\n populate(this, {\n arrayLength: parseInt(match[2] || \"-1\"),\n arrayChildren: ParamType.fromObject({\n type: match[1],\n components: this.components\n }),\n baseType: \"array\"\n });\n } else {\n populate(this, {\n arrayLength: null,\n arrayChildren: null,\n baseType: this.components != null ? \"tuple\" : this.type\n });\n }\n this._isParamType = true;\n Object.freeze(this);\n }\n // Format the parameter fragment\n // - sighash: \"(uint256,address)\"\n // - minimal: \"tuple(uint256,address) indexed\"\n // - full: \"tuple(uint256 foo, address bar) indexed baz\"\n format(format) {\n if (!format) {\n format = FormatTypes.sighash;\n }\n if (!FormatTypes[format]) {\n logger.throwArgumentError(\"invalid format type\", \"format\", format);\n }\n if (format === FormatTypes.json) {\n let result = {\n type: this.baseType === \"tuple\" ? \"tuple\" : this.type,\n name: this.name || undefined\n };\n if (typeof this.indexed === \"boolean\") {\n result.indexed = this.indexed;\n }\n if (this.components) {\n result.components = this.components.map(comp => JSON.parse(comp.format(format)));\n }\n return JSON.stringify(result);\n }\n let result = \"\";\n // Array\n if (this.baseType === \"array\") {\n result += this.arrayChildren.format(format);\n result += \"[\" + (this.arrayLength < 0 ? \"\" : String(this.arrayLength)) + \"]\";\n } else {\n if (this.baseType === \"tuple\") {\n if (format !== FormatTypes.sighash) {\n result += this.type;\n }\n result += \"(\" + this.components.map(comp => comp.format(format)).join(format === FormatTypes.full ? \", \" : \",\") + \")\";\n } else {\n result += this.type;\n }\n }\n if (format !== FormatTypes.sighash) {\n if (this.indexed === true) {\n result += \" indexed\";\n }\n if (format === FormatTypes.full && this.name) {\n result += \" \" + this.name;\n }\n }\n return result;\n }\n static from(value, allowIndexed) {\n if (typeof value === \"string\") {\n return ParamType.fromString(value, allowIndexed);\n }\n return ParamType.fromObject(value);\n }\n static fromObject(value) {\n if (ParamType.isParamType(value)) {\n return value;\n }\n return new ParamType(_constructorGuard, {\n name: value.name || null,\n type: verifyType(value.type),\n indexed: value.indexed == null ? null : !!value.indexed,\n components: value.components ? value.components.map(ParamType.fromObject) : null\n });\n }\n static fromString(value, allowIndexed) {\n function ParamTypify(node) {\n return ParamType.fromObject({\n name: node.name,\n type: node.type,\n indexed: node.indexed,\n components: node.components\n });\n }\n return ParamTypify(parseParamType(value, !!allowIndexed));\n }\n static isParamType(value) {\n return !!(value != null && value._isParamType);\n }\n}\n;\nfunction parseParams(value, allowIndex) {\n return splitNesting(value).map(param => ParamType.fromString(param, allowIndex));\n}\nexport class Fragment {\n constructor(constructorGuard, params) {\n if (constructorGuard !== _constructorGuard) {\n logger.throwError(\"use a static from method\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"new Fragment()\"\n });\n }\n populate(this, params);\n this._isFragment = true;\n Object.freeze(this);\n }\n static from(value) {\n if (Fragment.isFragment(value)) {\n return value;\n }\n if (typeof value === \"string\") {\n return Fragment.fromString(value);\n }\n return Fragment.fromObject(value);\n }\n static fromObject(value) {\n if (Fragment.isFragment(value)) {\n return value;\n }\n switch (value.type) {\n case \"function\":\n return FunctionFragment.fromObject(value);\n case \"event\":\n return EventFragment.fromObject(value);\n case \"constructor\":\n return ConstructorFragment.fromObject(value);\n case \"error\":\n return ErrorFragment.fromObject(value);\n case \"fallback\":\n case \"receive\":\n // @TODO: Something? Maybe return a FunctionFragment? A custom DefaultFunctionFragment?\n return null;\n }\n return logger.throwArgumentError(\"invalid fragment object\", \"value\", value);\n }\n static fromString(value) {\n // Make sure the \"returns\" is surrounded by a space and all whitespace is exactly one space\n value = value.replace(/\\s/g, \" \");\n value = value.replace(/\\(/g, \" (\").replace(/\\)/g, \") \").replace(/\\s+/g, \" \");\n value = value.trim();\n if (value.split(\" \")[0] === \"event\") {\n return EventFragment.fromString(value.substring(5).trim());\n } else if (value.split(\" \")[0] === \"function\") {\n return FunctionFragment.fromString(value.substring(8).trim());\n } else if (value.split(\"(\")[0].trim() === \"constructor\") {\n return ConstructorFragment.fromString(value.trim());\n } else if (value.split(\" \")[0] === \"error\") {\n return ErrorFragment.fromString(value.substring(5).trim());\n }\n return logger.throwArgumentError(\"unsupported fragment\", \"value\", value);\n }\n static isFragment(value) {\n return !!(value && value._isFragment);\n }\n}\nexport class EventFragment extends Fragment {\n format(format) {\n if (!format) {\n format = FormatTypes.sighash;\n }\n if (!FormatTypes[format]) {\n logger.throwArgumentError(\"invalid format type\", \"format\", format);\n }\n if (format === FormatTypes.json) {\n return JSON.stringify({\n type: \"event\",\n anonymous: this.anonymous,\n name: this.name,\n inputs: this.inputs.map(input => JSON.parse(input.format(format)))\n });\n }\n let result = \"\";\n if (format !== FormatTypes.sighash) {\n result += \"event \";\n }\n result += this.name + \"(\" + this.inputs.map(input => input.format(format)).join(format === FormatTypes.full ? \", \" : \",\") + \") \";\n if (format !== FormatTypes.sighash) {\n if (this.anonymous) {\n result += \"anonymous \";\n }\n }\n return result.trim();\n }\n static from(value) {\n if (typeof value === \"string\") {\n return EventFragment.fromString(value);\n }\n return EventFragment.fromObject(value);\n }\n static fromObject(value) {\n if (EventFragment.isEventFragment(value)) {\n return value;\n }\n if (value.type !== \"event\") {\n logger.throwArgumentError(\"invalid event object\", \"value\", value);\n }\n const params = {\n name: verifyIdentifier(value.name),\n anonymous: value.anonymous,\n inputs: value.inputs ? value.inputs.map(ParamType.fromObject) : [],\n type: \"event\"\n };\n return new EventFragment(_constructorGuard, params);\n }\n static fromString(value) {\n let match = value.match(regexParen);\n if (!match) {\n logger.throwArgumentError(\"invalid event string\", \"value\", value);\n }\n let anonymous = false;\n match[3].split(\" \").forEach(modifier => {\n switch (modifier.trim()) {\n case \"anonymous\":\n anonymous = true;\n break;\n case \"\":\n break;\n default:\n logger.warn(\"unknown modifier: \" + modifier);\n }\n });\n return EventFragment.fromObject({\n name: match[1].trim(),\n anonymous: anonymous,\n inputs: parseParams(match[2], true),\n type: \"event\"\n });\n }\n static isEventFragment(value) {\n return value && value._isFragment && value.type === \"event\";\n }\n}\nfunction parseGas(value, params) {\n params.gas = null;\n let comps = value.split(\"@\");\n if (comps.length !== 1) {\n if (comps.length > 2) {\n logger.throwArgumentError(\"invalid human-readable ABI signature\", \"value\", value);\n }\n if (!comps[1].match(/^[0-9]+$/)) {\n logger.throwArgumentError(\"invalid human-readable ABI signature gas\", \"value\", value);\n }\n params.gas = BigNumber.from(comps[1]);\n return comps[0];\n }\n return value;\n}\nfunction parseModifiers(value, params) {\n params.constant = false;\n params.payable = false;\n params.stateMutability = \"nonpayable\";\n value.split(\" \").forEach(modifier => {\n switch (modifier.trim()) {\n case \"constant\":\n params.constant = true;\n break;\n case \"payable\":\n params.payable = true;\n params.stateMutability = \"payable\";\n break;\n case \"nonpayable\":\n params.payable = false;\n params.stateMutability = \"nonpayable\";\n break;\n case \"pure\":\n params.constant = true;\n params.stateMutability = \"pure\";\n break;\n case \"view\":\n params.constant = true;\n params.stateMutability = \"view\";\n break;\n case \"external\":\n case \"public\":\n case \"\":\n break;\n default:\n console.log(\"unknown modifier: \" + modifier);\n }\n });\n}\nfunction verifyState(value) {\n let result = {\n constant: false,\n payable: true,\n stateMutability: \"payable\"\n };\n if (value.stateMutability != null) {\n result.stateMutability = value.stateMutability;\n // Set (and check things are consistent) the constant property\n result.constant = result.stateMutability === \"view\" || result.stateMutability === \"pure\";\n if (value.constant != null) {\n if (!!value.constant !== result.constant) {\n logger.throwArgumentError(\"cannot have constant function with mutability \" + result.stateMutability, \"value\", value);\n }\n }\n // Set (and check things are consistent) the payable property\n result.payable = result.stateMutability === \"payable\";\n if (value.payable != null) {\n if (!!value.payable !== result.payable) {\n logger.throwArgumentError(\"cannot have payable function with mutability \" + result.stateMutability, \"value\", value);\n }\n }\n } else if (value.payable != null) {\n result.payable = !!value.payable;\n // If payable we can assume non-constant; otherwise we can't assume\n if (value.constant == null && !result.payable && value.type !== \"constructor\") {\n logger.throwArgumentError(\"unable to determine stateMutability\", \"value\", value);\n }\n result.constant = !!value.constant;\n if (result.constant) {\n result.stateMutability = \"view\";\n } else {\n result.stateMutability = result.payable ? \"payable\" : \"nonpayable\";\n }\n if (result.payable && result.constant) {\n logger.throwArgumentError(\"cannot have constant payable function\", \"value\", value);\n }\n } else if (value.constant != null) {\n result.constant = !!value.constant;\n result.payable = !result.constant;\n result.stateMutability = result.constant ? \"view\" : \"payable\";\n } else if (value.type !== \"constructor\") {\n logger.throwArgumentError(\"unable to determine stateMutability\", \"value\", value);\n }\n return result;\n}\nexport class ConstructorFragment extends Fragment {\n format(format) {\n if (!format) {\n format = FormatTypes.sighash;\n }\n if (!FormatTypes[format]) {\n logger.throwArgumentError(\"invalid format type\", \"format\", format);\n }\n if (format === FormatTypes.json) {\n return JSON.stringify({\n type: \"constructor\",\n stateMutability: this.stateMutability !== \"nonpayable\" ? this.stateMutability : undefined,\n payable: this.payable,\n gas: this.gas ? this.gas.toNumber() : undefined,\n inputs: this.inputs.map(input => JSON.parse(input.format(format)))\n });\n }\n if (format === FormatTypes.sighash) {\n logger.throwError(\"cannot format a constructor for sighash\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"format(sighash)\"\n });\n }\n let result = \"constructor(\" + this.inputs.map(input => input.format(format)).join(format === FormatTypes.full ? \", \" : \",\") + \") \";\n if (this.stateMutability && this.stateMutability !== \"nonpayable\") {\n result += this.stateMutability + \" \";\n }\n return result.trim();\n }\n static from(value) {\n if (typeof value === \"string\") {\n return ConstructorFragment.fromString(value);\n }\n return ConstructorFragment.fromObject(value);\n }\n static fromObject(value) {\n if (ConstructorFragment.isConstructorFragment(value)) {\n return value;\n }\n if (value.type !== \"constructor\") {\n logger.throwArgumentError(\"invalid constructor object\", \"value\", value);\n }\n let state = verifyState(value);\n if (state.constant) {\n logger.throwArgumentError(\"constructor cannot be constant\", \"value\", value);\n }\n const params = {\n name: null,\n type: value.type,\n inputs: value.inputs ? value.inputs.map(ParamType.fromObject) : [],\n payable: state.payable,\n stateMutability: state.stateMutability,\n gas: value.gas ? BigNumber.from(value.gas) : null\n };\n return new ConstructorFragment(_constructorGuard, params);\n }\n static fromString(value) {\n let params = {\n type: \"constructor\"\n };\n value = parseGas(value, params);\n let parens = value.match(regexParen);\n if (!parens || parens[1].trim() !== \"constructor\") {\n logger.throwArgumentError(\"invalid constructor string\", \"value\", value);\n }\n params.inputs = parseParams(parens[2].trim(), false);\n parseModifiers(parens[3].trim(), params);\n return ConstructorFragment.fromObject(params);\n }\n static isConstructorFragment(value) {\n return value && value._isFragment && value.type === \"constructor\";\n }\n}\nexport class FunctionFragment extends ConstructorFragment {\n format(format) {\n if (!format) {\n format = FormatTypes.sighash;\n }\n if (!FormatTypes[format]) {\n logger.throwArgumentError(\"invalid format type\", \"format\", format);\n }\n if (format === FormatTypes.json) {\n return JSON.stringify({\n type: \"function\",\n name: this.name,\n constant: this.constant,\n stateMutability: this.stateMutability !== \"nonpayable\" ? this.stateMutability : undefined,\n payable: this.payable,\n gas: this.gas ? this.gas.toNumber() : undefined,\n inputs: this.inputs.map(input => JSON.parse(input.format(format))),\n outputs: this.outputs.map(output => JSON.parse(output.format(format)))\n });\n }\n let result = \"\";\n if (format !== FormatTypes.sighash) {\n result += \"function \";\n }\n result += this.name + \"(\" + this.inputs.map(input => input.format(format)).join(format === FormatTypes.full ? \", \" : \",\") + \") \";\n if (format !== FormatTypes.sighash) {\n if (this.stateMutability) {\n if (this.stateMutability !== \"nonpayable\") {\n result += this.stateMutability + \" \";\n }\n } else if (this.constant) {\n result += \"view \";\n }\n if (this.outputs && this.outputs.length) {\n result += \"returns (\" + this.outputs.map(output => output.format(format)).join(\", \") + \") \";\n }\n if (this.gas != null) {\n result += \"@\" + this.gas.toString() + \" \";\n }\n }\n return result.trim();\n }\n static from(value) {\n if (typeof value === \"string\") {\n return FunctionFragment.fromString(value);\n }\n return FunctionFragment.fromObject(value);\n }\n static fromObject(value) {\n if (FunctionFragment.isFunctionFragment(value)) {\n return value;\n }\n if (value.type !== \"function\") {\n logger.throwArgumentError(\"invalid function object\", \"value\", value);\n }\n let state = verifyState(value);\n const params = {\n type: value.type,\n name: verifyIdentifier(value.name),\n constant: state.constant,\n inputs: value.inputs ? value.inputs.map(ParamType.fromObject) : [],\n outputs: value.outputs ? value.outputs.map(ParamType.fromObject) : [],\n payable: state.payable,\n stateMutability: state.stateMutability,\n gas: value.gas ? BigNumber.from(value.gas) : null\n };\n return new FunctionFragment(_constructorGuard, params);\n }\n static fromString(value) {\n let params = {\n type: \"function\"\n };\n value = parseGas(value, params);\n let comps = value.split(\" returns \");\n if (comps.length > 2) {\n logger.throwArgumentError(\"invalid function string\", \"value\", value);\n }\n let parens = comps[0].match(regexParen);\n if (!parens) {\n logger.throwArgumentError(\"invalid function signature\", \"value\", value);\n }\n params.name = parens[1].trim();\n if (params.name) {\n verifyIdentifier(params.name);\n }\n params.inputs = parseParams(parens[2], false);\n parseModifiers(parens[3].trim(), params);\n // We have outputs\n if (comps.length > 1) {\n let returns = comps[1].match(regexParen);\n if (returns[1].trim() != \"\" || returns[3].trim() != \"\") {\n logger.throwArgumentError(\"unexpected tokens\", \"value\", value);\n }\n params.outputs = parseParams(returns[2], false);\n } else {\n params.outputs = [];\n }\n return FunctionFragment.fromObject(params);\n }\n static isFunctionFragment(value) {\n return value && value._isFragment && value.type === \"function\";\n }\n}\n//export class StructFragment extends Fragment {\n//}\nfunction checkForbidden(fragment) {\n const sig = fragment.format();\n if (sig === \"Error(string)\" || sig === \"Panic(uint256)\") {\n logger.throwArgumentError(`cannot specify user defined ${sig} error`, \"fragment\", fragment);\n }\n return fragment;\n}\nexport class ErrorFragment extends Fragment {\n format(format) {\n if (!format) {\n format = FormatTypes.sighash;\n }\n if (!FormatTypes[format]) {\n logger.throwArgumentError(\"invalid format type\", \"format\", format);\n }\n if (format === FormatTypes.json) {\n return JSON.stringify({\n type: \"error\",\n name: this.name,\n inputs: this.inputs.map(input => JSON.parse(input.format(format)))\n });\n }\n let result = \"\";\n if (format !== FormatTypes.sighash) {\n result += \"error \";\n }\n result += this.name + \"(\" + this.inputs.map(input => input.format(format)).join(format === FormatTypes.full ? \", \" : \",\") + \") \";\n return result.trim();\n }\n static from(value) {\n if (typeof value === \"string\") {\n return ErrorFragment.fromString(value);\n }\n return ErrorFragment.fromObject(value);\n }\n static fromObject(value) {\n if (ErrorFragment.isErrorFragment(value)) {\n return value;\n }\n if (value.type !== \"error\") {\n logger.throwArgumentError(\"invalid error object\", \"value\", value);\n }\n const params = {\n type: value.type,\n name: verifyIdentifier(value.name),\n inputs: value.inputs ? value.inputs.map(ParamType.fromObject) : []\n };\n return checkForbidden(new ErrorFragment(_constructorGuard, params));\n }\n static fromString(value) {\n let params = {\n type: \"error\"\n };\n let parens = value.match(regexParen);\n if (!parens) {\n logger.throwArgumentError(\"invalid error signature\", \"value\", value);\n }\n params.name = parens[1].trim();\n if (params.name) {\n verifyIdentifier(params.name);\n }\n params.inputs = parseParams(parens[2], false);\n return checkForbidden(ErrorFragment.fromObject(params));\n }\n static isErrorFragment(value) {\n return value && value._isFragment && value.type === \"error\";\n }\n}\nfunction verifyType(type) {\n // These need to be transformed to their full description\n if (type.match(/^uint($|[^1-9])/)) {\n type = \"uint256\" + type.substring(4);\n } else if (type.match(/^int($|[^1-9])/)) {\n type = \"int256\" + type.substring(3);\n }\n // @TODO: more verification\n return type;\n}\n// See: https://github.com/ethereum/solidity/blob/1f8f1a3db93a548d0555e3e14cfc55a10e25b60e/docs/grammar/SolidityLexer.g4#L234\nconst regexIdentifier = new RegExp(\"^[a-zA-Z$_][a-zA-Z0-9$_]*$\");\nfunction verifyIdentifier(value) {\n if (!value || !value.match(regexIdentifier)) {\n logger.throwArgumentError(`invalid identifier \"${value}\"`, \"value\", value);\n }\n return value;\n}\nconst regexParen = new RegExp(\"^([^)(]*)\\\\((.*)\\\\)([^)(]*)$\");\nfunction splitNesting(value) {\n value = value.trim();\n let result = [];\n let accum = \"\";\n let depth = 0;\n for (let offset = 0; offset < value.length; offset++) {\n let c = value[offset];\n if (c === \",\" && depth === 0) {\n result.push(accum);\n accum = \"\";\n } else {\n accum += c;\n if (c === \"(\") {\n depth++;\n } else if (c === \")\") {\n depth--;\n if (depth === -1) {\n logger.throwArgumentError(\"unbalanced parenthesis\", \"value\", value);\n }\n }\n }\n }\n if (accum) {\n result.push(accum);\n }\n return result;\n}\n","\"use strict\";\n\nimport { arrayify, concat, hexConcat, hexlify } from \"@ethersproject/bytes\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"../_version\";\nconst logger = new Logger(version);\nexport function checkResultErrors(result) {\n // Find the first error (if any)\n const errors = [];\n const checkErrors = function (path, object) {\n if (!Array.isArray(object)) {\n return;\n }\n for (let key in object) {\n const childPath = path.slice();\n childPath.push(key);\n try {\n checkErrors(childPath, object[key]);\n } catch (error) {\n errors.push({\n path: childPath,\n error: error\n });\n }\n }\n };\n checkErrors([], result);\n return errors;\n}\nexport class Coder {\n constructor(name, type, localName, dynamic) {\n // @TODO: defineReadOnly these\n this.name = name;\n this.type = type;\n this.localName = localName;\n this.dynamic = dynamic;\n }\n _throwError(message, value) {\n logger.throwArgumentError(message, this.localName, value);\n }\n}\nexport class Writer {\n constructor(wordSize) {\n defineReadOnly(this, \"wordSize\", wordSize || 32);\n this._data = [];\n this._dataLength = 0;\n this._padding = new Uint8Array(wordSize);\n }\n get data() {\n return hexConcat(this._data);\n }\n get length() {\n return this._dataLength;\n }\n _writeData(data) {\n this._data.push(data);\n this._dataLength += data.length;\n return data.length;\n }\n appendWriter(writer) {\n return this._writeData(concat(writer._data));\n }\n // Arrayish items; padded on the right to wordSize\n writeBytes(value) {\n let bytes = arrayify(value);\n const paddingOffset = bytes.length % this.wordSize;\n if (paddingOffset) {\n bytes = concat([bytes, this._padding.slice(paddingOffset)]);\n }\n return this._writeData(bytes);\n }\n _getValue(value) {\n let bytes = arrayify(BigNumber.from(value));\n if (bytes.length > this.wordSize) {\n logger.throwError(\"value out-of-bounds\", Logger.errors.BUFFER_OVERRUN, {\n length: this.wordSize,\n offset: bytes.length\n });\n }\n if (bytes.length % this.wordSize) {\n bytes = concat([this._padding.slice(bytes.length % this.wordSize), bytes]);\n }\n return bytes;\n }\n // BigNumberish items; padded on the left to wordSize\n writeValue(value) {\n return this._writeData(this._getValue(value));\n }\n writeUpdatableValue() {\n const offset = this._data.length;\n this._data.push(this._padding);\n this._dataLength += this.wordSize;\n return value => {\n this._data[offset] = this._getValue(value);\n };\n }\n}\nexport class Reader {\n constructor(data, wordSize, coerceFunc, allowLoose) {\n defineReadOnly(this, \"_data\", arrayify(data));\n defineReadOnly(this, \"wordSize\", wordSize || 32);\n defineReadOnly(this, \"_coerceFunc\", coerceFunc);\n defineReadOnly(this, \"allowLoose\", allowLoose);\n this._offset = 0;\n }\n get data() {\n return hexlify(this._data);\n }\n get consumed() {\n return this._offset;\n }\n // The default Coerce function\n static coerce(name, value) {\n let match = name.match(\"^u?int([0-9]+)$\");\n if (match && parseInt(match[1]) <= 48) {\n value = value.toNumber();\n }\n return value;\n }\n coerce(name, value) {\n if (this._coerceFunc) {\n return this._coerceFunc(name, value);\n }\n return Reader.coerce(name, value);\n }\n _peekBytes(offset, length, loose) {\n let alignedLength = Math.ceil(length / this.wordSize) * this.wordSize;\n if (this._offset + alignedLength > this._data.length) {\n if (this.allowLoose && loose && this._offset + length <= this._data.length) {\n alignedLength = length;\n } else {\n logger.throwError(\"data out-of-bounds\", Logger.errors.BUFFER_OVERRUN, {\n length: this._data.length,\n offset: this._offset + alignedLength\n });\n }\n }\n return this._data.slice(this._offset, this._offset + alignedLength);\n }\n subReader(offset) {\n return new Reader(this._data.slice(this._offset + offset), this.wordSize, this._coerceFunc, this.allowLoose);\n }\n readBytes(length, loose) {\n let bytes = this._peekBytes(0, length, !!loose);\n this._offset += bytes.length;\n // @TODO: Make sure the length..end bytes are all 0?\n return bytes.slice(0, length);\n }\n readValue() {\n return BigNumber.from(this.readBytes(this.wordSize));\n }\n}\n","\"use strict\";\n\nimport { getAddress } from \"@ethersproject/address\";\nimport { hexZeroPad } from \"@ethersproject/bytes\";\nimport { Coder } from \"./abstract-coder\";\nexport class AddressCoder extends Coder {\n constructor(localName) {\n super(\"address\", \"address\", localName, false);\n }\n defaultValue() {\n return \"0x0000000000000000000000000000000000000000\";\n }\n encode(writer, value) {\n try {\n value = getAddress(value);\n } catch (error) {\n this._throwError(error.message, value);\n }\n return writer.writeValue(value);\n }\n decode(reader) {\n return getAddress(hexZeroPad(reader.readValue().toHexString(), 20));\n }\n}\n","\"use strict\";\n\nimport { Coder } from \"./abstract-coder\";\n// Clones the functionality of an existing Coder, but without a localName\nexport class AnonymousCoder extends Coder {\n constructor(coder) {\n super(coder.name, coder.type, undefined, coder.dynamic);\n this.coder = coder;\n }\n defaultValue() {\n return this.coder.defaultValue();\n }\n encode(writer, value) {\n return this.coder.encode(writer, value);\n }\n decode(reader) {\n return this.coder.decode(reader);\n }\n}\n","\"use strict\";\n\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"../_version\";\nconst logger = new Logger(version);\nimport { Coder, Writer } from \"./abstract-coder\";\nimport { AnonymousCoder } from \"./anonymous\";\nexport function pack(writer, coders, values) {\n let arrayValues = null;\n if (Array.isArray(values)) {\n arrayValues = values;\n } else if (values && typeof values === \"object\") {\n let unique = {};\n arrayValues = coders.map(coder => {\n const name = coder.localName;\n if (!name) {\n logger.throwError(\"cannot encode object for signature with missing names\", Logger.errors.INVALID_ARGUMENT, {\n argument: \"values\",\n coder: coder,\n value: values\n });\n }\n if (unique[name]) {\n logger.throwError(\"cannot encode object for signature with duplicate names\", Logger.errors.INVALID_ARGUMENT, {\n argument: \"values\",\n coder: coder,\n value: values\n });\n }\n unique[name] = true;\n return values[name];\n });\n } else {\n logger.throwArgumentError(\"invalid tuple value\", \"tuple\", values);\n }\n if (coders.length !== arrayValues.length) {\n logger.throwArgumentError(\"types/value length mismatch\", \"tuple\", values);\n }\n let staticWriter = new Writer(writer.wordSize);\n let dynamicWriter = new Writer(writer.wordSize);\n let updateFuncs = [];\n coders.forEach((coder, index) => {\n let value = arrayValues[index];\n if (coder.dynamic) {\n // Get current dynamic offset (for the future pointer)\n let dynamicOffset = dynamicWriter.length;\n // Encode the dynamic value into the dynamicWriter\n coder.encode(dynamicWriter, value);\n // Prepare to populate the correct offset once we are done\n let updateFunc = staticWriter.writeUpdatableValue();\n updateFuncs.push(baseOffset => {\n updateFunc(baseOffset + dynamicOffset);\n });\n } else {\n coder.encode(staticWriter, value);\n }\n });\n // Backfill all the dynamic offsets, now that we know the static length\n updateFuncs.forEach(func => {\n func(staticWriter.length);\n });\n let length = writer.appendWriter(staticWriter);\n length += writer.appendWriter(dynamicWriter);\n return length;\n}\nexport function unpack(reader, coders) {\n let values = [];\n // A reader anchored to this base\n let baseReader = reader.subReader(0);\n coders.forEach(coder => {\n let value = null;\n if (coder.dynamic) {\n let offset = reader.readValue();\n let offsetReader = baseReader.subReader(offset.toNumber());\n try {\n value = coder.decode(offsetReader);\n } catch (error) {\n // Cannot recover from this\n if (error.code === Logger.errors.BUFFER_OVERRUN) {\n throw error;\n }\n value = error;\n value.baseType = coder.name;\n value.name = coder.localName;\n value.type = coder.type;\n }\n } else {\n try {\n value = coder.decode(reader);\n } catch (error) {\n // Cannot recover from this\n if (error.code === Logger.errors.BUFFER_OVERRUN) {\n throw error;\n }\n value = error;\n value.baseType = coder.name;\n value.name = coder.localName;\n value.type = coder.type;\n }\n }\n if (value != undefined) {\n values.push(value);\n }\n });\n // We only output named properties for uniquely named coders\n const uniqueNames = coders.reduce((accum, coder) => {\n const name = coder.localName;\n if (name) {\n if (!accum[name]) {\n accum[name] = 0;\n }\n accum[name]++;\n }\n return accum;\n }, {});\n // Add any named parameters (i.e. tuples)\n coders.forEach((coder, index) => {\n let name = coder.localName;\n if (!name || uniqueNames[name] !== 1) {\n return;\n }\n if (name === \"length\") {\n name = \"_length\";\n }\n if (values[name] != null) {\n return;\n }\n const value = values[index];\n if (value instanceof Error) {\n Object.defineProperty(values, name, {\n enumerable: true,\n get: () => {\n throw value;\n }\n });\n } else {\n values[name] = value;\n }\n });\n for (let i = 0; i < values.length; i++) {\n const value = values[i];\n if (value instanceof Error) {\n Object.defineProperty(values, i, {\n enumerable: true,\n get: () => {\n throw value;\n }\n });\n }\n }\n return Object.freeze(values);\n}\nexport class ArrayCoder extends Coder {\n constructor(coder, length, localName) {\n const type = coder.type + \"[\" + (length >= 0 ? length : \"\") + \"]\";\n const dynamic = length === -1 || coder.dynamic;\n super(\"array\", type, localName, dynamic);\n this.coder = coder;\n this.length = length;\n }\n defaultValue() {\n // Verifies the child coder is valid (even if the array is dynamic or 0-length)\n const defaultChild = this.coder.defaultValue();\n const result = [];\n for (let i = 0; i < this.length; i++) {\n result.push(defaultChild);\n }\n return result;\n }\n encode(writer, value) {\n if (!Array.isArray(value)) {\n this._throwError(\"expected array value\", value);\n }\n let count = this.length;\n if (count === -1) {\n count = value.length;\n writer.writeValue(value.length);\n }\n logger.checkArgumentCount(value.length, count, \"coder array\" + (this.localName ? \" \" + this.localName : \"\"));\n let coders = [];\n for (let i = 0; i < value.length; i++) {\n coders.push(this.coder);\n }\n return pack(writer, coders, value);\n }\n decode(reader) {\n let count = this.length;\n if (count === -1) {\n count = reader.readValue().toNumber();\n // Check that there is *roughly* enough data to ensure\n // stray random data is not being read as a length. Each\n // slot requires at least 32 bytes for their value (or 32\n // bytes as a link to the data). This could use a much\n // tighter bound, but we are erroring on the side of safety.\n if (count * 32 > reader._data.length) {\n logger.throwError(\"insufficient data length\", Logger.errors.BUFFER_OVERRUN, {\n length: reader._data.length,\n count: count\n });\n }\n }\n let coders = [];\n for (let i = 0; i < count; i++) {\n coders.push(new AnonymousCoder(this.coder));\n }\n return reader.coerce(this.name, unpack(reader, coders));\n }\n}\n","\"use strict\";\n\nimport { Coder } from \"./abstract-coder\";\nexport class BooleanCoder extends Coder {\n constructor(localName) {\n super(\"bool\", \"bool\", localName, false);\n }\n defaultValue() {\n return false;\n }\n encode(writer, value) {\n return writer.writeValue(value ? 1 : 0);\n }\n decode(reader) {\n return reader.coerce(this.type, !reader.readValue().isZero());\n }\n}\n","\"use strict\";\n\nimport { arrayify, hexlify } from \"@ethersproject/bytes\";\nimport { Coder } from \"./abstract-coder\";\nexport class DynamicBytesCoder extends Coder {\n constructor(type, localName) {\n super(type, type, localName, true);\n }\n defaultValue() {\n return \"0x\";\n }\n encode(writer, value) {\n value = arrayify(value);\n let length = writer.writeValue(value.length);\n length += writer.writeBytes(value);\n return length;\n }\n decode(reader) {\n return reader.readBytes(reader.readValue().toNumber(), true);\n }\n}\nexport class BytesCoder extends DynamicBytesCoder {\n constructor(localName) {\n super(\"bytes\", localName);\n }\n decode(reader) {\n return reader.coerce(this.name, hexlify(super.decode(reader)));\n }\n}\n","\"use strict\";\n\nimport { arrayify, hexlify } from \"@ethersproject/bytes\";\nimport { Coder } from \"./abstract-coder\";\n// @TODO: Merge this with bytes\nexport class FixedBytesCoder extends Coder {\n constructor(size, localName) {\n let name = \"bytes\" + String(size);\n super(name, name, localName, false);\n this.size = size;\n }\n defaultValue() {\n return \"0x0000000000000000000000000000000000000000000000000000000000000000\".substring(0, 2 + this.size * 2);\n }\n encode(writer, value) {\n let data = arrayify(value);\n if (data.length !== this.size) {\n this._throwError(\"incorrect data length\", value);\n }\n return writer.writeBytes(data);\n }\n decode(reader) {\n return reader.coerce(this.name, hexlify(reader.readBytes(this.size)));\n }\n}\n","\"use strict\";\n\nimport { Coder } from \"./abstract-coder\";\nexport class NullCoder extends Coder {\n constructor(localName) {\n super(\"null\", \"\", localName, false);\n }\n defaultValue() {\n return null;\n }\n encode(writer, value) {\n if (value != null) {\n this._throwError(\"not null\", value);\n }\n return writer.writeBytes([]);\n }\n decode(reader) {\n reader.readBytes(0);\n return reader.coerce(this.name, null);\n }\n}\n","\"use strict\";\n\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { MaxUint256, NegativeOne, One, Zero } from \"@ethersproject/constants\";\nimport { Coder } from \"./abstract-coder\";\nexport class NumberCoder extends Coder {\n constructor(size, signed, localName) {\n const name = (signed ? \"int\" : \"uint\") + size * 8;\n super(name, name, localName, false);\n this.size = size;\n this.signed = signed;\n }\n defaultValue() {\n return 0;\n }\n encode(writer, value) {\n let v = BigNumber.from(value);\n // Check bounds are safe for encoding\n let maxUintValue = MaxUint256.mask(writer.wordSize * 8);\n if (this.signed) {\n let bounds = maxUintValue.mask(this.size * 8 - 1);\n if (v.gt(bounds) || v.lt(bounds.add(One).mul(NegativeOne))) {\n this._throwError(\"value out-of-bounds\", value);\n }\n } else if (v.lt(Zero) || v.gt(maxUintValue.mask(this.size * 8))) {\n this._throwError(\"value out-of-bounds\", value);\n }\n v = v.toTwos(this.size * 8).mask(this.size * 8);\n if (this.signed) {\n v = v.fromTwos(this.size * 8).toTwos(8 * writer.wordSize);\n }\n return writer.writeValue(v);\n }\n decode(reader) {\n let value = reader.readValue().mask(this.size * 8);\n if (this.signed) {\n value = value.fromTwos(this.size * 8);\n }\n return reader.coerce(this.name, value);\n }\n}\n","\"use strict\";\n\nimport { toUtf8Bytes, toUtf8String } from \"@ethersproject/strings\";\nimport { DynamicBytesCoder } from \"./bytes\";\nexport class StringCoder extends DynamicBytesCoder {\n constructor(localName) {\n super(\"string\", localName);\n }\n defaultValue() {\n return \"\";\n }\n encode(writer, value) {\n return super.encode(writer, toUtf8Bytes(value));\n }\n decode(reader) {\n return toUtf8String(super.decode(reader));\n }\n}\n","\"use strict\";\n\nimport { Coder } from \"./abstract-coder\";\nimport { pack, unpack } from \"./array\";\nexport class TupleCoder extends Coder {\n constructor(coders, localName) {\n let dynamic = false;\n const types = [];\n coders.forEach(coder => {\n if (coder.dynamic) {\n dynamic = true;\n }\n types.push(coder.type);\n });\n const type = \"tuple(\" + types.join(\",\") + \")\";\n super(\"tuple\", type, localName, dynamic);\n this.coders = coders;\n }\n defaultValue() {\n const values = [];\n this.coders.forEach(coder => {\n values.push(coder.defaultValue());\n });\n // We only output named properties for uniquely named coders\n const uniqueNames = this.coders.reduce((accum, coder) => {\n const name = coder.localName;\n if (name) {\n if (!accum[name]) {\n accum[name] = 0;\n }\n accum[name]++;\n }\n return accum;\n }, {});\n // Add named values\n this.coders.forEach((coder, index) => {\n let name = coder.localName;\n if (!name || uniqueNames[name] !== 1) {\n return;\n }\n if (name === \"length\") {\n name = \"_length\";\n }\n if (values[name] != null) {\n return;\n }\n values[name] = values[index];\n });\n return Object.freeze(values);\n }\n encode(writer, value) {\n return pack(writer, this.coders, value);\n }\n decode(reader) {\n return reader.coerce(this.name, unpack(reader, this.coders));\n }\n}\n","\"use strict\";\n\n// See: https://github.com/ethereum/wiki/wiki/Ethereum-Contract-ABI\nimport { arrayify } from \"@ethersproject/bytes\";\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { Reader, Writer } from \"./coders/abstract-coder\";\nimport { AddressCoder } from \"./coders/address\";\nimport { ArrayCoder } from \"./coders/array\";\nimport { BooleanCoder } from \"./coders/boolean\";\nimport { BytesCoder } from \"./coders/bytes\";\nimport { FixedBytesCoder } from \"./coders/fixed-bytes\";\nimport { NullCoder } from \"./coders/null\";\nimport { NumberCoder } from \"./coders/number\";\nimport { StringCoder } from \"./coders/string\";\nimport { TupleCoder } from \"./coders/tuple\";\nimport { ParamType } from \"./fragments\";\nconst paramTypeBytes = new RegExp(/^bytes([0-9]*)$/);\nconst paramTypeNumber = new RegExp(/^(u?int)([0-9]*)$/);\nexport class AbiCoder {\n constructor(coerceFunc) {\n defineReadOnly(this, \"coerceFunc\", coerceFunc || null);\n }\n _getCoder(param) {\n switch (param.baseType) {\n case \"address\":\n return new AddressCoder(param.name);\n case \"bool\":\n return new BooleanCoder(param.name);\n case \"string\":\n return new StringCoder(param.name);\n case \"bytes\":\n return new BytesCoder(param.name);\n case \"array\":\n return new ArrayCoder(this._getCoder(param.arrayChildren), param.arrayLength, param.name);\n case \"tuple\":\n return new TupleCoder((param.components || []).map(component => {\n return this._getCoder(component);\n }), param.name);\n case \"\":\n return new NullCoder(param.name);\n }\n // u?int[0-9]*\n let match = param.type.match(paramTypeNumber);\n if (match) {\n let size = parseInt(match[2] || \"256\");\n if (size === 0 || size > 256 || size % 8 !== 0) {\n logger.throwArgumentError(\"invalid \" + match[1] + \" bit length\", \"param\", param);\n }\n return new NumberCoder(size / 8, match[1] === \"int\", param.name);\n }\n // bytes[0-9]+\n match = param.type.match(paramTypeBytes);\n if (match) {\n let size = parseInt(match[1]);\n if (size === 0 || size > 32) {\n logger.throwArgumentError(\"invalid bytes length\", \"param\", param);\n }\n return new FixedBytesCoder(size, param.name);\n }\n return logger.throwArgumentError(\"invalid type\", \"type\", param.type);\n }\n _getWordSize() {\n return 32;\n }\n _getReader(data, allowLoose) {\n return new Reader(data, this._getWordSize(), this.coerceFunc, allowLoose);\n }\n _getWriter() {\n return new Writer(this._getWordSize());\n }\n getDefaultValue(types) {\n const coders = types.map(type => this._getCoder(ParamType.from(type)));\n const coder = new TupleCoder(coders, \"_\");\n return coder.defaultValue();\n }\n encode(types, values) {\n if (types.length !== values.length) {\n logger.throwError(\"types/values length mismatch\", Logger.errors.INVALID_ARGUMENT, {\n count: {\n types: types.length,\n values: values.length\n },\n value: {\n types: types,\n values: values\n }\n });\n }\n const coders = types.map(type => this._getCoder(ParamType.from(type)));\n const coder = new TupleCoder(coders, \"_\");\n const writer = this._getWriter();\n coder.encode(writer, values);\n return writer.data;\n }\n decode(types, data, loose) {\n const coders = types.map(type => this._getCoder(ParamType.from(type)));\n const coder = new TupleCoder(coders, \"_\");\n return coder.decode(this._getReader(arrayify(data), loose));\n }\n}\nexport const defaultAbiCoder = new AbiCoder();\n","\"use strict\";\n\nimport { getAddress } from \"@ethersproject/address\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { arrayify, concat, hexDataSlice, hexlify, hexZeroPad, isHexString } from \"@ethersproject/bytes\";\nimport { id } from \"@ethersproject/hash\";\nimport { keccak256 } from \"@ethersproject/keccak256\";\nimport { defineReadOnly, Description, getStatic } from \"@ethersproject/properties\";\nimport { defaultAbiCoder } from \"./abi-coder\";\nimport { checkResultErrors } from \"./coders/abstract-coder\";\nimport { ConstructorFragment, EventFragment, FormatTypes, Fragment, FunctionFragment, ParamType } from \"./fragments\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nexport { checkResultErrors };\nexport class LogDescription extends Description {}\nexport class TransactionDescription extends Description {}\nexport class ErrorDescription extends Description {}\nexport class Indexed extends Description {\n static isIndexed(value) {\n return !!(value && value._isIndexed);\n }\n}\nconst BuiltinErrors = {\n \"0x08c379a0\": {\n signature: \"Error(string)\",\n name: \"Error\",\n inputs: [\"string\"],\n reason: true\n },\n \"0x4e487b71\": {\n signature: \"Panic(uint256)\",\n name: \"Panic\",\n inputs: [\"uint256\"]\n }\n};\nfunction wrapAccessError(property, error) {\n const wrap = new Error(`deferred error during ABI decoding triggered accessing ${property}`);\n wrap.error = error;\n return wrap;\n}\n/*\nfunction checkNames(fragment: Fragment, type: \"input\" | \"output\", params: Array): void {\n params.reduce((accum, param) => {\n if (param.name) {\n if (accum[param.name]) {\n logger.throwArgumentError(`duplicate ${ type } parameter ${ JSON.stringify(param.name) } in ${ fragment.format(\"full\") }`, \"fragment\", fragment);\n }\n accum[param.name] = true;\n }\n return accum;\n }, <{ [ name: string ]: boolean }>{ });\n}\n*/\nexport class Interface {\n constructor(fragments) {\n let abi = [];\n if (typeof fragments === \"string\") {\n abi = JSON.parse(fragments);\n } else {\n abi = fragments;\n }\n defineReadOnly(this, \"fragments\", abi.map(fragment => {\n return Fragment.from(fragment);\n }).filter(fragment => fragment != null));\n defineReadOnly(this, \"_abiCoder\", getStatic(new.target, \"getAbiCoder\")());\n defineReadOnly(this, \"functions\", {});\n defineReadOnly(this, \"errors\", {});\n defineReadOnly(this, \"events\", {});\n defineReadOnly(this, \"structs\", {});\n // Add all fragments by their signature\n this.fragments.forEach(fragment => {\n let bucket = null;\n switch (fragment.type) {\n case \"constructor\":\n if (this.deploy) {\n logger.warn(\"duplicate definition - constructor\");\n return;\n }\n //checkNames(fragment, \"input\", fragment.inputs);\n defineReadOnly(this, \"deploy\", fragment);\n return;\n case \"function\":\n //checkNames(fragment, \"input\", fragment.inputs);\n //checkNames(fragment, \"output\", (fragment).outputs);\n bucket = this.functions;\n break;\n case \"event\":\n //checkNames(fragment, \"input\", fragment.inputs);\n bucket = this.events;\n break;\n case \"error\":\n bucket = this.errors;\n break;\n default:\n return;\n }\n let signature = fragment.format();\n if (bucket[signature]) {\n logger.warn(\"duplicate definition - \" + signature);\n return;\n }\n bucket[signature] = fragment;\n });\n // If we do not have a constructor add a default\n if (!this.deploy) {\n defineReadOnly(this, \"deploy\", ConstructorFragment.from({\n payable: false,\n type: \"constructor\"\n }));\n }\n defineReadOnly(this, \"_isInterface\", true);\n }\n format(format) {\n if (!format) {\n format = FormatTypes.full;\n }\n if (format === FormatTypes.sighash) {\n logger.throwArgumentError(\"interface does not support formatting sighash\", \"format\", format);\n }\n const abi = this.fragments.map(fragment => fragment.format(format));\n // We need to re-bundle the JSON fragments a bit\n if (format === FormatTypes.json) {\n return JSON.stringify(abi.map(j => JSON.parse(j)));\n }\n return abi;\n }\n // Sub-classes can override these to handle other blockchains\n static getAbiCoder() {\n return defaultAbiCoder;\n }\n static getAddress(address) {\n return getAddress(address);\n }\n static getSighash(fragment) {\n return hexDataSlice(id(fragment.format()), 0, 4);\n }\n static getEventTopic(eventFragment) {\n return id(eventFragment.format());\n }\n // Find a function definition by any means necessary (unless it is ambiguous)\n getFunction(nameOrSignatureOrSighash) {\n if (isHexString(nameOrSignatureOrSighash)) {\n for (const name in this.functions) {\n if (nameOrSignatureOrSighash === this.getSighash(name)) {\n return this.functions[name];\n }\n }\n logger.throwArgumentError(\"no matching function\", \"sighash\", nameOrSignatureOrSighash);\n }\n // It is a bare name, look up the function (will return null if ambiguous)\n if (nameOrSignatureOrSighash.indexOf(\"(\") === -1) {\n const name = nameOrSignatureOrSighash.trim();\n const matching = Object.keys(this.functions).filter(f => f.split(\"(\" /* fix:) */)[0] === name);\n if (matching.length === 0) {\n logger.throwArgumentError(\"no matching function\", \"name\", name);\n } else if (matching.length > 1) {\n logger.throwArgumentError(\"multiple matching functions\", \"name\", name);\n }\n return this.functions[matching[0]];\n }\n // Normalize the signature and lookup the function\n const result = this.functions[FunctionFragment.fromString(nameOrSignatureOrSighash).format()];\n if (!result) {\n logger.throwArgumentError(\"no matching function\", \"signature\", nameOrSignatureOrSighash);\n }\n return result;\n }\n // Find an event definition by any means necessary (unless it is ambiguous)\n getEvent(nameOrSignatureOrTopic) {\n if (isHexString(nameOrSignatureOrTopic)) {\n const topichash = nameOrSignatureOrTopic.toLowerCase();\n for (const name in this.events) {\n if (topichash === this.getEventTopic(name)) {\n return this.events[name];\n }\n }\n logger.throwArgumentError(\"no matching event\", \"topichash\", topichash);\n }\n // It is a bare name, look up the function (will return null if ambiguous)\n if (nameOrSignatureOrTopic.indexOf(\"(\") === -1) {\n const name = nameOrSignatureOrTopic.trim();\n const matching = Object.keys(this.events).filter(f => f.split(\"(\" /* fix:) */)[0] === name);\n if (matching.length === 0) {\n logger.throwArgumentError(\"no matching event\", \"name\", name);\n } else if (matching.length > 1) {\n logger.throwArgumentError(\"multiple matching events\", \"name\", name);\n }\n return this.events[matching[0]];\n }\n // Normalize the signature and lookup the function\n const result = this.events[EventFragment.fromString(nameOrSignatureOrTopic).format()];\n if (!result) {\n logger.throwArgumentError(\"no matching event\", \"signature\", nameOrSignatureOrTopic);\n }\n return result;\n }\n // Find a function definition by any means necessary (unless it is ambiguous)\n getError(nameOrSignatureOrSighash) {\n if (isHexString(nameOrSignatureOrSighash)) {\n const getSighash = getStatic(this.constructor, \"getSighash\");\n for (const name in this.errors) {\n const error = this.errors[name];\n if (nameOrSignatureOrSighash === getSighash(error)) {\n return this.errors[name];\n }\n }\n logger.throwArgumentError(\"no matching error\", \"sighash\", nameOrSignatureOrSighash);\n }\n // It is a bare name, look up the function (will return null if ambiguous)\n if (nameOrSignatureOrSighash.indexOf(\"(\") === -1) {\n const name = nameOrSignatureOrSighash.trim();\n const matching = Object.keys(this.errors).filter(f => f.split(\"(\" /* fix:) */)[0] === name);\n if (matching.length === 0) {\n logger.throwArgumentError(\"no matching error\", \"name\", name);\n } else if (matching.length > 1) {\n logger.throwArgumentError(\"multiple matching errors\", \"name\", name);\n }\n return this.errors[matching[0]];\n }\n // Normalize the signature and lookup the function\n const result = this.errors[FunctionFragment.fromString(nameOrSignatureOrSighash).format()];\n if (!result) {\n logger.throwArgumentError(\"no matching error\", \"signature\", nameOrSignatureOrSighash);\n }\n return result;\n }\n // Get the sighash (the bytes4 selector) used by Solidity to identify a function\n getSighash(fragment) {\n if (typeof fragment === \"string\") {\n try {\n fragment = this.getFunction(fragment);\n } catch (error) {\n try {\n fragment = this.getError(fragment);\n } catch (_) {\n throw error;\n }\n }\n }\n return getStatic(this.constructor, \"getSighash\")(fragment);\n }\n // Get the topic (the bytes32 hash) used by Solidity to identify an event\n getEventTopic(eventFragment) {\n if (typeof eventFragment === \"string\") {\n eventFragment = this.getEvent(eventFragment);\n }\n return getStatic(this.constructor, \"getEventTopic\")(eventFragment);\n }\n _decodeParams(params, data) {\n return this._abiCoder.decode(params, data);\n }\n _encodeParams(params, values) {\n return this._abiCoder.encode(params, values);\n }\n encodeDeploy(values) {\n return this._encodeParams(this.deploy.inputs, values || []);\n }\n decodeErrorResult(fragment, data) {\n if (typeof fragment === \"string\") {\n fragment = this.getError(fragment);\n }\n const bytes = arrayify(data);\n if (hexlify(bytes.slice(0, 4)) !== this.getSighash(fragment)) {\n logger.throwArgumentError(`data signature does not match error ${fragment.name}.`, \"data\", hexlify(bytes));\n }\n return this._decodeParams(fragment.inputs, bytes.slice(4));\n }\n encodeErrorResult(fragment, values) {\n if (typeof fragment === \"string\") {\n fragment = this.getError(fragment);\n }\n return hexlify(concat([this.getSighash(fragment), this._encodeParams(fragment.inputs, values || [])]));\n }\n // Decode the data for a function call (e.g. tx.data)\n decodeFunctionData(functionFragment, data) {\n if (typeof functionFragment === \"string\") {\n functionFragment = this.getFunction(functionFragment);\n }\n const bytes = arrayify(data);\n if (hexlify(bytes.slice(0, 4)) !== this.getSighash(functionFragment)) {\n logger.throwArgumentError(`data signature does not match function ${functionFragment.name}.`, \"data\", hexlify(bytes));\n }\n return this._decodeParams(functionFragment.inputs, bytes.slice(4));\n }\n // Encode the data for a function call (e.g. tx.data)\n encodeFunctionData(functionFragment, values) {\n if (typeof functionFragment === \"string\") {\n functionFragment = this.getFunction(functionFragment);\n }\n return hexlify(concat([this.getSighash(functionFragment), this._encodeParams(functionFragment.inputs, values || [])]));\n }\n // Decode the result from a function call (e.g. from eth_call)\n decodeFunctionResult(functionFragment, data) {\n if (typeof functionFragment === \"string\") {\n functionFragment = this.getFunction(functionFragment);\n }\n let bytes = arrayify(data);\n let reason = null;\n let message = \"\";\n let errorArgs = null;\n let errorName = null;\n let errorSignature = null;\n switch (bytes.length % this._abiCoder._getWordSize()) {\n case 0:\n try {\n return this._abiCoder.decode(functionFragment.outputs, bytes);\n } catch (error) {}\n break;\n case 4:\n {\n const selector = hexlify(bytes.slice(0, 4));\n const builtin = BuiltinErrors[selector];\n if (builtin) {\n errorArgs = this._abiCoder.decode(builtin.inputs, bytes.slice(4));\n errorName = builtin.name;\n errorSignature = builtin.signature;\n if (builtin.reason) {\n reason = errorArgs[0];\n }\n if (errorName === \"Error\") {\n message = `; VM Exception while processing transaction: reverted with reason string ${JSON.stringify(errorArgs[0])}`;\n } else if (errorName === \"Panic\") {\n message = `; VM Exception while processing transaction: reverted with panic code ${errorArgs[0]}`;\n }\n } else {\n try {\n const error = this.getError(selector);\n errorArgs = this._abiCoder.decode(error.inputs, bytes.slice(4));\n errorName = error.name;\n errorSignature = error.format();\n } catch (error) {}\n }\n break;\n }\n }\n return logger.throwError(\"call revert exception\" + message, Logger.errors.CALL_EXCEPTION, {\n method: functionFragment.format(),\n data: hexlify(data),\n errorArgs,\n errorName,\n errorSignature,\n reason\n });\n }\n // Encode the result for a function call (e.g. for eth_call)\n encodeFunctionResult(functionFragment, values) {\n if (typeof functionFragment === \"string\") {\n functionFragment = this.getFunction(functionFragment);\n }\n return hexlify(this._abiCoder.encode(functionFragment.outputs, values || []));\n }\n // Create the filter for the event with search criteria (e.g. for eth_filterLog)\n encodeFilterTopics(eventFragment, values) {\n if (typeof eventFragment === \"string\") {\n eventFragment = this.getEvent(eventFragment);\n }\n if (values.length > eventFragment.inputs.length) {\n logger.throwError(\"too many arguments for \" + eventFragment.format(), Logger.errors.UNEXPECTED_ARGUMENT, {\n argument: \"values\",\n value: values\n });\n }\n let topics = [];\n if (!eventFragment.anonymous) {\n topics.push(this.getEventTopic(eventFragment));\n }\n const encodeTopic = (param, value) => {\n if (param.type === \"string\") {\n return id(value);\n } else if (param.type === \"bytes\") {\n return keccak256(hexlify(value));\n }\n if (param.type === \"bool\" && typeof value === \"boolean\") {\n value = value ? \"0x01\" : \"0x00\";\n }\n if (param.type.match(/^u?int/)) {\n value = BigNumber.from(value).toHexString();\n }\n // Check addresses are valid\n if (param.type === \"address\") {\n this._abiCoder.encode([\"address\"], [value]);\n }\n return hexZeroPad(hexlify(value), 32);\n };\n values.forEach((value, index) => {\n let param = eventFragment.inputs[index];\n if (!param.indexed) {\n if (value != null) {\n logger.throwArgumentError(\"cannot filter non-indexed parameters; must be null\", \"contract.\" + param.name, value);\n }\n return;\n }\n if (value == null) {\n topics.push(null);\n } else if (param.baseType === \"array\" || param.baseType === \"tuple\") {\n logger.throwArgumentError(\"filtering with tuples or arrays not supported\", \"contract.\" + param.name, value);\n } else if (Array.isArray(value)) {\n topics.push(value.map(value => encodeTopic(param, value)));\n } else {\n topics.push(encodeTopic(param, value));\n }\n });\n // Trim off trailing nulls\n while (topics.length && topics[topics.length - 1] === null) {\n topics.pop();\n }\n return topics;\n }\n encodeEventLog(eventFragment, values) {\n if (typeof eventFragment === \"string\") {\n eventFragment = this.getEvent(eventFragment);\n }\n const topics = [];\n const dataTypes = [];\n const dataValues = [];\n if (!eventFragment.anonymous) {\n topics.push(this.getEventTopic(eventFragment));\n }\n if (values.length !== eventFragment.inputs.length) {\n logger.throwArgumentError(\"event arguments/values mismatch\", \"values\", values);\n }\n eventFragment.inputs.forEach((param, index) => {\n const value = values[index];\n if (param.indexed) {\n if (param.type === \"string\") {\n topics.push(id(value));\n } else if (param.type === \"bytes\") {\n topics.push(keccak256(value));\n } else if (param.baseType === \"tuple\" || param.baseType === \"array\") {\n // @TODO\n throw new Error(\"not implemented\");\n } else {\n topics.push(this._abiCoder.encode([param.type], [value]));\n }\n } else {\n dataTypes.push(param);\n dataValues.push(value);\n }\n });\n return {\n data: this._abiCoder.encode(dataTypes, dataValues),\n topics: topics\n };\n }\n // Decode a filter for the event and the search criteria\n decodeEventLog(eventFragment, data, topics) {\n if (typeof eventFragment === \"string\") {\n eventFragment = this.getEvent(eventFragment);\n }\n if (topics != null && !eventFragment.anonymous) {\n let topicHash = this.getEventTopic(eventFragment);\n if (!isHexString(topics[0], 32) || topics[0].toLowerCase() !== topicHash) {\n logger.throwError(\"fragment/topic mismatch\", Logger.errors.INVALID_ARGUMENT, {\n argument: \"topics[0]\",\n expected: topicHash,\n value: topics[0]\n });\n }\n topics = topics.slice(1);\n }\n let indexed = [];\n let nonIndexed = [];\n let dynamic = [];\n eventFragment.inputs.forEach((param, index) => {\n if (param.indexed) {\n if (param.type === \"string\" || param.type === \"bytes\" || param.baseType === \"tuple\" || param.baseType === \"array\") {\n indexed.push(ParamType.fromObject({\n type: \"bytes32\",\n name: param.name\n }));\n dynamic.push(true);\n } else {\n indexed.push(param);\n dynamic.push(false);\n }\n } else {\n nonIndexed.push(param);\n dynamic.push(false);\n }\n });\n let resultIndexed = topics != null ? this._abiCoder.decode(indexed, concat(topics)) : null;\n let resultNonIndexed = this._abiCoder.decode(nonIndexed, data, true);\n let result = [];\n let nonIndexedIndex = 0,\n indexedIndex = 0;\n eventFragment.inputs.forEach((param, index) => {\n if (param.indexed) {\n if (resultIndexed == null) {\n result[index] = new Indexed({\n _isIndexed: true,\n hash: null\n });\n } else if (dynamic[index]) {\n result[index] = new Indexed({\n _isIndexed: true,\n hash: resultIndexed[indexedIndex++]\n });\n } else {\n try {\n result[index] = resultIndexed[indexedIndex++];\n } catch (error) {\n result[index] = error;\n }\n }\n } else {\n try {\n result[index] = resultNonIndexed[nonIndexedIndex++];\n } catch (error) {\n result[index] = error;\n }\n }\n // Add the keyword argument if named and safe\n if (param.name && result[param.name] == null) {\n const value = result[index];\n // Make error named values throw on access\n if (value instanceof Error) {\n Object.defineProperty(result, param.name, {\n enumerable: true,\n get: () => {\n throw wrapAccessError(`property ${JSON.stringify(param.name)}`, value);\n }\n });\n } else {\n result[param.name] = value;\n }\n }\n });\n // Make all error indexed values throw on access\n for (let i = 0; i < result.length; i++) {\n const value = result[i];\n if (value instanceof Error) {\n Object.defineProperty(result, i, {\n enumerable: true,\n get: () => {\n throw wrapAccessError(`index ${i}`, value);\n }\n });\n }\n }\n return Object.freeze(result);\n }\n // Given a transaction, find the matching function fragment (if any) and\n // determine all its properties and call parameters\n parseTransaction(tx) {\n let fragment = this.getFunction(tx.data.substring(0, 10).toLowerCase());\n if (!fragment) {\n return null;\n }\n return new TransactionDescription({\n args: this._abiCoder.decode(fragment.inputs, \"0x\" + tx.data.substring(10)),\n functionFragment: fragment,\n name: fragment.name,\n signature: fragment.format(),\n sighash: this.getSighash(fragment),\n value: BigNumber.from(tx.value || \"0\")\n });\n }\n // @TODO\n //parseCallResult(data: BytesLike): ??\n // Given an event log, find the matching event fragment (if any) and\n // determine all its properties and values\n parseLog(log) {\n let fragment = this.getEvent(log.topics[0]);\n if (!fragment || fragment.anonymous) {\n return null;\n }\n // @TODO: If anonymous, and the only method, and the input count matches, should we parse?\n // Probably not, because just because it is the only event in the ABI does\n // not mean we have the full ABI; maybe just a fragment?\n return new LogDescription({\n eventFragment: fragment,\n name: fragment.name,\n signature: fragment.format(),\n topic: this.getEventTopic(fragment),\n args: this.decodeEventLog(fragment, log.data, log.topics)\n });\n }\n parseError(data) {\n const hexData = hexlify(data);\n let fragment = this.getError(hexData.substring(0, 10).toLowerCase());\n if (!fragment) {\n return null;\n }\n return new ErrorDescription({\n args: this._abiCoder.decode(fragment.inputs, \"0x\" + hexData.substring(10)),\n errorFragment: fragment,\n name: fragment.name,\n signature: fragment.format(),\n sighash: this.getSighash(fragment)\n });\n }\n /*\n static from(value: Array | string | Interface) {\n if (Interface.isInterface(value)) {\n return value;\n }\n if (typeof(value) === \"string\") {\n return new Interface(JSON.parse(value));\n }\n return new Interface(value);\n }\n */\n static isInterface(value) {\n return !!(value && value._isInterface);\n }\n}\n","\"use strict\";\n\nimport { ConstructorFragment, ErrorFragment, EventFragment, FormatTypes, Fragment, FunctionFragment, ParamType } from \"./fragments\";\nimport { AbiCoder, defaultAbiCoder } from \"./abi-coder\";\nimport { checkResultErrors, Indexed, Interface, LogDescription, TransactionDescription } from \"./interface\";\nexport { ConstructorFragment, ErrorFragment, EventFragment, Fragment, FunctionFragment, ParamType, FormatTypes, AbiCoder, defaultAbiCoder, Interface, Indexed, checkResultErrors, LogDescription, TransactionDescription };\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getLength = exports.decode = exports.encode = void 0;\nvar bn_js_1 = __importDefault(require(\"bn.js\"));\n/**\n * RLP Encoding based on: https://github.com/ethereum/wiki/wiki/%5BEnglish%5D-RLP\n * This function takes in a data, convert it to buffer if not, and a length for recursion\n * @param input - will be converted to buffer\n * @returns returns buffer of encoded data\n **/\nfunction encode(input) {\n if (Array.isArray(input)) {\n var output = [];\n for (var i = 0; i < input.length; i++) {\n output.push(encode(input[i]));\n }\n var buf = Buffer.concat(output);\n return Buffer.concat([encodeLength(buf.length, 192), buf]);\n } else {\n var inputBuf = toBuffer(input);\n return inputBuf.length === 1 && inputBuf[0] < 128 ? inputBuf : Buffer.concat([encodeLength(inputBuf.length, 128), inputBuf]);\n }\n}\nexports.encode = encode;\n/**\n * Parse integers. Check if there is no leading zeros\n * @param v The value to parse\n * @param base The base to parse the integer into\n */\nfunction safeParseInt(v, base) {\n if (v[0] === '0' && v[1] === '0') {\n throw new Error('invalid RLP: extra zeros');\n }\n return parseInt(v, base);\n}\nfunction encodeLength(len, offset) {\n if (len < 56) {\n return Buffer.from([len + offset]);\n } else {\n var hexLength = intToHex(len);\n var lLength = hexLength.length / 2;\n var firstByte = intToHex(offset + 55 + lLength);\n return Buffer.from(firstByte + hexLength, 'hex');\n }\n}\nfunction decode(input, stream) {\n if (stream === void 0) {\n stream = false;\n }\n if (!input || input.length === 0) {\n return Buffer.from([]);\n }\n var inputBuffer = toBuffer(input);\n var decoded = _decode(inputBuffer);\n if (stream) {\n return decoded;\n }\n if (decoded.remainder.length !== 0) {\n throw new Error('invalid remainder');\n }\n return decoded.data;\n}\nexports.decode = decode;\n/**\n * Get the length of the RLP input\n * @param input\n * @returns The length of the input or an empty Buffer if no input\n */\nfunction getLength(input) {\n if (!input || input.length === 0) {\n return Buffer.from([]);\n }\n var inputBuffer = toBuffer(input);\n var firstByte = inputBuffer[0];\n if (firstByte <= 0x7f) {\n return inputBuffer.length;\n } else if (firstByte <= 0xb7) {\n return firstByte - 0x7f;\n } else if (firstByte <= 0xbf) {\n return firstByte - 0xb6;\n } else if (firstByte <= 0xf7) {\n // a list between 0-55 bytes long\n return firstByte - 0xbf;\n } else {\n // a list over 55 bytes long\n var llength = firstByte - 0xf6;\n var length_1 = safeParseInt(inputBuffer.slice(1, llength).toString('hex'), 16);\n return llength + length_1;\n }\n}\nexports.getLength = getLength;\n/** Decode an input with RLP */\nfunction _decode(input) {\n var length, llength, data, innerRemainder, d;\n var decoded = [];\n var firstByte = input[0];\n if (firstByte <= 0x7f) {\n // a single byte whose value is in the [0x00, 0x7f] range, that byte is its own RLP encoding.\n return {\n data: input.slice(0, 1),\n remainder: input.slice(1)\n };\n } else if (firstByte <= 0xb7) {\n // string is 0-55 bytes long. A single byte with value 0x80 plus the length of the string followed by the string\n // The range of the first byte is [0x80, 0xb7]\n length = firstByte - 0x7f;\n // set 0x80 null to 0\n if (firstByte === 0x80) {\n data = Buffer.from([]);\n } else {\n data = input.slice(1, length);\n }\n if (length === 2 && data[0] < 0x80) {\n throw new Error('invalid rlp encoding: byte must be less 0x80');\n }\n return {\n data: data,\n remainder: input.slice(length)\n };\n } else if (firstByte <= 0xbf) {\n // string is greater than 55 bytes long. A single byte with the value (0xb7 plus the length of the length),\n // followed by the length, followed by the string\n llength = firstByte - 0xb6;\n if (input.length - 1 < llength) {\n throw new Error('invalid RLP: not enough bytes for string length');\n }\n length = safeParseInt(input.slice(1, llength).toString('hex'), 16);\n if (length <= 55) {\n throw new Error('invalid RLP: expected string length to be greater than 55');\n }\n data = input.slice(llength, length + llength);\n if (data.length < length) {\n throw new Error('invalid RLP: not enough bytes for string');\n }\n return {\n data: data,\n remainder: input.slice(length + llength)\n };\n } else if (firstByte <= 0xf7) {\n // a list between 0-55 bytes long\n length = firstByte - 0xbf;\n innerRemainder = input.slice(1, length);\n while (innerRemainder.length) {\n d = _decode(innerRemainder);\n decoded.push(d.data);\n innerRemainder = d.remainder;\n }\n return {\n data: decoded,\n remainder: input.slice(length)\n };\n } else {\n // a list over 55 bytes long\n llength = firstByte - 0xf6;\n length = safeParseInt(input.slice(1, llength).toString('hex'), 16);\n var totalLength = llength + length;\n if (totalLength > input.length) {\n throw new Error('invalid rlp: total length is larger than the data');\n }\n innerRemainder = input.slice(llength, totalLength);\n if (innerRemainder.length === 0) {\n throw new Error('invalid rlp, List has a invalid length');\n }\n while (innerRemainder.length) {\n d = _decode(innerRemainder);\n decoded.push(d.data);\n innerRemainder = d.remainder;\n }\n return {\n data: decoded,\n remainder: input.slice(totalLength)\n };\n }\n}\n/** Check if a string is prefixed by 0x */\nfunction isHexPrefixed(str) {\n return str.slice(0, 2) === '0x';\n}\n/** Removes 0x from a given String */\nfunction stripHexPrefix(str) {\n if (typeof str !== 'string') {\n return str;\n }\n return isHexPrefixed(str) ? str.slice(2) : str;\n}\n/** Transform an integer into its hexadecimal value */\nfunction intToHex(integer) {\n if (integer < 0) {\n throw new Error('Invalid integer as argument, must be unsigned!');\n }\n var hex = integer.toString(16);\n return hex.length % 2 ? \"0\" + hex : hex;\n}\n/** Pad a string to be even */\nfunction padToEven(a) {\n return a.length % 2 ? \"0\" + a : a;\n}\n/** Transform an integer into a Buffer */\nfunction intToBuffer(integer) {\n var hex = intToHex(integer);\n return Buffer.from(hex, 'hex');\n}\n/** Transform anything into a Buffer */\nfunction toBuffer(v) {\n if (!Buffer.isBuffer(v)) {\n if (typeof v === 'string') {\n if (isHexPrefixed(v)) {\n return Buffer.from(padToEven(stripHexPrefix(v)), 'hex');\n } else {\n return Buffer.from(v);\n }\n } else if (typeof v === 'number' || typeof v === 'bigint') {\n if (!v) {\n return Buffer.from([]);\n } else {\n return intToBuffer(v);\n }\n } else if (v === null || v === undefined) {\n return Buffer.from([]);\n } else if (v instanceof Uint8Array) {\n return Buffer.from(v);\n } else if (bn_js_1.default.isBN(v)) {\n // converts a BN to a Buffer\n return Buffer.from(v.toArray());\n } else {\n throw new Error('invalid type');\n }\n }\n return v;\n}\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict';\n\nconst base64 = require('base64-js');\nconst ieee754 = require('ieee754');\nconst customInspectSymbol = typeof Symbol === 'function' && typeof Symbol['for'] === 'function' // eslint-disable-line dot-notation\n? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n: null;\nexports.Buffer = Buffer;\nexports.SlowBuffer = SlowBuffer;\nexports.INSPECT_MAX_BYTES = 50;\nconst K_MAX_LENGTH = 0x7fffffff;\nexports.kMaxLength = K_MAX_LENGTH;\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport();\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error('This browser lacks typed array (Uint8Array) support which is required by ' + '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.');\n}\nfunction typedArraySupport() {\n // Can typed array instances can be augmented?\n try {\n const arr = new Uint8Array(1);\n const proto = {\n foo: function () {\n return 42;\n }\n };\n Object.setPrototypeOf(proto, Uint8Array.prototype);\n Object.setPrototypeOf(arr, proto);\n return arr.foo() === 42;\n } catch (e) {\n return false;\n }\n}\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined;\n return this.buffer;\n }\n});\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined;\n return this.byteOffset;\n }\n});\nfunction createBuffer(length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"');\n }\n // Return an augmented `Uint8Array` instance\n const buf = new Uint8Array(length);\n Object.setPrototypeOf(buf, Buffer.prototype);\n return buf;\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer(arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError('The \"string\" argument must be of type string. Received type number');\n }\n return allocUnsafe(arg);\n }\n return from(arg, encodingOrOffset, length);\n}\nBuffer.poolSize = 8192; // not used by this implementation\n\nfunction from(value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset);\n }\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value);\n }\n if (value == null) {\n throw new TypeError('The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' + 'or Array-like Object. Received type ' + typeof value);\n }\n if (isInstance(value, ArrayBuffer) || value && isInstance(value.buffer, ArrayBuffer)) {\n return fromArrayBuffer(value, encodingOrOffset, length);\n }\n if (typeof SharedArrayBuffer !== 'undefined' && (isInstance(value, SharedArrayBuffer) || value && isInstance(value.buffer, SharedArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length);\n }\n if (typeof value === 'number') {\n throw new TypeError('The \"value\" argument must not be of type number. Received type number');\n }\n const valueOf = value.valueOf && value.valueOf();\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length);\n }\n const b = fromObject(value);\n if (b) return b;\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null && typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length);\n }\n throw new TypeError('The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' + 'or Array-like Object. Received type ' + typeof value);\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length);\n};\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype);\nObject.setPrototypeOf(Buffer, Uint8Array);\nfunction assertSize(size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number');\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"');\n }\n}\nfunction alloc(size, fill, encoding) {\n assertSize(size);\n if (size <= 0) {\n return createBuffer(size);\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string' ? createBuffer(size).fill(fill, encoding) : createBuffer(size).fill(fill);\n }\n return createBuffer(size);\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding);\n};\nfunction allocUnsafe(size) {\n assertSize(size);\n return createBuffer(size < 0 ? 0 : checked(size) | 0);\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size);\n};\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size);\n};\nfunction fromString(string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8';\n }\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding);\n }\n const length = byteLength(string, encoding) | 0;\n let buf = createBuffer(length);\n const actual = buf.write(string, encoding);\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual);\n }\n return buf;\n}\nfunction fromArrayLike(array) {\n const length = array.length < 0 ? 0 : checked(array.length) | 0;\n const buf = createBuffer(length);\n for (let i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255;\n }\n return buf;\n}\nfunction fromArrayView(arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n const copy = new Uint8Array(arrayView);\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength);\n }\n return fromArrayLike(arrayView);\n}\nfunction fromArrayBuffer(array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds');\n }\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds');\n }\n let buf;\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array);\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset);\n } else {\n buf = new Uint8Array(array, byteOffset, length);\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype);\n return buf;\n}\nfunction fromObject(obj) {\n if (Buffer.isBuffer(obj)) {\n const len = checked(obj.length) | 0;\n const buf = createBuffer(len);\n if (buf.length === 0) {\n return buf;\n }\n obj.copy(buf, 0, 0, len);\n return buf;\n }\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0);\n }\n return fromArrayLike(obj);\n }\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data);\n }\n}\nfunction checked(length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' + 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes');\n }\n return length | 0;\n}\nfunction SlowBuffer(length) {\n if (+length != length) {\n // eslint-disable-line eqeqeq\n length = 0;\n }\n return Buffer.alloc(+length);\n}\nBuffer.isBuffer = function isBuffer(b) {\n return b != null && b._isBuffer === true && b !== Buffer.prototype; // so Buffer.isBuffer(Buffer.prototype) will be false\n};\nBuffer.compare = function compare(a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength);\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength);\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array');\n }\n if (a === b) return 0;\n let x = a.length;\n let y = b.length;\n for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i];\n y = b[i];\n break;\n }\n }\n if (x < y) return -1;\n if (y < x) return 1;\n return 0;\n};\nBuffer.isEncoding = function isEncoding(encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true;\n default:\n return false;\n }\n};\nBuffer.concat = function concat(list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers');\n }\n if (list.length === 0) {\n return Buffer.alloc(0);\n }\n let i;\n if (length === undefined) {\n length = 0;\n for (i = 0; i < list.length; ++i) {\n length += list[i].length;\n }\n }\n const buffer = Buffer.allocUnsafe(length);\n let pos = 0;\n for (i = 0; i < list.length; ++i) {\n let buf = list[i];\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf);\n buf.copy(buffer, pos);\n } else {\n Uint8Array.prototype.set.call(buffer, buf, pos);\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers');\n } else {\n buf.copy(buffer, pos);\n }\n pos += buf.length;\n }\n return buffer;\n};\nfunction byteLength(string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length;\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength;\n }\n if (typeof string !== 'string') {\n throw new TypeError('The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' + 'Received type ' + typeof string);\n }\n const len = string.length;\n const mustMatch = arguments.length > 2 && arguments[2] === true;\n if (!mustMatch && len === 0) return 0;\n\n // Use a for loop to avoid recursion\n let loweredCase = false;\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len;\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length;\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2;\n case 'hex':\n return len >>> 1;\n case 'base64':\n return base64ToBytes(string).length;\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length; // assume utf8\n }\n encoding = ('' + encoding).toLowerCase();\n loweredCase = true;\n }\n }\n}\nBuffer.byteLength = byteLength;\nfunction slowToString(encoding, start, end) {\n let loweredCase = false;\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0;\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return '';\n }\n if (end === undefined || end > this.length) {\n end = this.length;\n }\n if (end <= 0) {\n return '';\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0;\n start >>>= 0;\n if (end <= start) {\n return '';\n }\n if (!encoding) encoding = 'utf8';\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end);\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end);\n case 'ascii':\n return asciiSlice(this, start, end);\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end);\n case 'base64':\n return base64Slice(this, start, end);\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end);\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding);\n encoding = (encoding + '').toLowerCase();\n loweredCase = true;\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true;\nfunction swap(b, n, m) {\n const i = b[n];\n b[n] = b[m];\n b[m] = i;\n}\nBuffer.prototype.swap16 = function swap16() {\n const len = this.length;\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits');\n }\n for (let i = 0; i < len; i += 2) {\n swap(this, i, i + 1);\n }\n return this;\n};\nBuffer.prototype.swap32 = function swap32() {\n const len = this.length;\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits');\n }\n for (let i = 0; i < len; i += 4) {\n swap(this, i, i + 3);\n swap(this, i + 1, i + 2);\n }\n return this;\n};\nBuffer.prototype.swap64 = function swap64() {\n const len = this.length;\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits');\n }\n for (let i = 0; i < len; i += 8) {\n swap(this, i, i + 7);\n swap(this, i + 1, i + 6);\n swap(this, i + 2, i + 5);\n swap(this, i + 3, i + 4);\n }\n return this;\n};\nBuffer.prototype.toString = function toString() {\n const length = this.length;\n if (length === 0) return '';\n if (arguments.length === 0) return utf8Slice(this, 0, length);\n return slowToString.apply(this, arguments);\n};\nBuffer.prototype.toLocaleString = Buffer.prototype.toString;\nBuffer.prototype.equals = function equals(b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer');\n if (this === b) return true;\n return Buffer.compare(this, b) === 0;\n};\nBuffer.prototype.inspect = function inspect() {\n let str = '';\n const max = exports.INSPECT_MAX_BYTES;\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim();\n if (this.length > max) str += ' ... ';\n return '';\n};\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect;\n}\nBuffer.prototype.compare = function compare(target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength);\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('The \"target\" argument must be one of type Buffer or Uint8Array. ' + 'Received type ' + typeof target);\n }\n if (start === undefined) {\n start = 0;\n }\n if (end === undefined) {\n end = target ? target.length : 0;\n }\n if (thisStart === undefined) {\n thisStart = 0;\n }\n if (thisEnd === undefined) {\n thisEnd = this.length;\n }\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index');\n }\n if (thisStart >= thisEnd && start >= end) {\n return 0;\n }\n if (thisStart >= thisEnd) {\n return -1;\n }\n if (start >= end) {\n return 1;\n }\n start >>>= 0;\n end >>>= 0;\n thisStart >>>= 0;\n thisEnd >>>= 0;\n if (this === target) return 0;\n let x = thisEnd - thisStart;\n let y = end - start;\n const len = Math.min(x, y);\n const thisCopy = this.slice(thisStart, thisEnd);\n const targetCopy = target.slice(start, end);\n for (let i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i];\n y = targetCopy[i];\n break;\n }\n }\n if (x < y) return -1;\n if (y < x) return 1;\n return 0;\n};\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf(buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1;\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset;\n byteOffset = 0;\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff;\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000;\n }\n byteOffset = +byteOffset; // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : buffer.length - 1;\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset;\n if (byteOffset >= buffer.length) {\n if (dir) return -1;else byteOffset = buffer.length - 1;\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0;else return -1;\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding);\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1;\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir);\n } else if (typeof val === 'number') {\n val = val & 0xFF; // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset);\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset);\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir);\n }\n throw new TypeError('val must be string, number or Buffer');\n}\nfunction arrayIndexOf(arr, val, byteOffset, encoding, dir) {\n let indexSize = 1;\n let arrLength = arr.length;\n let valLength = val.length;\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase();\n if (encoding === 'ucs2' || encoding === 'ucs-2' || encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1;\n }\n indexSize = 2;\n arrLength /= 2;\n valLength /= 2;\n byteOffset /= 2;\n }\n }\n function read(buf, i) {\n if (indexSize === 1) {\n return buf[i];\n } else {\n return buf.readUInt16BE(i * indexSize);\n }\n }\n let i;\n if (dir) {\n let foundIndex = -1;\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i;\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize;\n } else {\n if (foundIndex !== -1) i -= i - foundIndex;\n foundIndex = -1;\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength;\n for (i = byteOffset; i >= 0; i--) {\n let found = true;\n for (let j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false;\n break;\n }\n }\n if (found) return i;\n }\n }\n return -1;\n}\nBuffer.prototype.includes = function includes(val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1;\n};\nBuffer.prototype.indexOf = function indexOf(val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true);\n};\nBuffer.prototype.lastIndexOf = function lastIndexOf(val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false);\n};\nfunction hexWrite(buf, string, offset, length) {\n offset = Number(offset) || 0;\n const remaining = buf.length - offset;\n if (!length) {\n length = remaining;\n } else {\n length = Number(length);\n if (length > remaining) {\n length = remaining;\n }\n }\n const strLen = string.length;\n if (length > strLen / 2) {\n length = strLen / 2;\n }\n let i;\n for (i = 0; i < length; ++i) {\n const parsed = parseInt(string.substr(i * 2, 2), 16);\n if (numberIsNaN(parsed)) return i;\n buf[offset + i] = parsed;\n }\n return i;\n}\nfunction utf8Write(buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length);\n}\nfunction asciiWrite(buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length);\n}\nfunction base64Write(buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length);\n}\nfunction ucs2Write(buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length);\n}\nBuffer.prototype.write = function write(string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8';\n length = this.length;\n offset = 0;\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset;\n length = this.length;\n offset = 0;\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0;\n if (isFinite(length)) {\n length = length >>> 0;\n if (encoding === undefined) encoding = 'utf8';\n } else {\n encoding = length;\n length = undefined;\n }\n } else {\n throw new Error('Buffer.write(string, encoding, offset[, length]) is no longer supported');\n }\n const remaining = this.length - offset;\n if (length === undefined || length > remaining) length = remaining;\n if (string.length > 0 && (length < 0 || offset < 0) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds');\n }\n if (!encoding) encoding = 'utf8';\n let loweredCase = false;\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length);\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length);\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length);\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length);\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length);\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding);\n encoding = ('' + encoding).toLowerCase();\n loweredCase = true;\n }\n }\n};\nBuffer.prototype.toJSON = function toJSON() {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n };\n};\nfunction base64Slice(buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf);\n } else {\n return base64.fromByteArray(buf.slice(start, end));\n }\n}\nfunction utf8Slice(buf, start, end) {\n end = Math.min(buf.length, end);\n const res = [];\n let i = start;\n while (i < end) {\n const firstByte = buf[i];\n let codePoint = null;\n let bytesPerSequence = firstByte > 0xEF ? 4 : firstByte > 0xDF ? 3 : firstByte > 0xBF ? 2 : 1;\n if (i + bytesPerSequence <= end) {\n let secondByte, thirdByte, fourthByte, tempCodePoint;\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte;\n }\n break;\n case 2:\n secondByte = buf[i + 1];\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | secondByte & 0x3F;\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 3:\n secondByte = buf[i + 1];\n thirdByte = buf[i + 2];\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | thirdByte & 0x3F;\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint;\n }\n }\n break;\n case 4:\n secondByte = buf[i + 1];\n thirdByte = buf[i + 2];\n fourthByte = buf[i + 3];\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | fourthByte & 0x3F;\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint;\n }\n }\n }\n }\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD;\n bytesPerSequence = 1;\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000;\n res.push(codePoint >>> 10 & 0x3FF | 0xD800);\n codePoint = 0xDC00 | codePoint & 0x3FF;\n }\n res.push(codePoint);\n i += bytesPerSequence;\n }\n return decodeCodePointsArray(res);\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nconst MAX_ARGUMENTS_LENGTH = 0x1000;\nfunction decodeCodePointsArray(codePoints) {\n const len = codePoints.length;\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints); // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n let res = '';\n let i = 0;\n while (i < len) {\n res += String.fromCharCode.apply(String, codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH));\n }\n return res;\n}\nfunction asciiSlice(buf, start, end) {\n let ret = '';\n end = Math.min(buf.length, end);\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F);\n }\n return ret;\n}\nfunction latin1Slice(buf, start, end) {\n let ret = '';\n end = Math.min(buf.length, end);\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i]);\n }\n return ret;\n}\nfunction hexSlice(buf, start, end) {\n const len = buf.length;\n if (!start || start < 0) start = 0;\n if (!end || end < 0 || end > len) end = len;\n let out = '';\n for (let i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]];\n }\n return out;\n}\nfunction utf16leSlice(buf, start, end) {\n const bytes = buf.slice(start, end);\n let res = '';\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (let i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256);\n }\n return res;\n}\nBuffer.prototype.slice = function slice(start, end) {\n const len = this.length;\n start = ~~start;\n end = end === undefined ? len : ~~end;\n if (start < 0) {\n start += len;\n if (start < 0) start = 0;\n } else if (start > len) {\n start = len;\n }\n if (end < 0) {\n end += len;\n if (end < 0) end = 0;\n } else if (end > len) {\n end = len;\n }\n if (end < start) end = start;\n const newBuf = this.subarray(start, end);\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype);\n return newBuf;\n};\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset(offset, ext, length) {\n if (offset % 1 !== 0 || offset < 0) throw new RangeError('offset is not uint');\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length');\n}\nBuffer.prototype.readUintLE = Buffer.prototype.readUIntLE = function readUIntLE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) checkOffset(offset, byteLength, this.length);\n let val = this[offset];\n let mul = 1;\n let i = 0;\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul;\n }\n return val;\n};\nBuffer.prototype.readUintBE = Buffer.prototype.readUIntBE = function readUIntBE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length);\n }\n let val = this[offset + --byteLength];\n let mul = 1;\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul;\n }\n return val;\n};\nBuffer.prototype.readUint8 = Buffer.prototype.readUInt8 = function readUInt8(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 1, this.length);\n return this[offset];\n};\nBuffer.prototype.readUint16LE = Buffer.prototype.readUInt16LE = function readUInt16LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n return this[offset] | this[offset + 1] << 8;\n};\nBuffer.prototype.readUint16BE = Buffer.prototype.readUInt16BE = function readUInt16BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n return this[offset] << 8 | this[offset + 1];\n};\nBuffer.prototype.readUint32LE = Buffer.prototype.readUInt32LE = function readUInt32LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return (this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16) + this[offset + 3] * 0x1000000;\n};\nBuffer.prototype.readUint32BE = Buffer.prototype.readUInt32BE = function readUInt32BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return this[offset] * 0x1000000 + (this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3]);\n};\nBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n const first = this[offset];\n const last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n const lo = first + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 24;\n const hi = this[++offset] + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + last * 2 ** 24;\n return BigInt(lo) + (BigInt(hi) << BigInt(32));\n});\nBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n const first = this[offset];\n const last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n const hi = first * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + this[++offset];\n const lo = this[++offset] * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + last;\n return (BigInt(hi) << BigInt(32)) + BigInt(lo);\n});\nBuffer.prototype.readIntLE = function readIntLE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) checkOffset(offset, byteLength, this.length);\n let val = this[offset];\n let mul = 1;\n let i = 0;\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul;\n }\n mul *= 0x80;\n if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n return val;\n};\nBuffer.prototype.readIntBE = function readIntBE(offset, byteLength, noAssert) {\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) checkOffset(offset, byteLength, this.length);\n let i = byteLength;\n let mul = 1;\n let val = this[offset + --i];\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul;\n }\n mul *= 0x80;\n if (val >= mul) val -= Math.pow(2, 8 * byteLength);\n return val;\n};\nBuffer.prototype.readInt8 = function readInt8(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 1, this.length);\n if (!(this[offset] & 0x80)) return this[offset];\n return (0xff - this[offset] + 1) * -1;\n};\nBuffer.prototype.readInt16LE = function readInt16LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n const val = this[offset] | this[offset + 1] << 8;\n return val & 0x8000 ? val | 0xFFFF0000 : val;\n};\nBuffer.prototype.readInt16BE = function readInt16BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 2, this.length);\n const val = this[offset + 1] | this[offset] << 8;\n return val & 0x8000 ? val | 0xFFFF0000 : val;\n};\nBuffer.prototype.readInt32LE = function readInt32LE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16 | this[offset + 3] << 24;\n};\nBuffer.prototype.readInt32BE = function readInt32BE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return this[offset] << 24 | this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3];\n};\nBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n const first = this[offset];\n const last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n const val = this[offset + 4] + this[offset + 5] * 2 ** 8 + this[offset + 6] * 2 ** 16 + (last << 24); // Overflow\n\n return (BigInt(val) << BigInt(32)) + BigInt(first + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 24);\n});\nBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE(offset) {\n offset = offset >>> 0;\n validateNumber(offset, 'offset');\n const first = this[offset];\n const last = this[offset + 7];\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8);\n }\n const val = (first << 24) +\n // Overflow\n this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + this[++offset];\n return (BigInt(val) << BigInt(32)) + BigInt(this[++offset] * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + last);\n});\nBuffer.prototype.readFloatLE = function readFloatLE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return ieee754.read(this, offset, true, 23, 4);\n};\nBuffer.prototype.readFloatBE = function readFloatBE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 4, this.length);\n return ieee754.read(this, offset, false, 23, 4);\n};\nBuffer.prototype.readDoubleLE = function readDoubleLE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 8, this.length);\n return ieee754.read(this, offset, true, 52, 8);\n};\nBuffer.prototype.readDoubleBE = function readDoubleBE(offset, noAssert) {\n offset = offset >>> 0;\n if (!noAssert) checkOffset(offset, 8, this.length);\n return ieee754.read(this, offset, false, 52, 8);\n};\nfunction checkInt(buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance');\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds');\n if (offset + ext > buf.length) throw new RangeError('Index out of range');\n}\nBuffer.prototype.writeUintLE = Buffer.prototype.writeUIntLE = function writeUIntLE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1;\n checkInt(this, value, offset, byteLength, maxBytes, 0);\n }\n let mul = 1;\n let i = 0;\n this[offset] = value & 0xFF;\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = value / mul & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeUintBE = Buffer.prototype.writeUIntBE = function writeUIntBE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n byteLength = byteLength >>> 0;\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1;\n checkInt(this, value, offset, byteLength, maxBytes, 0);\n }\n let i = byteLength - 1;\n let mul = 1;\n this[offset + i] = value & 0xFF;\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = value / mul & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeUint8 = Buffer.prototype.writeUInt8 = function writeUInt8(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0);\n this[offset] = value & 0xff;\n return offset + 1;\n};\nBuffer.prototype.writeUint16LE = Buffer.prototype.writeUInt16LE = function writeUInt16LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n this[offset] = value & 0xff;\n this[offset + 1] = value >>> 8;\n return offset + 2;\n};\nBuffer.prototype.writeUint16BE = Buffer.prototype.writeUInt16BE = function writeUInt16BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0);\n this[offset] = value >>> 8;\n this[offset + 1] = value & 0xff;\n return offset + 2;\n};\nBuffer.prototype.writeUint32LE = Buffer.prototype.writeUInt32LE = function writeUInt32LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n this[offset + 3] = value >>> 24;\n this[offset + 2] = value >>> 16;\n this[offset + 1] = value >>> 8;\n this[offset] = value & 0xff;\n return offset + 4;\n};\nBuffer.prototype.writeUint32BE = Buffer.prototype.writeUInt32BE = function writeUInt32BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0);\n this[offset] = value >>> 24;\n this[offset + 1] = value >>> 16;\n this[offset + 2] = value >>> 8;\n this[offset + 3] = value & 0xff;\n return offset + 4;\n};\nfunction wrtBigUInt64LE(buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7);\n let lo = Number(value & BigInt(0xffffffff));\n buf[offset++] = lo;\n lo = lo >> 8;\n buf[offset++] = lo;\n lo = lo >> 8;\n buf[offset++] = lo;\n lo = lo >> 8;\n buf[offset++] = lo;\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n buf[offset++] = hi;\n hi = hi >> 8;\n buf[offset++] = hi;\n hi = hi >> 8;\n buf[offset++] = hi;\n hi = hi >> 8;\n buf[offset++] = hi;\n return offset;\n}\nfunction wrtBigUInt64BE(buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7);\n let lo = Number(value & BigInt(0xffffffff));\n buf[offset + 7] = lo;\n lo = lo >> 8;\n buf[offset + 6] = lo;\n lo = lo >> 8;\n buf[offset + 5] = lo;\n lo = lo >> 8;\n buf[offset + 4] = lo;\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff));\n buf[offset + 3] = hi;\n hi = hi >> 8;\n buf[offset + 2] = hi;\n hi = hi >> 8;\n buf[offset + 1] = hi;\n hi = hi >> 8;\n buf[offset] = hi;\n return offset + 8;\n}\nBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE(value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'));\n});\nBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE(value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'));\n});\nBuffer.prototype.writeIntLE = function writeIntLE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n const limit = Math.pow(2, 8 * byteLength - 1);\n checkInt(this, value, offset, byteLength, limit - 1, -limit);\n }\n let i = 0;\n let mul = 1;\n let sub = 0;\n this[offset] = value & 0xFF;\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1;\n }\n this[offset + i] = (value / mul >> 0) - sub & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeIntBE = function writeIntBE(value, offset, byteLength, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n const limit = Math.pow(2, 8 * byteLength - 1);\n checkInt(this, value, offset, byteLength, limit - 1, -limit);\n }\n let i = byteLength - 1;\n let mul = 1;\n let sub = 0;\n this[offset + i] = value & 0xFF;\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1;\n }\n this[offset + i] = (value / mul >> 0) - sub & 0xFF;\n }\n return offset + byteLength;\n};\nBuffer.prototype.writeInt8 = function writeInt8(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80);\n if (value < 0) value = 0xff + value + 1;\n this[offset] = value & 0xff;\n return offset + 1;\n};\nBuffer.prototype.writeInt16LE = function writeInt16LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n this[offset] = value & 0xff;\n this[offset + 1] = value >>> 8;\n return offset + 2;\n};\nBuffer.prototype.writeInt16BE = function writeInt16BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000);\n this[offset] = value >>> 8;\n this[offset + 1] = value & 0xff;\n return offset + 2;\n};\nBuffer.prototype.writeInt32LE = function writeInt32LE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n this[offset] = value & 0xff;\n this[offset + 1] = value >>> 8;\n this[offset + 2] = value >>> 16;\n this[offset + 3] = value >>> 24;\n return offset + 4;\n};\nBuffer.prototype.writeInt32BE = function writeInt32BE(value, offset, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000);\n if (value < 0) value = 0xffffffff + value + 1;\n this[offset] = value >>> 24;\n this[offset + 1] = value >>> 16;\n this[offset + 2] = value >>> 8;\n this[offset + 3] = value & 0xff;\n return offset + 4;\n};\nBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE(value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'));\n});\nBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE(value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'));\n});\nfunction checkIEEE754(buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range');\n if (offset < 0) throw new RangeError('Index out of range');\n}\nfunction writeFloat(buf, value, offset, littleEndian, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38);\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4);\n return offset + 4;\n}\nBuffer.prototype.writeFloatLE = function writeFloatLE(value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert);\n};\nBuffer.prototype.writeFloatBE = function writeFloatBE(value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert);\n};\nfunction writeDouble(buf, value, offset, littleEndian, noAssert) {\n value = +value;\n offset = offset >>> 0;\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308);\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8);\n return offset + 8;\n}\nBuffer.prototype.writeDoubleLE = function writeDoubleLE(value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert);\n};\nBuffer.prototype.writeDoubleBE = function writeDoubleBE(value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert);\n};\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy(target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer');\n if (!start) start = 0;\n if (!end && end !== 0) end = this.length;\n if (targetStart >= target.length) targetStart = target.length;\n if (!targetStart) targetStart = 0;\n if (end > 0 && end < start) end = start;\n\n // Copy 0 bytes; we're done\n if (end === start) return 0;\n if (target.length === 0 || this.length === 0) return 0;\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds');\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range');\n if (end < 0) throw new RangeError('sourceEnd out of bounds');\n\n // Are we oob?\n if (end > this.length) end = this.length;\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start;\n }\n const len = end - start;\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end);\n } else {\n Uint8Array.prototype.set.call(target, this.subarray(start, end), targetStart);\n }\n return len;\n};\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill(val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start;\n start = 0;\n end = this.length;\n } else if (typeof end === 'string') {\n encoding = end;\n end = this.length;\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string');\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding);\n }\n if (val.length === 1) {\n const code = val.charCodeAt(0);\n if (encoding === 'utf8' && code < 128 || encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code;\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255;\n } else if (typeof val === 'boolean') {\n val = Number(val);\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index');\n }\n if (end <= start) {\n return this;\n }\n start = start >>> 0;\n end = end === undefined ? this.length : end >>> 0;\n if (!val) val = 0;\n let i;\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val;\n }\n } else {\n const bytes = Buffer.isBuffer(val) ? val : Buffer.from(val, encoding);\n const len = bytes.length;\n if (len === 0) {\n throw new TypeError('The value \"' + val + '\" is invalid for argument \"value\"');\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len];\n }\n }\n return this;\n};\n\n// CUSTOM ERRORS\n// =============\n\n// Simplified versions from Node, changed for Buffer-only usage\nconst errors = {};\nfunction E(sym, getMessage, Base) {\n errors[sym] = class NodeError extends Base {\n constructor() {\n super();\n Object.defineProperty(this, 'message', {\n value: getMessage.apply(this, arguments),\n writable: true,\n configurable: true\n });\n\n // Add the error code to the name to include it in the stack trace.\n this.name = `${this.name} [${sym}]`;\n // Access the stack to generate the error message including the error code\n // from the name.\n this.stack; // eslint-disable-line no-unused-expressions\n // Reset the name to the actual name.\n delete this.name;\n }\n get code() {\n return sym;\n }\n set code(value) {\n Object.defineProperty(this, 'code', {\n configurable: true,\n enumerable: true,\n value,\n writable: true\n });\n }\n toString() {\n return `${this.name} [${sym}]: ${this.message}`;\n }\n };\n}\nE('ERR_BUFFER_OUT_OF_BOUNDS', function (name) {\n if (name) {\n return `${name} is outside of buffer bounds`;\n }\n return 'Attempt to access memory outside buffer bounds';\n}, RangeError);\nE('ERR_INVALID_ARG_TYPE', function (name, actual) {\n return `The \"${name}\" argument must be of type number. Received type ${typeof actual}`;\n}, TypeError);\nE('ERR_OUT_OF_RANGE', function (str, range, input) {\n let msg = `The value of \"${str}\" is out of range.`;\n let received = input;\n if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n received = addNumericalSeparator(String(input));\n } else if (typeof input === 'bigint') {\n received = String(input);\n if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) {\n received = addNumericalSeparator(received);\n }\n received += 'n';\n }\n msg += ` It must be ${range}. Received ${received}`;\n return msg;\n}, RangeError);\nfunction addNumericalSeparator(val) {\n let res = '';\n let i = val.length;\n const start = val[0] === '-' ? 1 : 0;\n for (; i >= start + 4; i -= 3) {\n res = `_${val.slice(i - 3, i)}${res}`;\n }\n return `${val.slice(0, i)}${res}`;\n}\n\n// CHECK FUNCTIONS\n// ===============\n\nfunction checkBounds(buf, offset, byteLength) {\n validateNumber(offset, 'offset');\n if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n boundsError(offset, buf.length - (byteLength + 1));\n }\n}\nfunction checkIntBI(value, min, max, buf, offset, byteLength) {\n if (value > max || value < min) {\n const n = typeof min === 'bigint' ? 'n' : '';\n let range;\n if (byteLength > 3) {\n if (min === 0 || min === BigInt(0)) {\n range = `>= 0${n} and < 2${n} ** ${(byteLength + 1) * 8}${n}`;\n } else {\n range = `>= -(2${n} ** ${(byteLength + 1) * 8 - 1}${n}) and < 2 ** ` + `${(byteLength + 1) * 8 - 1}${n}`;\n }\n } else {\n range = `>= ${min}${n} and <= ${max}${n}`;\n }\n throw new errors.ERR_OUT_OF_RANGE('value', range, value);\n }\n checkBounds(buf, offset, byteLength);\n}\nfunction validateNumber(value, name) {\n if (typeof value !== 'number') {\n throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value);\n }\n}\nfunction boundsError(value, length, type) {\n if (Math.floor(value) !== value) {\n validateNumber(value, type);\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value);\n }\n if (length < 0) {\n throw new errors.ERR_BUFFER_OUT_OF_BOUNDS();\n }\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', `>= ${type ? 1 : 0} and <= ${length}`, value);\n}\n\n// HELPER FUNCTIONS\n// ================\n\nconst INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g;\nfunction base64clean(str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0];\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '');\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return '';\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '=';\n }\n return str;\n}\nfunction utf8ToBytes(string, units) {\n units = units || Infinity;\n let codePoint;\n const length = string.length;\n let leadSurrogate = null;\n const bytes = [];\n for (let i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i);\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n continue;\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n continue;\n }\n\n // valid lead\n leadSurrogate = codePoint;\n continue;\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n leadSurrogate = codePoint;\n continue;\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000;\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD);\n }\n leadSurrogate = null;\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break;\n bytes.push(codePoint);\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break;\n bytes.push(codePoint >> 0x6 | 0xC0, codePoint & 0x3F | 0x80);\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break;\n bytes.push(codePoint >> 0xC | 0xE0, codePoint >> 0x6 & 0x3F | 0x80, codePoint & 0x3F | 0x80);\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break;\n bytes.push(codePoint >> 0x12 | 0xF0, codePoint >> 0xC & 0x3F | 0x80, codePoint >> 0x6 & 0x3F | 0x80, codePoint & 0x3F | 0x80);\n } else {\n throw new Error('Invalid code point');\n }\n }\n return bytes;\n}\nfunction asciiToBytes(str) {\n const byteArray = [];\n for (let i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF);\n }\n return byteArray;\n}\nfunction utf16leToBytes(str, units) {\n let c, hi, lo;\n const byteArray = [];\n for (let i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break;\n c = str.charCodeAt(i);\n hi = c >> 8;\n lo = c % 256;\n byteArray.push(lo);\n byteArray.push(hi);\n }\n return byteArray;\n}\nfunction base64ToBytes(str) {\n return base64.toByteArray(base64clean(str));\n}\nfunction blitBuffer(src, dst, offset, length) {\n let i;\n for (i = 0; i < length; ++i) {\n if (i + offset >= dst.length || i >= src.length) break;\n dst[i + offset] = src[i];\n }\n return i;\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance(obj, type) {\n return obj instanceof type || obj != null && obj.constructor != null && obj.constructor.name != null && obj.constructor.name === type.name;\n}\nfunction numberIsNaN(obj) {\n // For IE11 support\n return obj !== obj; // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nconst hexSliceLookupTable = function () {\n const alphabet = '0123456789abcdef';\n const table = new Array(256);\n for (let i = 0; i < 16; ++i) {\n const i16 = i * 16;\n for (let j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j];\n }\n }\n return table;\n}();\n\n// Return not function with Error if BigInt not supported\nfunction defineBigIntMethod(fn) {\n return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn;\n}\nfunction BufferBigIntNotDefined() {\n throw new Error('BigInt not supported');\n}","\"use strict\";\n\n/**\n * Re-exports commonly used modules:\n * * Exports [`BN`](https://github.com/indutny/bn.js), [`rlp`](https://github.com/ethereumjs/rlp).\n * @packageDocumentation\n */\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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 __setModuleDefault = this && this.__setModuleDefault || (Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rlp = exports.BN = void 0;\nvar bn_js_1 = __importDefault(require(\"bn.js\"));\nexports.BN = bn_js_1.default;\nvar rlp = __importStar(require(\"rlp\"));\nexports.rlp = rlp;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.KECCAK256_RLP = exports.KECCAK256_RLP_S = exports.KECCAK256_RLP_ARRAY = exports.KECCAK256_RLP_ARRAY_S = exports.KECCAK256_NULL = exports.KECCAK256_NULL_S = exports.TWO_POW256 = exports.MAX_INTEGER = exports.MAX_UINT64 = void 0;\nvar buffer_1 = require(\"buffer\");\nvar externals_1 = require(\"./externals\");\n/**\n * 2^64-1\n */\nexports.MAX_UINT64 = new externals_1.BN('ffffffffffffffff', 16);\n/**\n * The max integer that the evm can handle (2^256-1)\n */\nexports.MAX_INTEGER = new externals_1.BN('ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', 16);\n/**\n * 2^256\n */\nexports.TWO_POW256 = new externals_1.BN('10000000000000000000000000000000000000000000000000000000000000000', 16);\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL_S = 'c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470';\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL = buffer_1.Buffer.from(exports.KECCAK256_NULL_S, 'hex');\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY_S = '1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347';\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY = buffer_1.Buffer.from(exports.KECCAK256_RLP_ARRAY_S, 'hex');\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP_S = '56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421';\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP = buffer_1.Buffer.from(exports.KECCAK256_RLP_S, 'hex');\n","'use strict';\n\nvar hasSymbols = require('has-symbols/shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasToStringTagShams() {\n return hasSymbols() && !!Symbol.toStringTag;\n};","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar gOPD = require('gopd');\nvar $TypeError = require('es-errors/type');\nvar $floor = GetIntrinsic('%Math.floor%');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionLength(fn, length) {\n if (typeof fn !== 'function') {\n throw new $TypeError('`fn` is not a function');\n }\n if (typeof length !== 'number' || length < 0 || length > 0xFFFFFFFF || $floor(length) !== length) {\n throw new $TypeError('`length` must be a positive 32-bit integer');\n }\n var loose = arguments.length > 2 && !!arguments[2];\n var functionLengthIsConfigurable = true;\n var functionLengthIsWritable = true;\n if ('length' in fn && gOPD) {\n var desc = gOPD(fn, 'length');\n if (desc && !desc.configurable) {\n functionLengthIsConfigurable = false;\n }\n if (desc && !desc.writable) {\n functionLengthIsWritable = false;\n }\n }\n if (functionLengthIsConfigurable || functionLengthIsWritable || !loose) {\n if (hasDescriptors) {\n define( /** @type {Parameters[0]} */fn, 'length', length, true, true);\n } else {\n define( /** @type {Parameters[0]} */fn, 'length', length);\n }\n }\n return fn;\n};","'use strict';\n\nvar bind = require('function-bind');\nvar GetIntrinsic = require('get-intrinsic');\nvar setFunctionLength = require('set-function-length');\nvar $TypeError = require('es-errors/type');\nvar $apply = GetIntrinsic('%Function.prototype.apply%');\nvar $call = GetIntrinsic('%Function.prototype.call%');\nvar $reflectApply = GetIntrinsic('%Reflect.apply%', true) || bind.call($call, $apply);\nvar $defineProperty = require('es-define-property');\nvar $max = GetIntrinsic('%Math.max%');\nmodule.exports = function callBind(originalFunction) {\n if (typeof originalFunction !== 'function') {\n throw new $TypeError('a function is required');\n }\n var func = $reflectApply(bind, $call, arguments);\n return setFunctionLength(func, 1 + $max(0, originalFunction.length - (arguments.length - 1)), true);\n};\nvar applyBind = function applyBind() {\n return $reflectApply(bind, $apply, arguments);\n};\nif ($defineProperty) {\n $defineProperty(module.exports, 'apply', {\n value: applyBind\n });\n} else {\n module.exports.apply = applyBind;\n}","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar callBind = require('./');\nvar $indexOf = callBind(GetIntrinsic('String.prototype.indexOf'));\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n var intrinsic = GetIntrinsic(name, !!allowMissing);\n if (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n return callBind(intrinsic);\n }\n return intrinsic;\n};","'use strict';\n\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar callBound = require('call-bind/callBound');\nvar $toString = callBound('Object.prototype.toString');\nvar isStandardArguments = function isArguments(value) {\n if (hasToStringTag && value && typeof value === 'object' && Symbol.toStringTag in value) {\n return false;\n }\n return $toString(value) === '[object Arguments]';\n};\nvar isLegacyArguments = function isArguments(value) {\n if (isStandardArguments(value)) {\n return true;\n }\n return value !== null && typeof value === 'object' && typeof value.length === 'number' && value.length >= 0 && $toString(value) !== '[object Array]' && $toString(value.callee) === '[object Function]';\n};\nvar supportsStandardArguments = function () {\n return isStandardArguments(arguments);\n}();\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;","'use strict';\n\nvar toStr = Object.prototype.toString;\nvar fnToStr = Function.prototype.toString;\nvar isFnRegex = /^\\s*(?:function)?\\*/;\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar getProto = Object.getPrototypeOf;\nvar getGeneratorFunc = function () {\n // eslint-disable-line consistent-return\n if (!hasToStringTag) {\n return false;\n }\n try {\n return Function('return function*() {}')();\n } catch (e) {}\n};\nvar GeneratorFunction;\nmodule.exports = function isGeneratorFunction(fn) {\n if (typeof fn !== 'function') {\n return false;\n }\n if (isFnRegex.test(fnToStr.call(fn))) {\n return true;\n }\n if (!hasToStringTag) {\n var str = toStr.call(fn);\n return str === '[object GeneratorFunction]';\n }\n if (!getProto) {\n return false;\n }\n if (typeof GeneratorFunction === 'undefined') {\n var generatorFunc = getGeneratorFunc();\n GeneratorFunction = generatorFunc ? getProto(generatorFunc) : false;\n }\n return getProto(fn) === GeneratorFunction;\n};","'use strict';\n\nvar fnToStr = Function.prototype.toString;\nvar reflectApply = typeof Reflect === 'object' && Reflect !== null && Reflect.apply;\nvar badArrayLike;\nvar isCallableMarker;\nif (typeof reflectApply === 'function' && typeof Object.defineProperty === 'function') {\n try {\n badArrayLike = Object.defineProperty({}, 'length', {\n get: function () {\n throw isCallableMarker;\n }\n });\n isCallableMarker = {};\n // eslint-disable-next-line no-throw-literal\n reflectApply(function () {\n throw 42;\n }, null, badArrayLike);\n } catch (_) {\n if (_ !== isCallableMarker) {\n reflectApply = null;\n }\n }\n} else {\n reflectApply = null;\n}\nvar constructorRegex = /^\\s*class\\b/;\nvar isES6ClassFn = function isES6ClassFunction(value) {\n try {\n var fnStr = fnToStr.call(value);\n return constructorRegex.test(fnStr);\n } catch (e) {\n return false; // not a function\n }\n};\nvar tryFunctionObject = function tryFunctionToStr(value) {\n try {\n if (isES6ClassFn(value)) {\n return false;\n }\n fnToStr.call(value);\n return true;\n } catch (e) {\n return false;\n }\n};\nvar toStr = Object.prototype.toString;\nvar objectClass = '[object Object]';\nvar fnClass = '[object Function]';\nvar genClass = '[object GeneratorFunction]';\nvar ddaClass = '[object HTMLAllCollection]'; // IE 11\nvar ddaClass2 = '[object HTML document.all class]';\nvar ddaClass3 = '[object HTMLCollection]'; // IE 9-10\nvar hasToStringTag = typeof Symbol === 'function' && !!Symbol.toStringTag; // better: use `has-tostringtag`\n\nvar isIE68 = !(0 in [,]); // eslint-disable-line no-sparse-arrays, comma-spacing\n\nvar isDDA = function isDocumentDotAll() {\n return false;\n};\nif (typeof document === 'object') {\n // Firefox 3 canonicalizes DDA to undefined when it's not accessed directly\n var all = document.all;\n if (toStr.call(all) === toStr.call(document.all)) {\n isDDA = function isDocumentDotAll(value) {\n /* globals document: false */\n // in IE 6-8, typeof document.all is \"object\" and it's truthy\n if ((isIE68 || !value) && (typeof value === 'undefined' || typeof value === 'object')) {\n try {\n var str = toStr.call(value);\n return (str === ddaClass || str === ddaClass2 || str === ddaClass3 // opera 12.16\n || str === objectClass // IE 6-8\n ) && value('') == null; // eslint-disable-line eqeqeq\n } catch (e) {/**/}\n }\n return false;\n };\n }\n}\nmodule.exports = reflectApply ? function isCallable(value) {\n if (isDDA(value)) {\n return true;\n }\n if (!value) {\n return false;\n }\n if (typeof value !== 'function' && typeof value !== 'object') {\n return false;\n }\n try {\n reflectApply(value, null, badArrayLike);\n } catch (e) {\n if (e !== isCallableMarker) {\n return false;\n }\n }\n return !isES6ClassFn(value) && tryFunctionObject(value);\n} : function isCallable(value) {\n if (isDDA(value)) {\n return true;\n }\n if (!value) {\n return false;\n }\n if (typeof value !== 'function' && typeof value !== 'object') {\n return false;\n }\n if (hasToStringTag) {\n return tryFunctionObject(value);\n }\n if (isES6ClassFn(value)) {\n return false;\n }\n var strClass = toStr.call(value);\n if (strClass !== fnClass && strClass !== genClass && !/^\\[object HTML/.test(strClass)) {\n return false;\n }\n return tryFunctionObject(value);\n};","'use strict';\n\nvar isCallable = require('is-callable');\nvar toStr = Object.prototype.toString;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar forEachArray = function forEachArray(array, iterator, receiver) {\n for (var i = 0, len = array.length; i < len; i++) {\n if (hasOwnProperty.call(array, i)) {\n if (receiver == null) {\n iterator(array[i], i, array);\n } else {\n iterator.call(receiver, array[i], i, array);\n }\n }\n }\n};\nvar forEachString = function forEachString(string, iterator, receiver) {\n for (var i = 0, len = string.length; i < len; i++) {\n // no such thing as a sparse string.\n if (receiver == null) {\n iterator(string.charAt(i), i, string);\n } else {\n iterator.call(receiver, string.charAt(i), i, string);\n }\n }\n};\nvar forEachObject = function forEachObject(object, iterator, receiver) {\n for (var k in object) {\n if (hasOwnProperty.call(object, k)) {\n if (receiver == null) {\n iterator(object[k], k, object);\n } else {\n iterator.call(receiver, object[k], k, object);\n }\n }\n }\n};\nvar forEach = function forEach(list, iterator, thisArg) {\n if (!isCallable(iterator)) {\n throw new TypeError('iterator must be a function');\n }\n var receiver;\n if (arguments.length >= 3) {\n receiver = thisArg;\n }\n if (toStr.call(list) === '[object Array]') {\n forEachArray(list, iterator, receiver);\n } else if (typeof list === 'string') {\n forEachString(list, iterator, receiver);\n } else {\n forEachObject(list, iterator, receiver);\n }\n};\nmodule.exports = forEach;","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = ['Float32Array', 'Float64Array', 'Int8Array', 'Int16Array', 'Int32Array', 'Uint8Array', 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'BigInt64Array', 'BigUint64Array'];","'use strict';\n\nvar possibleNames = require('possible-typed-array-names');\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\n\n/** @type {import('.')} */\nmodule.exports = function availableTypedArrays() {\n var /** @type {ReturnType} */out = [];\n for (var i = 0; i < possibleNames.length; i++) {\n if (typeof g[possibleNames[i]] === 'function') {\n // @ts-expect-error\n out[out.length] = possibleNames[i];\n }\n }\n return out;\n};","'use strict';\n\nvar forEach = require('for-each');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBind = require('call-bind');\nvar callBound = require('call-bind/callBound');\nvar gOPD = require('gopd');\n\n/** @type {(O: object) => string} */\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\nvar $slice = callBound('String.prototype.slice');\nvar getPrototypeOf = Object.getPrototypeOf; // require('getprototypeof');\n\n/** @type {(array: readonly T[], value: unknown) => number} */\nvar $indexOf = callBound('Array.prototype.indexOf', true) || function indexOf(array, value) {\n for (var i = 0; i < array.length; i += 1) {\n if (array[i] === value) {\n return i;\n }\n }\n return -1;\n};\n\n/** @typedef {(receiver: import('.').TypedArray) => string | typeof Uint8Array.prototype.slice.call | typeof Uint8Array.prototype.set.call} Getter */\n/** @type {{ [k in `\\$${import('.').TypedArrayName}`]?: Getter } & { __proto__: null }} */\nvar cache = {\n __proto__: null\n};\nif (hasToStringTag && gOPD && getPrototypeOf) {\n forEach(typedArrays, function (typedArray) {\n var arr = new g[typedArray]();\n if (Symbol.toStringTag in arr) {\n var proto = getPrototypeOf(arr);\n // @ts-expect-error TS won't narrow inside a closure\n var descriptor = gOPD(proto, Symbol.toStringTag);\n if (!descriptor) {\n var superProto = getPrototypeOf(proto);\n // @ts-expect-error TS won't narrow inside a closure\n descriptor = gOPD(superProto, Symbol.toStringTag);\n }\n // @ts-expect-error TODO: fix\n cache['$' + typedArray] = callBind(descriptor.get);\n }\n });\n} else {\n forEach(typedArrays, function (typedArray) {\n var arr = new g[typedArray]();\n var fn = arr.slice || arr.set;\n if (fn) {\n // @ts-expect-error TODO: fix\n cache['$' + typedArray] = callBind(fn);\n }\n });\n}\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n /** @type {ReturnType} */var found = false;\n forEach(\n // eslint-disable-next-line no-extra-parens\n /** @type {Record<`\\$${TypedArrayName}`, Getter>} */ /** @type {any} */\n cache, /** @type {(getter: Getter, name: `\\$${import('.').TypedArrayName}`) => void} */\n function (getter, typedArray) {\n if (!found) {\n try {\n // @ts-expect-error TODO: fix\n if ('$' + getter(value) === typedArray) {\n found = $slice(typedArray, 1);\n }\n } catch (e) {/**/}\n }\n });\n return found;\n};\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar trySlices = function tryAllSlices(value) {\n /** @type {ReturnType} */var found = false;\n forEach(\n // eslint-disable-next-line no-extra-parens\n /** @type {Record<`\\$${TypedArrayName}`, Getter>} */ /** @type {any} */\n cache, /** @type {(getter: typeof cache, name: `\\$${import('.').TypedArrayName}`) => void} */function (getter, name) {\n if (!found) {\n try {\n // @ts-expect-error TODO: fix\n getter(value);\n found = $slice(name, 1);\n } catch (e) {/**/}\n }\n });\n return found;\n};\n\n/** @type {import('.')} */\nmodule.exports = function whichTypedArray(value) {\n if (!value || typeof value !== 'object') {\n return false;\n }\n if (!hasToStringTag) {\n /** @type {string} */\n var tag = $slice($toString(value), 8, -1);\n if ($indexOf(typedArrays, tag) > -1) {\n return tag;\n }\n if (tag !== 'Object') {\n return false;\n }\n // node < 0.6 hits here on real Typed Arrays\n return trySlices(value);\n }\n if (!gOPD) {\n return null;\n } // unknown engine\n return tryTypedArrays(value);\n};","'use strict';\n\nvar whichTypedArray = require('which-typed-array');\n\n/** @type {import('.')} */\nmodule.exports = function isTypedArray(value) {\n return !!whichTypedArray(value);\n};","// Currently in sync with Node.js lib/internal/util/types.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nvar isArgumentsObject = require('is-arguments');\nvar isGeneratorFunction = require('is-generator-function');\nvar whichTypedArray = require('which-typed-array');\nvar isTypedArray = require('is-typed-array');\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\nvar BigIntSupported = typeof BigInt !== 'undefined';\nvar SymbolSupported = typeof Symbol !== 'undefined';\nvar ObjectToString = uncurryThis(Object.prototype.toString);\nvar numberValue = uncurryThis(Number.prototype.valueOf);\nvar stringValue = uncurryThis(String.prototype.valueOf);\nvar booleanValue = uncurryThis(Boolean.prototype.valueOf);\nif (BigIntSupported) {\n var bigIntValue = uncurryThis(BigInt.prototype.valueOf);\n}\nif (SymbolSupported) {\n var symbolValue = uncurryThis(Symbol.prototype.valueOf);\n}\nfunction checkBoxedPrimitive(value, prototypeValueOf) {\n if (typeof value !== 'object') {\n return false;\n }\n try {\n prototypeValueOf(value);\n return true;\n } catch (e) {\n return false;\n }\n}\nexports.isArgumentsObject = isArgumentsObject;\nexports.isGeneratorFunction = isGeneratorFunction;\nexports.isTypedArray = isTypedArray;\n\n// Taken from here and modified for better browser support\n// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js\nfunction isPromise(input) {\n return typeof Promise !== 'undefined' && input instanceof Promise || input !== null && typeof input === 'object' && typeof input.then === 'function' && typeof input.catch === 'function';\n}\nexports.isPromise = isPromise;\nfunction isArrayBufferView(value) {\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n return ArrayBuffer.isView(value);\n }\n return isTypedArray(value) || isDataView(value);\n}\nexports.isArrayBufferView = isArrayBufferView;\nfunction isUint8Array(value) {\n return whichTypedArray(value) === 'Uint8Array';\n}\nexports.isUint8Array = isUint8Array;\nfunction isUint8ClampedArray(value) {\n return whichTypedArray(value) === 'Uint8ClampedArray';\n}\nexports.isUint8ClampedArray = isUint8ClampedArray;\nfunction isUint16Array(value) {\n return whichTypedArray(value) === 'Uint16Array';\n}\nexports.isUint16Array = isUint16Array;\nfunction isUint32Array(value) {\n return whichTypedArray(value) === 'Uint32Array';\n}\nexports.isUint32Array = isUint32Array;\nfunction isInt8Array(value) {\n return whichTypedArray(value) === 'Int8Array';\n}\nexports.isInt8Array = isInt8Array;\nfunction isInt16Array(value) {\n return whichTypedArray(value) === 'Int16Array';\n}\nexports.isInt16Array = isInt16Array;\nfunction isInt32Array(value) {\n return whichTypedArray(value) === 'Int32Array';\n}\nexports.isInt32Array = isInt32Array;\nfunction isFloat32Array(value) {\n return whichTypedArray(value) === 'Float32Array';\n}\nexports.isFloat32Array = isFloat32Array;\nfunction isFloat64Array(value) {\n return whichTypedArray(value) === 'Float64Array';\n}\nexports.isFloat64Array = isFloat64Array;\nfunction isBigInt64Array(value) {\n return whichTypedArray(value) === 'BigInt64Array';\n}\nexports.isBigInt64Array = isBigInt64Array;\nfunction isBigUint64Array(value) {\n return whichTypedArray(value) === 'BigUint64Array';\n}\nexports.isBigUint64Array = isBigUint64Array;\nfunction isMapToString(value) {\n return ObjectToString(value) === '[object Map]';\n}\nisMapToString.working = typeof Map !== 'undefined' && isMapToString(new Map());\nfunction isMap(value) {\n if (typeof Map === 'undefined') {\n return false;\n }\n return isMapToString.working ? isMapToString(value) : value instanceof Map;\n}\nexports.isMap = isMap;\nfunction isSetToString(value) {\n return ObjectToString(value) === '[object Set]';\n}\nisSetToString.working = typeof Set !== 'undefined' && isSetToString(new Set());\nfunction isSet(value) {\n if (typeof Set === 'undefined') {\n return false;\n }\n return isSetToString.working ? isSetToString(value) : value instanceof Set;\n}\nexports.isSet = isSet;\nfunction isWeakMapToString(value) {\n return ObjectToString(value) === '[object WeakMap]';\n}\nisWeakMapToString.working = typeof WeakMap !== 'undefined' && isWeakMapToString(new WeakMap());\nfunction isWeakMap(value) {\n if (typeof WeakMap === 'undefined') {\n return false;\n }\n return isWeakMapToString.working ? isWeakMapToString(value) : value instanceof WeakMap;\n}\nexports.isWeakMap = isWeakMap;\nfunction isWeakSetToString(value) {\n return ObjectToString(value) === '[object WeakSet]';\n}\nisWeakSetToString.working = typeof WeakSet !== 'undefined' && isWeakSetToString(new WeakSet());\nfunction isWeakSet(value) {\n return isWeakSetToString(value);\n}\nexports.isWeakSet = isWeakSet;\nfunction isArrayBufferToString(value) {\n return ObjectToString(value) === '[object ArrayBuffer]';\n}\nisArrayBufferToString.working = typeof ArrayBuffer !== 'undefined' && isArrayBufferToString(new ArrayBuffer());\nfunction isArrayBuffer(value) {\n if (typeof ArrayBuffer === 'undefined') {\n return false;\n }\n return isArrayBufferToString.working ? isArrayBufferToString(value) : value instanceof ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\nfunction isDataViewToString(value) {\n return ObjectToString(value) === '[object DataView]';\n}\nisDataViewToString.working = typeof ArrayBuffer !== 'undefined' && typeof DataView !== 'undefined' && isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1));\nfunction isDataView(value) {\n if (typeof DataView === 'undefined') {\n return false;\n }\n return isDataViewToString.working ? isDataViewToString(value) : value instanceof DataView;\n}\nexports.isDataView = isDataView;\n\n// Store a copy of SharedArrayBuffer in case it's deleted elsewhere\nvar SharedArrayBufferCopy = typeof SharedArrayBuffer !== 'undefined' ? SharedArrayBuffer : undefined;\nfunction isSharedArrayBufferToString(value) {\n return ObjectToString(value) === '[object SharedArrayBuffer]';\n}\nfunction isSharedArrayBuffer(value) {\n if (typeof SharedArrayBufferCopy === 'undefined') {\n return false;\n }\n if (typeof isSharedArrayBufferToString.working === 'undefined') {\n isSharedArrayBufferToString.working = isSharedArrayBufferToString(new SharedArrayBufferCopy());\n }\n return isSharedArrayBufferToString.working ? isSharedArrayBufferToString(value) : value instanceof SharedArrayBufferCopy;\n}\nexports.isSharedArrayBuffer = isSharedArrayBuffer;\nfunction isAsyncFunction(value) {\n return ObjectToString(value) === '[object AsyncFunction]';\n}\nexports.isAsyncFunction = isAsyncFunction;\nfunction isMapIterator(value) {\n return ObjectToString(value) === '[object Map Iterator]';\n}\nexports.isMapIterator = isMapIterator;\nfunction isSetIterator(value) {\n return ObjectToString(value) === '[object Set Iterator]';\n}\nexports.isSetIterator = isSetIterator;\nfunction isGeneratorObject(value) {\n return ObjectToString(value) === '[object Generator]';\n}\nexports.isGeneratorObject = isGeneratorObject;\nfunction isWebAssemblyCompiledModule(value) {\n return ObjectToString(value) === '[object WebAssembly.Module]';\n}\nexports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;\nfunction isNumberObject(value) {\n return checkBoxedPrimitive(value, numberValue);\n}\nexports.isNumberObject = isNumberObject;\nfunction isStringObject(value) {\n return checkBoxedPrimitive(value, stringValue);\n}\nexports.isStringObject = isStringObject;\nfunction isBooleanObject(value) {\n return checkBoxedPrimitive(value, booleanValue);\n}\nexports.isBooleanObject = isBooleanObject;\nfunction isBigIntObject(value) {\n return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);\n}\nexports.isBigIntObject = isBigIntObject;\nfunction isSymbolObject(value) {\n return SymbolSupported && checkBoxedPrimitive(value, symbolValue);\n}\nexports.isSymbolObject = isSymbolObject;\nfunction isBoxedPrimitive(value) {\n return isNumberObject(value) || isStringObject(value) || isBooleanObject(value) || isBigIntObject(value) || isSymbolObject(value);\n}\nexports.isBoxedPrimitive = isBoxedPrimitive;\nfunction isAnyArrayBuffer(value) {\n return typeof Uint8Array !== 'undefined' && (isArrayBuffer(value) || isSharedArrayBuffer(value));\n}\nexports.isAnyArrayBuffer = isAnyArrayBuffer;\n['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function (method) {\n Object.defineProperty(exports, method, {\n enumerable: false,\n value: function () {\n throw new Error(method + ' is not supported in userland');\n }\n });\n});","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object' && typeof arg.copy === 'function' && typeof arg.fill === 'function' && typeof arg.readUInt8 === 'function';\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors || function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n};\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function (f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function (x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s':\n return String(args[i++]);\n case '%d':\n return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function (fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function () {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n return deprecated;\n};\nvar debugs = {};\nvar debugEnvRegex = /^$/;\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&').replace(/\\*/g, '.*').replace(/,/g, '$|^').toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function (set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function () {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function () {};\n }\n }\n return debugs[set];\n};\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold': [1, 22],\n 'italic': [3, 23],\n 'underline': [4, 24],\n 'inverse': [7, 27],\n 'white': [37, 39],\n 'grey': [90, 39],\n 'black': [30, 39],\n 'blue': [34, 39],\n 'cyan': [36, 39],\n 'green': [32, 39],\n 'magenta': [35, 39],\n 'red': [31, 39],\n 'yellow': [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str + '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\nfunction arrayToHash(array) {\n var hash = {};\n array.forEach(function (val, idx) {\n hash[val] = true;\n });\n return hash;\n}\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect && value && isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value) && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n var base = '',\n array = false,\n braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n ctx.seen.push(value);\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function (key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n ctx.seen.pop();\n return reduceToSingleString(output, base, braces);\n}\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value)) return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '').replace(/'/g, \"\\\\'\").replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value)) return ctx.stylize('' + value, 'number');\n if (isBoolean(value)) return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value)) return ctx.stylize('null', 'null');\n}\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function (key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, key, true));\n }\n });\n return output;\n}\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || {\n value: value[key]\n };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function (line) {\n return ' ' + line;\n }).join('\\n').slice(2);\n } else {\n str = '\\n' + str.split('\\n').map(function (line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.slice(1, -1);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\").replace(/\\\\\"/g, '\"').replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n return name + ': ' + str;\n}\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function (prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n if (length > 60) {\n return braces[0] + (base === '' ? '' : base + '\\n ') + ' ' + output.join(',\\n ') + ' ' + braces[1];\n }\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\nfunction isError(e) {\n return isObject(e) && (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\nfunction isPrimitive(arg) {\n return arg === null || typeof arg === 'boolean' || typeof arg === 'number' || typeof arg === 'string' || typeof arg === 'symbol' ||\n // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\nexports.isBuffer = require('./support/isBuffer');\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()), pad(d.getMinutes()), pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function () {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\nexports._extend = function (origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function') throw new TypeError('The \"original\" argument must be of type Function');\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn,\n enumerable: false,\n writable: false,\n configurable: true\n });\n return fn;\n }\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n return promise;\n }\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn,\n enumerable: false,\n writable: false,\n configurable: true\n });\n return Object.defineProperties(fn, getOwnPropertyDescriptors(original));\n};\nexports.promisify.custom = kCustomPromisifiedSymbol;\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function () {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args).then(function (ret) {\n process.nextTick(cb.bind(null, null, ret));\n }, function (rej) {\n process.nextTick(callbackifyOnRejected.bind(null, rej, cb));\n });\n }\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified, getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;","// Currently in sync with Node.js lib/internal/assert/assertion_error.js\n// https://github.com/nodejs/node/commit/0817840f775032169ddd70c85ac059f18ffcc81c\n\n'use strict';\n\nfunction ownKeys(e, r) {\n var t = Object.keys(e);\n if (Object.getOwnPropertySymbols) {\n var o = Object.getOwnPropertySymbols(e);\n r && (o = o.filter(function (r) {\n return Object.getOwnPropertyDescriptor(e, r).enumerable;\n })), t.push.apply(t, o);\n }\n return t;\n}\nfunction _objectSpread(e) {\n for (var r = 1; r < arguments.length; r++) {\n var t = null != arguments[r] ? arguments[r] : {};\n r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {\n _defineProperty(e, r, t[r]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {\n Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n });\n }\n return e;\n}\nfunction _defineProperty(obj, key, value) {\n key = _toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}\nfunction _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = _isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = _getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = _getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return _possibleConstructorReturn(this, result);\n };\n}\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return _assertThisInitialized(self);\n}\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nfunction _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !_isNativeFunction(Class)) return Class;\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n _cache.set(Class, Wrapper);\n }\n function Wrapper() {\n return _construct(Class, arguments, _getPrototypeOf(this).constructor);\n }\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return _setPrototypeOf(Wrapper, Class);\n };\n return _wrapNativeSuper(Class);\n}\nfunction _construct(Parent, args, Class) {\n if (_isNativeReflectConstruct()) {\n _construct = Reflect.construct.bind();\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) _setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n return _construct.apply(null, arguments);\n}\nfunction _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\nfunction _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\nfunction _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}\nvar _require = require('util/'),\n inspect = _require.inspect;\nvar _require2 = require('../errors'),\n ERR_INVALID_ARG_TYPE = _require2.codes.ERR_INVALID_ARG_TYPE;\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n return str.substring(this_len - search.length, this_len) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/repeat\nfunction repeat(str, count) {\n count = Math.floor(count);\n if (str.length == 0 || count == 0) return '';\n var maxCount = str.length * count;\n count = Math.floor(Math.log(count) / Math.log(2));\n while (count) {\n str += str;\n count--;\n }\n str += str.substring(0, maxCount - str.length);\n return str;\n}\nvar blue = '';\nvar green = '';\nvar red = '';\nvar white = '';\nvar kReadableOperator = {\n deepStrictEqual: 'Expected values to be strictly deep-equal:',\n strictEqual: 'Expected values to be strictly equal:',\n strictEqualObject: 'Expected \"actual\" to be reference-equal to \"expected\":',\n deepEqual: 'Expected values to be loosely deep-equal:',\n equal: 'Expected values to be loosely equal:',\n notDeepStrictEqual: 'Expected \"actual\" not to be strictly deep-equal to:',\n notStrictEqual: 'Expected \"actual\" to be strictly unequal to:',\n notStrictEqualObject: 'Expected \"actual\" not to be reference-equal to \"expected\":',\n notDeepEqual: 'Expected \"actual\" not to be loosely deep-equal to:',\n notEqual: 'Expected \"actual\" to be loosely unequal to:',\n notIdentical: 'Values identical but not reference-equal:'\n};\n\n// Comparing short primitives should just show === / !== instead of using the\n// diff.\nvar kMaxShortLength = 10;\nfunction copyError(source) {\n var keys = Object.keys(source);\n var target = Object.create(Object.getPrototypeOf(source));\n keys.forEach(function (key) {\n target[key] = source[key];\n });\n Object.defineProperty(target, 'message', {\n value: source.message\n });\n return target;\n}\nfunction inspectValue(val) {\n // The util.inspect default values could be changed. This makes sure the\n // error messages contain the necessary information nevertheless.\n return inspect(val, {\n compact: false,\n customInspect: false,\n depth: 1000,\n maxArrayLength: Infinity,\n // Assert compares only enumerable properties (with a few exceptions).\n showHidden: false,\n // Having a long line as error is better than wrapping the line for\n // comparison for now.\n // TODO(BridgeAR): `breakLength` should be limited as soon as soon as we\n // have meta information about the inspected properties (i.e., know where\n // in what line the property starts and ends).\n breakLength: Infinity,\n // Assert does not detect proxies currently.\n showProxy: false,\n sorted: true,\n // Inspect getters as we also check them when comparing entries.\n getters: true\n });\n}\nfunction createErrDiff(actual, expected, operator) {\n var other = '';\n var res = '';\n var lastPos = 0;\n var end = '';\n var skipped = false;\n var actualInspected = inspectValue(actual);\n var actualLines = actualInspected.split('\\n');\n var expectedLines = inspectValue(expected).split('\\n');\n var i = 0;\n var indicator = '';\n\n // In case both values are objects explicitly mark them as not reference equal\n // for the `strictEqual` operator.\n if (operator === 'strictEqual' && _typeof(actual) === 'object' && _typeof(expected) === 'object' && actual !== null && expected !== null) {\n operator = 'strictEqualObject';\n }\n\n // If \"actual\" and \"expected\" fit on a single line and they are not strictly\n // equal, check further special handling.\n if (actualLines.length === 1 && expectedLines.length === 1 && actualLines[0] !== expectedLines[0]) {\n var inputLength = actualLines[0].length + expectedLines[0].length;\n // If the character length of \"actual\" and \"expected\" together is less than\n // kMaxShortLength and if neither is an object and at least one of them is\n // not `zero`, use the strict equal comparison to visualize the output.\n if (inputLength <= kMaxShortLength) {\n if ((_typeof(actual) !== 'object' || actual === null) && (_typeof(expected) !== 'object' || expected === null) && (actual !== 0 || expected !== 0)) {\n // -0 === +0\n return \"\".concat(kReadableOperator[operator], \"\\n\\n\") + \"\".concat(actualLines[0], \" !== \").concat(expectedLines[0], \"\\n\");\n }\n } else if (operator !== 'strictEqualObject') {\n // If the stderr is a tty and the input length is lower than the current\n // columns per line, add a mismatch indicator below the output. If it is\n // not a tty, use a default value of 80 characters.\n var maxLength = process.stderr && process.stderr.isTTY ? process.stderr.columns : 80;\n if (inputLength < maxLength) {\n while (actualLines[0][i] === expectedLines[0][i]) {\n i++;\n }\n // Ignore the first characters.\n if (i > 2) {\n // Add position indicator for the first mismatch in case it is a\n // single line and the input length is less than the column length.\n indicator = \"\\n \".concat(repeat(' ', i), \"^\");\n i = 0;\n }\n }\n }\n }\n\n // Remove all ending lines that match (this optimizes the output for\n // readability by reducing the number of total changed lines).\n var a = actualLines[actualLines.length - 1];\n var b = expectedLines[expectedLines.length - 1];\n while (a === b) {\n if (i++ < 2) {\n end = \"\\n \".concat(a).concat(end);\n } else {\n other = a;\n }\n actualLines.pop();\n expectedLines.pop();\n if (actualLines.length === 0 || expectedLines.length === 0) break;\n a = actualLines[actualLines.length - 1];\n b = expectedLines[expectedLines.length - 1];\n }\n var maxLines = Math.max(actualLines.length, expectedLines.length);\n // Strict equal with identical objects that are not identical by reference.\n // E.g., assert.deepStrictEqual({ a: Symbol() }, { a: Symbol() })\n if (maxLines === 0) {\n // We have to get the result again. The lines were all removed before.\n var _actualLines = actualInspected.split('\\n');\n\n // Only remove lines in case it makes sense to collapse those.\n // TODO: Accept env to always show the full error.\n if (_actualLines.length > 30) {\n _actualLines[26] = \"\".concat(blue, \"...\").concat(white);\n while (_actualLines.length > 27) {\n _actualLines.pop();\n }\n }\n return \"\".concat(kReadableOperator.notIdentical, \"\\n\\n\").concat(_actualLines.join('\\n'), \"\\n\");\n }\n if (i > 3) {\n end = \"\\n\".concat(blue, \"...\").concat(white).concat(end);\n skipped = true;\n }\n if (other !== '') {\n end = \"\\n \".concat(other).concat(end);\n other = '';\n }\n var printedLines = 0;\n var msg = kReadableOperator[operator] + \"\\n\".concat(green, \"+ actual\").concat(white, \" \").concat(red, \"- expected\").concat(white);\n var skippedMsg = \" \".concat(blue, \"...\").concat(white, \" Lines skipped\");\n for (i = 0; i < maxLines; i++) {\n // Only extra expected lines exist\n var cur = i - lastPos;\n if (actualLines.length < i + 1) {\n // If the last diverging line is more than one line above and the\n // current line is at least line three, add some of the former lines and\n // also add dots to indicate skipped entries.\n if (cur > 1 && i > 2) {\n if (cur > 4) {\n res += \"\\n\".concat(blue, \"...\").concat(white);\n skipped = true;\n } else if (cur > 3) {\n res += \"\\n \".concat(expectedLines[i - 2]);\n printedLines++;\n }\n res += \"\\n \".concat(expectedLines[i - 1]);\n printedLines++;\n }\n // Mark the current line as the last diverging one.\n lastPos = i;\n // Add the expected line to the cache.\n other += \"\\n\".concat(red, \"-\").concat(white, \" \").concat(expectedLines[i]);\n printedLines++;\n // Only extra actual lines exist\n } else if (expectedLines.length < i + 1) {\n // If the last diverging line is more than one line above and the\n // current line is at least line three, add some of the former lines and\n // also add dots to indicate skipped entries.\n if (cur > 1 && i > 2) {\n if (cur > 4) {\n res += \"\\n\".concat(blue, \"...\").concat(white);\n skipped = true;\n } else if (cur > 3) {\n res += \"\\n \".concat(actualLines[i - 2]);\n printedLines++;\n }\n res += \"\\n \".concat(actualLines[i - 1]);\n printedLines++;\n }\n // Mark the current line as the last diverging one.\n lastPos = i;\n // Add the actual line to the result.\n res += \"\\n\".concat(green, \"+\").concat(white, \" \").concat(actualLines[i]);\n printedLines++;\n // Lines diverge\n } else {\n var expectedLine = expectedLines[i];\n var actualLine = actualLines[i];\n // If the lines diverge, specifically check for lines that only diverge by\n // a trailing comma. In that case it is actually identical and we should\n // mark it as such.\n var divergingLines = actualLine !== expectedLine && (!endsWith(actualLine, ',') || actualLine.slice(0, -1) !== expectedLine);\n // If the expected line has a trailing comma but is otherwise identical,\n // add a comma at the end of the actual line. Otherwise the output could\n // look weird as in:\n //\n // [\n // 1 // No comma at the end!\n // + 2\n // ]\n //\n if (divergingLines && endsWith(expectedLine, ',') && expectedLine.slice(0, -1) === actualLine) {\n divergingLines = false;\n actualLine += ',';\n }\n if (divergingLines) {\n // If the last diverging line is more than one line above and the\n // current line is at least line three, add some of the former lines and\n // also add dots to indicate skipped entries.\n if (cur > 1 && i > 2) {\n if (cur > 4) {\n res += \"\\n\".concat(blue, \"...\").concat(white);\n skipped = true;\n } else if (cur > 3) {\n res += \"\\n \".concat(actualLines[i - 2]);\n printedLines++;\n }\n res += \"\\n \".concat(actualLines[i - 1]);\n printedLines++;\n }\n // Mark the current line as the last diverging one.\n lastPos = i;\n // Add the actual line to the result and cache the expected diverging\n // line so consecutive diverging lines show up as +++--- and not +-+-+-.\n res += \"\\n\".concat(green, \"+\").concat(white, \" \").concat(actualLine);\n other += \"\\n\".concat(red, \"-\").concat(white, \" \").concat(expectedLine);\n printedLines += 2;\n // Lines are identical\n } else {\n // Add all cached information to the result before adding other things\n // and reset the cache.\n res += other;\n other = '';\n // If the last diverging line is exactly one line above or if it is the\n // very first line, add the line to the result.\n if (cur === 1 || i === 0) {\n res += \"\\n \".concat(actualLine);\n printedLines++;\n }\n }\n }\n // Inspected object to big (Show ~20 rows max)\n if (printedLines > 20 && i < maxLines - 2) {\n return \"\".concat(msg).concat(skippedMsg, \"\\n\").concat(res, \"\\n\").concat(blue, \"...\").concat(white).concat(other, \"\\n\") + \"\".concat(blue, \"...\").concat(white);\n }\n }\n return \"\".concat(msg).concat(skipped ? skippedMsg : '', \"\\n\").concat(res).concat(other).concat(end).concat(indicator);\n}\nvar AssertionError = /*#__PURE__*/function (_Error, _inspect$custom) {\n _inherits(AssertionError, _Error);\n var _super = _createSuper(AssertionError);\n function AssertionError(options) {\n var _this;\n _classCallCheck(this, AssertionError);\n if (_typeof(options) !== 'object' || options === null) {\n throw new ERR_INVALID_ARG_TYPE('options', 'Object', options);\n }\n var message = options.message,\n operator = options.operator,\n stackStartFn = options.stackStartFn;\n var actual = options.actual,\n expected = options.expected;\n var limit = Error.stackTraceLimit;\n Error.stackTraceLimit = 0;\n if (message != null) {\n _this = _super.call(this, String(message));\n } else {\n if (process.stderr && process.stderr.isTTY) {\n // Reset on each call to make sure we handle dynamically set environment\n // variables correct.\n if (process.stderr && process.stderr.getColorDepth && process.stderr.getColorDepth() !== 1) {\n blue = \"\\x1B[34m\";\n green = \"\\x1B[32m\";\n white = \"\\x1B[39m\";\n red = \"\\x1B[31m\";\n } else {\n blue = '';\n green = '';\n white = '';\n red = '';\n }\n }\n // Prevent the error stack from being visible by duplicating the error\n // in a very close way to the original in case both sides are actually\n // instances of Error.\n if (_typeof(actual) === 'object' && actual !== null && _typeof(expected) === 'object' && expected !== null && 'stack' in actual && actual instanceof Error && 'stack' in expected && expected instanceof Error) {\n actual = copyError(actual);\n expected = copyError(expected);\n }\n if (operator === 'deepStrictEqual' || operator === 'strictEqual') {\n _this = _super.call(this, createErrDiff(actual, expected, operator));\n } else if (operator === 'notDeepStrictEqual' || operator === 'notStrictEqual') {\n // In case the objects are equal but the operator requires unequal, show\n // the first object and say A equals B\n var base = kReadableOperator[operator];\n var res = inspectValue(actual).split('\\n');\n\n // In case \"actual\" is an object, it should not be reference equal.\n if (operator === 'notStrictEqual' && _typeof(actual) === 'object' && actual !== null) {\n base = kReadableOperator.notStrictEqualObject;\n }\n\n // Only remove lines in case it makes sense to collapse those.\n // TODO: Accept env to always show the full error.\n if (res.length > 30) {\n res[26] = \"\".concat(blue, \"...\").concat(white);\n while (res.length > 27) {\n res.pop();\n }\n }\n\n // Only print a single input.\n if (res.length === 1) {\n _this = _super.call(this, \"\".concat(base, \" \").concat(res[0]));\n } else {\n _this = _super.call(this, \"\".concat(base, \"\\n\\n\").concat(res.join('\\n'), \"\\n\"));\n }\n } else {\n var _res = inspectValue(actual);\n var other = '';\n var knownOperators = kReadableOperator[operator];\n if (operator === 'notDeepEqual' || operator === 'notEqual') {\n _res = \"\".concat(kReadableOperator[operator], \"\\n\\n\").concat(_res);\n if (_res.length > 1024) {\n _res = \"\".concat(_res.slice(0, 1021), \"...\");\n }\n } else {\n other = \"\".concat(inspectValue(expected));\n if (_res.length > 512) {\n _res = \"\".concat(_res.slice(0, 509), \"...\");\n }\n if (other.length > 512) {\n other = \"\".concat(other.slice(0, 509), \"...\");\n }\n if (operator === 'deepEqual' || operator === 'equal') {\n _res = \"\".concat(knownOperators, \"\\n\\n\").concat(_res, \"\\n\\nshould equal\\n\\n\");\n } else {\n other = \" \".concat(operator, \" \").concat(other);\n }\n }\n _this = _super.call(this, \"\".concat(_res).concat(other));\n }\n }\n Error.stackTraceLimit = limit;\n _this.generatedMessage = !message;\n Object.defineProperty(_assertThisInitialized(_this), 'name', {\n value: 'AssertionError [ERR_ASSERTION]',\n enumerable: false,\n writable: true,\n configurable: true\n });\n _this.code = 'ERR_ASSERTION';\n _this.actual = actual;\n _this.expected = expected;\n _this.operator = operator;\n if (Error.captureStackTrace) {\n // eslint-disable-next-line no-restricted-syntax\n Error.captureStackTrace(_assertThisInitialized(_this), stackStartFn);\n }\n // Create error message including the error code in the name.\n _this.stack;\n // Reset the name.\n _this.name = 'AssertionError';\n return _possibleConstructorReturn(_this);\n }\n _createClass(AssertionError, [{\n key: \"toString\",\n value: function toString() {\n return \"\".concat(this.name, \" [\").concat(this.code, \"]: \").concat(this.message);\n }\n }, {\n key: _inspect$custom,\n value: function value(recurseTimes, ctx) {\n // This limits the `actual` and `expected` property default inspection to\n // the minimum depth. Otherwise those values would be too verbose compared\n // to the actual error message which contains a combined view of these two\n // input values.\n return inspect(this, _objectSpread(_objectSpread({}, ctx), {}, {\n customInspect: false,\n depth: 0\n }));\n }\n }]);\n return AssertionError;\n}( /*#__PURE__*/_wrapNativeSuper(Error), inspect.custom);\nmodule.exports = AssertionError;","'use strict';\n\n// modified from https://github.com/es-shims/es6-shim\nvar objectKeys = require('object-keys');\nvar hasSymbols = require('has-symbols/shams')();\nvar callBound = require('call-bind/callBound');\nvar toObject = Object;\nvar $push = callBound('Array.prototype.push');\nvar $propIsEnumerable = callBound('Object.prototype.propertyIsEnumerable');\nvar originalGetSymbols = hasSymbols ? Object.getOwnPropertySymbols : null;\n\n// eslint-disable-next-line no-unused-vars\nmodule.exports = function assign(target, source1) {\n if (target == null) {\n throw new TypeError('target must be an object');\n }\n var to = toObject(target); // step 1\n if (arguments.length === 1) {\n return to; // step 2\n }\n for (var s = 1; s < arguments.length; ++s) {\n var from = toObject(arguments[s]); // step 3.a.i\n\n // step 3.a.ii:\n var keys = objectKeys(from);\n var getSymbols = hasSymbols && (Object.getOwnPropertySymbols || originalGetSymbols);\n if (getSymbols) {\n var syms = getSymbols(from);\n for (var j = 0; j < syms.length; ++j) {\n var key = syms[j];\n if ($propIsEnumerable(from, key)) {\n $push(keys, key);\n }\n }\n }\n\n // step 3.a.iii:\n for (var i = 0; i < keys.length; ++i) {\n var nextKey = keys[i];\n if ($propIsEnumerable(from, nextKey)) {\n // step 3.a.iii.2\n var propValue = from[nextKey]; // step 3.a.iii.2.a\n to[nextKey] = propValue; // step 3.a.iii.2.b\n }\n }\n }\n return to; // step 4\n};","'use strict';\n\nvar implementation = require('./implementation');\nvar lacksProperEnumerationOrder = function () {\n if (!Object.assign) {\n return false;\n }\n /*\n * v8, specifically in node 4.x, has a bug with incorrect property enumeration order\n * note: this does not detect the bug unless there's 20 characters\n */\n var str = 'abcdefghijklmnopqrst';\n var letters = str.split('');\n var map = {};\n for (var i = 0; i < letters.length; ++i) {\n map[letters[i]] = letters[i];\n }\n var obj = Object.assign({}, map);\n var actual = '';\n for (var k in obj) {\n actual += k;\n }\n return str !== actual;\n};\nvar assignHasPendingExceptions = function () {\n if (!Object.assign || !Object.preventExtensions) {\n return false;\n }\n /*\n * Firefox 37 still has \"pending exception\" logic in its Object.assign implementation,\n * which is 72% slower than our shim, and Firefox 40's native implementation.\n */\n var thrower = Object.preventExtensions({\n 1: 2\n });\n try {\n Object.assign(thrower, 'xy');\n } catch (e) {\n return thrower[1] === 'y';\n }\n return false;\n};\nmodule.exports = function getPolyfill() {\n if (!Object.assign) {\n return implementation;\n }\n if (lacksProperEnumerationOrder()) {\n return implementation;\n }\n if (assignHasPendingExceptions()) {\n return implementation;\n }\n return Object.assign;\n};","'use strict';\n\nvar numberIsNaN = function (value) {\n return value !== value;\n};\nmodule.exports = function is(a, b) {\n if (a === 0 && b === 0) {\n return 1 / a === 1 / b;\n }\n if (a === b) {\n return true;\n }\n if (numberIsNaN(a) && numberIsNaN(b)) {\n return true;\n }\n return false;\n};","'use strict';\n\nvar implementation = require('./implementation');\nmodule.exports = function getPolyfill() {\n return typeof Object.is === 'function' ? Object.is : implementation;\n};","'use strict';\n\nvar getPolyfill = require('./polyfill');\nvar define = require('define-properties');\nmodule.exports = function shimObjectIs() {\n var polyfill = getPolyfill();\n define(Object, {\n is: polyfill\n }, {\n is: function testObjectIs() {\n return Object.is !== polyfill;\n }\n });\n return polyfill;\n};","'use strict';\n\nvar define = require('define-properties');\nvar callBind = require('call-bind');\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\nvar polyfill = callBind(getPolyfill(), Object);\ndefine(polyfill, {\n getPolyfill: getPolyfill,\n implementation: implementation,\n shim: shim\n});\nmodule.exports = polyfill;","'use strict';\n\n/* http://www.ecma-international.org/ecma-262/6.0/#sec-number.isnan */\nmodule.exports = function isNaN(value) {\n return value !== value;\n};","'use strict';\n\nvar implementation = require('./implementation');\nmodule.exports = function getPolyfill() {\n if (Number.isNaN && Number.isNaN(NaN) && !Number.isNaN('a')) {\n return Number.isNaN;\n }\n return implementation;\n};","'use strict';\n\nvar define = require('define-properties');\nvar getPolyfill = require('./polyfill');\n\n/* http://www.ecma-international.org/ecma-262/6.0/#sec-number.isnan */\n\nmodule.exports = function shimNumberIsNaN() {\n var polyfill = getPolyfill();\n define(Number, {\n isNaN: polyfill\n }, {\n isNaN: function testIsNaN() {\n return Number.isNaN !== polyfill;\n }\n });\n return polyfill;\n};","'use strict';\n\nvar callBind = require('call-bind');\nvar define = require('define-properties');\nvar implementation = require('./implementation');\nvar getPolyfill = require('./polyfill');\nvar shim = require('./shim');\nvar polyfill = callBind(getPolyfill(), Number);\n\n/* http://www.ecma-international.org/ecma-262/6.0/#sec-number.isnan */\n\ndefine(polyfill, {\n getPolyfill: getPolyfill,\n implementation: implementation,\n shim: shim\n});\nmodule.exports = polyfill;","// Currently in sync with Node.js lib/internal/util/comparisons.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nfunction _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n}\nfunction _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}\nfunction _iterableToArrayLimit(r, l) {\n var t = null == r ? null : \"undefined\" != typeof Symbol && r[Symbol.iterator] || r[\"@@iterator\"];\n if (null != t) {\n var e,\n n,\n i,\n u,\n a = [],\n f = !0,\n o = !1;\n try {\n if (i = (t = t.call(r)).next, 0 === l) {\n if (Object(t) !== t) return;\n f = !1;\n } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);\n } catch (r) {\n o = !0, n = r;\n } finally {\n try {\n if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return;\n } finally {\n if (o) throw n;\n }\n }\n return a;\n }\n}\nfunction _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _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}\nvar regexFlagsSupported = /a/g.flags !== undefined;\nvar arrayFromSet = function arrayFromSet(set) {\n var array = [];\n set.forEach(function (value) {\n return array.push(value);\n });\n return array;\n};\nvar arrayFromMap = function arrayFromMap(map) {\n var array = [];\n map.forEach(function (value, key) {\n return array.push([key, value]);\n });\n return array;\n};\nvar objectIs = Object.is ? Object.is : require('object-is');\nvar objectGetOwnPropertySymbols = Object.getOwnPropertySymbols ? Object.getOwnPropertySymbols : function () {\n return [];\n};\nvar numberIsNaN = Number.isNaN ? Number.isNaN : require('is-nan');\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\nvar hasOwnProperty = uncurryThis(Object.prototype.hasOwnProperty);\nvar propertyIsEnumerable = uncurryThis(Object.prototype.propertyIsEnumerable);\nvar objectToString = uncurryThis(Object.prototype.toString);\nvar _require$types = require('util/').types,\n isAnyArrayBuffer = _require$types.isAnyArrayBuffer,\n isArrayBufferView = _require$types.isArrayBufferView,\n isDate = _require$types.isDate,\n isMap = _require$types.isMap,\n isRegExp = _require$types.isRegExp,\n isSet = _require$types.isSet,\n isNativeError = _require$types.isNativeError,\n isBoxedPrimitive = _require$types.isBoxedPrimitive,\n isNumberObject = _require$types.isNumberObject,\n isStringObject = _require$types.isStringObject,\n isBooleanObject = _require$types.isBooleanObject,\n isBigIntObject = _require$types.isBigIntObject,\n isSymbolObject = _require$types.isSymbolObject,\n isFloat32Array = _require$types.isFloat32Array,\n isFloat64Array = _require$types.isFloat64Array;\nfunction isNonIndex(key) {\n if (key.length === 0 || key.length > 10) return true;\n for (var i = 0; i < key.length; i++) {\n var code = key.charCodeAt(i);\n if (code < 48 || code > 57) return true;\n }\n // The maximum size for an array is 2 ** 32 -1.\n return key.length === 10 && key >= Math.pow(2, 32);\n}\nfunction getOwnNonIndexProperties(value) {\n return Object.keys(value).filter(isNonIndex).concat(objectGetOwnPropertySymbols(value).filter(Object.prototype.propertyIsEnumerable.bind(value)));\n}\n\n// Taken from https://github.com/feross/buffer/blob/680e9e5e488f22aac27599a57dc844a6315928dd/index.js\n// original notice:\n/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\nfunction compare(a, b) {\n if (a === b) {\n return 0;\n }\n var x = a.length;\n var y = b.length;\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i];\n y = b[i];\n break;\n }\n }\n if (x < y) {\n return -1;\n }\n if (y < x) {\n return 1;\n }\n return 0;\n}\nvar ONLY_ENUMERABLE = undefined;\nvar kStrict = true;\nvar kLoose = false;\nvar kNoIterator = 0;\nvar kIsArray = 1;\nvar kIsSet = 2;\nvar kIsMap = 3;\n\n// Check if they have the same source and flags\nfunction areSimilarRegExps(a, b) {\n return regexFlagsSupported ? a.source === b.source && a.flags === b.flags : RegExp.prototype.toString.call(a) === RegExp.prototype.toString.call(b);\n}\nfunction areSimilarFloatArrays(a, b) {\n if (a.byteLength !== b.byteLength) {\n return false;\n }\n for (var offset = 0; offset < a.byteLength; offset++) {\n if (a[offset] !== b[offset]) {\n return false;\n }\n }\n return true;\n}\nfunction areSimilarTypedArrays(a, b) {\n if (a.byteLength !== b.byteLength) {\n return false;\n }\n return compare(new Uint8Array(a.buffer, a.byteOffset, a.byteLength), new Uint8Array(b.buffer, b.byteOffset, b.byteLength)) === 0;\n}\nfunction areEqualArrayBuffers(buf1, buf2) {\n return buf1.byteLength === buf2.byteLength && compare(new Uint8Array(buf1), new Uint8Array(buf2)) === 0;\n}\nfunction isEqualBoxedPrimitive(val1, val2) {\n if (isNumberObject(val1)) {\n return isNumberObject(val2) && objectIs(Number.prototype.valueOf.call(val1), Number.prototype.valueOf.call(val2));\n }\n if (isStringObject(val1)) {\n return isStringObject(val2) && String.prototype.valueOf.call(val1) === String.prototype.valueOf.call(val2);\n }\n if (isBooleanObject(val1)) {\n return isBooleanObject(val2) && Boolean.prototype.valueOf.call(val1) === Boolean.prototype.valueOf.call(val2);\n }\n if (isBigIntObject(val1)) {\n return isBigIntObject(val2) && BigInt.prototype.valueOf.call(val1) === BigInt.prototype.valueOf.call(val2);\n }\n return isSymbolObject(val2) && Symbol.prototype.valueOf.call(val1) === Symbol.prototype.valueOf.call(val2);\n}\n\n// Notes: Type tags are historical [[Class]] properties that can be set by\n// FunctionTemplate::SetClassName() in C++ or Symbol.toStringTag in JS\n// and retrieved using Object.prototype.toString.call(obj) in JS\n// See https://tc39.github.io/ecma262/#sec-object.prototype.tostring\n// for a list of tags pre-defined in the spec.\n// There are some unspecified tags in the wild too (e.g. typed array tags).\n// Since tags can be altered, they only serve fast failures\n//\n// Typed arrays and buffers are checked by comparing the content in their\n// underlying ArrayBuffer. This optimization requires that it's\n// reasonable to interpret their underlying memory in the same way,\n// which is checked by comparing their type tags.\n// (e.g. a Uint8Array and a Uint16Array with the same memory content\n// could still be different because they will be interpreted differently).\n//\n// For strict comparison, objects should have\n// a) The same built-in type tags\n// b) The same prototypes.\n\nfunction innerDeepEqual(val1, val2, strict, memos) {\n // All identical values are equivalent, as determined by ===.\n if (val1 === val2) {\n if (val1 !== 0) return true;\n return strict ? objectIs(val1, val2) : true;\n }\n\n // Check more closely if val1 and val2 are equal.\n if (strict) {\n if (_typeof(val1) !== 'object') {\n return typeof val1 === 'number' && numberIsNaN(val1) && numberIsNaN(val2);\n }\n if (_typeof(val2) !== 'object' || val1 === null || val2 === null) {\n return false;\n }\n if (Object.getPrototypeOf(val1) !== Object.getPrototypeOf(val2)) {\n return false;\n }\n } else {\n if (val1 === null || _typeof(val1) !== 'object') {\n if (val2 === null || _typeof(val2) !== 'object') {\n // eslint-disable-next-line eqeqeq\n return val1 == val2;\n }\n return false;\n }\n if (val2 === null || _typeof(val2) !== 'object') {\n return false;\n }\n }\n var val1Tag = objectToString(val1);\n var val2Tag = objectToString(val2);\n if (val1Tag !== val2Tag) {\n return false;\n }\n if (Array.isArray(val1)) {\n // Check for sparse arrays and general fast path\n if (val1.length !== val2.length) {\n return false;\n }\n var keys1 = getOwnNonIndexProperties(val1, ONLY_ENUMERABLE);\n var keys2 = getOwnNonIndexProperties(val2, ONLY_ENUMERABLE);\n if (keys1.length !== keys2.length) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kIsArray, keys1);\n }\n // [browserify] This triggers on certain types in IE (Map/Set) so we don't\n // wan't to early return out of the rest of the checks. However we can check\n // if the second value is one of these values and the first isn't.\n if (val1Tag === '[object Object]') {\n // return keyCheck(val1, val2, strict, memos, kNoIterator);\n if (!isMap(val1) && isMap(val2) || !isSet(val1) && isSet(val2)) {\n return false;\n }\n }\n if (isDate(val1)) {\n if (!isDate(val2) || Date.prototype.getTime.call(val1) !== Date.prototype.getTime.call(val2)) {\n return false;\n }\n } else if (isRegExp(val1)) {\n if (!isRegExp(val2) || !areSimilarRegExps(val1, val2)) {\n return false;\n }\n } else if (isNativeError(val1) || val1 instanceof Error) {\n // Do not compare the stack as it might differ even though the error itself\n // is otherwise identical.\n if (val1.message !== val2.message || val1.name !== val2.name) {\n return false;\n }\n } else if (isArrayBufferView(val1)) {\n if (!strict && (isFloat32Array(val1) || isFloat64Array(val1))) {\n if (!areSimilarFloatArrays(val1, val2)) {\n return false;\n }\n } else if (!areSimilarTypedArrays(val1, val2)) {\n return false;\n }\n // Buffer.compare returns true, so val1.length === val2.length. If they both\n // only contain numeric keys, we don't need to exam further than checking\n // the symbols.\n var _keys = getOwnNonIndexProperties(val1, ONLY_ENUMERABLE);\n var _keys2 = getOwnNonIndexProperties(val2, ONLY_ENUMERABLE);\n if (_keys.length !== _keys2.length) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kNoIterator, _keys);\n } else if (isSet(val1)) {\n if (!isSet(val2) || val1.size !== val2.size) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kIsSet);\n } else if (isMap(val1)) {\n if (!isMap(val2) || val1.size !== val2.size) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kIsMap);\n } else if (isAnyArrayBuffer(val1)) {\n if (!areEqualArrayBuffers(val1, val2)) {\n return false;\n }\n } else if (isBoxedPrimitive(val1) && !isEqualBoxedPrimitive(val1, val2)) {\n return false;\n }\n return keyCheck(val1, val2, strict, memos, kNoIterator);\n}\nfunction getEnumerables(val, keys) {\n return keys.filter(function (k) {\n return propertyIsEnumerable(val, k);\n });\n}\nfunction keyCheck(val1, val2, strict, memos, iterationType, aKeys) {\n // For all remaining Object pairs, including Array, objects and Maps,\n // equivalence is determined by having:\n // a) The same number of owned enumerable properties\n // b) The same set of keys/indexes (although not necessarily the same order)\n // c) Equivalent values for every corresponding key/index\n // d) For Sets and Maps, equal contents\n // Note: this accounts for both named and indexed properties on Arrays.\n if (arguments.length === 5) {\n aKeys = Object.keys(val1);\n var bKeys = Object.keys(val2);\n\n // The pair must have the same number of owned properties.\n if (aKeys.length !== bKeys.length) {\n return false;\n }\n }\n\n // Cheap key test\n var i = 0;\n for (; i < aKeys.length; i++) {\n if (!hasOwnProperty(val2, aKeys[i])) {\n return false;\n }\n }\n if (strict && arguments.length === 5) {\n var symbolKeysA = objectGetOwnPropertySymbols(val1);\n if (symbolKeysA.length !== 0) {\n var count = 0;\n for (i = 0; i < symbolKeysA.length; i++) {\n var key = symbolKeysA[i];\n if (propertyIsEnumerable(val1, key)) {\n if (!propertyIsEnumerable(val2, key)) {\n return false;\n }\n aKeys.push(key);\n count++;\n } else if (propertyIsEnumerable(val2, key)) {\n return false;\n }\n }\n var symbolKeysB = objectGetOwnPropertySymbols(val2);\n if (symbolKeysA.length !== symbolKeysB.length && getEnumerables(val2, symbolKeysB).length !== count) {\n return false;\n }\n } else {\n var _symbolKeysB = objectGetOwnPropertySymbols(val2);\n if (_symbolKeysB.length !== 0 && getEnumerables(val2, _symbolKeysB).length !== 0) {\n return false;\n }\n }\n }\n if (aKeys.length === 0 && (iterationType === kNoIterator || iterationType === kIsArray && val1.length === 0 || val1.size === 0)) {\n return true;\n }\n\n // Use memos to handle cycles.\n if (memos === undefined) {\n memos = {\n val1: new Map(),\n val2: new Map(),\n position: 0\n };\n } else {\n // We prevent up to two map.has(x) calls by directly retrieving the value\n // and checking for undefined. The map can only contain numbers, so it is\n // safe to check for undefined only.\n var val2MemoA = memos.val1.get(val1);\n if (val2MemoA !== undefined) {\n var val2MemoB = memos.val2.get(val2);\n if (val2MemoB !== undefined) {\n return val2MemoA === val2MemoB;\n }\n }\n memos.position++;\n }\n memos.val1.set(val1, memos.position);\n memos.val2.set(val2, memos.position);\n var areEq = objEquiv(val1, val2, strict, aKeys, memos, iterationType);\n memos.val1.delete(val1);\n memos.val2.delete(val2);\n return areEq;\n}\nfunction setHasEqualElement(set, val1, strict, memo) {\n // Go looking.\n var setValues = arrayFromSet(set);\n for (var i = 0; i < setValues.length; i++) {\n var val2 = setValues[i];\n if (innerDeepEqual(val1, val2, strict, memo)) {\n // Remove the matching element to make sure we do not check that again.\n set.delete(val2);\n return true;\n }\n }\n return false;\n}\n\n// See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Equality_comparisons_and_sameness#Loose_equality_using\n// Sadly it is not possible to detect corresponding values properly in case the\n// type is a string, number, bigint or boolean. The reason is that those values\n// can match lots of different string values (e.g., 1n == '+00001').\nfunction findLooseMatchingPrimitives(prim) {\n switch (_typeof(prim)) {\n case 'undefined':\n return null;\n case 'object':\n // Only pass in null as object!\n return undefined;\n case 'symbol':\n return false;\n case 'string':\n prim = +prim;\n // Loose equal entries exist only if the string is possible to convert to\n // a regular number and not NaN.\n // Fall through\n case 'number':\n if (numberIsNaN(prim)) {\n return false;\n }\n }\n return true;\n}\nfunction setMightHaveLoosePrim(a, b, prim) {\n var altValue = findLooseMatchingPrimitives(prim);\n if (altValue != null) return altValue;\n return b.has(altValue) && !a.has(altValue);\n}\nfunction mapMightHaveLoosePrim(a, b, prim, item, memo) {\n var altValue = findLooseMatchingPrimitives(prim);\n if (altValue != null) {\n return altValue;\n }\n var curB = b.get(altValue);\n if (curB === undefined && !b.has(altValue) || !innerDeepEqual(item, curB, false, memo)) {\n return false;\n }\n return !a.has(altValue) && innerDeepEqual(item, curB, false, memo);\n}\nfunction setEquiv(a, b, strict, memo) {\n // This is a lazily initiated Set of entries which have to be compared\n // pairwise.\n var set = null;\n var aValues = arrayFromSet(a);\n for (var i = 0; i < aValues.length; i++) {\n var val = aValues[i];\n // Note: Checking for the objects first improves the performance for object\n // heavy sets but it is a minor slow down for primitives. As they are fast\n // to check this improves the worst case scenario instead.\n if (_typeof(val) === 'object' && val !== null) {\n if (set === null) {\n set = new Set();\n }\n // If the specified value doesn't exist in the second set its an not null\n // object (or non strict only: a not matching primitive) we'll need to go\n // hunting for something thats deep-(strict-)equal to it. To make this\n // O(n log n) complexity we have to copy these values in a new set first.\n set.add(val);\n } else if (!b.has(val)) {\n if (strict) return false;\n\n // Fast path to detect missing string, symbol, undefined and null values.\n if (!setMightHaveLoosePrim(a, b, val)) {\n return false;\n }\n if (set === null) {\n set = new Set();\n }\n set.add(val);\n }\n }\n if (set !== null) {\n var bValues = arrayFromSet(b);\n for (var _i = 0; _i < bValues.length; _i++) {\n var _val = bValues[_i];\n // We have to check if a primitive value is already\n // matching and only if it's not, go hunting for it.\n if (_typeof(_val) === 'object' && _val !== null) {\n if (!setHasEqualElement(set, _val, strict, memo)) return false;\n } else if (!strict && !a.has(_val) && !setHasEqualElement(set, _val, strict, memo)) {\n return false;\n }\n }\n return set.size === 0;\n }\n return true;\n}\nfunction mapHasEqualEntry(set, map, key1, item1, strict, memo) {\n // To be able to handle cases like:\n // Map([[{}, 'a'], [{}, 'b']]) vs Map([[{}, 'b'], [{}, 'a']])\n // ... we need to consider *all* matching keys, not just the first we find.\n var setValues = arrayFromSet(set);\n for (var i = 0; i < setValues.length; i++) {\n var key2 = setValues[i];\n if (innerDeepEqual(key1, key2, strict, memo) && innerDeepEqual(item1, map.get(key2), strict, memo)) {\n set.delete(key2);\n return true;\n }\n }\n return false;\n}\nfunction mapEquiv(a, b, strict, memo) {\n var set = null;\n var aEntries = arrayFromMap(a);\n for (var i = 0; i < aEntries.length; i++) {\n var _aEntries$i = _slicedToArray(aEntries[i], 2),\n key = _aEntries$i[0],\n item1 = _aEntries$i[1];\n if (_typeof(key) === 'object' && key !== null) {\n if (set === null) {\n set = new Set();\n }\n set.add(key);\n } else {\n // By directly retrieving the value we prevent another b.has(key) check in\n // almost all possible cases.\n var item2 = b.get(key);\n if (item2 === undefined && !b.has(key) || !innerDeepEqual(item1, item2, strict, memo)) {\n if (strict) return false;\n // Fast path to detect missing string, symbol, undefined and null\n // keys.\n if (!mapMightHaveLoosePrim(a, b, key, item1, memo)) return false;\n if (set === null) {\n set = new Set();\n }\n set.add(key);\n }\n }\n }\n if (set !== null) {\n var bEntries = arrayFromMap(b);\n for (var _i2 = 0; _i2 < bEntries.length; _i2++) {\n var _bEntries$_i = _slicedToArray(bEntries[_i2], 2),\n _key = _bEntries$_i[0],\n item = _bEntries$_i[1];\n if (_typeof(_key) === 'object' && _key !== null) {\n if (!mapHasEqualEntry(set, a, _key, item, strict, memo)) return false;\n } else if (!strict && (!a.has(_key) || !innerDeepEqual(a.get(_key), item, false, memo)) && !mapHasEqualEntry(set, a, _key, item, false, memo)) {\n return false;\n }\n }\n return set.size === 0;\n }\n return true;\n}\nfunction objEquiv(a, b, strict, keys, memos, iterationType) {\n // Sets and maps don't have their entries accessible via normal object\n // properties.\n var i = 0;\n if (iterationType === kIsSet) {\n if (!setEquiv(a, b, strict, memos)) {\n return false;\n }\n } else if (iterationType === kIsMap) {\n if (!mapEquiv(a, b, strict, memos)) {\n return false;\n }\n } else if (iterationType === kIsArray) {\n for (; i < a.length; i++) {\n if (hasOwnProperty(a, i)) {\n if (!hasOwnProperty(b, i) || !innerDeepEqual(a[i], b[i], strict, memos)) {\n return false;\n }\n } else if (hasOwnProperty(b, i)) {\n return false;\n } else {\n // Array is sparse.\n var keysA = Object.keys(a);\n for (; i < keysA.length; i++) {\n var key = keysA[i];\n if (!hasOwnProperty(b, key) || !innerDeepEqual(a[key], b[key], strict, memos)) {\n return false;\n }\n }\n if (keysA.length !== Object.keys(b).length) {\n return false;\n }\n return true;\n }\n }\n }\n\n // The pair must have equivalent values for every corresponding key.\n // Possibly expensive deep test:\n for (i = 0; i < keys.length; i++) {\n var _key2 = keys[i];\n if (!innerDeepEqual(a[_key2], b[_key2], strict, memos)) {\n return false;\n }\n }\n return true;\n}\nfunction isDeepEqual(val1, val2) {\n return innerDeepEqual(val1, val2, kLoose);\n}\nfunction isDeepStrictEqual(val1, val2) {\n return innerDeepEqual(val1, val2, kStrict);\n}\nmodule.exports = {\n isDeepEqual: isDeepEqual,\n isDeepStrictEqual: isDeepStrictEqual\n};","// Currently in sync with Node.js lib/assert.js\n// https://github.com/nodejs/node/commit/2a51ae424a513ec9a6aa3466baa0cc1d55dd4f3b\n\n// Originally from narwhal.js (http://narwhaljs.org)\n// Copyright (c) 2009 Thomas Robinson <280north.com>\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\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell 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 BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nfunction _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}\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}\nfunction _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nvar _require = require('./internal/errors'),\n _require$codes = _require.codes,\n ERR_AMBIGUOUS_ARGUMENT = _require$codes.ERR_AMBIGUOUS_ARGUMENT,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_INVALID_ARG_VALUE = _require$codes.ERR_INVALID_ARG_VALUE,\n ERR_INVALID_RETURN_VALUE = _require$codes.ERR_INVALID_RETURN_VALUE,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS;\nvar AssertionError = require('./internal/assert/assertion_error');\nvar _require2 = require('util/'),\n inspect = _require2.inspect;\nvar _require$types = require('util/').types,\n isPromise = _require$types.isPromise,\n isRegExp = _require$types.isRegExp;\nvar objectAssign = require('object.assign/polyfill')();\nvar objectIs = require('object-is/polyfill')();\nvar RegExpPrototypeTest = require('call-bind/callBound')('RegExp.prototype.test');\nvar errorCache = new Map();\nvar isDeepEqual;\nvar isDeepStrictEqual;\nvar parseExpressionAt;\nvar findNodeAround;\nvar decoder;\nfunction lazyLoadComparison() {\n var comparison = require('./internal/util/comparisons');\n isDeepEqual = comparison.isDeepEqual;\n isDeepStrictEqual = comparison.isDeepStrictEqual;\n}\n\n// Escape control characters but not \\n and \\t to keep the line breaks and\n// indentation intact.\n// eslint-disable-next-line no-control-regex\nvar escapeSequencesRegExp = /[\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f]/g;\nvar meta = [\"\\\\u0000\", \"\\\\u0001\", \"\\\\u0002\", \"\\\\u0003\", \"\\\\u0004\", \"\\\\u0005\", \"\\\\u0006\", \"\\\\u0007\", '\\\\b', '', '', \"\\\\u000b\", '\\\\f', '', \"\\\\u000e\", \"\\\\u000f\", \"\\\\u0010\", \"\\\\u0011\", \"\\\\u0012\", \"\\\\u0013\", \"\\\\u0014\", \"\\\\u0015\", \"\\\\u0016\", \"\\\\u0017\", \"\\\\u0018\", \"\\\\u0019\", \"\\\\u001a\", \"\\\\u001b\", \"\\\\u001c\", \"\\\\u001d\", \"\\\\u001e\", \"\\\\u001f\"];\nvar escapeFn = function escapeFn(str) {\n return meta[str.charCodeAt(0)];\n};\nvar warned = false;\n\n// The assert module provides functions that throw\n// AssertionError's when particular conditions are not met. The\n// assert module must conform to the following interface.\n\nvar assert = module.exports = ok;\nvar NO_EXCEPTION_SENTINEL = {};\n\n// All of the following functions must throw an AssertionError\n// when a corresponding condition is not met, with a message that\n// may be undefined if not provided. All assertion methods provide\n// both the actual and expected values to the assertion error for\n// display purposes.\n\nfunction innerFail(obj) {\n if (obj.message instanceof Error) throw obj.message;\n throw new AssertionError(obj);\n}\nfunction fail(actual, expected, message, operator, stackStartFn) {\n var argsLen = arguments.length;\n var internalMessage;\n if (argsLen === 0) {\n internalMessage = 'Failed';\n } else if (argsLen === 1) {\n message = actual;\n actual = undefined;\n } else {\n if (warned === false) {\n warned = true;\n var warn = process.emitWarning ? process.emitWarning : console.warn.bind(console);\n warn('assert.fail() with more than one argument is deprecated. ' + 'Please use assert.strictEqual() instead or only pass a message.', 'DeprecationWarning', 'DEP0094');\n }\n if (argsLen === 2) operator = '!=';\n }\n if (message instanceof Error) throw message;\n var errArgs = {\n actual: actual,\n expected: expected,\n operator: operator === undefined ? 'fail' : operator,\n stackStartFn: stackStartFn || fail\n };\n if (message !== undefined) {\n errArgs.message = message;\n }\n var err = new AssertionError(errArgs);\n if (internalMessage) {\n err.message = internalMessage;\n err.generatedMessage = true;\n }\n throw err;\n}\nassert.fail = fail;\n\n// The AssertionError is defined in internal/error.\nassert.AssertionError = AssertionError;\nfunction innerOk(fn, argLen, value, message) {\n if (!value) {\n var generatedMessage = false;\n if (argLen === 0) {\n generatedMessage = true;\n message = 'No value argument passed to `assert.ok()`';\n } else if (message instanceof Error) {\n throw message;\n }\n var err = new AssertionError({\n actual: value,\n expected: true,\n message: message,\n operator: '==',\n stackStartFn: fn\n });\n err.generatedMessage = generatedMessage;\n throw err;\n }\n}\n\n// Pure assertion tests whether a value is truthy, as determined\n// by !!value.\nfunction ok() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n innerOk.apply(void 0, [ok, args.length].concat(args));\n}\nassert.ok = ok;\n\n// The equality assertion tests shallow, coercive equality with ==.\n/* eslint-disable no-restricted-properties */\nassert.equal = function equal(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n // eslint-disable-next-line eqeqeq\n if (actual != expected) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: '==',\n stackStartFn: equal\n });\n }\n};\n\n// The non-equality assertion tests for whether two objects are not\n// equal with !=.\nassert.notEqual = function notEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n // eslint-disable-next-line eqeqeq\n if (actual == expected) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: '!=',\n stackStartFn: notEqual\n });\n }\n};\n\n// The equivalence assertion tests a deep equality relation.\nassert.deepEqual = function deepEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (!isDeepEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'deepEqual',\n stackStartFn: deepEqual\n });\n }\n};\n\n// The non-equivalence assertion tests for any deep inequality.\nassert.notDeepEqual = function notDeepEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (isDeepEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notDeepEqual',\n stackStartFn: notDeepEqual\n });\n }\n};\n/* eslint-enable */\n\nassert.deepStrictEqual = function deepStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (!isDeepStrictEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'deepStrictEqual',\n stackStartFn: deepStrictEqual\n });\n }\n};\nassert.notDeepStrictEqual = notDeepStrictEqual;\nfunction notDeepStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (isDeepStrictEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notDeepStrictEqual',\n stackStartFn: notDeepStrictEqual\n });\n }\n}\nassert.strictEqual = function strictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (!objectIs(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'strictEqual',\n stackStartFn: strictEqual\n });\n }\n};\nassert.notStrictEqual = function notStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (objectIs(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notStrictEqual',\n stackStartFn: notStrictEqual\n });\n }\n};\nvar Comparison = /*#__PURE__*/_createClass(function Comparison(obj, keys, actual) {\n var _this = this;\n _classCallCheck(this, Comparison);\n keys.forEach(function (key) {\n if (key in obj) {\n if (actual !== undefined && typeof actual[key] === 'string' && isRegExp(obj[key]) && RegExpPrototypeTest(obj[key], actual[key])) {\n _this[key] = actual[key];\n } else {\n _this[key] = obj[key];\n }\n }\n });\n});\nfunction compareExceptionKey(actual, expected, key, message, keys, fn) {\n if (!(key in actual) || !isDeepStrictEqual(actual[key], expected[key])) {\n if (!message) {\n // Create placeholder objects to create a nice output.\n var a = new Comparison(actual, keys);\n var b = new Comparison(expected, keys, actual);\n var err = new AssertionError({\n actual: a,\n expected: b,\n operator: 'deepStrictEqual',\n stackStartFn: fn\n });\n err.actual = actual;\n err.expected = expected;\n err.operator = fn.name;\n throw err;\n }\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: fn.name,\n stackStartFn: fn\n });\n }\n}\nfunction expectedException(actual, expected, msg, fn) {\n if (typeof expected !== 'function') {\n if (isRegExp(expected)) return RegExpPrototypeTest(expected, actual);\n // assert.doesNotThrow does not accept objects.\n if (arguments.length === 2) {\n throw new ERR_INVALID_ARG_TYPE('expected', ['Function', 'RegExp'], expected);\n }\n\n // Handle primitives properly.\n if (_typeof(actual) !== 'object' || actual === null) {\n var err = new AssertionError({\n actual: actual,\n expected: expected,\n message: msg,\n operator: 'deepStrictEqual',\n stackStartFn: fn\n });\n err.operator = fn.name;\n throw err;\n }\n var keys = Object.keys(expected);\n // Special handle errors to make sure the name and the message are compared\n // as well.\n if (expected instanceof Error) {\n keys.push('name', 'message');\n } else if (keys.length === 0) {\n throw new ERR_INVALID_ARG_VALUE('error', expected, 'may not be an empty object');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n keys.forEach(function (key) {\n if (typeof actual[key] === 'string' && isRegExp(expected[key]) && RegExpPrototypeTest(expected[key], actual[key])) {\n return;\n }\n compareExceptionKey(actual, expected, key, msg, keys, fn);\n });\n return true;\n }\n // Guard instanceof against arrow functions as they don't have a prototype.\n if (expected.prototype !== undefined && actual instanceof expected) {\n return true;\n }\n if (Error.isPrototypeOf(expected)) {\n return false;\n }\n return expected.call({}, actual) === true;\n}\nfunction getActual(fn) {\n if (typeof fn !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('fn', 'Function', fn);\n }\n try {\n fn();\n } catch (e) {\n return e;\n }\n return NO_EXCEPTION_SENTINEL;\n}\nfunction checkIsPromise(obj) {\n // Accept native ES6 promises and promises that are implemented in a similar\n // way. Do not accept thenables that use a function as `obj` and that have no\n // `catch` handler.\n\n // TODO: thenables are checked up until they have the correct methods,\n // but according to documentation, the `then` method should receive\n // the `fulfill` and `reject` arguments as well or it may be never resolved.\n\n return isPromise(obj) || obj !== null && _typeof(obj) === 'object' && typeof obj.then === 'function' && typeof obj.catch === 'function';\n}\nfunction waitForActual(promiseFn) {\n return Promise.resolve().then(function () {\n var resultPromise;\n if (typeof promiseFn === 'function') {\n // Return a rejected promise if `promiseFn` throws synchronously.\n resultPromise = promiseFn();\n // Fail in case no promise is returned.\n if (!checkIsPromise(resultPromise)) {\n throw new ERR_INVALID_RETURN_VALUE('instance of Promise', 'promiseFn', resultPromise);\n }\n } else if (checkIsPromise(promiseFn)) {\n resultPromise = promiseFn;\n } else {\n throw new ERR_INVALID_ARG_TYPE('promiseFn', ['Function', 'Promise'], promiseFn);\n }\n return Promise.resolve().then(function () {\n return resultPromise;\n }).then(function () {\n return NO_EXCEPTION_SENTINEL;\n }).catch(function (e) {\n return e;\n });\n });\n}\nfunction expectsError(stackStartFn, actual, error, message) {\n if (typeof error === 'string') {\n if (arguments.length === 4) {\n throw new ERR_INVALID_ARG_TYPE('error', ['Object', 'Error', 'Function', 'RegExp'], error);\n }\n if (_typeof(actual) === 'object' && actual !== null) {\n if (actual.message === error) {\n throw new ERR_AMBIGUOUS_ARGUMENT('error/message', \"The error message \\\"\".concat(actual.message, \"\\\" is identical to the message.\"));\n }\n } else if (actual === error) {\n throw new ERR_AMBIGUOUS_ARGUMENT('error/message', \"The error \\\"\".concat(actual, \"\\\" is identical to the message.\"));\n }\n message = error;\n error = undefined;\n } else if (error != null && _typeof(error) !== 'object' && typeof error !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('error', ['Object', 'Error', 'Function', 'RegExp'], error);\n }\n if (actual === NO_EXCEPTION_SENTINEL) {\n var details = '';\n if (error && error.name) {\n details += \" (\".concat(error.name, \")\");\n }\n details += message ? \": \".concat(message) : '.';\n var fnType = stackStartFn.name === 'rejects' ? 'rejection' : 'exception';\n innerFail({\n actual: undefined,\n expected: error,\n operator: stackStartFn.name,\n message: \"Missing expected \".concat(fnType).concat(details),\n stackStartFn: stackStartFn\n });\n }\n if (error && !expectedException(actual, error, message, stackStartFn)) {\n throw actual;\n }\n}\nfunction expectsNoError(stackStartFn, actual, error, message) {\n if (actual === NO_EXCEPTION_SENTINEL) return;\n if (typeof error === 'string') {\n message = error;\n error = undefined;\n }\n if (!error || expectedException(actual, error)) {\n var details = message ? \": \".concat(message) : '.';\n var fnType = stackStartFn.name === 'doesNotReject' ? 'rejection' : 'exception';\n innerFail({\n actual: actual,\n expected: error,\n operator: stackStartFn.name,\n message: \"Got unwanted \".concat(fnType).concat(details, \"\\n\") + \"Actual message: \\\"\".concat(actual && actual.message, \"\\\"\"),\n stackStartFn: stackStartFn\n });\n }\n throw actual;\n}\nassert.throws = function throws(promiseFn) {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n expectsError.apply(void 0, [throws, getActual(promiseFn)].concat(args));\n};\nassert.rejects = function rejects(promiseFn) {\n for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {\n args[_key3 - 1] = arguments[_key3];\n }\n return waitForActual(promiseFn).then(function (result) {\n return expectsError.apply(void 0, [rejects, result].concat(args));\n });\n};\nassert.doesNotThrow = function doesNotThrow(fn) {\n for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {\n args[_key4 - 1] = arguments[_key4];\n }\n expectsNoError.apply(void 0, [doesNotThrow, getActual(fn)].concat(args));\n};\nassert.doesNotReject = function doesNotReject(fn) {\n for (var _len5 = arguments.length, args = new Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) {\n args[_key5 - 1] = arguments[_key5];\n }\n return waitForActual(fn).then(function (result) {\n return expectsNoError.apply(void 0, [doesNotReject, result].concat(args));\n });\n};\nassert.ifError = function ifError(err) {\n if (err !== null && err !== undefined) {\n var message = 'ifError got unwanted exception: ';\n if (_typeof(err) === 'object' && typeof err.message === 'string') {\n if (err.message.length === 0 && err.constructor) {\n message += err.constructor.name;\n } else {\n message += err.message;\n }\n } else {\n message += inspect(err);\n }\n var newErr = new AssertionError({\n actual: err,\n expected: null,\n operator: 'ifError',\n message: message,\n stackStartFn: ifError\n });\n\n // Make sure we actually have a stack trace!\n var origStack = err.stack;\n if (typeof origStack === 'string') {\n // This will remove any duplicated frames from the error frames taken\n // from within `ifError` and add the original error frames to the newly\n // created ones.\n var tmp2 = origStack.split('\\n');\n tmp2.shift();\n // Filter all frames existing in err.stack.\n var tmp1 = newErr.stack.split('\\n');\n for (var i = 0; i < tmp2.length; i++) {\n // Find the first occurrence of the frame.\n var pos = tmp1.indexOf(tmp2[i]);\n if (pos !== -1) {\n // Only keep new frames.\n tmp1 = tmp1.slice(0, pos);\n break;\n }\n }\n newErr.stack = \"\".concat(tmp1.join('\\n'), \"\\n\").concat(tmp2.join('\\n'));\n }\n throw newErr;\n }\n};\n\n// Currently in sync with Node.js lib/assert.js\n// https://github.com/nodejs/node/commit/2a871df3dfb8ea663ef5e1f8f62701ec51384ecb\nfunction internalMatch(string, regexp, message, fn, fnName) {\n if (!isRegExp(regexp)) {\n throw new ERR_INVALID_ARG_TYPE('regexp', 'RegExp', regexp);\n }\n var match = fnName === 'match';\n if (typeof string !== 'string' || RegExpPrototypeTest(regexp, string) !== match) {\n if (message instanceof Error) {\n throw message;\n }\n var generatedMessage = !message;\n\n // 'The input was expected to not match the regular expression ' +\n message = message || (typeof string !== 'string' ? 'The \"string\" argument must be of type string. Received type ' + \"\".concat(_typeof(string), \" (\").concat(inspect(string), \")\") : (match ? 'The input did not match the regular expression ' : 'The input was expected to not match the regular expression ') + \"\".concat(inspect(regexp), \". Input:\\n\\n\").concat(inspect(string), \"\\n\"));\n var err = new AssertionError({\n actual: string,\n expected: regexp,\n message: message,\n operator: fnName,\n stackStartFn: fn\n });\n err.generatedMessage = generatedMessage;\n throw err;\n }\n}\nassert.match = function match(string, regexp, message) {\n internalMatch(string, regexp, message, match, 'match');\n};\nassert.doesNotMatch = function doesNotMatch(string, regexp, message) {\n internalMatch(string, regexp, message, doesNotMatch, 'doesNotMatch');\n};\n\n// Expose a strict only variant of assert\nfunction strict() {\n for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {\n args[_key6] = arguments[_key6];\n }\n innerOk.apply(void 0, [strict, args.length].concat(args));\n}\nassert.strict = objectAssign(strict, assert, {\n equal: assert.strictEqual,\n deepEqual: assert.deepStrictEqual,\n notEqual: assert.notStrictEqual,\n notDeepEqual: assert.notDeepStrictEqual\n});\nassert.strict.strict = assert.strict;","// Currently in sync with Node.js lib/internal/errors.js\n// https://github.com/nodejs/node/commit/3b044962c48fe313905877a96b5d0894a5404f6f\n\n/* eslint node-core/documented-errors: \"error\" */\n/* eslint node-core/alphabetize-errors: \"error\" */\n/* eslint node-core/prefer-util-format-errors: \"error\" */\n\n'use strict';\n\n// The whole point behind this internal module is to allow Node.js to no\n// longer be forced to treat every error message change as a semver-major\n// change. The NodeError classes here all expose a `code` property whose\n// value statically and permanently identifies the error. While the error\n// message may change, the code should not.\nfunction _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}\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}\nfunction _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = _isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = _getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = _getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return _possibleConstructorReturn(this, result);\n };\n}\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return _assertThisInitialized(self);\n}\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nfunction _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\nvar codes = {};\n\n// Lazy loaded\nvar assert;\nvar util;\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n var NodeError = /*#__PURE__*/function (_Base) {\n _inherits(NodeError, _Base);\n var _super = _createSuper(NodeError);\n function NodeError(arg1, arg2, arg3) {\n var _this;\n _classCallCheck(this, NodeError);\n _this = _super.call(this, getMessage(arg1, arg2, arg3));\n _this.code = code;\n return _this;\n }\n return _createClass(NodeError);\n }(Base);\n codes[code] = NodeError;\n}\n\n// https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n return str.substring(this_len - search.length, this_len) === search;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\ncreateErrorType('ERR_AMBIGUOUS_ARGUMENT', 'The \"%s\" argument is ambiguous. %s', TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n if (assert === undefined) assert = require('../assert');\n assert(typeof name === 'string', \"'name' must be a string\");\n\n // determiner: 'must be' or 'must not be'\n var determiner;\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n var msg;\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n\n // TODO(BridgeAR): Improve the output by showing `null` and similar.\n msg += \". Received type \".concat(_typeof(actual));\n return msg;\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_VALUE', function (name, value) {\n var reason = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'is invalid';\n if (util === undefined) util = require('util/');\n var inspected = util.inspect(value);\n if (inspected.length > 128) {\n inspected = \"\".concat(inspected.slice(0, 128), \"...\");\n }\n return \"The argument '\".concat(name, \"' \").concat(reason, \". Received \").concat(inspected);\n}, TypeError, RangeError);\ncreateErrorType('ERR_INVALID_RETURN_VALUE', function (input, name, value) {\n var type;\n if (value && value.constructor && value.constructor.name) {\n type = \"instance of \".concat(value.constructor.name);\n } else {\n type = \"type \".concat(_typeof(value));\n }\n return \"Expected \".concat(input, \" to be returned from the \\\"\").concat(name, \"\\\"\") + \" function but got \".concat(type, \".\");\n}, TypeError);\ncreateErrorType('ERR_MISSING_ARGS', function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n if (assert === undefined) assert = require('../assert');\n assert(args.length > 0, 'At least one arg needs to be specified');\n var msg = 'The ';\n var len = args.length;\n args = args.map(function (a) {\n return \"\\\"\".concat(a, \"\\\"\");\n });\n switch (len) {\n case 1:\n msg += \"\".concat(args[0], \" argument\");\n break;\n case 2:\n msg += \"\".concat(args[0], \" and \").concat(args[1], \" arguments\");\n break;\n default:\n msg += args.slice(0, len - 1).join(', ');\n msg += \", and \".concat(args[len - 1], \" arguments\");\n break;\n }\n return \"\".concat(msg, \" must be specified\");\n}, TypeError);\nmodule.exports.codes = codes;","// Currently in sync with Node.js lib/assert.js\n// https://github.com/nodejs/node/commit/2a51ae424a513ec9a6aa3466baa0cc1d55dd4f3b\n\n// Originally from narwhal.js (http://narwhaljs.org)\n// Copyright (c) 2009 Thomas Robinson <280north.com>\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\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell 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 BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nfunction _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}\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}\nfunction _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nvar _require = require('./internal/errors'),\n _require$codes = _require.codes,\n ERR_AMBIGUOUS_ARGUMENT = _require$codes.ERR_AMBIGUOUS_ARGUMENT,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_INVALID_ARG_VALUE = _require$codes.ERR_INVALID_ARG_VALUE,\n ERR_INVALID_RETURN_VALUE = _require$codes.ERR_INVALID_RETURN_VALUE,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS;\nvar AssertionError = require('./internal/assert/assertion_error');\nvar _require2 = require('util/'),\n inspect = _require2.inspect;\nvar _require$types = require('util/').types,\n isPromise = _require$types.isPromise,\n isRegExp = _require$types.isRegExp;\nvar objectAssign = require('object.assign/polyfill')();\nvar objectIs = require('object-is/polyfill')();\nvar RegExpPrototypeTest = require('call-bind/callBound')('RegExp.prototype.test');\nvar errorCache = new Map();\nvar isDeepEqual;\nvar isDeepStrictEqual;\nvar parseExpressionAt;\nvar findNodeAround;\nvar decoder;\nfunction lazyLoadComparison() {\n var comparison = require('./internal/util/comparisons');\n isDeepEqual = comparison.isDeepEqual;\n isDeepStrictEqual = comparison.isDeepStrictEqual;\n}\n\n// Escape control characters but not \\n and \\t to keep the line breaks and\n// indentation intact.\n// eslint-disable-next-line no-control-regex\nvar escapeSequencesRegExp = /[\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f]/g;\nvar meta = [\"\\\\u0000\", \"\\\\u0001\", \"\\\\u0002\", \"\\\\u0003\", \"\\\\u0004\", \"\\\\u0005\", \"\\\\u0006\", \"\\\\u0007\", '\\\\b', '', '', \"\\\\u000b\", '\\\\f', '', \"\\\\u000e\", \"\\\\u000f\", \"\\\\u0010\", \"\\\\u0011\", \"\\\\u0012\", \"\\\\u0013\", \"\\\\u0014\", \"\\\\u0015\", \"\\\\u0016\", \"\\\\u0017\", \"\\\\u0018\", \"\\\\u0019\", \"\\\\u001a\", \"\\\\u001b\", \"\\\\u001c\", \"\\\\u001d\", \"\\\\u001e\", \"\\\\u001f\"];\nvar escapeFn = function escapeFn(str) {\n return meta[str.charCodeAt(0)];\n};\nvar warned = false;\n\n// The assert module provides functions that throw\n// AssertionError's when particular conditions are not met. The\n// assert module must conform to the following interface.\n\nvar assert = module.exports = ok;\nvar NO_EXCEPTION_SENTINEL = {};\n\n// All of the following functions must throw an AssertionError\n// when a corresponding condition is not met, with a message that\n// may be undefined if not provided. All assertion methods provide\n// both the actual and expected values to the assertion error for\n// display purposes.\n\nfunction innerFail(obj) {\n if (obj.message instanceof Error) throw obj.message;\n throw new AssertionError(obj);\n}\nfunction fail(actual, expected, message, operator, stackStartFn) {\n var argsLen = arguments.length;\n var internalMessage;\n if (argsLen === 0) {\n internalMessage = 'Failed';\n } else if (argsLen === 1) {\n message = actual;\n actual = undefined;\n } else {\n if (warned === false) {\n warned = true;\n var warn = process.emitWarning ? process.emitWarning : console.warn.bind(console);\n warn('assert.fail() with more than one argument is deprecated. ' + 'Please use assert.strictEqual() instead or only pass a message.', 'DeprecationWarning', 'DEP0094');\n }\n if (argsLen === 2) operator = '!=';\n }\n if (message instanceof Error) throw message;\n var errArgs = {\n actual: actual,\n expected: expected,\n operator: operator === undefined ? 'fail' : operator,\n stackStartFn: stackStartFn || fail\n };\n if (message !== undefined) {\n errArgs.message = message;\n }\n var err = new AssertionError(errArgs);\n if (internalMessage) {\n err.message = internalMessage;\n err.generatedMessage = true;\n }\n throw err;\n}\nassert.fail = fail;\n\n// The AssertionError is defined in internal/error.\nassert.AssertionError = AssertionError;\nfunction innerOk(fn, argLen, value, message) {\n if (!value) {\n var generatedMessage = false;\n if (argLen === 0) {\n generatedMessage = true;\n message = 'No value argument passed to `assert.ok()`';\n } else if (message instanceof Error) {\n throw message;\n }\n var err = new AssertionError({\n actual: value,\n expected: true,\n message: message,\n operator: '==',\n stackStartFn: fn\n });\n err.generatedMessage = generatedMessage;\n throw err;\n }\n}\n\n// Pure assertion tests whether a value is truthy, as determined\n// by !!value.\nfunction ok() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n innerOk.apply(void 0, [ok, args.length].concat(args));\n}\nassert.ok = ok;\n\n// The equality assertion tests shallow, coercive equality with ==.\n/* eslint-disable no-restricted-properties */\nassert.equal = function equal(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n // eslint-disable-next-line eqeqeq\n if (actual != expected) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: '==',\n stackStartFn: equal\n });\n }\n};\n\n// The non-equality assertion tests for whether two objects are not\n// equal with !=.\nassert.notEqual = function notEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n // eslint-disable-next-line eqeqeq\n if (actual == expected) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: '!=',\n stackStartFn: notEqual\n });\n }\n};\n\n// The equivalence assertion tests a deep equality relation.\nassert.deepEqual = function deepEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (!isDeepEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'deepEqual',\n stackStartFn: deepEqual\n });\n }\n};\n\n// The non-equivalence assertion tests for any deep inequality.\nassert.notDeepEqual = function notDeepEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (isDeepEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notDeepEqual',\n stackStartFn: notDeepEqual\n });\n }\n};\n/* eslint-enable */\n\nassert.deepStrictEqual = function deepStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (!isDeepStrictEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'deepStrictEqual',\n stackStartFn: deepStrictEqual\n });\n }\n};\nassert.notDeepStrictEqual = notDeepStrictEqual;\nfunction notDeepStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n if (isDeepStrictEqual(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notDeepStrictEqual',\n stackStartFn: notDeepStrictEqual\n });\n }\n}\nassert.strictEqual = function strictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (!objectIs(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'strictEqual',\n stackStartFn: strictEqual\n });\n }\n};\nassert.notStrictEqual = function notStrictEqual(actual, expected, message) {\n if (arguments.length < 2) {\n throw new ERR_MISSING_ARGS('actual', 'expected');\n }\n if (objectIs(actual, expected)) {\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: 'notStrictEqual',\n stackStartFn: notStrictEqual\n });\n }\n};\nvar Comparison = /*#__PURE__*/_createClass(function Comparison(obj, keys, actual) {\n var _this = this;\n _classCallCheck(this, Comparison);\n keys.forEach(function (key) {\n if (key in obj) {\n if (actual !== undefined && typeof actual[key] === 'string' && isRegExp(obj[key]) && RegExpPrototypeTest(obj[key], actual[key])) {\n _this[key] = actual[key];\n } else {\n _this[key] = obj[key];\n }\n }\n });\n});\nfunction compareExceptionKey(actual, expected, key, message, keys, fn) {\n if (!(key in actual) || !isDeepStrictEqual(actual[key], expected[key])) {\n if (!message) {\n // Create placeholder objects to create a nice output.\n var a = new Comparison(actual, keys);\n var b = new Comparison(expected, keys, actual);\n var err = new AssertionError({\n actual: a,\n expected: b,\n operator: 'deepStrictEqual',\n stackStartFn: fn\n });\n err.actual = actual;\n err.expected = expected;\n err.operator = fn.name;\n throw err;\n }\n innerFail({\n actual: actual,\n expected: expected,\n message: message,\n operator: fn.name,\n stackStartFn: fn\n });\n }\n}\nfunction expectedException(actual, expected, msg, fn) {\n if (typeof expected !== 'function') {\n if (isRegExp(expected)) return RegExpPrototypeTest(expected, actual);\n // assert.doesNotThrow does not accept objects.\n if (arguments.length === 2) {\n throw new ERR_INVALID_ARG_TYPE('expected', ['Function', 'RegExp'], expected);\n }\n\n // Handle primitives properly.\n if (_typeof(actual) !== 'object' || actual === null) {\n var err = new AssertionError({\n actual: actual,\n expected: expected,\n message: msg,\n operator: 'deepStrictEqual',\n stackStartFn: fn\n });\n err.operator = fn.name;\n throw err;\n }\n var keys = Object.keys(expected);\n // Special handle errors to make sure the name and the message are compared\n // as well.\n if (expected instanceof Error) {\n keys.push('name', 'message');\n } else if (keys.length === 0) {\n throw new ERR_INVALID_ARG_VALUE('error', expected, 'may not be an empty object');\n }\n if (isDeepEqual === undefined) lazyLoadComparison();\n keys.forEach(function (key) {\n if (typeof actual[key] === 'string' && isRegExp(expected[key]) && RegExpPrototypeTest(expected[key], actual[key])) {\n return;\n }\n compareExceptionKey(actual, expected, key, msg, keys, fn);\n });\n return true;\n }\n // Guard instanceof against arrow functions as they don't have a prototype.\n if (expected.prototype !== undefined && actual instanceof expected) {\n return true;\n }\n if (Error.isPrototypeOf(expected)) {\n return false;\n }\n return expected.call({}, actual) === true;\n}\nfunction getActual(fn) {\n if (typeof fn !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('fn', 'Function', fn);\n }\n try {\n fn();\n } catch (e) {\n return e;\n }\n return NO_EXCEPTION_SENTINEL;\n}\nfunction checkIsPromise(obj) {\n // Accept native ES6 promises and promises that are implemented in a similar\n // way. Do not accept thenables that use a function as `obj` and that have no\n // `catch` handler.\n\n // TODO: thenables are checked up until they have the correct methods,\n // but according to documentation, the `then` method should receive\n // the `fulfill` and `reject` arguments as well or it may be never resolved.\n\n return isPromise(obj) || obj !== null && _typeof(obj) === 'object' && typeof obj.then === 'function' && typeof obj.catch === 'function';\n}\nfunction waitForActual(promiseFn) {\n return Promise.resolve().then(function () {\n var resultPromise;\n if (typeof promiseFn === 'function') {\n // Return a rejected promise if `promiseFn` throws synchronously.\n resultPromise = promiseFn();\n // Fail in case no promise is returned.\n if (!checkIsPromise(resultPromise)) {\n throw new ERR_INVALID_RETURN_VALUE('instance of Promise', 'promiseFn', resultPromise);\n }\n } else if (checkIsPromise(promiseFn)) {\n resultPromise = promiseFn;\n } else {\n throw new ERR_INVALID_ARG_TYPE('promiseFn', ['Function', 'Promise'], promiseFn);\n }\n return Promise.resolve().then(function () {\n return resultPromise;\n }).then(function () {\n return NO_EXCEPTION_SENTINEL;\n }).catch(function (e) {\n return e;\n });\n });\n}\nfunction expectsError(stackStartFn, actual, error, message) {\n if (typeof error === 'string') {\n if (arguments.length === 4) {\n throw new ERR_INVALID_ARG_TYPE('error', ['Object', 'Error', 'Function', 'RegExp'], error);\n }\n if (_typeof(actual) === 'object' && actual !== null) {\n if (actual.message === error) {\n throw new ERR_AMBIGUOUS_ARGUMENT('error/message', \"The error message \\\"\".concat(actual.message, \"\\\" is identical to the message.\"));\n }\n } else if (actual === error) {\n throw new ERR_AMBIGUOUS_ARGUMENT('error/message', \"The error \\\"\".concat(actual, \"\\\" is identical to the message.\"));\n }\n message = error;\n error = undefined;\n } else if (error != null && _typeof(error) !== 'object' && typeof error !== 'function') {\n throw new ERR_INVALID_ARG_TYPE('error', ['Object', 'Error', 'Function', 'RegExp'], error);\n }\n if (actual === NO_EXCEPTION_SENTINEL) {\n var details = '';\n if (error && error.name) {\n details += \" (\".concat(error.name, \")\");\n }\n details += message ? \": \".concat(message) : '.';\n var fnType = stackStartFn.name === 'rejects' ? 'rejection' : 'exception';\n innerFail({\n actual: undefined,\n expected: error,\n operator: stackStartFn.name,\n message: \"Missing expected \".concat(fnType).concat(details),\n stackStartFn: stackStartFn\n });\n }\n if (error && !expectedException(actual, error, message, stackStartFn)) {\n throw actual;\n }\n}\nfunction expectsNoError(stackStartFn, actual, error, message) {\n if (actual === NO_EXCEPTION_SENTINEL) return;\n if (typeof error === 'string') {\n message = error;\n error = undefined;\n }\n if (!error || expectedException(actual, error)) {\n var details = message ? \": \".concat(message) : '.';\n var fnType = stackStartFn.name === 'doesNotReject' ? 'rejection' : 'exception';\n innerFail({\n actual: actual,\n expected: error,\n operator: stackStartFn.name,\n message: \"Got unwanted \".concat(fnType).concat(details, \"\\n\") + \"Actual message: \\\"\".concat(actual && actual.message, \"\\\"\"),\n stackStartFn: stackStartFn\n });\n }\n throw actual;\n}\nassert.throws = function throws(promiseFn) {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n expectsError.apply(void 0, [throws, getActual(promiseFn)].concat(args));\n};\nassert.rejects = function rejects(promiseFn) {\n for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {\n args[_key3 - 1] = arguments[_key3];\n }\n return waitForActual(promiseFn).then(function (result) {\n return expectsError.apply(void 0, [rejects, result].concat(args));\n });\n};\nassert.doesNotThrow = function doesNotThrow(fn) {\n for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {\n args[_key4 - 1] = arguments[_key4];\n }\n expectsNoError.apply(void 0, [doesNotThrow, getActual(fn)].concat(args));\n};\nassert.doesNotReject = function doesNotReject(fn) {\n for (var _len5 = arguments.length, args = new Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) {\n args[_key5 - 1] = arguments[_key5];\n }\n return waitForActual(fn).then(function (result) {\n return expectsNoError.apply(void 0, [doesNotReject, result].concat(args));\n });\n};\nassert.ifError = function ifError(err) {\n if (err !== null && err !== undefined) {\n var message = 'ifError got unwanted exception: ';\n if (_typeof(err) === 'object' && typeof err.message === 'string') {\n if (err.message.length === 0 && err.constructor) {\n message += err.constructor.name;\n } else {\n message += err.message;\n }\n } else {\n message += inspect(err);\n }\n var newErr = new AssertionError({\n actual: err,\n expected: null,\n operator: 'ifError',\n message: message,\n stackStartFn: ifError\n });\n\n // Make sure we actually have a stack trace!\n var origStack = err.stack;\n if (typeof origStack === 'string') {\n // This will remove any duplicated frames from the error frames taken\n // from within `ifError` and add the original error frames to the newly\n // created ones.\n var tmp2 = origStack.split('\\n');\n tmp2.shift();\n // Filter all frames existing in err.stack.\n var tmp1 = newErr.stack.split('\\n');\n for (var i = 0; i < tmp2.length; i++) {\n // Find the first occurrence of the frame.\n var pos = tmp1.indexOf(tmp2[i]);\n if (pos !== -1) {\n // Only keep new frames.\n tmp1 = tmp1.slice(0, pos);\n break;\n }\n }\n newErr.stack = \"\".concat(tmp1.join('\\n'), \"\\n\").concat(tmp2.join('\\n'));\n }\n throw newErr;\n }\n};\n\n// Currently in sync with Node.js lib/assert.js\n// https://github.com/nodejs/node/commit/2a871df3dfb8ea663ef5e1f8f62701ec51384ecb\nfunction internalMatch(string, regexp, message, fn, fnName) {\n if (!isRegExp(regexp)) {\n throw new ERR_INVALID_ARG_TYPE('regexp', 'RegExp', regexp);\n }\n var match = fnName === 'match';\n if (typeof string !== 'string' || RegExpPrototypeTest(regexp, string) !== match) {\n if (message instanceof Error) {\n throw message;\n }\n var generatedMessage = !message;\n\n // 'The input was expected to not match the regular expression ' +\n message = message || (typeof string !== 'string' ? 'The \"string\" argument must be of type string. Received type ' + \"\".concat(_typeof(string), \" (\").concat(inspect(string), \")\") : (match ? 'The input did not match the regular expression ' : 'The input was expected to not match the regular expression ') + \"\".concat(inspect(regexp), \". Input:\\n\\n\").concat(inspect(string), \"\\n\"));\n var err = new AssertionError({\n actual: string,\n expected: regexp,\n message: message,\n operator: fnName,\n stackStartFn: fn\n });\n err.generatedMessage = generatedMessage;\n throw err;\n }\n}\nassert.match = function match(string, regexp, message) {\n internalMatch(string, regexp, message, match, 'match');\n};\nassert.doesNotMatch = function doesNotMatch(string, regexp, message) {\n internalMatch(string, regexp, message, doesNotMatch, 'doesNotMatch');\n};\n\n// Expose a strict only variant of assert\nfunction strict() {\n for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {\n args[_key6] = arguments[_key6];\n }\n innerOk.apply(void 0, [strict, args.length].concat(args));\n}\nassert.strict = objectAssign(strict, assert, {\n equal: assert.strictEqual,\n deepEqual: assert.deepStrictEqual,\n notEqual: assert.notStrictEqual,\n notDeepEqual: assert.notDeepStrictEqual\n});\nassert.strict.strict = assert.strict;","const errors = {\n IMPOSSIBLE_CASE: 'Impossible case. Please create issue.',\n TWEAK_ADD: 'The tweak was out of range or the resulted private key is invalid',\n TWEAK_MUL: 'The tweak was out of range or equal to zero',\n CONTEXT_RANDOMIZE_UNKNOW: 'Unknow error on context randomization',\n SECKEY_INVALID: 'Private Key is invalid',\n PUBKEY_PARSE: 'Public Key could not be parsed',\n PUBKEY_SERIALIZE: 'Public Key serialization error',\n PUBKEY_COMBINE: 'The sum of the public keys is not valid',\n SIG_PARSE: 'Signature could not be parsed',\n SIGN: 'The nonce generation function failed, or the private key was invalid',\n RECOVER: 'Public key could not be recover',\n ECDH: 'Scalar was invalid (zero or overflow)'\n};\nfunction assert(cond, msg) {\n if (!cond) throw new Error(msg);\n}\nfunction isUint8Array(name, value, length) {\n assert(value instanceof Uint8Array, `Expected ${name} to be an Uint8Array`);\n if (length !== undefined) {\n if (Array.isArray(length)) {\n const numbers = length.join(', ');\n const msg = `Expected ${name} to be an Uint8Array with length [${numbers}]`;\n assert(length.includes(value.length), msg);\n } else {\n const msg = `Expected ${name} to be an Uint8Array with length ${length}`;\n assert(value.length === length, msg);\n }\n }\n}\nfunction isCompressed(value) {\n assert(toTypeString(value) === 'Boolean', 'Expected compressed to be a Boolean');\n}\nfunction getAssertedOutput(output = len => new Uint8Array(len), length) {\n if (typeof output === 'function') output = output(length);\n isUint8Array('output', output, length);\n return output;\n}\nfunction toTypeString(value) {\n return Object.prototype.toString.call(value).slice(8, -1);\n}\nmodule.exports = secp256k1 => {\n return {\n contextRandomize(seed) {\n assert(seed === null || seed instanceof Uint8Array, 'Expected seed to be an Uint8Array or null');\n if (seed !== null) isUint8Array('seed', seed, 32);\n switch (secp256k1.contextRandomize(seed)) {\n case 1:\n throw new Error(errors.CONTEXT_RANDOMIZE_UNKNOW);\n }\n },\n privateKeyVerify(seckey) {\n isUint8Array('private key', seckey, 32);\n return secp256k1.privateKeyVerify(seckey) === 0;\n },\n privateKeyNegate(seckey) {\n isUint8Array('private key', seckey, 32);\n switch (secp256k1.privateKeyNegate(seckey)) {\n case 0:\n return seckey;\n case 1:\n throw new Error(errors.IMPOSSIBLE_CASE);\n }\n },\n privateKeyTweakAdd(seckey, tweak) {\n isUint8Array('private key', seckey, 32);\n isUint8Array('tweak', tweak, 32);\n switch (secp256k1.privateKeyTweakAdd(seckey, tweak)) {\n case 0:\n return seckey;\n case 1:\n throw new Error(errors.TWEAK_ADD);\n }\n },\n privateKeyTweakMul(seckey, tweak) {\n isUint8Array('private key', seckey, 32);\n isUint8Array('tweak', tweak, 32);\n switch (secp256k1.privateKeyTweakMul(seckey, tweak)) {\n case 0:\n return seckey;\n case 1:\n throw new Error(errors.TWEAK_MUL);\n }\n },\n publicKeyVerify(pubkey) {\n isUint8Array('public key', pubkey, [33, 65]);\n return secp256k1.publicKeyVerify(pubkey) === 0;\n },\n publicKeyCreate(seckey, compressed = true, output) {\n isUint8Array('private key', seckey, 32);\n isCompressed(compressed);\n output = getAssertedOutput(output, compressed ? 33 : 65);\n switch (secp256k1.publicKeyCreate(output, seckey)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.SECKEY_INVALID);\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE);\n }\n },\n publicKeyConvert(pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65]);\n isCompressed(compressed);\n output = getAssertedOutput(output, compressed ? 33 : 65);\n switch (secp256k1.publicKeyConvert(output, pubkey)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.PUBKEY_PARSE);\n case 2:\n throw new Error(errors.PUBKEY_SERIALIZE);\n }\n },\n publicKeyNegate(pubkey, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65]);\n isCompressed(compressed);\n output = getAssertedOutput(output, compressed ? 33 : 65);\n switch (secp256k1.publicKeyNegate(output, pubkey)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.PUBKEY_PARSE);\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE);\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE);\n }\n },\n publicKeyCombine(pubkeys, compressed = true, output) {\n assert(Array.isArray(pubkeys), 'Expected public keys to be an Array');\n assert(pubkeys.length > 0, 'Expected public keys array will have more than zero items');\n for (const pubkey of pubkeys) {\n isUint8Array('public key', pubkey, [33, 65]);\n }\n isCompressed(compressed);\n output = getAssertedOutput(output, compressed ? 33 : 65);\n switch (secp256k1.publicKeyCombine(output, pubkeys)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.PUBKEY_PARSE);\n case 2:\n throw new Error(errors.PUBKEY_COMBINE);\n case 3:\n throw new Error(errors.PUBKEY_SERIALIZE);\n }\n },\n publicKeyTweakAdd(pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65]);\n isUint8Array('tweak', tweak, 32);\n isCompressed(compressed);\n output = getAssertedOutput(output, compressed ? 33 : 65);\n switch (secp256k1.publicKeyTweakAdd(output, pubkey, tweak)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.PUBKEY_PARSE);\n case 2:\n throw new Error(errors.TWEAK_ADD);\n }\n },\n publicKeyTweakMul(pubkey, tweak, compressed = true, output) {\n isUint8Array('public key', pubkey, [33, 65]);\n isUint8Array('tweak', tweak, 32);\n isCompressed(compressed);\n output = getAssertedOutput(output, compressed ? 33 : 65);\n switch (secp256k1.publicKeyTweakMul(output, pubkey, tweak)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.PUBKEY_PARSE);\n case 2:\n throw new Error(errors.TWEAK_MUL);\n }\n },\n signatureNormalize(sig) {\n isUint8Array('signature', sig, 64);\n switch (secp256k1.signatureNormalize(sig)) {\n case 0:\n return sig;\n case 1:\n throw new Error(errors.SIG_PARSE);\n }\n },\n signatureExport(sig, output) {\n isUint8Array('signature', sig, 64);\n output = getAssertedOutput(output, 72);\n const obj = {\n output,\n outputlen: 72\n };\n switch (secp256k1.signatureExport(obj, sig)) {\n case 0:\n return output.slice(0, obj.outputlen);\n case 1:\n throw new Error(errors.SIG_PARSE);\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE);\n }\n },\n signatureImport(sig, output) {\n isUint8Array('signature', sig);\n output = getAssertedOutput(output, 64);\n switch (secp256k1.signatureImport(output, sig)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.SIG_PARSE);\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE);\n }\n },\n ecdsaSign(msg32, seckey, options = {}, output) {\n isUint8Array('message', msg32, 32);\n isUint8Array('private key', seckey, 32);\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object');\n if (options.data !== undefined) isUint8Array('options.data', options.data);\n if (options.noncefn !== undefined) assert(toTypeString(options.noncefn) === 'Function', 'Expected options.noncefn to be a Function');\n output = getAssertedOutput(output, 64);\n const obj = {\n signature: output,\n recid: null\n };\n switch (secp256k1.ecdsaSign(obj, msg32, seckey, options.data, options.noncefn)) {\n case 0:\n return obj;\n case 1:\n throw new Error(errors.SIGN);\n case 2:\n throw new Error(errors.IMPOSSIBLE_CASE);\n }\n },\n ecdsaVerify(sig, msg32, pubkey) {\n isUint8Array('signature', sig, 64);\n isUint8Array('message', msg32, 32);\n isUint8Array('public key', pubkey, [33, 65]);\n switch (secp256k1.ecdsaVerify(sig, msg32, pubkey)) {\n case 0:\n return true;\n case 3:\n return false;\n case 1:\n throw new Error(errors.SIG_PARSE);\n case 2:\n throw new Error(errors.PUBKEY_PARSE);\n }\n },\n ecdsaRecover(sig, recid, msg32, compressed = true, output) {\n isUint8Array('signature', sig, 64);\n assert(toTypeString(recid) === 'Number' && recid >= 0 && recid <= 3, 'Expected recovery id to be a Number within interval [0, 3]');\n isUint8Array('message', msg32, 32);\n isCompressed(compressed);\n output = getAssertedOutput(output, compressed ? 33 : 65);\n switch (secp256k1.ecdsaRecover(output, sig, recid, msg32)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.SIG_PARSE);\n case 2:\n throw new Error(errors.RECOVER);\n case 3:\n throw new Error(errors.IMPOSSIBLE_CASE);\n }\n },\n ecdh(pubkey, seckey, options = {}, output) {\n isUint8Array('public key', pubkey, [33, 65]);\n isUint8Array('private key', seckey, 32);\n assert(toTypeString(options) === 'Object', 'Expected options to be an Object');\n if (options.data !== undefined) isUint8Array('options.data', options.data);\n if (options.hashfn !== undefined) {\n assert(toTypeString(options.hashfn) === 'Function', 'Expected options.hashfn to be a Function');\n if (options.xbuf !== undefined) isUint8Array('options.xbuf', options.xbuf, 32);\n if (options.ybuf !== undefined) isUint8Array('options.ybuf', options.ybuf, 32);\n isUint8Array('output', output);\n } else {\n output = getAssertedOutput(output, 32);\n }\n switch (secp256k1.ecdh(output, pubkey, seckey, options.data, options.hashfn, options.xbuf, options.ybuf)) {\n case 0:\n return output;\n case 1:\n throw new Error(errors.PUBKEY_PARSE);\n case 2:\n throw new Error(errors.ECDH);\n }\n }\n };\n};","const EC = require('elliptic').ec;\nconst ec = new EC('secp256k1');\nconst ecparams = ec.curve;\n\n// Hack, we can not use bn.js@5, while elliptic uses bn.js@4\n// See https://github.com/indutny/elliptic/issues/191#issuecomment-569888758\nconst BN = ecparams.n.constructor;\nfunction loadCompressedPublicKey(first, xbuf) {\n let x = new BN(xbuf);\n\n // overflow\n if (x.cmp(ecparams.p) >= 0) return null;\n x = x.toRed(ecparams.red);\n\n // compute corresponding Y\n let y = x.redSqr().redIMul(x).redIAdd(ecparams.b).redSqrt();\n if (first === 0x03 !== y.isOdd()) y = y.redNeg();\n\n // x*x*x + b = y*y\n const x3 = x.redSqr().redIMul(x);\n if (!y.redSqr().redISub(x3.redIAdd(ecparams.b)).isZero()) return null;\n return ec.keyPair({\n pub: {\n x: x,\n y: y\n }\n });\n}\nfunction loadUncompressedPublicKey(first, xbuf, ybuf) {\n let x = new BN(xbuf);\n let y = new BN(ybuf);\n\n // overflow\n if (x.cmp(ecparams.p) >= 0 || y.cmp(ecparams.p) >= 0) return null;\n x = x.toRed(ecparams.red);\n y = y.toRed(ecparams.red);\n\n // is odd flag\n if ((first === 0x06 || first === 0x07) && y.isOdd() !== (first === 0x07)) return null;\n\n // x*x*x + b = y*y\n const x3 = x.redSqr().redIMul(x);\n if (!y.redSqr().redISub(x3.redIAdd(ecparams.b)).isZero()) return null;\n return ec.keyPair({\n pub: {\n x: x,\n y: y\n }\n });\n}\nfunction loadPublicKey(pubkey) {\n // length should be validated in interface\n const first = pubkey[0];\n switch (first) {\n case 0x02:\n case 0x03:\n if (pubkey.length !== 33) return null;\n return loadCompressedPublicKey(first, pubkey.subarray(1, 33));\n case 0x04:\n case 0x06:\n case 0x07:\n if (pubkey.length !== 65) return null;\n return loadUncompressedPublicKey(first, pubkey.subarray(1, 33), pubkey.subarray(33, 65));\n default:\n return null;\n }\n}\nfunction savePublicKey(output, point) {\n const pubkey = point.encode(null, output.length === 33);\n // Loop should be faster because we do not need create extra Uint8Array\n // output.set(new Uint8Array(pubkey))\n for (let i = 0; i < output.length; ++i) output[i] = pubkey[i];\n}\nmodule.exports = {\n contextRandomize() {\n return 0;\n },\n privateKeyVerify(seckey) {\n const bn = new BN(seckey);\n return bn.cmp(ecparams.n) < 0 && !bn.isZero() ? 0 : 1;\n },\n privateKeyNegate(seckey) {\n const bn = new BN(seckey);\n const negate = ecparams.n.sub(bn).umod(ecparams.n).toArrayLike(Uint8Array, 'be', 32);\n seckey.set(negate);\n return 0;\n },\n privateKeyTweakAdd(seckey, tweak) {\n const bn = new BN(tweak);\n if (bn.cmp(ecparams.n) >= 0) return 1;\n bn.iadd(new BN(seckey));\n if (bn.cmp(ecparams.n) >= 0) bn.isub(ecparams.n);\n if (bn.isZero()) return 1;\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32);\n seckey.set(tweaked);\n return 0;\n },\n privateKeyTweakMul(seckey, tweak) {\n let bn = new BN(tweak);\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1;\n bn.imul(new BN(seckey));\n if (bn.cmp(ecparams.n) >= 0) bn = bn.umod(ecparams.n);\n const tweaked = bn.toArrayLike(Uint8Array, 'be', 32);\n seckey.set(tweaked);\n return 0;\n },\n publicKeyVerify(pubkey) {\n const pair = loadPublicKey(pubkey);\n return pair === null ? 1 : 0;\n },\n publicKeyCreate(output, seckey) {\n const bn = new BN(seckey);\n if (bn.cmp(ecparams.n) >= 0 || bn.isZero()) return 1;\n const point = ec.keyFromPrivate(seckey).getPublic();\n savePublicKey(output, point);\n return 0;\n },\n publicKeyConvert(output, pubkey) {\n const pair = loadPublicKey(pubkey);\n if (pair === null) return 1;\n const point = pair.getPublic();\n savePublicKey(output, point);\n return 0;\n },\n publicKeyNegate(output, pubkey) {\n const pair = loadPublicKey(pubkey);\n if (pair === null) return 1;\n const point = pair.getPublic();\n point.y = point.y.redNeg();\n savePublicKey(output, point);\n return 0;\n },\n publicKeyCombine(output, pubkeys) {\n const pairs = new Array(pubkeys.length);\n for (let i = 0; i < pubkeys.length; ++i) {\n pairs[i] = loadPublicKey(pubkeys[i]);\n if (pairs[i] === null) return 1;\n }\n let point = pairs[0].getPublic();\n for (let i = 1; i < pairs.length; ++i) point = point.add(pairs[i].pub);\n if (point.isInfinity()) return 2;\n savePublicKey(output, point);\n return 0;\n },\n publicKeyTweakAdd(output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey);\n if (pair === null) return 1;\n tweak = new BN(tweak);\n if (tweak.cmp(ecparams.n) >= 0) return 2;\n const point = pair.getPublic().add(ecparams.g.mul(tweak));\n if (point.isInfinity()) return 2;\n savePublicKey(output, point);\n return 0;\n },\n publicKeyTweakMul(output, pubkey, tweak) {\n const pair = loadPublicKey(pubkey);\n if (pair === null) return 1;\n tweak = new BN(tweak);\n if (tweak.cmp(ecparams.n) >= 0 || tweak.isZero()) return 2;\n const point = pair.getPublic().mul(tweak);\n savePublicKey(output, point);\n return 0;\n },\n signatureNormalize(sig) {\n const r = new BN(sig.subarray(0, 32));\n const s = new BN(sig.subarray(32, 64));\n if (r.cmp(ecparams.n) >= 0 || s.cmp(ecparams.n) >= 0) return 1;\n if (s.cmp(ec.nh) === 1) {\n sig.set(ecparams.n.sub(s).toArrayLike(Uint8Array, 'be', 32), 32);\n }\n return 0;\n },\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureExport(obj, sig) {\n const sigR = sig.subarray(0, 32);\n const sigS = sig.subarray(32, 64);\n if (new BN(sigR).cmp(ecparams.n) >= 0) return 1;\n if (new BN(sigS).cmp(ecparams.n) >= 0) return 1;\n const {\n output\n } = obj;\n\n // Prepare R\n let r = output.subarray(4, 4 + 33);\n r[0] = 0x00;\n r.set(sigR, 1);\n let lenR = 33;\n let posR = 0;\n for (; lenR > 1 && r[posR] === 0x00 && !(r[posR + 1] & 0x80); --lenR, ++posR);\n r = r.subarray(posR);\n if (r[0] & 0x80) return 1;\n if (lenR > 1 && r[0] === 0x00 && !(r[1] & 0x80)) return 1;\n\n // Prepare S\n let s = output.subarray(6 + 33, 6 + 33 + 33);\n s[0] = 0x00;\n s.set(sigS, 1);\n let lenS = 33;\n let posS = 0;\n for (; lenS > 1 && s[posS] === 0x00 && !(s[posS + 1] & 0x80); --lenS, ++posS);\n s = s.subarray(posS);\n if (s[0] & 0x80) return 1;\n if (lenS > 1 && s[0] === 0x00 && !(s[1] & 0x80)) return 1;\n\n // Set output length for return\n obj.outputlen = 6 + lenR + lenS;\n\n // Output in specified format\n // 0x30 [total-length] 0x02 [R-length] [R] 0x02 [S-length] [S]\n output[0] = 0x30;\n output[1] = obj.outputlen - 2;\n output[2] = 0x02;\n output[3] = r.length;\n output.set(r, 4);\n output[4 + lenR] = 0x02;\n output[5 + lenR] = s.length;\n output.set(s, 6 + lenR);\n return 0;\n },\n // Copied 1-to-1 from https://github.com/bitcoinjs/bip66/blob/master/index.js\n // Adapted for Uint8Array instead Buffer\n signatureImport(output, sig) {\n if (sig.length < 8) return 1;\n if (sig.length > 72) return 1;\n if (sig[0] !== 0x30) return 1;\n if (sig[1] !== sig.length - 2) return 1;\n if (sig[2] !== 0x02) return 1;\n const lenR = sig[3];\n if (lenR === 0) return 1;\n if (5 + lenR >= sig.length) return 1;\n if (sig[4 + lenR] !== 0x02) return 1;\n const lenS = sig[5 + lenR];\n if (lenS === 0) return 1;\n if (6 + lenR + lenS !== sig.length) return 1;\n if (sig[4] & 0x80) return 1;\n if (lenR > 1 && sig[4] === 0x00 && !(sig[5] & 0x80)) return 1;\n if (sig[lenR + 6] & 0x80) return 1;\n if (lenS > 1 && sig[lenR + 6] === 0x00 && !(sig[lenR + 7] & 0x80)) return 1;\n let sigR = sig.subarray(4, 4 + lenR);\n if (sigR.length === 33 && sigR[0] === 0x00) sigR = sigR.subarray(1);\n if (sigR.length > 32) return 1;\n let sigS = sig.subarray(6 + lenR);\n if (sigS.length === 33 && sigS[0] === 0x00) sigS = sigS.slice(1);\n if (sigS.length > 32) throw new Error('S length is too long');\n let r = new BN(sigR);\n if (r.cmp(ecparams.n) >= 0) r = new BN(0);\n let s = new BN(sig.subarray(6 + lenR));\n if (s.cmp(ecparams.n) >= 0) s = new BN(0);\n output.set(r.toArrayLike(Uint8Array, 'be', 32), 0);\n output.set(s.toArrayLike(Uint8Array, 'be', 32), 32);\n return 0;\n },\n ecdsaSign(obj, message, seckey, data, noncefn) {\n if (noncefn) {\n const _noncefn = noncefn;\n noncefn = counter => {\n const nonce = _noncefn(message, seckey, null, data, counter);\n const isValid = nonce instanceof Uint8Array && nonce.length === 32;\n if (!isValid) throw new Error('This is the way');\n return new BN(nonce);\n };\n }\n const d = new BN(seckey);\n if (d.cmp(ecparams.n) >= 0 || d.isZero()) return 1;\n let sig;\n try {\n sig = ec.sign(message, seckey, {\n canonical: true,\n k: noncefn,\n pers: data\n });\n } catch (err) {\n return 1;\n }\n obj.signature.set(sig.r.toArrayLike(Uint8Array, 'be', 32), 0);\n obj.signature.set(sig.s.toArrayLike(Uint8Array, 'be', 32), 32);\n obj.recid = sig.recoveryParam;\n return 0;\n },\n ecdsaVerify(sig, msg32, pubkey) {\n const sigObj = {\n r: sig.subarray(0, 32),\n s: sig.subarray(32, 64)\n };\n const sigr = new BN(sigObj.r);\n const sigs = new BN(sigObj.s);\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1;\n if (sigs.cmp(ec.nh) === 1 || sigr.isZero() || sigs.isZero()) return 3;\n const pair = loadPublicKey(pubkey);\n if (pair === null) return 2;\n const point = pair.getPublic();\n const isValid = ec.verify(msg32, sigObj, point);\n return isValid ? 0 : 3;\n },\n ecdsaRecover(output, sig, recid, msg32) {\n const sigObj = {\n r: sig.slice(0, 32),\n s: sig.slice(32, 64)\n };\n const sigr = new BN(sigObj.r);\n const sigs = new BN(sigObj.s);\n if (sigr.cmp(ecparams.n) >= 0 || sigs.cmp(ecparams.n) >= 0) return 1;\n if (sigr.isZero() || sigs.isZero()) return 2;\n\n // Can throw `throw new Error('Unable to find sencond key candinate');`\n let point;\n try {\n point = ec.recoverPubKey(msg32, sigObj, recid);\n } catch (err) {\n return 2;\n }\n savePublicKey(output, point);\n return 0;\n },\n ecdh(output, pubkey, seckey, data, hashfn, xbuf, ybuf) {\n const pair = loadPublicKey(pubkey);\n if (pair === null) return 1;\n const scalar = new BN(seckey);\n if (scalar.cmp(ecparams.n) >= 0 || scalar.isZero()) return 2;\n const point = pair.getPublic().mul(scalar);\n if (hashfn === undefined) {\n const data = point.encode(null, true);\n const sha256 = ec.hash().update(data).digest();\n for (let i = 0; i < 32; ++i) output[i] = sha256[i];\n } else {\n if (!xbuf) xbuf = new Uint8Array(32);\n const x = point.getX().toArray('be', 32);\n for (let i = 0; i < 32; ++i) xbuf[i] = x[i];\n if (!ybuf) ybuf = new Uint8Array(32);\n const y = point.getY().toArray('be', 32);\n for (let i = 0; i < 32; ++i) ybuf[i] = y[i];\n const hash = hashfn(xbuf, ybuf, data);\n const isValid = hash instanceof Uint8Array && hash.length === output.length;\n if (!isValid) return 2;\n output.set(hash);\n }\n return 0;\n }\n};","module.exports = require('./lib')(require('./lib/elliptic'));","/*! safe-buffer. MIT License. Feross Aboukhadijeh */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer');\nvar Buffer = buffer.Buffer;\n\n// alternative to using Object.keys for old browsers\nfunction copyProps(src, dst) {\n for (var key in src) {\n dst[key] = src[key];\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer;\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports);\n exports.Buffer = SafeBuffer;\n}\nfunction SafeBuffer(arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length);\n}\nSafeBuffer.prototype = Object.create(Buffer.prototype);\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer);\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number');\n }\n return Buffer(arg, encodingOrOffset, length);\n};\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number');\n }\n var buf = Buffer(size);\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding);\n } else {\n buf.fill(fill);\n }\n } else {\n buf.fill(0);\n }\n return buf;\n};\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number');\n }\n return Buffer(size);\n};\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number');\n }\n return buffer.SlowBuffer(size);\n};","'use strict';\n\n// limit of Crypto.getRandomValues()\n// https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues\nvar MAX_BYTES = 65536;\n\n// Node supports requesting up to this number of bytes\n// https://github.com/nodejs/node/blob/master/lib/internal/crypto/random.js#L48\nvar MAX_UINT32 = 4294967295;\nfunction oldBrowser() {\n throw new Error('Secure random number generation is not supported by this browser.\\nUse Chrome, Firefox or Internet Explorer 11');\n}\nvar Buffer = require('safe-buffer').Buffer;\nvar crypto = global.crypto || global.msCrypto;\nif (crypto && crypto.getRandomValues) {\n module.exports = randomBytes;\n} else {\n module.exports = oldBrowser;\n}\nfunction randomBytes(size, cb) {\n // phantomjs needs to throw\n if (size > MAX_UINT32) throw new RangeError('requested too many random bytes');\n var bytes = Buffer.allocUnsafe(size);\n if (size > 0) {\n // getRandomValues fails on IE if size == 0\n if (size > MAX_BYTES) {\n // this is the max bytes crypto.getRandomValues\n // can do at once see https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n for (var generated = 0; generated < size; generated += MAX_BYTES) {\n // buffer.slice automatically checks if the end is past the end of\n // the buffer so we don't have to here\n crypto.getRandomValues(bytes.slice(generated, generated + MAX_BYTES));\n }\n } else {\n crypto.getRandomValues(bytes);\n }\n }\n if (typeof cb === 'function') {\n return process.nextTick(function () {\n cb(null, bytes);\n });\n }\n return bytes;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar randombytes = require(\"randombytes\");\nfunction getRandomBytes(bytes) {\n return new Promise(function (resolve, reject) {\n randombytes(bytes, function (err, resp) {\n if (err) {\n reject(err);\n return;\n }\n resolve(resp);\n });\n });\n}\nexports.getRandomBytes = getRandomBytes;\nfunction getRandomBytesSync(bytes) {\n return randombytes(bytes);\n}\nexports.getRandomBytesSync = getRandomBytesSync;\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = this && this.__generator || function (thisArg, body) {\n var _ = {\n label: 0,\n sent: function () {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n },\n f,\n y,\n t,\n g;\n return g = {\n next: verb(0),\n \"throw\": verb(1),\n \"return\": verb(2)\n }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function () {\n return this;\n }), g;\n function verb(n) {\n return function (v) {\n return step([n, v]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [0];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [6, e];\n y = 0;\n } finally {\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n};\nfunction __export(m) {\n for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\n}\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar secp256k1_1 = require(\"secp256k1\");\nvar random_1 = require(\"./random\");\nvar SECP256K1_PRIVATE_KEY_SIZE = 32;\nfunction createPrivateKey() {\n return __awaiter(this, void 0, void 0, function () {\n var pk;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (!true) return [3 /*break*/, 2];\n return [4 /*yield*/, random_1.getRandomBytes(SECP256K1_PRIVATE_KEY_SIZE)];\n case 1:\n pk = _a.sent();\n if (secp256k1_1.privateKeyVerify(pk)) {\n return [2 /*return*/, pk];\n }\n return [3 /*break*/, 0];\n case 2:\n return [2 /*return*/];\n }\n });\n });\n}\nexports.createPrivateKey = createPrivateKey;\nfunction createPrivateKeySync() {\n while (true) {\n var pk = random_1.getRandomBytesSync(SECP256K1_PRIVATE_KEY_SIZE);\n if (secp256k1_1.privateKeyVerify(pk)) {\n return pk;\n }\n }\n}\nexports.createPrivateKeySync = createPrivateKeySync;\n__export(require(\"secp256k1\"));\n","\"use strict\";\n\n/*\nThe MIT License\n\nCopyright (c) 2016 Nick Dodson. nickdodson.com\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE\n */\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isHexString = exports.getKeys = exports.fromAscii = exports.fromUtf8 = exports.toAscii = exports.arrayContainsArray = exports.getBinarySize = exports.padToEven = exports.stripHexPrefix = exports.isHexPrefixed = void 0;\n/**\n * Returns a `Boolean` on whether or not the a `String` starts with '0x'\n * @param str the string input value\n * @return a boolean if it is or is not hex prefixed\n * @throws if the str input is not a string\n */\nfunction isHexPrefixed(str) {\n if (typeof str !== 'string') {\n throw new Error(\"[isHexPrefixed] input must be type 'string', received type \".concat(typeof str));\n }\n return str[0] === '0' && str[1] === 'x';\n}\nexports.isHexPrefixed = isHexPrefixed;\n/**\n * Removes '0x' from a given `String` if present\n * @param str the string value\n * @returns the string without 0x prefix\n */\nvar stripHexPrefix = function (str) {\n if (typeof str !== 'string') throw new Error(\"[stripHexPrefix] input must be type 'string', received \".concat(typeof str));\n return isHexPrefixed(str) ? str.slice(2) : str;\n};\nexports.stripHexPrefix = stripHexPrefix;\n/**\n * Pads a `String` to have an even length\n * @param value\n * @return output\n */\nfunction padToEven(value) {\n var a = value;\n if (typeof a !== 'string') {\n throw new Error(\"[padToEven] value must be type 'string', received \".concat(typeof a));\n }\n if (a.length % 2) a = \"0\".concat(a);\n return a;\n}\nexports.padToEven = padToEven;\n/**\n * Get the binary size of a string\n * @param str\n * @returns the number of bytes contained within the string\n */\nfunction getBinarySize(str) {\n if (typeof str !== 'string') {\n throw new Error(\"[getBinarySize] method requires input type 'string', recieved \".concat(typeof str));\n }\n return Buffer.byteLength(str, 'utf8');\n}\nexports.getBinarySize = getBinarySize;\n/**\n * Returns TRUE if the first specified array contains all elements\n * from the second one. FALSE otherwise.\n *\n * @param superset\n * @param subset\n *\n */\nfunction arrayContainsArray(superset, subset, some) {\n if (Array.isArray(superset) !== true) {\n throw new Error(\"[arrayContainsArray] method requires input 'superset' to be an array, got type '\".concat(typeof superset, \"'\"));\n }\n if (Array.isArray(subset) !== true) {\n throw new Error(\"[arrayContainsArray] method requires input 'subset' to be an array, got type '\".concat(typeof subset, \"'\"));\n }\n return subset[some ? 'some' : 'every'](function (value) {\n return superset.indexOf(value) >= 0;\n });\n}\nexports.arrayContainsArray = arrayContainsArray;\n/**\n * Should be called to get ascii from its hex representation\n *\n * @param string in hex\n * @returns ascii string representation of hex value\n */\nfunction toAscii(hex) {\n var str = '';\n var i = 0;\n var l = hex.length;\n if (hex.substring(0, 2) === '0x') i = 2;\n for (; i < l; i += 2) {\n var code = parseInt(hex.substr(i, 2), 16);\n str += String.fromCharCode(code);\n }\n return str;\n}\nexports.toAscii = toAscii;\n/**\n * Should be called to get hex representation (prefixed by 0x) of utf8 string\n *\n * @param string\n * @param optional padding\n * @returns hex representation of input string\n */\nfunction fromUtf8(stringValue) {\n var str = Buffer.from(stringValue, 'utf8');\n return \"0x\".concat(padToEven(str.toString('hex')).replace(/^0+|0+$/g, ''));\n}\nexports.fromUtf8 = fromUtf8;\n/**\n * Should be called to get hex representation (prefixed by 0x) of ascii string\n *\n * @param string\n * @param optional padding\n * @returns hex representation of input string\n */\nfunction fromAscii(stringValue) {\n var hex = '';\n for (var i = 0; i < stringValue.length; i++) {\n var code = stringValue.charCodeAt(i);\n var n = code.toString(16);\n hex += n.length < 2 ? \"0\".concat(n) : n;\n }\n return \"0x\".concat(hex);\n}\nexports.fromAscii = fromAscii;\n/**\n * Returns the keys from an array of objects.\n * @example\n * ```js\n * getKeys([{a: '1', b: '2'}, {a: '3', b: '4'}], 'a') => ['1', '3']\n *````\n * @param params\n * @param key\n * @param allowEmpty\n * @returns output just a simple array of output keys\n */\nfunction getKeys(params, key, allowEmpty) {\n if (!Array.isArray(params)) {\n throw new Error(\"[getKeys] method expects input 'params' to be an array, got \".concat(typeof params));\n }\n if (typeof key !== 'string') {\n throw new Error(\"[getKeys] method expects input 'key' to be type 'string', got \".concat(typeof params));\n }\n var result = [];\n for (var i = 0; i < params.length; i++) {\n var value = params[i][key];\n if (allowEmpty && !value) {\n value = '';\n } else if (typeof value !== 'string') {\n throw new Error(\"invalid abi - expected type 'string', received \".concat(typeof value));\n }\n result.push(value);\n }\n return result;\n}\nexports.getKeys = getKeys;\n/**\n * Is the string a hex string.\n *\n * @param value\n * @param length\n * @returns output the string is a hex string\n */\nfunction isHexString(value, length) {\n if (typeof value !== 'string' || !value.match(/^0x[0-9A-Fa-f]*$/)) return false;\n if (length && value.length !== 2 + 2 * length) return false;\n return true;\n}\nexports.isHexString = isHexString;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.assertIsString = exports.assertIsArray = exports.assertIsBuffer = exports.assertIsHexString = void 0;\nvar internal_1 = require(\"./internal\");\n/**\n * Throws if a string is not hex prefixed\n * @param {string} input string to check hex prefix of\n */\nvar assertIsHexString = function (input) {\n if (!(0, internal_1.isHexString)(input)) {\n var msg = \"This method only supports 0x-prefixed hex strings but input was: \".concat(input);\n throw new Error(msg);\n }\n};\nexports.assertIsHexString = assertIsHexString;\n/**\n * Throws if input is not a buffer\n * @param {Buffer} input value to check\n */\nvar assertIsBuffer = function (input) {\n if (!Buffer.isBuffer(input)) {\n var msg = \"This method only supports Buffer but input was: \".concat(input);\n throw new Error(msg);\n }\n};\nexports.assertIsBuffer = assertIsBuffer;\n/**\n * Throws if input is not an array\n * @param {number[]} input value to check\n */\nvar assertIsArray = function (input) {\n if (!Array.isArray(input)) {\n var msg = \"This method only supports number arrays but input was: \".concat(input);\n throw new Error(msg);\n }\n};\nexports.assertIsArray = assertIsArray;\n/**\n * Throws if input is not a string\n * @param {string} input value to check\n */\nvar assertIsString = function (input) {\n if (typeof input !== 'string') {\n var msg = \"This method only supports strings but input was: \".concat(input);\n throw new Error(msg);\n }\n};\nexports.assertIsString = assertIsString;\n","\"use strict\";\n\nvar __values = this && this.__values || function (o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nvar __read = this && this.__read || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bufArrToArr = exports.arrToBufArr = exports.validateNoLeadingZeroes = exports.baToJSON = exports.toUtf8 = exports.addHexPrefix = exports.toUnsigned = exports.fromSigned = exports.bufferToHex = exports.bufferToInt = exports.toBuffer = exports.unpadHexString = exports.unpadArray = exports.unpadBuffer = exports.setLengthRight = exports.setLengthLeft = exports.zeros = exports.intToBuffer = exports.intToHex = void 0;\nvar externals_1 = require(\"./externals\");\nvar internal_1 = require(\"./internal\");\nvar helpers_1 = require(\"./helpers\");\n/**\n * Converts a `Number` into a hex `String`\n * @param {Number} i\n * @return {String}\n */\nvar intToHex = function (i) {\n if (!Number.isSafeInteger(i) || i < 0) {\n throw new Error(\"Received an invalid integer type: \".concat(i));\n }\n return \"0x\".concat(i.toString(16));\n};\nexports.intToHex = intToHex;\n/**\n * Converts an `Number` to a `Buffer`\n * @param {Number} i\n * @return {Buffer}\n */\nvar intToBuffer = function (i) {\n var hex = (0, exports.intToHex)(i);\n return Buffer.from((0, internal_1.padToEven)(hex.slice(2)), 'hex');\n};\nexports.intToBuffer = intToBuffer;\n/**\n * Returns a buffer filled with 0s.\n * @param bytes the number of bytes the buffer should be\n */\nvar zeros = function (bytes) {\n return Buffer.allocUnsafe(bytes).fill(0);\n};\nexports.zeros = zeros;\n/**\n * Pads a `Buffer` with zeros till it has `length` bytes.\n * Truncates the beginning or end of input if its length exceeds `length`.\n * @param msg the value to pad (Buffer)\n * @param length the number of bytes the output should be\n * @param right whether to start padding form the left or right\n * @return (Buffer)\n */\nvar setLength = function (msg, length, right) {\n var buf = (0, exports.zeros)(length);\n if (right) {\n if (msg.length < length) {\n msg.copy(buf);\n return buf;\n }\n return msg.slice(0, length);\n } else {\n if (msg.length < length) {\n msg.copy(buf, length - msg.length);\n return buf;\n }\n return msg.slice(-length);\n }\n};\n/**\n * Left Pads a `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @param msg the value to pad (Buffer)\n * @param length the number of bytes the output should be\n * @return (Buffer)\n */\nvar setLengthLeft = function (msg, length) {\n (0, helpers_1.assertIsBuffer)(msg);\n return setLength(msg, length, false);\n};\nexports.setLengthLeft = setLengthLeft;\n/**\n * Right Pads a `Buffer` with trailing zeros till it has `length` bytes.\n * it truncates the end if it exceeds.\n * @param msg the value to pad (Buffer)\n * @param length the number of bytes the output should be\n * @return (Buffer)\n */\nvar setLengthRight = function (msg, length) {\n (0, helpers_1.assertIsBuffer)(msg);\n return setLength(msg, length, true);\n};\nexports.setLengthRight = setLengthRight;\n/**\n * Trims leading zeros from a `Buffer`, `String` or `Number[]`.\n * @param a (Buffer|Array|String)\n * @return (Buffer|Array|String)\n */\nvar stripZeros = function (a) {\n var first = a[0];\n while (a.length > 0 && first.toString() === '0') {\n a = a.slice(1);\n first = a[0];\n }\n return a;\n};\n/**\n * Trims leading zeros from a `Buffer`.\n * @param a (Buffer)\n * @return (Buffer)\n */\nvar unpadBuffer = function (a) {\n (0, helpers_1.assertIsBuffer)(a);\n return stripZeros(a);\n};\nexports.unpadBuffer = unpadBuffer;\n/**\n * Trims leading zeros from an `Array` (of numbers).\n * @param a (number[])\n * @return (number[])\n */\nvar unpadArray = function (a) {\n (0, helpers_1.assertIsArray)(a);\n return stripZeros(a);\n};\nexports.unpadArray = unpadArray;\n/**\n * Trims leading zeros from a hex-prefixed `String`.\n * @param a (String)\n * @return (String)\n */\nvar unpadHexString = function (a) {\n (0, helpers_1.assertIsHexString)(a);\n a = (0, internal_1.stripHexPrefix)(a);\n return stripZeros(a);\n};\nexports.unpadHexString = unpadHexString;\n/**\n * Attempts to turn a value into a `Buffer`.\n * Inputs supported: `Buffer`, `String` (hex-prefixed), `Number`, null/undefined, `BN` and other objects\n * with a `toArray()` or `toBuffer()` method.\n * @param v the value\n */\nvar toBuffer = function (v) {\n if (v === null || v === undefined) {\n return Buffer.allocUnsafe(0);\n }\n if (Buffer.isBuffer(v)) {\n return Buffer.from(v);\n }\n if (Array.isArray(v) || v instanceof Uint8Array) {\n return Buffer.from(v);\n }\n if (typeof v === 'string') {\n if (!(0, internal_1.isHexString)(v)) {\n throw new Error(\"Cannot convert string to buffer. toBuffer only supports 0x-prefixed hex strings and this string was given: \".concat(v));\n }\n return Buffer.from((0, internal_1.padToEven)((0, internal_1.stripHexPrefix)(v)), 'hex');\n }\n if (typeof v === 'number') {\n return (0, exports.intToBuffer)(v);\n }\n if (externals_1.BN.isBN(v)) {\n if (v.isNeg()) {\n throw new Error(\"Cannot convert negative BN to buffer. Given: \".concat(v));\n }\n return v.toArrayLike(Buffer);\n }\n if (v.toArray) {\n // converts a BN to a Buffer\n return Buffer.from(v.toArray());\n }\n if (v.toBuffer) {\n return Buffer.from(v.toBuffer());\n }\n throw new Error('invalid type');\n};\nexports.toBuffer = toBuffer;\n/**\n * Converts a `Buffer` to a `Number`.\n * @param buf `Buffer` object to convert\n * @throws If the input number exceeds 53 bits.\n */\nvar bufferToInt = function (buf) {\n return new externals_1.BN((0, exports.toBuffer)(buf)).toNumber();\n};\nexports.bufferToInt = bufferToInt;\n/**\n * Converts a `Buffer` into a `0x`-prefixed hex `String`.\n * @param buf `Buffer` object to convert\n */\nvar bufferToHex = function (buf) {\n buf = (0, exports.toBuffer)(buf);\n return '0x' + buf.toString('hex');\n};\nexports.bufferToHex = bufferToHex;\n/**\n * Interprets a `Buffer` as a signed integer and returns a `BN`. Assumes 256-bit numbers.\n * @param num Signed integer value\n */\nvar fromSigned = function (num) {\n return new externals_1.BN(num).fromTwos(256);\n};\nexports.fromSigned = fromSigned;\n/**\n * Converts a `BN` to an unsigned integer and returns it as a `Buffer`. Assumes 256-bit numbers.\n * @param num\n */\nvar toUnsigned = function (num) {\n return Buffer.from(num.toTwos(256).toArray());\n};\nexports.toUnsigned = toUnsigned;\n/**\n * Adds \"0x\" to a given `String` if it does not already start with \"0x\".\n */\nvar addHexPrefix = function (str) {\n if (typeof str !== 'string') {\n return str;\n }\n return (0, internal_1.isHexPrefixed)(str) ? str : '0x' + str;\n};\nexports.addHexPrefix = addHexPrefix;\n/**\n * Returns the utf8 string representation from a hex string.\n *\n * Examples:\n *\n * Input 1: '657468657265756d000000000000000000000000000000000000000000000000'\n * Input 2: '657468657265756d'\n * Input 3: '000000000000000000000000000000000000000000000000657468657265756d'\n *\n * Output (all 3 input variants): 'ethereum'\n *\n * Note that this method is not intended to be used with hex strings\n * representing quantities in both big endian or little endian notation.\n *\n * @param string Hex string, should be `0x` prefixed\n * @return Utf8 string\n */\nvar toUtf8 = function (hex) {\n var zerosRegexp = /^(00)+|(00)+$/g;\n hex = (0, internal_1.stripHexPrefix)(hex);\n if (hex.length % 2 !== 0) {\n throw new Error('Invalid non-even hex string input for toUtf8() provided');\n }\n var bufferVal = Buffer.from(hex.replace(zerosRegexp, ''), 'hex');\n return bufferVal.toString('utf8');\n};\nexports.toUtf8 = toUtf8;\n/**\n * Converts a `Buffer` or `Array` to JSON.\n * @param ba (Buffer|Array)\n * @return (Array|String|null)\n */\nvar baToJSON = function (ba) {\n if (Buffer.isBuffer(ba)) {\n return \"0x\".concat(ba.toString('hex'));\n } else if (ba instanceof Array) {\n var array = [];\n for (var i = 0; i < ba.length; i++) {\n array.push((0, exports.baToJSON)(ba[i]));\n }\n return array;\n }\n};\nexports.baToJSON = baToJSON;\n/**\n * Checks provided Buffers for leading zeroes and throws if found.\n *\n * Examples:\n *\n * Valid values: 0x1, 0x, 0x01, 0x1234\n * Invalid values: 0x0, 0x00, 0x001, 0x0001\n *\n * Note: This method is useful for validating that RLP encoded integers comply with the rule that all\n * integer values encoded to RLP must be in the most compact form and contain no leading zero bytes\n * @param values An object containing string keys and Buffer values\n * @throws if any provided value is found to have leading zero bytes\n */\nvar validateNoLeadingZeroes = function (values) {\n var e_1, _a;\n try {\n for (var _b = __values(Object.entries(values)), _c = _b.next(); !_c.done; _c = _b.next()) {\n var _d = __read(_c.value, 2),\n k = _d[0],\n v = _d[1];\n if (v !== undefined && v.length > 0 && v[0] === 0) {\n throw new Error(\"\".concat(k, \" cannot have leading zeroes, received: \").concat(v.toString('hex')));\n }\n }\n } catch (e_1_1) {\n e_1 = {\n error: e_1_1\n };\n } finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n } finally {\n if (e_1) throw e_1.error;\n }\n }\n};\nexports.validateNoLeadingZeroes = validateNoLeadingZeroes;\nfunction arrToBufArr(arr) {\n if (!Array.isArray(arr)) {\n return Buffer.from(arr);\n }\n return arr.map(function (a) {\n return arrToBufArr(a);\n });\n}\nexports.arrToBufArr = arrToBufArr;\nfunction bufArrToArr(arr) {\n if (!Array.isArray(arr)) {\n return Uint8Array.from(arr !== null && arr !== void 0 ? arr : []);\n }\n return arr.map(function (a) {\n return bufArrToArr(a);\n });\n}\nexports.bufArrToArr = bufArrToArr;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nfunction createHashFunction(hashConstructor) {\n return function (msg) {\n var hash = hashConstructor();\n hash.update(msg);\n return Buffer.from(hash.digest());\n };\n}\nexports.createHashFunction = createHashFunction;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null;\nvar ReflectApply = R && typeof R.apply === 'function' ? R.apply : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n};\nvar ReflectOwnKeys;\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys;\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target).concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n};\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function () {\n return defaultMaxListeners;\n },\n set: function (arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\nEventEmitter.init = function () {\n if (this._events === undefined || this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined) return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = type === 'error';\n var events = this._events;\n if (events !== undefined) doError = doError && events.error === undefined;else if (!doError) return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0) er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n var handler = events[type];\n if (handler === undefined) return false;\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i) ReflectApply(listeners[i], this, args);\n }\n return true;\n};\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n checkListener(listener);\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type, listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] = prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' + existing.length + ' ' + String(type) + ' listeners ' + 'added. Use emitter.setMaxListeners() to ' + 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n return target;\n}\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\nEventEmitter.prototype.prependListener = function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n};\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0) return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\nfunction _onceWrap(target, type, listener) {\n var state = {\n fired: false,\n wrapFn: undefined,\n target: target,\n type: type,\n listener: listener\n };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\nEventEmitter.prototype.prependOnceListener = function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n};\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener = function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n checkListener(listener);\n events = this._events;\n if (events === undefined) return this;\n list = events[type];\n if (list === undefined) return this;\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0) this._events = Object.create(null);else {\n delete events[type];\n if (events.removeListener) this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n if (position < 0) return this;\n if (position === 0) list.shift();else {\n spliceOne(list, position);\n }\n if (list.length === 1) events[type] = list[0];\n if (events.removeListener !== undefined) this.emit('removeListener', type, originalListener || listener);\n }\n return this;\n};\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(type) {\n var listeners, events, i;\n events = this._events;\n if (events === undefined) return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0) this._events = Object.create(null);else delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n listeners = events[type];\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n return this;\n};\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n if (events === undefined) return [];\n var evlistener = events[type];\n if (evlistener === undefined) return [];\n if (typeof evlistener === 'function') return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n return unwrap ? unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\nEventEmitter.listenerCount = function (emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n if (events !== undefined) {\n var evlistener = events[type];\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n return 0;\n}\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i) copy[i] = arr[i];\n return copy;\n}\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++) list[index] = list[index + 1];\n list.pop();\n}\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n }\n ;\n eventTargetAgnosticAddListener(emitter, name, resolver, {\n once: true\n });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, {\n once: true\n });\n }\n });\n}\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}","module.exports = require('events').EventEmitter;","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors || function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n};\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function (f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function (x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s':\n return String(args[i++]);\n case '%d':\n return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function (fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function () {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n return deprecated;\n};\nvar debugs = {};\nvar debugEnvRegex = /^$/;\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&').replace(/\\*/g, '.*').replace(/,/g, '$|^').toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function (set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function () {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function () {};\n }\n }\n return debugs[set];\n};\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold': [1, 22],\n 'italic': [3, 23],\n 'underline': [4, 24],\n 'inverse': [7, 27],\n 'white': [37, 39],\n 'grey': [90, 39],\n 'black': [30, 39],\n 'blue': [34, 39],\n 'cyan': [36, 39],\n 'green': [32, 39],\n 'magenta': [35, 39],\n 'red': [31, 39],\n 'yellow': [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str + '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\nfunction arrayToHash(array) {\n var hash = {};\n array.forEach(function (val, idx) {\n hash[val] = true;\n });\n return hash;\n}\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect && value && isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value) && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n var base = '',\n array = false,\n braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n ctx.seen.push(value);\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function (key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n ctx.seen.pop();\n return reduceToSingleString(output, base, braces);\n}\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value)) return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '').replace(/'/g, \"\\\\'\").replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value)) return ctx.stylize('' + value, 'number');\n if (isBoolean(value)) return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value)) return ctx.stylize('null', 'null');\n}\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function (key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, key, true));\n }\n });\n return output;\n}\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || {\n value: value[key]\n };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function (line) {\n return ' ' + line;\n }).join('\\n').slice(2);\n } else {\n str = '\\n' + str.split('\\n').map(function (line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.slice(1, -1);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\").replace(/\\\\\"/g, '\"').replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n return name + ': ' + str;\n}\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function (prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n if (length > 60) {\n return braces[0] + (base === '' ? '' : base + '\\n ') + ' ' + output.join(',\\n ') + ' ' + braces[1];\n }\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\nfunction isError(e) {\n return isObject(e) && (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\nfunction isPrimitive(arg) {\n return arg === null || typeof arg === 'boolean' || typeof arg === 'number' || typeof arg === 'string' || typeof arg === 'symbol' ||\n // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\nexports.isBuffer = require('./support/isBuffer');\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()), pad(d.getMinutes()), pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function () {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\nexports._extend = function (origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function') throw new TypeError('The \"original\" argument must be of type Function');\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn,\n enumerable: false,\n writable: false,\n configurable: true\n });\n return fn;\n }\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n return promise;\n }\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn,\n enumerable: false,\n writable: false,\n configurable: true\n });\n return Object.defineProperties(fn, getOwnPropertyDescriptors(original));\n};\nexports.promisify.custom = kCustomPromisifiedSymbol;\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function () {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args).then(function (ret) {\n process.nextTick(cb.bind(null, null, ret));\n }, function (rej) {\n process.nextTick(callbackifyOnRejected.bind(null, rej, cb));\n });\n }\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified, getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;","'use strict';\n\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _objectSpread(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n _defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nfunction _defineProperty(obj, key, value) {\n key = _toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return typeof key === \"symbol\" ? key : String(key);\n}\nfunction _toPrimitive(input, hint) {\n if (typeof input !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (typeof res !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nvar _require = require('buffer'),\n Buffer = _require.Buffer;\nvar _require2 = require('util'),\n inspect = _require2.inspect;\nvar custom = inspect && inspect.custom || 'inspect';\nfunction copyBuffer(src, target, offset) {\n Buffer.prototype.copy.call(src, target, offset);\n}\nmodule.exports = /*#__PURE__*/function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n _createClass(BufferList, [{\n key: \"push\",\n value: function push(v) {\n var entry = {\n data: v,\n next: null\n };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n }\n }, {\n key: \"unshift\",\n value: function unshift(v) {\n var entry = {\n data: v,\n next: this.head\n };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n }\n }, {\n key: \"shift\",\n value: function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n }\n }, {\n key: \"clear\",\n value: function clear() {\n this.head = this.tail = null;\n this.length = 0;\n }\n }, {\n key: \"join\",\n value: function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) ret += s + p.data;\n return ret;\n }\n }, {\n key: \"concat\",\n value: function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n }\n\n // Consumes a specified amount of bytes or characters from the buffered data.\n }, {\n key: \"consume\",\n value: function consume(n, hasStrings) {\n var ret;\n if (n < this.head.data.length) {\n // `slice` is the same for buffers and strings.\n ret = this.head.data.slice(0, n);\n this.head.data = this.head.data.slice(n);\n } else if (n === this.head.data.length) {\n // First chunk is a perfect match.\n ret = this.shift();\n } else {\n // Result spans more than one buffer.\n ret = hasStrings ? this._getString(n) : this._getBuffer(n);\n }\n return ret;\n }\n }, {\n key: \"first\",\n value: function first() {\n return this.head.data;\n }\n\n // Consumes a specified amount of characters from the buffered data.\n }, {\n key: \"_getString\",\n value: function _getString(n) {\n var p = this.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Consumes a specified amount of bytes from the buffered data.\n }, {\n key: \"_getBuffer\",\n value: function _getBuffer(n) {\n var ret = Buffer.allocUnsafe(n);\n var p = this.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) this.head = p.next;else this.head = this.tail = null;\n } else {\n this.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n this.length -= c;\n return ret;\n }\n\n // Make sure the linked list only shows the minimal necessary information.\n }, {\n key: custom,\n value: function value(_, options) {\n return inspect(this, _objectSpread(_objectSpread({}, options), {}, {\n // Only inspect one level.\n depth: 0,\n // It should not recurse.\n customInspect: false\n }));\n }\n }]);\n return BufferList;\n}();","'use strict';\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err) {\n if (!this._writableState) {\n process.nextTick(emitErrorNT, this, err);\n } else if (!this._writableState.errorEmitted) {\n this._writableState.errorEmitted = true;\n process.nextTick(emitErrorNT, this, err);\n }\n }\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n if (!_this._writableState) {\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else if (!_this._writableState.errorEmitted) {\n _this._writableState.errorEmitted = true;\n process.nextTick(emitErrorAndCloseNT, _this, err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n } else if (cb) {\n process.nextTick(emitCloseNT, _this);\n cb(err);\n } else {\n process.nextTick(emitCloseNT, _this);\n }\n });\n return this;\n}\nfunction emitErrorAndCloseNT(self, err) {\n emitErrorNT(self, err);\n emitCloseNT(self);\n}\nfunction emitCloseNT(self) {\n if (self._writableState && !self._writableState.emitClose) return;\n if (self._readableState && !self._readableState.emitClose) return;\n self.emit('close');\n}\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finalCalled = false;\n this._writableState.prefinished = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\nfunction errorOrDestroy(stream, err) {\n // We have tests that rely on errors being emitted\n // in the same tick, so changing this is semver major.\n // For now when you opt-in to autoDestroy we allow\n // the error to be emitted nextTick. In a future\n // semver major update we should change the default to this.\n\n var rState = stream._readableState;\n var wState = stream._writableState;\n if (rState && rState.autoDestroy || wState && wState.autoDestroy) stream.destroy(err);else stream.emit('error', err);\n}\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy,\n errorOrDestroy: errorOrDestroy\n};","'use strict';\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\nvar codes = {};\nfunction createErrorType(code, message, Base) {\n if (!Base) {\n Base = Error;\n }\n function getMessage(arg1, arg2, arg3) {\n if (typeof message === 'string') {\n return message;\n } else {\n return message(arg1, arg2, arg3);\n }\n }\n var NodeError = /*#__PURE__*/\n function (_Base) {\n _inheritsLoose(NodeError, _Base);\n function NodeError(arg1, arg2, arg3) {\n return _Base.call(this, getMessage(arg1, arg2, arg3)) || this;\n }\n return NodeError;\n }(Base);\n NodeError.prototype.name = Base.name;\n NodeError.prototype.code = code;\n codes[code] = NodeError;\n} // https://github.com/nodejs/node/blob/v10.8.0/lib/internal/errors.js\n\nfunction oneOf(expected, thing) {\n if (Array.isArray(expected)) {\n var len = expected.length;\n expected = expected.map(function (i) {\n return String(i);\n });\n if (len > 2) {\n return \"one of \".concat(thing, \" \").concat(expected.slice(0, len - 1).join(', '), \", or \") + expected[len - 1];\n } else if (len === 2) {\n return \"one of \".concat(thing, \" \").concat(expected[0], \" or \").concat(expected[1]);\n } else {\n return \"of \".concat(thing, \" \").concat(expected[0]);\n }\n } else {\n return \"of \".concat(thing, \" \").concat(String(expected));\n }\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith\n\nfunction startsWith(str, search, pos) {\n return str.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith\n\nfunction endsWith(str, search, this_len) {\n if (this_len === undefined || this_len > str.length) {\n this_len = str.length;\n }\n return str.substring(this_len - search.length, this_len) === search;\n} // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/includes\n\nfunction includes(str, search, start) {\n if (typeof start !== 'number') {\n start = 0;\n }\n if (start + search.length > str.length) {\n return false;\n } else {\n return str.indexOf(search, start) !== -1;\n }\n}\ncreateErrorType('ERR_INVALID_OPT_VALUE', function (name, value) {\n return 'The value \"' + value + '\" is invalid for option \"' + name + '\"';\n}, TypeError);\ncreateErrorType('ERR_INVALID_ARG_TYPE', function (name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n var determiner;\n if (typeof expected === 'string' && startsWith(expected, 'not ')) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n } else {\n determiner = 'must be';\n }\n var msg;\n if (endsWith(name, ' argument')) {\n // For cases like 'first argument'\n msg = \"The \".concat(name, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n } else {\n var type = includes(name, '.') ? 'property' : 'argument';\n msg = \"The \\\"\".concat(name, \"\\\" \").concat(type, \" \").concat(determiner, \" \").concat(oneOf(expected, 'type'));\n }\n msg += \". Received type \".concat(typeof actual);\n return msg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_PUSH_AFTER_EOF', 'stream.push() after EOF');\ncreateErrorType('ERR_METHOD_NOT_IMPLEMENTED', function (name) {\n return 'The ' + name + ' method is not implemented';\n});\ncreateErrorType('ERR_STREAM_PREMATURE_CLOSE', 'Premature close');\ncreateErrorType('ERR_STREAM_DESTROYED', function (name) {\n return 'Cannot call ' + name + ' after a stream was destroyed';\n});\ncreateErrorType('ERR_MULTIPLE_CALLBACK', 'Callback called multiple times');\ncreateErrorType('ERR_STREAM_CANNOT_PIPE', 'Cannot pipe, not readable');\ncreateErrorType('ERR_STREAM_WRITE_AFTER_END', 'write after end');\ncreateErrorType('ERR_STREAM_NULL_VALUES', 'May not write null values to stream', TypeError);\ncreateErrorType('ERR_UNKNOWN_ENCODING', function (arg) {\n return 'Unknown encoding: ' + arg;\n}, TypeError);\ncreateErrorType('ERR_STREAM_UNSHIFT_AFTER_END_EVENT', 'stream.unshift() after end event');\nmodule.exports.codes = codes;","'use strict';\n\nvar ERR_INVALID_OPT_VALUE = require('../../../errors').codes.ERR_INVALID_OPT_VALUE;\nfunction highWaterMarkFrom(options, isDuplex, duplexKey) {\n return options.highWaterMark != null ? options.highWaterMark : isDuplex ? options[duplexKey] : null;\n}\nfunction getHighWaterMark(state, options, duplexKey, isDuplex) {\n var hwm = highWaterMarkFrom(options, isDuplex, duplexKey);\n if (hwm != null) {\n if (!(isFinite(hwm) && Math.floor(hwm) === hwm) || hwm < 0) {\n var name = isDuplex ? duplexKey : 'highWaterMark';\n throw new ERR_INVALID_OPT_VALUE(name, hwm);\n }\n return Math.floor(hwm);\n }\n\n // Default value\n return state.objectMode ? 16 : 16 * 1024;\n}\nmodule.exports = {\n getHighWaterMark: getHighWaterMark\n};","/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate(fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config(name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/* */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_STREAM_CANNOT_PIPE = _require$codes.ERR_STREAM_CANNOT_PIPE,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED,\n ERR_STREAM_NULL_VALUES = _require$codes.ERR_STREAM_NULL_VALUES,\n ERR_STREAM_WRITE_AFTER_END = _require$codes.ERR_STREAM_WRITE_AFTER_END,\n ERR_UNKNOWN_ENCODING = _require$codes.ERR_UNKNOWN_ENCODING;\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nrequire('inherits')(Writable, Stream);\nfunction nop() {}\nfunction WritableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream,\n // e.g. options.readableObjectMode vs. options.writableObjectMode, etc.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n this.highWaterMark = getHighWaterMark(this, options, 'writableHighWaterMark', isDuplex);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'finish' (and potentially 'end')\n this.autoDestroy = !!options.autoDestroy;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function writableStateBufferGetter() {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function value(object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function realHasInstance(object) {\n return object instanceof this;\n };\n}\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the WritableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n if (!isDuplex && !realHasInstance.call(Writable, this)) return new Writable(options);\n this._writableState = new WritableState(options, this, isDuplex);\n\n // legacy.\n this.writable = true;\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n if (typeof options.writev === 'function') this._writev = options.writev;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n if (typeof options.final === 'function') this._final = options.final;\n }\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n errorOrDestroy(this, new ERR_STREAM_CANNOT_PIPE());\n};\nfunction writeAfterEnd(stream, cb) {\n var er = new ERR_STREAM_WRITE_AFTER_END();\n // TODO: defer error events consistently everywhere, not just the cb\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var er;\n if (chunk === null) {\n er = new ERR_STREAM_NULL_VALUES();\n } else if (typeof chunk !== 'string' && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer'], chunk);\n }\n if (er) {\n errorOrDestroy(stream, er);\n process.nextTick(cb, er);\n return false;\n }\n return true;\n}\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n if (typeof cb !== 'function') cb = nop;\n if (state.ending) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n return ret;\n};\nWritable.prototype.cork = function () {\n this._writableState.corked++;\n};\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n if (state.corked) {\n state.corked--;\n if (!state.writing && !state.corked && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new ERR_UNKNOWN_ENCODING(encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n state.length += len;\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n return ret;\n}\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (state.destroyed) state.onwrite(new ERR_STREAM_DESTROYED('write'));else if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n process.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n process.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n errorOrDestroy(stream, er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n if (typeof cb !== 'function') throw new ERR_MULTIPLE_CALLBACK();\n onwriteStateUpdate(state);\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state) || stream.destroyed;\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n if (sync) {\n process.nextTick(afterWrite, stream, state, finished, cb);\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n if (entry === null) state.lastBufferedRequest = null;\n }\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_write()'));\n};\nWritable.prototype._writev = null;\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending) endWritable(this, state, cb);\n return this;\n};\nObject.defineProperty(Writable.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n errorOrDestroy(stream, err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function' && !state.destroyed) {\n state.pendingcb++;\n state.finalCalled = true;\n process.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the readable side is ready for autoDestroy as well\n var rState = stream._readableState;\n if (!rState || rState.autoDestroy && rState.endEmitted) {\n stream.destroy();\n }\n }\n }\n }\n return need;\n}\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) process.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n\n // reuse the free corkReq.\n state.corkedRequestsFree.next = corkReq;\n}\nObject.defineProperty(Writable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n cb(err);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) keys.push(key);\n return keys;\n};\n/**/\n\nmodule.exports = Duplex;\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\nrequire('inherits')(Duplex, Readable);\n{\n // Allow the keys array to be GC'ed.\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n Readable.call(this, options);\n Writable.call(this, options);\n this.allowHalfOpen = true;\n if (options) {\n if (options.readable === false) this.readable = false;\n if (options.writable === false) this.writable = false;\n if (options.allowHalfOpen === false) {\n this.allowHalfOpen = false;\n this.once('end', onend);\n }\n }\n}\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.highWaterMark;\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState && this._writableState.getBuffer();\n }\n});\nObject.defineProperty(Duplex.prototype, 'writableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._writableState.length;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // If the writable side ended, then we're ok.\n if (this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n process.nextTick(onEndNT, this);\n}\nfunction onEndNT(self) {\n self.end();\n}\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});","/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer');\nvar Buffer = buffer.Buffer;\n\n// alternative to using Object.keys for old browsers\nfunction copyProps(src, dst) {\n for (var key in src) {\n dst[key] = src[key];\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer;\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports);\n exports.Buffer = SafeBuffer;\n}\nfunction SafeBuffer(arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length);\n}\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer);\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number');\n }\n return Buffer(arg, encodingOrOffset, length);\n};\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number');\n }\n var buf = Buffer(size);\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding);\n } else {\n buf.fill(fill);\n }\n } else {\n buf.fill(0);\n }\n return buf;\n};\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number');\n }\n return Buffer(size);\n};\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number');\n }\n return buffer.SlowBuffer(size);\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\nvar Buffer = require('safe-buffer').Buffer;\n/**/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n case 'raw':\n return true;\n default:\n return false;\n }\n};\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n}\n;\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","// Ported from https://github.com/mafintosh/end-of-stream with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar ERR_STREAM_PREMATURE_CLOSE = require('../../../errors').codes.ERR_STREAM_PREMATURE_CLOSE;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n callback.apply(this, args);\n };\n}\nfunction noop() {}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction eos(stream, opts, callback) {\n if (typeof opts === 'function') return eos(stream, null, opts);\n if (!opts) opts = {};\n callback = once(callback || noop);\n var readable = opts.readable || opts.readable !== false && stream.readable;\n var writable = opts.writable || opts.writable !== false && stream.writable;\n var onlegacyfinish = function onlegacyfinish() {\n if (!stream.writable) onfinish();\n };\n var writableEnded = stream._writableState && stream._writableState.finished;\n var onfinish = function onfinish() {\n writable = false;\n writableEnded = true;\n if (!readable) callback.call(stream);\n };\n var readableEnded = stream._readableState && stream._readableState.endEmitted;\n var onend = function onend() {\n readable = false;\n readableEnded = true;\n if (!writable) callback.call(stream);\n };\n var onerror = function onerror(err) {\n callback.call(stream, err);\n };\n var onclose = function onclose() {\n var err;\n if (readable && !readableEnded) {\n if (!stream._readableState || !stream._readableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n if (writable && !writableEnded) {\n if (!stream._writableState || !stream._writableState.ended) err = new ERR_STREAM_PREMATURE_CLOSE();\n return callback.call(stream, err);\n }\n };\n var onrequest = function onrequest() {\n stream.req.on('finish', onfinish);\n };\n if (isRequest(stream)) {\n stream.on('complete', onfinish);\n stream.on('abort', onclose);\n if (stream.req) onrequest();else stream.on('request', onrequest);\n } else if (writable && !stream._writableState) {\n // legacy streams\n stream.on('end', onlegacyfinish);\n stream.on('close', onlegacyfinish);\n }\n stream.on('end', onend);\n stream.on('finish', onfinish);\n if (opts.error !== false) stream.on('error', onerror);\n stream.on('close', onclose);\n return function () {\n stream.removeListener('complete', onfinish);\n stream.removeListener('abort', onclose);\n stream.removeListener('request', onrequest);\n if (stream.req) stream.req.removeListener('finish', onfinish);\n stream.removeListener('end', onlegacyfinish);\n stream.removeListener('close', onlegacyfinish);\n stream.removeListener('finish', onfinish);\n stream.removeListener('end', onend);\n stream.removeListener('error', onerror);\n stream.removeListener('close', onclose);\n };\n}\nmodule.exports = eos;","'use strict';\n\nvar _Object$setPrototypeO;\nfunction _defineProperty(obj, key, value) {\n key = _toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return typeof key === \"symbol\" ? key : String(key);\n}\nfunction _toPrimitive(input, hint) {\n if (typeof input !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (typeof res !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nvar finished = require('./end-of-stream');\nvar kLastResolve = Symbol('lastResolve');\nvar kLastReject = Symbol('lastReject');\nvar kError = Symbol('error');\nvar kEnded = Symbol('ended');\nvar kLastPromise = Symbol('lastPromise');\nvar kHandlePromise = Symbol('handlePromise');\nvar kStream = Symbol('stream');\nfunction createIterResult(value, done) {\n return {\n value: value,\n done: done\n };\n}\nfunction readAndResolve(iter) {\n var resolve = iter[kLastResolve];\n if (resolve !== null) {\n var data = iter[kStream].read();\n // we defer if data is null\n // we can be expecting either 'end' or\n // 'error'\n if (data !== null) {\n iter[kLastPromise] = null;\n iter[kLastResolve] = null;\n iter[kLastReject] = null;\n resolve(createIterResult(data, false));\n }\n }\n}\nfunction onReadable(iter) {\n // we wait for the next tick, because it might\n // emit an error with process.nextTick\n process.nextTick(readAndResolve, iter);\n}\nfunction wrapForNext(lastPromise, iter) {\n return function (resolve, reject) {\n lastPromise.then(function () {\n if (iter[kEnded]) {\n resolve(createIterResult(undefined, true));\n return;\n }\n iter[kHandlePromise](resolve, reject);\n }, reject);\n };\n}\nvar AsyncIteratorPrototype = Object.getPrototypeOf(function () {});\nvar ReadableStreamAsyncIteratorPrototype = Object.setPrototypeOf((_Object$setPrototypeO = {\n get stream() {\n return this[kStream];\n },\n next: function next() {\n var _this = this;\n // if we have detected an error in the meanwhile\n // reject straight away\n var error = this[kError];\n if (error !== null) {\n return Promise.reject(error);\n }\n if (this[kEnded]) {\n return Promise.resolve(createIterResult(undefined, true));\n }\n if (this[kStream].destroyed) {\n // We need to defer via nextTick because if .destroy(err) is\n // called, the error will be emitted via nextTick, and\n // we cannot guarantee that there is no error lingering around\n // waiting to be emitted.\n return new Promise(function (resolve, reject) {\n process.nextTick(function () {\n if (_this[kError]) {\n reject(_this[kError]);\n } else {\n resolve(createIterResult(undefined, true));\n }\n });\n });\n }\n\n // if we have multiple next() calls\n // we will wait for the previous Promise to finish\n // this logic is optimized to support for await loops,\n // where next() is only called once at a time\n var lastPromise = this[kLastPromise];\n var promise;\n if (lastPromise) {\n promise = new Promise(wrapForNext(lastPromise, this));\n } else {\n // fast path needed to support multiple this.push()\n // without triggering the next() queue\n var data = this[kStream].read();\n if (data !== null) {\n return Promise.resolve(createIterResult(data, false));\n }\n promise = new Promise(this[kHandlePromise]);\n }\n this[kLastPromise] = promise;\n return promise;\n }\n}, _defineProperty(_Object$setPrototypeO, Symbol.asyncIterator, function () {\n return this;\n}), _defineProperty(_Object$setPrototypeO, \"return\", function _return() {\n var _this2 = this;\n // destroy(err, cb) is a private API\n // we can guarantee we have that here, because we control the\n // Readable class this is attached to\n return new Promise(function (resolve, reject) {\n _this2[kStream].destroy(null, function (err) {\n if (err) {\n reject(err);\n return;\n }\n resolve(createIterResult(undefined, true));\n });\n });\n}), _Object$setPrototypeO), AsyncIteratorPrototype);\nvar createReadableStreamAsyncIterator = function createReadableStreamAsyncIterator(stream) {\n var _Object$create;\n var iterator = Object.create(ReadableStreamAsyncIteratorPrototype, (_Object$create = {}, _defineProperty(_Object$create, kStream, {\n value: stream,\n writable: true\n }), _defineProperty(_Object$create, kLastResolve, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kLastReject, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kError, {\n value: null,\n writable: true\n }), _defineProperty(_Object$create, kEnded, {\n value: stream._readableState.endEmitted,\n writable: true\n }), _defineProperty(_Object$create, kHandlePromise, {\n value: function value(resolve, reject) {\n var data = iterator[kStream].read();\n if (data) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(data, false));\n } else {\n iterator[kLastResolve] = resolve;\n iterator[kLastReject] = reject;\n }\n },\n writable: true\n }), _Object$create));\n iterator[kLastPromise] = null;\n finished(stream, function (err) {\n if (err && err.code !== 'ERR_STREAM_PREMATURE_CLOSE') {\n var reject = iterator[kLastReject];\n // reject if we are waiting for data in the Promise\n // returned by next() and store the error\n if (reject !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n reject(err);\n }\n iterator[kError] = err;\n return;\n }\n var resolve = iterator[kLastResolve];\n if (resolve !== null) {\n iterator[kLastPromise] = null;\n iterator[kLastResolve] = null;\n iterator[kLastReject] = null;\n resolve(createIterResult(undefined, true));\n }\n iterator[kEnded] = true;\n });\n stream.on('readable', onReadable.bind(null, iterator));\n return iterator;\n};\nmodule.exports = createReadableStreamAsyncIterator;","module.exports = function () {\n throw new Error('Readable.from is not available in the browser');\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nmodule.exports = Readable;\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\nvar EElistenerCount = function EElistenerCount(emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\nvar Buffer = require('buffer').Buffer;\nvar OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\nvar debugUtil = require('util');\nvar debug;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function debug() {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/buffer_list');\nvar destroyImpl = require('./internal/streams/destroy');\nvar _require = require('./internal/streams/state'),\n getHighWaterMark = _require.getHighWaterMark;\nvar _require$codes = require('../errors').codes,\n ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,\n ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;\n\n// Lazy loaded to improve the startup performance.\nvar StringDecoder;\nvar createReadableStreamAsyncIterator;\nvar from;\nrequire('inherits')(Readable, Stream);\nvar errorOrDestroy = destroyImpl.errorOrDestroy;\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\nfunction ReadableState(options, stream, isDuplex) {\n Duplex = Duplex || require('./_stream_duplex');\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n this.paused = true;\n\n // Should close be emitted on destroy. Defaults to true.\n this.emitClose = options.emitClose !== false;\n\n // Should .destroy() be called after 'end' (and potentially 'finish')\n this.autoDestroy = !!options.autoDestroy;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n if (!(this instanceof Readable)) return new Readable(options);\n\n // Checking for a Stream.Duplex instance is faster here instead of inside\n // the ReadableState constructor, at least with V8 6.5\n var isDuplex = this instanceof Duplex;\n this._readableState = new ReadableState(options, this, isDuplex);\n\n // legacy\n this.readable = true;\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n Stream.call(this);\n}\nObject.defineProperty(Readable.prototype, 'destroyed', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function set(value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n debug('readableAddChunk', chunk);\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n errorOrDestroy(stream, er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n if (addToFront) {\n if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());\n } else if (state.destroyed) {\n return false;\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n maybeReadMore(stream, state);\n }\n }\n\n // We can push more data if we are below the highWaterMark.\n // Also, if we have no data yet, we can stand some more bytes.\n // This is to work around cases where hwm=0, such as the repl.\n return !state.ended && (state.length < state.highWaterMark || state.length === 0);\n}\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n state.awaitDrain = 0;\n stream.emit('data', chunk);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);\n }\n return er;\n}\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n var decoder = new StringDecoder(enc);\n this._readableState.decoder = decoder;\n // If setEncoding(null), decoder.encoding equals utf8\n this._readableState.encoding = this._readableState.decoder.encoding;\n\n // Iterate over current buffer to convert already stored Buffers:\n var p = this._readableState.buffer.head;\n var content = '';\n while (p !== null) {\n content += decoder.write(p.data);\n p = p.next;\n }\n this._readableState.buffer.clear();\n if (content !== '') this._readableState.buffer.push(content);\n this._readableState.length = content.length;\n return this;\n};\n\n// Don't raise the hwm > 1GB\nvar MAX_HWM = 0x40000000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n if (ret === null) {\n state.needReadable = state.length <= state.highWaterMark;\n n = 0;\n } else {\n state.length -= n;\n state.awaitDrain = 0;\n }\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n if (ret !== null) this.emit('data', ret);\n return ret;\n};\nfunction onEofChunk(stream, state) {\n debug('onEofChunk');\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n if (state.sync) {\n // if we are sync, wait until next tick to emit the data.\n // Otherwise we risk emitting data in the flow()\n // the readable code triggers during a read() call\n emitReadable(stream);\n } else {\n // emit 'readable' now to make sure it gets picked up.\n state.needReadable = false;\n if (!state.emittedReadable) {\n state.emittedReadable = true;\n emitReadable_(stream);\n }\n }\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n debug('emitReadable', state.needReadable, state.emittedReadable);\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n process.nextTick(emitReadable_, stream);\n }\n}\nfunction emitReadable_(stream) {\n var state = stream._readableState;\n debug('emitReadable_', state.destroyed, state.length, state.ended);\n if (!state.destroyed && (state.length || state.ended)) {\n stream.emit('readable');\n state.emittedReadable = false;\n }\n\n // The stream needs another readable event if\n // 1. It is not flowing, as the flow mechanism will take\n // care of it.\n // 2. It is not ended.\n // 3. It is below the highWaterMark, so we can schedule\n // another readable later.\n state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n process.nextTick(maybeReadMore_, stream, state);\n }\n}\nfunction maybeReadMore_(stream, state) {\n // Attempt to read more data if we should.\n //\n // The conditions for reading more data are (one of):\n // - Not enough data buffered (state.length < state.highWaterMark). The loop\n // is responsible for filling the buffer with enough data if such data\n // is available. If highWaterMark is 0 and we are not in the flowing mode\n // we should _not_ attempt to buffer any extra data. We'll get more data\n // when the stream consumer calls read() instead.\n // - No data in the buffer, and the stream is in flowing mode. In this mode\n // the loop below is responsible for ensuring read() is called. Failing to\n // call read here would abort the flow and there's no other mechanism for\n // continuing the flow if the stream consumer has just subscribed to the\n // 'data' event.\n //\n // In addition to the above conditions to keep reading data, the following\n // conditions prevent the data from being read:\n // - The stream has ended (state.ended).\n // - There is already a pending 'read' operation (state.reading). This is a\n // case where the the stream has called the implementation defined _read()\n // method, but they are processing the call asynchronously and have _not_\n // called push() with new data. In this case we skip performing more\n // read()s. The execution ends in this method again after the _read() ends\n // up calling push() with more data.\n while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {\n var len = state.length;\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));\n};\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n var ret = dest.write(chunk);\n debug('dest.write', ret);\n if (ret === false) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', state.awaitDrain);\n state.awaitDrain++;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n return dest;\n};\nfunction pipeOnDrain(src) {\n return function pipeOnDrainFunctionResult() {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = {\n hasUnpiped: false\n };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n for (var i = 0; i < len; i++) dests[i].emit('unpipe', this, {\n hasUnpiped: false\n });\n return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n dest.emit('unpipe', this, unpipeInfo);\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n var state = this._readableState;\n if (ev === 'data') {\n // update readableListening so that resume() may be a no-op\n // a few lines down. This is needed to support once('readable').\n state.readableListening = this.listenerCount('readable') > 0;\n\n // Try start flowing on next tick if stream isn't explicitly paused\n if (state.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.flowing = false;\n state.emittedReadable = false;\n debug('on readable', state.length, state.reading);\n if (state.length) {\n emitReadable(this);\n } else if (!state.reading) {\n process.nextTick(nReadingNextTick, this);\n }\n }\n }\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\nReadable.prototype.removeListener = function (ev, fn) {\n var res = Stream.prototype.removeListener.call(this, ev, fn);\n if (ev === 'readable') {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nReadable.prototype.removeAllListeners = function (ev) {\n var res = Stream.prototype.removeAllListeners.apply(this, arguments);\n if (ev === 'readable' || ev === undefined) {\n // We need to check if there is someone still listening to\n // readable and reset the state. However this needs to happen\n // after readable has been emitted but before I/O (nextTick) to\n // support once('readable', fn) cycles. This means that calling\n // resume within the same tick will have no\n // effect.\n process.nextTick(updateReadableListening, this);\n }\n return res;\n};\nfunction updateReadableListening(self) {\n var state = self._readableState;\n state.readableListening = self.listenerCount('readable') > 0;\n if (state.resumeScheduled && !state.paused) {\n // flowing needs to be set to true now, otherwise\n // the upcoming resume will not flow.\n state.flowing = true;\n\n // crude way to check if we should resume\n } else if (self.listenerCount('data') > 0) {\n self.resume();\n }\n}\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n // we flow only if there is no one listening\n // for readable, but we still have to call\n // resume()\n state.flowing = !state.readableListening;\n resume(this, state);\n }\n state.paused = false;\n return this;\n};\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n process.nextTick(resume_, stream, state);\n }\n}\nfunction resume_(stream, state) {\n debug('resume', state.reading);\n if (!state.reading) {\n stream.read(0);\n }\n state.resumeScheduled = false;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (this._readableState.flowing !== false) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n this._readableState.paused = true;\n return this;\n};\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null);\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n var state = this._readableState;\n var paused = false;\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n _this.push(null);\n });\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function methodWrap(method) {\n return function methodWrapReturnFunction() {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n return this;\n};\nif (typeof Symbol === 'function') {\n Readable.prototype[Symbol.asyncIterator] = function () {\n if (createReadableStreamAsyncIterator === undefined) {\n createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');\n }\n return createReadableStreamAsyncIterator(this);\n };\n}\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.highWaterMark;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableBuffer', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState && this._readableState.buffer;\n }\n});\nObject.defineProperty(Readable.prototype, 'readableFlowing', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.flowing;\n },\n set: function set(state) {\n if (this._readableState) {\n this._readableState.flowing = state;\n }\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\nObject.defineProperty(Readable.prototype, 'readableLength', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function get() {\n return this._readableState.length;\n }\n});\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = state.buffer.consume(n, state.decoder);\n }\n return ret;\n}\nfunction endReadable(stream) {\n var state = stream._readableState;\n debug('endReadable', state.endEmitted);\n if (!state.endEmitted) {\n state.ended = true;\n process.nextTick(endReadableNT, state, stream);\n }\n}\nfunction endReadableNT(state, stream) {\n debug('endReadableNT', state.endEmitted, state.length);\n\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n if (state.autoDestroy) {\n // In case of duplex streams we need a way to detect\n // if the writable side is ready for autoDestroy as well\n var wState = stream._writableState;\n if (!wState || wState.autoDestroy && wState.finished) {\n stream.destroy();\n }\n }\n }\n}\nif (typeof Symbol === 'function') {\n Readable.from = function (iterable, opts) {\n if (from === undefined) {\n from = require('./internal/streams/from');\n }\n return from(Readable, iterable, opts);\n };\n}\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\nvar _require$codes = require('../errors').codes,\n ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,\n ERR_MULTIPLE_CALLBACK = _require$codes.ERR_MULTIPLE_CALLBACK,\n ERR_TRANSFORM_ALREADY_TRANSFORMING = _require$codes.ERR_TRANSFORM_ALREADY_TRANSFORMING,\n ERR_TRANSFORM_WITH_LENGTH_0 = _require$codes.ERR_TRANSFORM_WITH_LENGTH_0;\nvar Duplex = require('./_stream_duplex');\nrequire('inherits')(Transform, Duplex);\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n var cb = ts.writecb;\n if (cb === null) {\n return this.emit('error', new ERR_MULTIPLE_CALLBACK());\n }\n ts.writechunk = null;\n ts.writecb = null;\n if (data != null)\n // single equals check for both `null` and `undefined`\n this.push(data);\n cb(er);\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n Duplex.call(this, options);\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\nfunction prefinish() {\n var _this = this;\n if (typeof this._flush === 'function' && !this._readableState.destroyed) {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n cb(new ERR_METHOD_NOT_IMPLEMENTED('_transform()'));\n};\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n if (ts.writechunk !== null && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\nTransform.prototype._destroy = function (err, cb) {\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n });\n};\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n if (data != null)\n // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // TODO(BridgeAR): Write a test for these two error cases\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new ERR_TRANSFORM_WITH_LENGTH_0();\n if (stream._transformState.transforming) throw new ERR_TRANSFORM_ALREADY_TRANSFORMING();\n return stream.push(null);\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// 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 permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\nvar Transform = require('./_stream_transform');\nrequire('inherits')(PassThrough, Transform);\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n Transform.call(this, options);\n}\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","// Ported from https://github.com/mafintosh/pump with\n// permission from the author, Mathias Buus (@mafintosh).\n\n'use strict';\n\nvar eos;\nfunction once(callback) {\n var called = false;\n return function () {\n if (called) return;\n called = true;\n callback.apply(void 0, arguments);\n };\n}\nvar _require$codes = require('../../../errors').codes,\n ERR_MISSING_ARGS = _require$codes.ERR_MISSING_ARGS,\n ERR_STREAM_DESTROYED = _require$codes.ERR_STREAM_DESTROYED;\nfunction noop(err) {\n // Rethrow the error if it exists to avoid swallowing it\n if (err) throw err;\n}\nfunction isRequest(stream) {\n return stream.setHeader && typeof stream.abort === 'function';\n}\nfunction destroyer(stream, reading, writing, callback) {\n callback = once(callback);\n var closed = false;\n stream.on('close', function () {\n closed = true;\n });\n if (eos === undefined) eos = require('./end-of-stream');\n eos(stream, {\n readable: reading,\n writable: writing\n }, function (err) {\n if (err) return callback(err);\n closed = true;\n callback();\n });\n var destroyed = false;\n return function (err) {\n if (closed) return;\n if (destroyed) return;\n destroyed = true;\n\n // request.destroy just do .end - .abort is what we want\n if (isRequest(stream)) return stream.abort();\n if (typeof stream.destroy === 'function') return stream.destroy();\n callback(err || new ERR_STREAM_DESTROYED('pipe'));\n };\n}\nfunction call(fn) {\n fn();\n}\nfunction pipe(from, to) {\n return from.pipe(to);\n}\nfunction popCallback(streams) {\n if (!streams.length) return noop;\n if (typeof streams[streams.length - 1] !== 'function') return noop;\n return streams.pop();\n}\nfunction pipeline() {\n for (var _len = arguments.length, streams = new Array(_len), _key = 0; _key < _len; _key++) {\n streams[_key] = arguments[_key];\n }\n var callback = popCallback(streams);\n if (Array.isArray(streams[0])) streams = streams[0];\n if (streams.length < 2) {\n throw new ERR_MISSING_ARGS('streams');\n }\n var error;\n var destroys = streams.map(function (stream, i) {\n var reading = i < streams.length - 1;\n var writing = i > 0;\n return destroyer(stream, reading, writing, function (err) {\n if (!error) error = err;\n if (err) destroys.forEach(call);\n if (reading) return;\n destroys.forEach(call);\n callback(error);\n });\n });\n return streams.reduce(pipe);\n}\nmodule.exports = pipeline;","exports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\nexports.finished = require('./lib/internal/streams/end-of-stream.js');\nexports.pipeline = require('./lib/internal/streams/pipeline.js');","const {\n Transform\n} = require('readable-stream');\nmodule.exports = KeccakState => class Keccak extends Transform {\n constructor(rate, capacity, delimitedSuffix, hashBitLength, options) {\n super(options);\n this._rate = rate;\n this._capacity = capacity;\n this._delimitedSuffix = delimitedSuffix;\n this._hashBitLength = hashBitLength;\n this._options = options;\n this._state = new KeccakState();\n this._state.initialize(rate, capacity);\n this._finalized = false;\n }\n _transform(chunk, encoding, callback) {\n let error = null;\n try {\n this.update(chunk, encoding);\n } catch (err) {\n error = err;\n }\n callback(error);\n }\n _flush(callback) {\n let error = null;\n try {\n this.push(this.digest());\n } catch (err) {\n error = err;\n }\n callback(error);\n }\n update(data, encoding) {\n if (!Buffer.isBuffer(data) && typeof data !== 'string') throw new TypeError('Data must be a string or a buffer');\n if (this._finalized) throw new Error('Digest already called');\n if (!Buffer.isBuffer(data)) data = Buffer.from(data, encoding);\n this._state.absorb(data);\n return this;\n }\n digest(encoding) {\n if (this._finalized) throw new Error('Digest already called');\n this._finalized = true;\n if (this._delimitedSuffix) this._state.absorbLastFewBits(this._delimitedSuffix);\n let digest = this._state.squeeze(this._hashBitLength / 8);\n if (encoding !== undefined) digest = digest.toString(encoding);\n this._resetState();\n return digest;\n }\n\n // remove result from memory\n _resetState() {\n this._state.initialize(this._rate, this._capacity);\n return this;\n }\n\n // because sometimes we need hash right now and little later\n _clone() {\n const clone = new Keccak(this._rate, this._capacity, this._delimitedSuffix, this._hashBitLength, this._options);\n this._state.copy(clone._state);\n clone._finalized = this._finalized;\n return clone;\n }\n};","const {\n Transform\n} = require('readable-stream');\nmodule.exports = KeccakState => class Shake extends Transform {\n constructor(rate, capacity, delimitedSuffix, options) {\n super(options);\n this._rate = rate;\n this._capacity = capacity;\n this._delimitedSuffix = delimitedSuffix;\n this._options = options;\n this._state = new KeccakState();\n this._state.initialize(rate, capacity);\n this._finalized = false;\n }\n _transform(chunk, encoding, callback) {\n let error = null;\n try {\n this.update(chunk, encoding);\n } catch (err) {\n error = err;\n }\n callback(error);\n }\n _flush() {}\n _read(size) {\n this.push(this.squeeze(size));\n }\n update(data, encoding) {\n if (!Buffer.isBuffer(data) && typeof data !== 'string') throw new TypeError('Data must be a string or a buffer');\n if (this._finalized) throw new Error('Squeeze already called');\n if (!Buffer.isBuffer(data)) data = Buffer.from(data, encoding);\n this._state.absorb(data);\n return this;\n }\n squeeze(dataByteLength, encoding) {\n if (!this._finalized) {\n this._finalized = true;\n this._state.absorbLastFewBits(this._delimitedSuffix);\n }\n let data = this._state.squeeze(dataByteLength);\n if (encoding !== undefined) data = data.toString(encoding);\n return data;\n }\n _resetState() {\n this._state.initialize(this._rate, this._capacity);\n return this;\n }\n _clone() {\n const clone = new Shake(this._rate, this._capacity, this._delimitedSuffix, this._options);\n this._state.copy(clone._state);\n clone._finalized = this._finalized;\n return clone;\n }\n};","const createKeccak = require('./keccak');\nconst createShake = require('./shake');\nmodule.exports = function (KeccakState) {\n const Keccak = createKeccak(KeccakState);\n const Shake = createShake(KeccakState);\n return function (algorithm, options) {\n const hash = typeof algorithm === 'string' ? algorithm.toLowerCase() : algorithm;\n switch (hash) {\n case 'keccak224':\n return new Keccak(1152, 448, null, 224, options);\n case 'keccak256':\n return new Keccak(1088, 512, null, 256, options);\n case 'keccak384':\n return new Keccak(832, 768, null, 384, options);\n case 'keccak512':\n return new Keccak(576, 1024, null, 512, options);\n case 'sha3-224':\n return new Keccak(1152, 448, 0x06, 224, options);\n case 'sha3-256':\n return new Keccak(1088, 512, 0x06, 256, options);\n case 'sha3-384':\n return new Keccak(832, 768, 0x06, 384, options);\n case 'sha3-512':\n return new Keccak(576, 1024, 0x06, 512, options);\n case 'shake128':\n return new Shake(1344, 256, 0x1f, options);\n case 'shake256':\n return new Shake(1088, 512, 0x1f, options);\n default:\n throw new Error('Invald algorithm: ' + algorithm);\n }\n };\n};","const P1600_ROUND_CONSTANTS = [1, 0, 32898, 0, 32906, 2147483648, 2147516416, 2147483648, 32907, 0, 2147483649, 0, 2147516545, 2147483648, 32777, 2147483648, 138, 0, 136, 0, 2147516425, 0, 2147483658, 0, 2147516555, 0, 139, 2147483648, 32905, 2147483648, 32771, 2147483648, 32770, 2147483648, 128, 2147483648, 32778, 0, 2147483658, 2147483648, 2147516545, 2147483648, 32896, 2147483648, 2147483649, 0, 2147516424, 2147483648];\nexports.p1600 = function (s) {\n for (let round = 0; round < 24; ++round) {\n // theta\n const lo0 = s[0] ^ s[10] ^ s[20] ^ s[30] ^ s[40];\n const hi0 = s[1] ^ s[11] ^ s[21] ^ s[31] ^ s[41];\n const lo1 = s[2] ^ s[12] ^ s[22] ^ s[32] ^ s[42];\n const hi1 = s[3] ^ s[13] ^ s[23] ^ s[33] ^ s[43];\n const lo2 = s[4] ^ s[14] ^ s[24] ^ s[34] ^ s[44];\n const hi2 = s[5] ^ s[15] ^ s[25] ^ s[35] ^ s[45];\n const lo3 = s[6] ^ s[16] ^ s[26] ^ s[36] ^ s[46];\n const hi3 = s[7] ^ s[17] ^ s[27] ^ s[37] ^ s[47];\n const lo4 = s[8] ^ s[18] ^ s[28] ^ s[38] ^ s[48];\n const hi4 = s[9] ^ s[19] ^ s[29] ^ s[39] ^ s[49];\n let lo = lo4 ^ (lo1 << 1 | hi1 >>> 31);\n let hi = hi4 ^ (hi1 << 1 | lo1 >>> 31);\n const t1slo0 = s[0] ^ lo;\n const t1shi0 = s[1] ^ hi;\n const t1slo5 = s[10] ^ lo;\n const t1shi5 = s[11] ^ hi;\n const t1slo10 = s[20] ^ lo;\n const t1shi10 = s[21] ^ hi;\n const t1slo15 = s[30] ^ lo;\n const t1shi15 = s[31] ^ hi;\n const t1slo20 = s[40] ^ lo;\n const t1shi20 = s[41] ^ hi;\n lo = lo0 ^ (lo2 << 1 | hi2 >>> 31);\n hi = hi0 ^ (hi2 << 1 | lo2 >>> 31);\n const t1slo1 = s[2] ^ lo;\n const t1shi1 = s[3] ^ hi;\n const t1slo6 = s[12] ^ lo;\n const t1shi6 = s[13] ^ hi;\n const t1slo11 = s[22] ^ lo;\n const t1shi11 = s[23] ^ hi;\n const t1slo16 = s[32] ^ lo;\n const t1shi16 = s[33] ^ hi;\n const t1slo21 = s[42] ^ lo;\n const t1shi21 = s[43] ^ hi;\n lo = lo1 ^ (lo3 << 1 | hi3 >>> 31);\n hi = hi1 ^ (hi3 << 1 | lo3 >>> 31);\n const t1slo2 = s[4] ^ lo;\n const t1shi2 = s[5] ^ hi;\n const t1slo7 = s[14] ^ lo;\n const t1shi7 = s[15] ^ hi;\n const t1slo12 = s[24] ^ lo;\n const t1shi12 = s[25] ^ hi;\n const t1slo17 = s[34] ^ lo;\n const t1shi17 = s[35] ^ hi;\n const t1slo22 = s[44] ^ lo;\n const t1shi22 = s[45] ^ hi;\n lo = lo2 ^ (lo4 << 1 | hi4 >>> 31);\n hi = hi2 ^ (hi4 << 1 | lo4 >>> 31);\n const t1slo3 = s[6] ^ lo;\n const t1shi3 = s[7] ^ hi;\n const t1slo8 = s[16] ^ lo;\n const t1shi8 = s[17] ^ hi;\n const t1slo13 = s[26] ^ lo;\n const t1shi13 = s[27] ^ hi;\n const t1slo18 = s[36] ^ lo;\n const t1shi18 = s[37] ^ hi;\n const t1slo23 = s[46] ^ lo;\n const t1shi23 = s[47] ^ hi;\n lo = lo3 ^ (lo0 << 1 | hi0 >>> 31);\n hi = hi3 ^ (hi0 << 1 | lo0 >>> 31);\n const t1slo4 = s[8] ^ lo;\n const t1shi4 = s[9] ^ hi;\n const t1slo9 = s[18] ^ lo;\n const t1shi9 = s[19] ^ hi;\n const t1slo14 = s[28] ^ lo;\n const t1shi14 = s[29] ^ hi;\n const t1slo19 = s[38] ^ lo;\n const t1shi19 = s[39] ^ hi;\n const t1slo24 = s[48] ^ lo;\n const t1shi24 = s[49] ^ hi;\n\n // rho & pi\n const t2slo0 = t1slo0;\n const t2shi0 = t1shi0;\n const t2slo16 = t1shi5 << 4 | t1slo5 >>> 28;\n const t2shi16 = t1slo5 << 4 | t1shi5 >>> 28;\n const t2slo7 = t1slo10 << 3 | t1shi10 >>> 29;\n const t2shi7 = t1shi10 << 3 | t1slo10 >>> 29;\n const t2slo23 = t1shi15 << 9 | t1slo15 >>> 23;\n const t2shi23 = t1slo15 << 9 | t1shi15 >>> 23;\n const t2slo14 = t1slo20 << 18 | t1shi20 >>> 14;\n const t2shi14 = t1shi20 << 18 | t1slo20 >>> 14;\n const t2slo10 = t1slo1 << 1 | t1shi1 >>> 31;\n const t2shi10 = t1shi1 << 1 | t1slo1 >>> 31;\n const t2slo1 = t1shi6 << 12 | t1slo6 >>> 20;\n const t2shi1 = t1slo6 << 12 | t1shi6 >>> 20;\n const t2slo17 = t1slo11 << 10 | t1shi11 >>> 22;\n const t2shi17 = t1shi11 << 10 | t1slo11 >>> 22;\n const t2slo8 = t1shi16 << 13 | t1slo16 >>> 19;\n const t2shi8 = t1slo16 << 13 | t1shi16 >>> 19;\n const t2slo24 = t1slo21 << 2 | t1shi21 >>> 30;\n const t2shi24 = t1shi21 << 2 | t1slo21 >>> 30;\n const t2slo20 = t1shi2 << 30 | t1slo2 >>> 2;\n const t2shi20 = t1slo2 << 30 | t1shi2 >>> 2;\n const t2slo11 = t1slo7 << 6 | t1shi7 >>> 26;\n const t2shi11 = t1shi7 << 6 | t1slo7 >>> 26;\n const t2slo2 = t1shi12 << 11 | t1slo12 >>> 21;\n const t2shi2 = t1slo12 << 11 | t1shi12 >>> 21;\n const t2slo18 = t1slo17 << 15 | t1shi17 >>> 17;\n const t2shi18 = t1shi17 << 15 | t1slo17 >>> 17;\n const t2slo9 = t1shi22 << 29 | t1slo22 >>> 3;\n const t2shi9 = t1slo22 << 29 | t1shi22 >>> 3;\n const t2slo5 = t1slo3 << 28 | t1shi3 >>> 4;\n const t2shi5 = t1shi3 << 28 | t1slo3 >>> 4;\n const t2slo21 = t1shi8 << 23 | t1slo8 >>> 9;\n const t2shi21 = t1slo8 << 23 | t1shi8 >>> 9;\n const t2slo12 = t1slo13 << 25 | t1shi13 >>> 7;\n const t2shi12 = t1shi13 << 25 | t1slo13 >>> 7;\n const t2slo3 = t1slo18 << 21 | t1shi18 >>> 11;\n const t2shi3 = t1shi18 << 21 | t1slo18 >>> 11;\n const t2slo19 = t1shi23 << 24 | t1slo23 >>> 8;\n const t2shi19 = t1slo23 << 24 | t1shi23 >>> 8;\n const t2slo15 = t1slo4 << 27 | t1shi4 >>> 5;\n const t2shi15 = t1shi4 << 27 | t1slo4 >>> 5;\n const t2slo6 = t1slo9 << 20 | t1shi9 >>> 12;\n const t2shi6 = t1shi9 << 20 | t1slo9 >>> 12;\n const t2slo22 = t1shi14 << 7 | t1slo14 >>> 25;\n const t2shi22 = t1slo14 << 7 | t1shi14 >>> 25;\n const t2slo13 = t1slo19 << 8 | t1shi19 >>> 24;\n const t2shi13 = t1shi19 << 8 | t1slo19 >>> 24;\n const t2slo4 = t1slo24 << 14 | t1shi24 >>> 18;\n const t2shi4 = t1shi24 << 14 | t1slo24 >>> 18;\n\n // chi\n s[0] = t2slo0 ^ ~t2slo1 & t2slo2;\n s[1] = t2shi0 ^ ~t2shi1 & t2shi2;\n s[10] = t2slo5 ^ ~t2slo6 & t2slo7;\n s[11] = t2shi5 ^ ~t2shi6 & t2shi7;\n s[20] = t2slo10 ^ ~t2slo11 & t2slo12;\n s[21] = t2shi10 ^ ~t2shi11 & t2shi12;\n s[30] = t2slo15 ^ ~t2slo16 & t2slo17;\n s[31] = t2shi15 ^ ~t2shi16 & t2shi17;\n s[40] = t2slo20 ^ ~t2slo21 & t2slo22;\n s[41] = t2shi20 ^ ~t2shi21 & t2shi22;\n s[2] = t2slo1 ^ ~t2slo2 & t2slo3;\n s[3] = t2shi1 ^ ~t2shi2 & t2shi3;\n s[12] = t2slo6 ^ ~t2slo7 & t2slo8;\n s[13] = t2shi6 ^ ~t2shi7 & t2shi8;\n s[22] = t2slo11 ^ ~t2slo12 & t2slo13;\n s[23] = t2shi11 ^ ~t2shi12 & t2shi13;\n s[32] = t2slo16 ^ ~t2slo17 & t2slo18;\n s[33] = t2shi16 ^ ~t2shi17 & t2shi18;\n s[42] = t2slo21 ^ ~t2slo22 & t2slo23;\n s[43] = t2shi21 ^ ~t2shi22 & t2shi23;\n s[4] = t2slo2 ^ ~t2slo3 & t2slo4;\n s[5] = t2shi2 ^ ~t2shi3 & t2shi4;\n s[14] = t2slo7 ^ ~t2slo8 & t2slo9;\n s[15] = t2shi7 ^ ~t2shi8 & t2shi9;\n s[24] = t2slo12 ^ ~t2slo13 & t2slo14;\n s[25] = t2shi12 ^ ~t2shi13 & t2shi14;\n s[34] = t2slo17 ^ ~t2slo18 & t2slo19;\n s[35] = t2shi17 ^ ~t2shi18 & t2shi19;\n s[44] = t2slo22 ^ ~t2slo23 & t2slo24;\n s[45] = t2shi22 ^ ~t2shi23 & t2shi24;\n s[6] = t2slo3 ^ ~t2slo4 & t2slo0;\n s[7] = t2shi3 ^ ~t2shi4 & t2shi0;\n s[16] = t2slo8 ^ ~t2slo9 & t2slo5;\n s[17] = t2shi8 ^ ~t2shi9 & t2shi5;\n s[26] = t2slo13 ^ ~t2slo14 & t2slo10;\n s[27] = t2shi13 ^ ~t2shi14 & t2shi10;\n s[36] = t2slo18 ^ ~t2slo19 & t2slo15;\n s[37] = t2shi18 ^ ~t2shi19 & t2shi15;\n s[46] = t2slo23 ^ ~t2slo24 & t2slo20;\n s[47] = t2shi23 ^ ~t2shi24 & t2shi20;\n s[8] = t2slo4 ^ ~t2slo0 & t2slo1;\n s[9] = t2shi4 ^ ~t2shi0 & t2shi1;\n s[18] = t2slo9 ^ ~t2slo5 & t2slo6;\n s[19] = t2shi9 ^ ~t2shi5 & t2shi6;\n s[28] = t2slo14 ^ ~t2slo10 & t2slo11;\n s[29] = t2shi14 ^ ~t2shi10 & t2shi11;\n s[38] = t2slo19 ^ ~t2slo15 & t2slo16;\n s[39] = t2shi19 ^ ~t2shi15 & t2shi16;\n s[48] = t2slo24 ^ ~t2slo20 & t2slo21;\n s[49] = t2shi24 ^ ~t2shi20 & t2shi21;\n\n // iota\n s[0] ^= P1600_ROUND_CONSTANTS[round * 2];\n s[1] ^= P1600_ROUND_CONSTANTS[round * 2 + 1];\n }\n};","const keccakState = require('./keccak-state-unroll');\nfunction Keccak() {\n // much faster than `new Array(50)`\n this.state = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];\n this.blockSize = null;\n this.count = 0;\n this.squeezing = false;\n}\nKeccak.prototype.initialize = function (rate, capacity) {\n for (let i = 0; i < 50; ++i) this.state[i] = 0;\n this.blockSize = rate / 8;\n this.count = 0;\n this.squeezing = false;\n};\nKeccak.prototype.absorb = function (data) {\n for (let i = 0; i < data.length; ++i) {\n this.state[~~(this.count / 4)] ^= data[i] << 8 * (this.count % 4);\n this.count += 1;\n if (this.count === this.blockSize) {\n keccakState.p1600(this.state);\n this.count = 0;\n }\n }\n};\nKeccak.prototype.absorbLastFewBits = function (bits) {\n this.state[~~(this.count / 4)] ^= bits << 8 * (this.count % 4);\n if ((bits & 0x80) !== 0 && this.count === this.blockSize - 1) keccakState.p1600(this.state);\n this.state[~~((this.blockSize - 1) / 4)] ^= 0x80 << 8 * ((this.blockSize - 1) % 4);\n keccakState.p1600(this.state);\n this.count = 0;\n this.squeezing = true;\n};\nKeccak.prototype.squeeze = function (length) {\n if (!this.squeezing) this.absorbLastFewBits(0x01);\n const output = Buffer.alloc(length);\n for (let i = 0; i < length; ++i) {\n output[i] = this.state[~~(this.count / 4)] >>> 8 * (this.count % 4) & 0xff;\n this.count += 1;\n if (this.count === this.blockSize) {\n keccakState.p1600(this.state);\n this.count = 0;\n }\n }\n return output;\n};\nKeccak.prototype.copy = function (dest) {\n for (let i = 0; i < 50; ++i) dest.state[i] = this.state[i];\n dest.blockSize = this.blockSize;\n dest.count = this.count;\n dest.squeezing = this.squeezing;\n};\nmodule.exports = Keccak;","module.exports = require('./lib/api')(require('./lib/keccak'));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar hash_utils_1 = require(\"./hash-utils\");\nvar createKeccakHash = require(\"keccak\");\nexports.keccak224 = hash_utils_1.createHashFunction(function () {\n return createKeccakHash(\"keccak224\");\n});\nexports.keccak256 = hash_utils_1.createHashFunction(function () {\n return createKeccakHash(\"keccak256\");\n});\nexports.keccak384 = hash_utils_1.createHashFunction(function () {\n return createKeccakHash(\"keccak384\");\n});\nexports.keccak512 = hash_utils_1.createHashFunction(function () {\n return createKeccakHash(\"keccak512\");\n});\n","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar Transform = require('stream').Transform;\nvar inherits = require('inherits');\nfunction HashBase(blockSize) {\n Transform.call(this);\n this._block = Buffer.allocUnsafe(blockSize);\n this._blockSize = blockSize;\n this._blockOffset = 0;\n this._length = [0, 0, 0, 0];\n this._finalized = false;\n}\ninherits(HashBase, Transform);\nHashBase.prototype._transform = function (chunk, encoding, callback) {\n var error = null;\n try {\n this.update(chunk, encoding);\n } catch (err) {\n error = err;\n }\n callback(error);\n};\nHashBase.prototype._flush = function (callback) {\n var error = null;\n try {\n this.push(this.digest());\n } catch (err) {\n error = err;\n }\n callback(error);\n};\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined' && typeof Uint8Array !== 'undefined' && ArrayBuffer.isView && (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT);\nfunction toBuffer(data, encoding) {\n // No need to do anything for exact instance\n // This is only valid when safe-buffer.Buffer === buffer.Buffer, i.e. when Buffer.from/Buffer.alloc existed\n if (data instanceof Buffer) return data;\n\n // Convert strings to Buffer\n if (typeof data === 'string') return Buffer.from(data, encoding);\n\n /*\n * Wrap any TypedArray instances and DataViews\n * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n */\n if (useArrayBuffer && ArrayBuffer.isView(data)) {\n if (data.byteLength === 0) return Buffer.alloc(0); // Bug in Node.js <6.3.1, which treats this as out-of-bounds\n var res = Buffer.from(data.buffer, data.byteOffset, data.byteLength);\n // Recheck result size, as offset/length doesn't work on Node.js <5.10\n // We just go to Uint8Array case if this fails\n if (res.byteLength === data.byteLength) return res;\n }\n\n /*\n * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n * Doesn't make sense with other TypedArray instances\n */\n if (useUint8Array && data instanceof Uint8Array) return Buffer.from(data);\n\n /*\n * Old Buffer polyfill on an engine that doesn't have TypedArray support\n * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n * Convert to our current Buffer implementation\n */\n if (Buffer.isBuffer(data) && data.constructor && typeof data.constructor.isBuffer === 'function' && data.constructor.isBuffer(data)) {\n return Buffer.from(data);\n }\n throw new TypeError('The \"data\" argument must be of type string or an instance of Buffer, TypedArray, or DataView.');\n}\nHashBase.prototype.update = function (data, encoding) {\n if (this._finalized) throw new Error('Digest already called');\n data = toBuffer(data, encoding); // asserts correct input type\n\n // consume data\n var block = this._block;\n var offset = 0;\n while (this._blockOffset + data.length - offset >= this._blockSize) {\n for (var i = this._blockOffset; i < this._blockSize;) block[i++] = data[offset++];\n this._update();\n this._blockOffset = 0;\n }\n while (offset < data.length) block[this._blockOffset++] = data[offset++];\n\n // update length\n for (var j = 0, carry = data.length * 8; carry > 0; ++j) {\n this._length[j] += carry;\n carry = this._length[j] / 0x0100000000 | 0;\n if (carry > 0) this._length[j] -= 0x0100000000 * carry;\n }\n return this;\n};\nHashBase.prototype._update = function () {\n throw new Error('_update is not implemented');\n};\nHashBase.prototype.digest = function (encoding) {\n if (this._finalized) throw new Error('Digest already called');\n this._finalized = true;\n var digest = this._digest();\n if (encoding !== undefined) digest = digest.toString(encoding);\n\n // reset state\n this._block.fill(0);\n this._blockOffset = 0;\n for (var i = 0; i < 4; ++i) this._length[i] = 0;\n return digest;\n};\nHashBase.prototype._digest = function () {\n throw new Error('_digest is not implemented');\n};\nmodule.exports = HashBase;","'use strict';\n\nvar inherits = require('inherits');\nvar HashBase = require('hash-base');\nvar Buffer = require('safe-buffer').Buffer;\nvar ARRAY16 = new Array(16);\nfunction MD5() {\n HashBase.call(this, 64);\n\n // state\n this._a = 0x67452301;\n this._b = 0xefcdab89;\n this._c = 0x98badcfe;\n this._d = 0x10325476;\n}\ninherits(MD5, HashBase);\nMD5.prototype._update = function () {\n var M = ARRAY16;\n for (var i = 0; i < 16; ++i) M[i] = this._block.readInt32LE(i * 4);\n var a = this._a;\n var b = this._b;\n var c = this._c;\n var d = this._d;\n a = fnF(a, b, c, d, M[0], 0xd76aa478, 7);\n d = fnF(d, a, b, c, M[1], 0xe8c7b756, 12);\n c = fnF(c, d, a, b, M[2], 0x242070db, 17);\n b = fnF(b, c, d, a, M[3], 0xc1bdceee, 22);\n a = fnF(a, b, c, d, M[4], 0xf57c0faf, 7);\n d = fnF(d, a, b, c, M[5], 0x4787c62a, 12);\n c = fnF(c, d, a, b, M[6], 0xa8304613, 17);\n b = fnF(b, c, d, a, M[7], 0xfd469501, 22);\n a = fnF(a, b, c, d, M[8], 0x698098d8, 7);\n d = fnF(d, a, b, c, M[9], 0x8b44f7af, 12);\n c = fnF(c, d, a, b, M[10], 0xffff5bb1, 17);\n b = fnF(b, c, d, a, M[11], 0x895cd7be, 22);\n a = fnF(a, b, c, d, M[12], 0x6b901122, 7);\n d = fnF(d, a, b, c, M[13], 0xfd987193, 12);\n c = fnF(c, d, a, b, M[14], 0xa679438e, 17);\n b = fnF(b, c, d, a, M[15], 0x49b40821, 22);\n a = fnG(a, b, c, d, M[1], 0xf61e2562, 5);\n d = fnG(d, a, b, c, M[6], 0xc040b340, 9);\n c = fnG(c, d, a, b, M[11], 0x265e5a51, 14);\n b = fnG(b, c, d, a, M[0], 0xe9b6c7aa, 20);\n a = fnG(a, b, c, d, M[5], 0xd62f105d, 5);\n d = fnG(d, a, b, c, M[10], 0x02441453, 9);\n c = fnG(c, d, a, b, M[15], 0xd8a1e681, 14);\n b = fnG(b, c, d, a, M[4], 0xe7d3fbc8, 20);\n a = fnG(a, b, c, d, M[9], 0x21e1cde6, 5);\n d = fnG(d, a, b, c, M[14], 0xc33707d6, 9);\n c = fnG(c, d, a, b, M[3], 0xf4d50d87, 14);\n b = fnG(b, c, d, a, M[8], 0x455a14ed, 20);\n a = fnG(a, b, c, d, M[13], 0xa9e3e905, 5);\n d = fnG(d, a, b, c, M[2], 0xfcefa3f8, 9);\n c = fnG(c, d, a, b, M[7], 0x676f02d9, 14);\n b = fnG(b, c, d, a, M[12], 0x8d2a4c8a, 20);\n a = fnH(a, b, c, d, M[5], 0xfffa3942, 4);\n d = fnH(d, a, b, c, M[8], 0x8771f681, 11);\n c = fnH(c, d, a, b, M[11], 0x6d9d6122, 16);\n b = fnH(b, c, d, a, M[14], 0xfde5380c, 23);\n a = fnH(a, b, c, d, M[1], 0xa4beea44, 4);\n d = fnH(d, a, b, c, M[4], 0x4bdecfa9, 11);\n c = fnH(c, d, a, b, M[7], 0xf6bb4b60, 16);\n b = fnH(b, c, d, a, M[10], 0xbebfbc70, 23);\n a = fnH(a, b, c, d, M[13], 0x289b7ec6, 4);\n d = fnH(d, a, b, c, M[0], 0xeaa127fa, 11);\n c = fnH(c, d, a, b, M[3], 0xd4ef3085, 16);\n b = fnH(b, c, d, a, M[6], 0x04881d05, 23);\n a = fnH(a, b, c, d, M[9], 0xd9d4d039, 4);\n d = fnH(d, a, b, c, M[12], 0xe6db99e5, 11);\n c = fnH(c, d, a, b, M[15], 0x1fa27cf8, 16);\n b = fnH(b, c, d, a, M[2], 0xc4ac5665, 23);\n a = fnI(a, b, c, d, M[0], 0xf4292244, 6);\n d = fnI(d, a, b, c, M[7], 0x432aff97, 10);\n c = fnI(c, d, a, b, M[14], 0xab9423a7, 15);\n b = fnI(b, c, d, a, M[5], 0xfc93a039, 21);\n a = fnI(a, b, c, d, M[12], 0x655b59c3, 6);\n d = fnI(d, a, b, c, M[3], 0x8f0ccc92, 10);\n c = fnI(c, d, a, b, M[10], 0xffeff47d, 15);\n b = fnI(b, c, d, a, M[1], 0x85845dd1, 21);\n a = fnI(a, b, c, d, M[8], 0x6fa87e4f, 6);\n d = fnI(d, a, b, c, M[15], 0xfe2ce6e0, 10);\n c = fnI(c, d, a, b, M[6], 0xa3014314, 15);\n b = fnI(b, c, d, a, M[13], 0x4e0811a1, 21);\n a = fnI(a, b, c, d, M[4], 0xf7537e82, 6);\n d = fnI(d, a, b, c, M[11], 0xbd3af235, 10);\n c = fnI(c, d, a, b, M[2], 0x2ad7d2bb, 15);\n b = fnI(b, c, d, a, M[9], 0xeb86d391, 21);\n this._a = this._a + a | 0;\n this._b = this._b + b | 0;\n this._c = this._c + c | 0;\n this._d = this._d + d | 0;\n};\nMD5.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80;\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64);\n this._update();\n this._blockOffset = 0;\n }\n this._block.fill(0, this._blockOffset, 56);\n this._block.writeUInt32LE(this._length[0], 56);\n this._block.writeUInt32LE(this._length[1], 60);\n this._update();\n\n // produce result\n var buffer = Buffer.allocUnsafe(16);\n buffer.writeInt32LE(this._a, 0);\n buffer.writeInt32LE(this._b, 4);\n buffer.writeInt32LE(this._c, 8);\n buffer.writeInt32LE(this._d, 12);\n return buffer;\n};\nfunction rotl(x, n) {\n return x << n | x >>> 32 - n;\n}\nfunction fnF(a, b, c, d, m, k, s) {\n return rotl(a + (b & c | ~b & d) + m + k | 0, s) + b | 0;\n}\nfunction fnG(a, b, c, d, m, k, s) {\n return rotl(a + (b & d | c & ~d) + m + k | 0, s) + b | 0;\n}\nfunction fnH(a, b, c, d, m, k, s) {\n return rotl(a + (b ^ c ^ d) + m + k | 0, s) + b | 0;\n}\nfunction fnI(a, b, c, d, m, k, s) {\n return rotl(a + (c ^ (b | ~d)) + m + k | 0, s) + b | 0;\n}\nmodule.exports = MD5;","'use strict';\n\nvar Buffer = require('buffer').Buffer;\nvar inherits = require('inherits');\nvar HashBase = require('hash-base');\nvar ARRAY16 = new Array(16);\nvar zl = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13];\nvar zr = [5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11];\nvar sl = [11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6];\nvar sr = [8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11];\nvar hl = [0x00000000, 0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xa953fd4e];\nvar hr = [0x50a28be6, 0x5c4dd124, 0x6d703ef3, 0x7a6d76e9, 0x00000000];\nfunction RIPEMD160() {\n HashBase.call(this, 64);\n\n // state\n this._a = 0x67452301;\n this._b = 0xefcdab89;\n this._c = 0x98badcfe;\n this._d = 0x10325476;\n this._e = 0xc3d2e1f0;\n}\ninherits(RIPEMD160, HashBase);\nRIPEMD160.prototype._update = function () {\n var words = ARRAY16;\n for (var j = 0; j < 16; ++j) words[j] = this._block.readInt32LE(j * 4);\n var al = this._a | 0;\n var bl = this._b | 0;\n var cl = this._c | 0;\n var dl = this._d | 0;\n var el = this._e | 0;\n var ar = this._a | 0;\n var br = this._b | 0;\n var cr = this._c | 0;\n var dr = this._d | 0;\n var er = this._e | 0;\n\n // computation\n for (var i = 0; i < 80; i += 1) {\n var tl;\n var tr;\n if (i < 16) {\n tl = fn1(al, bl, cl, dl, el, words[zl[i]], hl[0], sl[i]);\n tr = fn5(ar, br, cr, dr, er, words[zr[i]], hr[0], sr[i]);\n } else if (i < 32) {\n tl = fn2(al, bl, cl, dl, el, words[zl[i]], hl[1], sl[i]);\n tr = fn4(ar, br, cr, dr, er, words[zr[i]], hr[1], sr[i]);\n } else if (i < 48) {\n tl = fn3(al, bl, cl, dl, el, words[zl[i]], hl[2], sl[i]);\n tr = fn3(ar, br, cr, dr, er, words[zr[i]], hr[2], sr[i]);\n } else if (i < 64) {\n tl = fn4(al, bl, cl, dl, el, words[zl[i]], hl[3], sl[i]);\n tr = fn2(ar, br, cr, dr, er, words[zr[i]], hr[3], sr[i]);\n } else {\n // if (i<80) {\n tl = fn5(al, bl, cl, dl, el, words[zl[i]], hl[4], sl[i]);\n tr = fn1(ar, br, cr, dr, er, words[zr[i]], hr[4], sr[i]);\n }\n al = el;\n el = dl;\n dl = rotl(cl, 10);\n cl = bl;\n bl = tl;\n ar = er;\n er = dr;\n dr = rotl(cr, 10);\n cr = br;\n br = tr;\n }\n\n // update state\n var t = this._b + cl + dr | 0;\n this._b = this._c + dl + er | 0;\n this._c = this._d + el + ar | 0;\n this._d = this._e + al + br | 0;\n this._e = this._a + bl + cr | 0;\n this._a = t;\n};\nRIPEMD160.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80;\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64);\n this._update();\n this._blockOffset = 0;\n }\n this._block.fill(0, this._blockOffset, 56);\n this._block.writeUInt32LE(this._length[0], 56);\n this._block.writeUInt32LE(this._length[1], 60);\n this._update();\n\n // produce result\n var buffer = Buffer.alloc ? Buffer.alloc(20) : new Buffer(20);\n buffer.writeInt32LE(this._a, 0);\n buffer.writeInt32LE(this._b, 4);\n buffer.writeInt32LE(this._c, 8);\n buffer.writeInt32LE(this._d, 12);\n buffer.writeInt32LE(this._e, 16);\n return buffer;\n};\nfunction rotl(x, n) {\n return x << n | x >>> 32 - n;\n}\nfunction fn1(a, b, c, d, e, m, k, s) {\n return rotl(a + (b ^ c ^ d) + m + k | 0, s) + e | 0;\n}\nfunction fn2(a, b, c, d, e, m, k, s) {\n return rotl(a + (b & c | ~b & d) + m + k | 0, s) + e | 0;\n}\nfunction fn3(a, b, c, d, e, m, k, s) {\n return rotl(a + ((b | ~c) ^ d) + m + k | 0, s) + e | 0;\n}\nfunction fn4(a, b, c, d, e, m, k, s) {\n return rotl(a + (b & d | c & ~d) + m + k | 0, s) + e | 0;\n}\nfunction fn5(a, b, c, d, e, m, k, s) {\n return rotl(a + (b ^ (c | ~d)) + m + k | 0, s) + e | 0;\n}\nmodule.exports = RIPEMD160;","var Buffer = require('safe-buffer').Buffer;\n\n// prototype class for hash functions\nfunction Hash(blockSize, finalSize) {\n this._block = Buffer.alloc(blockSize);\n this._finalSize = finalSize;\n this._blockSize = blockSize;\n this._len = 0;\n}\nHash.prototype.update = function (data, enc) {\n if (typeof data === 'string') {\n enc = enc || 'utf8';\n data = Buffer.from(data, enc);\n }\n var block = this._block;\n var blockSize = this._blockSize;\n var length = data.length;\n var accum = this._len;\n for (var offset = 0; offset < length;) {\n var assigned = accum % blockSize;\n var remainder = Math.min(length - offset, blockSize - assigned);\n for (var i = 0; i < remainder; i++) {\n block[assigned + i] = data[offset + i];\n }\n accum += remainder;\n offset += remainder;\n if (accum % blockSize === 0) {\n this._update(block);\n }\n }\n this._len += length;\n return this;\n};\nHash.prototype.digest = function (enc) {\n var rem = this._len % this._blockSize;\n this._block[rem] = 0x80;\n\n // zero (rem + 1) trailing bits, where (rem + 1) is the smallest\n // non-negative solution to the equation (length + 1 + (rem + 1)) === finalSize mod blockSize\n this._block.fill(0, rem + 1);\n if (rem >= this._finalSize) {\n this._update(this._block);\n this._block.fill(0);\n }\n var bits = this._len * 8;\n\n // uint32\n if (bits <= 0xffffffff) {\n this._block.writeUInt32BE(bits, this._blockSize - 4);\n\n // uint64\n } else {\n var lowBits = (bits & 0xffffffff) >>> 0;\n var highBits = (bits - lowBits) / 0x100000000;\n this._block.writeUInt32BE(highBits, this._blockSize - 8);\n this._block.writeUInt32BE(lowBits, this._blockSize - 4);\n }\n this._update(this._block);\n var hash = this._hash();\n return enc ? hash.toString(enc) : hash;\n};\nHash.prototype._update = function () {\n throw new Error('_update must be implemented by subclass');\n};\nmodule.exports = Hash;","/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-0, as defined\n * in FIPS PUB 180-1\n * This source code is derived from sha1.js of the same repository.\n * The difference between SHA-0 and SHA-1 is just a bitwise rotate left\n * operation was added.\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\nvar K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0];\nvar W = new Array(80);\nfunction Sha() {\n this.init();\n this._w = W;\n Hash.call(this, 64, 56);\n}\ninherits(Sha, Hash);\nSha.prototype.init = function () {\n this._a = 0x67452301;\n this._b = 0xefcdab89;\n this._c = 0x98badcfe;\n this._d = 0x10325476;\n this._e = 0xc3d2e1f0;\n return this;\n};\nfunction rotl5(num) {\n return num << 5 | num >>> 27;\n}\nfunction rotl30(num) {\n return num << 30 | num >>> 2;\n}\nfunction ft(s, b, c, d) {\n if (s === 0) return b & c | ~b & d;\n if (s === 2) return b & c | b & d | c & d;\n return b ^ c ^ d;\n}\nSha.prototype._update = function (M) {\n var W = this._w;\n var a = this._a | 0;\n var b = this._b | 0;\n var c = this._c | 0;\n var d = this._d | 0;\n var e = this._e | 0;\n for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4);\n for (; i < 80; ++i) W[i] = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16];\n for (var j = 0; j < 80; ++j) {\n var s = ~~(j / 20);\n var t = rotl5(a) + ft(s, b, c, d) + e + W[j] + K[s] | 0;\n e = d;\n d = c;\n c = rotl30(b);\n b = a;\n a = t;\n }\n this._a = a + this._a | 0;\n this._b = b + this._b | 0;\n this._c = c + this._c | 0;\n this._d = d + this._d | 0;\n this._e = e + this._e | 0;\n};\nSha.prototype._hash = function () {\n var H = Buffer.allocUnsafe(20);\n H.writeInt32BE(this._a | 0, 0);\n H.writeInt32BE(this._b | 0, 4);\n H.writeInt32BE(this._c | 0, 8);\n H.writeInt32BE(this._d | 0, 12);\n H.writeInt32BE(this._e | 0, 16);\n return H;\n};\nmodule.exports = Sha;","/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined\n * in FIPS PUB 180-1\n * Version 2.1a Copyright Paul Johnston 2000 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for details.\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\nvar K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0];\nvar W = new Array(80);\nfunction Sha1() {\n this.init();\n this._w = W;\n Hash.call(this, 64, 56);\n}\ninherits(Sha1, Hash);\nSha1.prototype.init = function () {\n this._a = 0x67452301;\n this._b = 0xefcdab89;\n this._c = 0x98badcfe;\n this._d = 0x10325476;\n this._e = 0xc3d2e1f0;\n return this;\n};\nfunction rotl1(num) {\n return num << 1 | num >>> 31;\n}\nfunction rotl5(num) {\n return num << 5 | num >>> 27;\n}\nfunction rotl30(num) {\n return num << 30 | num >>> 2;\n}\nfunction ft(s, b, c, d) {\n if (s === 0) return b & c | ~b & d;\n if (s === 2) return b & c | b & d | c & d;\n return b ^ c ^ d;\n}\nSha1.prototype._update = function (M) {\n var W = this._w;\n var a = this._a | 0;\n var b = this._b | 0;\n var c = this._c | 0;\n var d = this._d | 0;\n var e = this._e | 0;\n for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4);\n for (; i < 80; ++i) W[i] = rotl1(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16]);\n for (var j = 0; j < 80; ++j) {\n var s = ~~(j / 20);\n var t = rotl5(a) + ft(s, b, c, d) + e + W[j] + K[s] | 0;\n e = d;\n d = c;\n c = rotl30(b);\n b = a;\n a = t;\n }\n this._a = a + this._a | 0;\n this._b = b + this._b | 0;\n this._c = c + this._c | 0;\n this._d = d + this._d | 0;\n this._e = e + this._e | 0;\n};\nSha1.prototype._hash = function () {\n var H = Buffer.allocUnsafe(20);\n H.writeInt32BE(this._a | 0, 0);\n H.writeInt32BE(this._b | 0, 4);\n H.writeInt32BE(this._c | 0, 8);\n H.writeInt32BE(this._d | 0, 12);\n H.writeInt32BE(this._e | 0, 16);\n return H;\n};\nmodule.exports = Sha1;","/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\nvar K = [0x428A2F98, 0x71374491, 0xB5C0FBCF, 0xE9B5DBA5, 0x3956C25B, 0x59F111F1, 0x923F82A4, 0xAB1C5ED5, 0xD807AA98, 0x12835B01, 0x243185BE, 0x550C7DC3, 0x72BE5D74, 0x80DEB1FE, 0x9BDC06A7, 0xC19BF174, 0xE49B69C1, 0xEFBE4786, 0x0FC19DC6, 0x240CA1CC, 0x2DE92C6F, 0x4A7484AA, 0x5CB0A9DC, 0x76F988DA, 0x983E5152, 0xA831C66D, 0xB00327C8, 0xBF597FC7, 0xC6E00BF3, 0xD5A79147, 0x06CA6351, 0x14292967, 0x27B70A85, 0x2E1B2138, 0x4D2C6DFC, 0x53380D13, 0x650A7354, 0x766A0ABB, 0x81C2C92E, 0x92722C85, 0xA2BFE8A1, 0xA81A664B, 0xC24B8B70, 0xC76C51A3, 0xD192E819, 0xD6990624, 0xF40E3585, 0x106AA070, 0x19A4C116, 0x1E376C08, 0x2748774C, 0x34B0BCB5, 0x391C0CB3, 0x4ED8AA4A, 0x5B9CCA4F, 0x682E6FF3, 0x748F82EE, 0x78A5636F, 0x84C87814, 0x8CC70208, 0x90BEFFFA, 0xA4506CEB, 0xBEF9A3F7, 0xC67178F2];\nvar W = new Array(64);\nfunction Sha256() {\n this.init();\n this._w = W; // new Array(64)\n\n Hash.call(this, 64, 56);\n}\ninherits(Sha256, Hash);\nSha256.prototype.init = function () {\n this._a = 0x6a09e667;\n this._b = 0xbb67ae85;\n this._c = 0x3c6ef372;\n this._d = 0xa54ff53a;\n this._e = 0x510e527f;\n this._f = 0x9b05688c;\n this._g = 0x1f83d9ab;\n this._h = 0x5be0cd19;\n return this;\n};\nfunction ch(x, y, z) {\n return z ^ x & (y ^ z);\n}\nfunction maj(x, y, z) {\n return x & y | z & (x | y);\n}\nfunction sigma0(x) {\n return (x >>> 2 | x << 30) ^ (x >>> 13 | x << 19) ^ (x >>> 22 | x << 10);\n}\nfunction sigma1(x) {\n return (x >>> 6 | x << 26) ^ (x >>> 11 | x << 21) ^ (x >>> 25 | x << 7);\n}\nfunction gamma0(x) {\n return (x >>> 7 | x << 25) ^ (x >>> 18 | x << 14) ^ x >>> 3;\n}\nfunction gamma1(x) {\n return (x >>> 17 | x << 15) ^ (x >>> 19 | x << 13) ^ x >>> 10;\n}\nSha256.prototype._update = function (M) {\n var W = this._w;\n var a = this._a | 0;\n var b = this._b | 0;\n var c = this._c | 0;\n var d = this._d | 0;\n var e = this._e | 0;\n var f = this._f | 0;\n var g = this._g | 0;\n var h = this._h | 0;\n for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4);\n for (; i < 64; ++i) W[i] = gamma1(W[i - 2]) + W[i - 7] + gamma0(W[i - 15]) + W[i - 16] | 0;\n for (var j = 0; j < 64; ++j) {\n var T1 = h + sigma1(e) + ch(e, f, g) + K[j] + W[j] | 0;\n var T2 = sigma0(a) + maj(a, b, c) | 0;\n h = g;\n g = f;\n f = e;\n e = d + T1 | 0;\n d = c;\n c = b;\n b = a;\n a = T1 + T2 | 0;\n }\n this._a = a + this._a | 0;\n this._b = b + this._b | 0;\n this._c = c + this._c | 0;\n this._d = d + this._d | 0;\n this._e = e + this._e | 0;\n this._f = f + this._f | 0;\n this._g = g + this._g | 0;\n this._h = h + this._h | 0;\n};\nSha256.prototype._hash = function () {\n var H = Buffer.allocUnsafe(32);\n H.writeInt32BE(this._a, 0);\n H.writeInt32BE(this._b, 4);\n H.writeInt32BE(this._c, 8);\n H.writeInt32BE(this._d, 12);\n H.writeInt32BE(this._e, 16);\n H.writeInt32BE(this._f, 20);\n H.writeInt32BE(this._g, 24);\n H.writeInt32BE(this._h, 28);\n return H;\n};\nmodule.exports = Sha256;","/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits');\nvar Sha256 = require('./sha256');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\nvar W = new Array(64);\nfunction Sha224() {\n this.init();\n this._w = W; // new Array(64)\n\n Hash.call(this, 64, 56);\n}\ninherits(Sha224, Sha256);\nSha224.prototype.init = function () {\n this._a = 0xc1059ed8;\n this._b = 0x367cd507;\n this._c = 0x3070dd17;\n this._d = 0xf70e5939;\n this._e = 0xffc00b31;\n this._f = 0x68581511;\n this._g = 0x64f98fa7;\n this._h = 0xbefa4fa4;\n return this;\n};\nSha224.prototype._hash = function () {\n var H = Buffer.allocUnsafe(28);\n H.writeInt32BE(this._a, 0);\n H.writeInt32BE(this._b, 4);\n H.writeInt32BE(this._c, 8);\n H.writeInt32BE(this._d, 12);\n H.writeInt32BE(this._e, 16);\n H.writeInt32BE(this._f, 20);\n H.writeInt32BE(this._g, 24);\n return H;\n};\nmodule.exports = Sha224;","var inherits = require('inherits');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\nvar K = [0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd, 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc, 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019, 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118, 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe, 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2, 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1, 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694, 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3, 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65, 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483, 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5, 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210, 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4, 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725, 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70, 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926, 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df, 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8, 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b, 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001, 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30, 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910, 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8, 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53, 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8, 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb, 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3, 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60, 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec, 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9, 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b, 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207, 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178, 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6, 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b, 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493, 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c, 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a, 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817];\nvar W = new Array(160);\nfunction Sha512() {\n this.init();\n this._w = W;\n Hash.call(this, 128, 112);\n}\ninherits(Sha512, Hash);\nSha512.prototype.init = function () {\n this._ah = 0x6a09e667;\n this._bh = 0xbb67ae85;\n this._ch = 0x3c6ef372;\n this._dh = 0xa54ff53a;\n this._eh = 0x510e527f;\n this._fh = 0x9b05688c;\n this._gh = 0x1f83d9ab;\n this._hh = 0x5be0cd19;\n this._al = 0xf3bcc908;\n this._bl = 0x84caa73b;\n this._cl = 0xfe94f82b;\n this._dl = 0x5f1d36f1;\n this._el = 0xade682d1;\n this._fl = 0x2b3e6c1f;\n this._gl = 0xfb41bd6b;\n this._hl = 0x137e2179;\n return this;\n};\nfunction Ch(x, y, z) {\n return z ^ x & (y ^ z);\n}\nfunction maj(x, y, z) {\n return x & y | z & (x | y);\n}\nfunction sigma0(x, xl) {\n return (x >>> 28 | xl << 4) ^ (xl >>> 2 | x << 30) ^ (xl >>> 7 | x << 25);\n}\nfunction sigma1(x, xl) {\n return (x >>> 14 | xl << 18) ^ (x >>> 18 | xl << 14) ^ (xl >>> 9 | x << 23);\n}\nfunction Gamma0(x, xl) {\n return (x >>> 1 | xl << 31) ^ (x >>> 8 | xl << 24) ^ x >>> 7;\n}\nfunction Gamma0l(x, xl) {\n return (x >>> 1 | xl << 31) ^ (x >>> 8 | xl << 24) ^ (x >>> 7 | xl << 25);\n}\nfunction Gamma1(x, xl) {\n return (x >>> 19 | xl << 13) ^ (xl >>> 29 | x << 3) ^ x >>> 6;\n}\nfunction Gamma1l(x, xl) {\n return (x >>> 19 | xl << 13) ^ (xl >>> 29 | x << 3) ^ (x >>> 6 | xl << 26);\n}\nfunction getCarry(a, b) {\n return a >>> 0 < b >>> 0 ? 1 : 0;\n}\nSha512.prototype._update = function (M) {\n var W = this._w;\n var ah = this._ah | 0;\n var bh = this._bh | 0;\n var ch = this._ch | 0;\n var dh = this._dh | 0;\n var eh = this._eh | 0;\n var fh = this._fh | 0;\n var gh = this._gh | 0;\n var hh = this._hh | 0;\n var al = this._al | 0;\n var bl = this._bl | 0;\n var cl = this._cl | 0;\n var dl = this._dl | 0;\n var el = this._el | 0;\n var fl = this._fl | 0;\n var gl = this._gl | 0;\n var hl = this._hl | 0;\n for (var i = 0; i < 32; i += 2) {\n W[i] = M.readInt32BE(i * 4);\n W[i + 1] = M.readInt32BE(i * 4 + 4);\n }\n for (; i < 160; i += 2) {\n var xh = W[i - 15 * 2];\n var xl = W[i - 15 * 2 + 1];\n var gamma0 = Gamma0(xh, xl);\n var gamma0l = Gamma0l(xl, xh);\n xh = W[i - 2 * 2];\n xl = W[i - 2 * 2 + 1];\n var gamma1 = Gamma1(xh, xl);\n var gamma1l = Gamma1l(xl, xh);\n\n // W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16]\n var Wi7h = W[i - 7 * 2];\n var Wi7l = W[i - 7 * 2 + 1];\n var Wi16h = W[i - 16 * 2];\n var Wi16l = W[i - 16 * 2 + 1];\n var Wil = gamma0l + Wi7l | 0;\n var Wih = gamma0 + Wi7h + getCarry(Wil, gamma0l) | 0;\n Wil = Wil + gamma1l | 0;\n Wih = Wih + gamma1 + getCarry(Wil, gamma1l) | 0;\n Wil = Wil + Wi16l | 0;\n Wih = Wih + Wi16h + getCarry(Wil, Wi16l) | 0;\n W[i] = Wih;\n W[i + 1] = Wil;\n }\n for (var j = 0; j < 160; j += 2) {\n Wih = W[j];\n Wil = W[j + 1];\n var majh = maj(ah, bh, ch);\n var majl = maj(al, bl, cl);\n var sigma0h = sigma0(ah, al);\n var sigma0l = sigma0(al, ah);\n var sigma1h = sigma1(eh, el);\n var sigma1l = sigma1(el, eh);\n\n // t1 = h + sigma1 + ch + K[j] + W[j]\n var Kih = K[j];\n var Kil = K[j + 1];\n var chh = Ch(eh, fh, gh);\n var chl = Ch(el, fl, gl);\n var t1l = hl + sigma1l | 0;\n var t1h = hh + sigma1h + getCarry(t1l, hl) | 0;\n t1l = t1l + chl | 0;\n t1h = t1h + chh + getCarry(t1l, chl) | 0;\n t1l = t1l + Kil | 0;\n t1h = t1h + Kih + getCarry(t1l, Kil) | 0;\n t1l = t1l + Wil | 0;\n t1h = t1h + Wih + getCarry(t1l, Wil) | 0;\n\n // t2 = sigma0 + maj\n var t2l = sigma0l + majl | 0;\n var t2h = sigma0h + majh + getCarry(t2l, sigma0l) | 0;\n hh = gh;\n hl = gl;\n gh = fh;\n gl = fl;\n fh = eh;\n fl = el;\n el = dl + t1l | 0;\n eh = dh + t1h + getCarry(el, dl) | 0;\n dh = ch;\n dl = cl;\n ch = bh;\n cl = bl;\n bh = ah;\n bl = al;\n al = t1l + t2l | 0;\n ah = t1h + t2h + getCarry(al, t1l) | 0;\n }\n this._al = this._al + al | 0;\n this._bl = this._bl + bl | 0;\n this._cl = this._cl + cl | 0;\n this._dl = this._dl + dl | 0;\n this._el = this._el + el | 0;\n this._fl = this._fl + fl | 0;\n this._gl = this._gl + gl | 0;\n this._hl = this._hl + hl | 0;\n this._ah = this._ah + ah + getCarry(this._al, al) | 0;\n this._bh = this._bh + bh + getCarry(this._bl, bl) | 0;\n this._ch = this._ch + ch + getCarry(this._cl, cl) | 0;\n this._dh = this._dh + dh + getCarry(this._dl, dl) | 0;\n this._eh = this._eh + eh + getCarry(this._el, el) | 0;\n this._fh = this._fh + fh + getCarry(this._fl, fl) | 0;\n this._gh = this._gh + gh + getCarry(this._gl, gl) | 0;\n this._hh = this._hh + hh + getCarry(this._hl, hl) | 0;\n};\nSha512.prototype._hash = function () {\n var H = Buffer.allocUnsafe(64);\n function writeInt64BE(h, l, offset) {\n H.writeInt32BE(h, offset);\n H.writeInt32BE(l, offset + 4);\n }\n writeInt64BE(this._ah, this._al, 0);\n writeInt64BE(this._bh, this._bl, 8);\n writeInt64BE(this._ch, this._cl, 16);\n writeInt64BE(this._dh, this._dl, 24);\n writeInt64BE(this._eh, this._el, 32);\n writeInt64BE(this._fh, this._fl, 40);\n writeInt64BE(this._gh, this._gl, 48);\n writeInt64BE(this._hh, this._hl, 56);\n return H;\n};\nmodule.exports = Sha512;","var inherits = require('inherits');\nvar SHA512 = require('./sha512');\nvar Hash = require('./hash');\nvar Buffer = require('safe-buffer').Buffer;\nvar W = new Array(160);\nfunction Sha384() {\n this.init();\n this._w = W;\n Hash.call(this, 128, 112);\n}\ninherits(Sha384, SHA512);\nSha384.prototype.init = function () {\n this._ah = 0xcbbb9d5d;\n this._bh = 0x629a292a;\n this._ch = 0x9159015a;\n this._dh = 0x152fecd8;\n this._eh = 0x67332667;\n this._fh = 0x8eb44a87;\n this._gh = 0xdb0c2e0d;\n this._hh = 0x47b5481d;\n this._al = 0xc1059ed8;\n this._bl = 0x367cd507;\n this._cl = 0x3070dd17;\n this._dl = 0xf70e5939;\n this._el = 0xffc00b31;\n this._fl = 0x68581511;\n this._gl = 0x64f98fa7;\n this._hl = 0xbefa4fa4;\n return this;\n};\nSha384.prototype._hash = function () {\n var H = Buffer.allocUnsafe(48);\n function writeInt64BE(h, l, offset) {\n H.writeInt32BE(h, offset);\n H.writeInt32BE(l, offset + 4);\n }\n writeInt64BE(this._ah, this._al, 0);\n writeInt64BE(this._bh, this._bl, 8);\n writeInt64BE(this._ch, this._cl, 16);\n writeInt64BE(this._dh, this._dl, 24);\n writeInt64BE(this._eh, this._el, 32);\n writeInt64BE(this._fh, this._fl, 40);\n return H;\n};\nmodule.exports = Sha384;","var exports = module.exports = function SHA(algorithm) {\n algorithm = algorithm.toLowerCase();\n var Algorithm = exports[algorithm];\n if (!Algorithm) throw new Error(algorithm + ' is not supported (we accept pull requests)');\n return new Algorithm();\n};\nexports.sha = require('./sha');\nexports.sha1 = require('./sha1');\nexports.sha224 = require('./sha224');\nexports.sha256 = require('./sha256');\nexports.sha384 = require('./sha384');\nexports.sha512 = require('./sha512');","'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\nvar Transform = require('stream').Transform;\nvar StringDecoder = require('string_decoder').StringDecoder;\nvar inherits = require('inherits');\nfunction CipherBase(hashMode) {\n Transform.call(this);\n this.hashMode = typeof hashMode === 'string';\n if (this.hashMode) {\n this[hashMode] = this._finalOrDigest;\n } else {\n this['final'] = this._finalOrDigest;\n }\n if (this._final) {\n this.__final = this._final;\n this._final = null;\n }\n this._decoder = null;\n this._encoding = null;\n}\ninherits(CipherBase, Transform);\nvar useUint8Array = typeof Uint8Array !== 'undefined';\nvar useArrayBuffer = typeof ArrayBuffer !== 'undefined' && typeof Uint8Array !== 'undefined' && ArrayBuffer.isView && (Buffer.prototype instanceof Uint8Array || Buffer.TYPED_ARRAY_SUPPORT);\nCipherBase.prototype.update = function (data, inputEnc, outputEnc) {\n var bufferData;\n if (data instanceof Buffer) {\n // No need to do anything\n bufferData = data;\n } else if (typeof data === 'string') {\n // Convert strings to Buffer\n bufferData = Buffer.from(data, inputEnc);\n } else if (useArrayBuffer && ArrayBuffer.isView(data)) {\n /*\n * Wrap any TypedArray instances and DataViews\n * Makes sense only on engines with full TypedArray support -- let Buffer detect that\n */\n bufferData = Buffer.from(data.buffer, data.byteOffset, data.byteLength);\n } else if (useUint8Array && data instanceof Uint8Array) {\n /*\n * Uint8Array in engines where Buffer.from might not work with ArrayBuffer, just copy over\n * Doesn't make sense with other TypedArray instances\n */\n bufferData = Buffer.from(data);\n } else if (Buffer.isBuffer(data) && data.constructor && data.constructor.isBuffer && data.constructor.isBuffer(data)) {\n /*\n * Old Buffer polyfill on an engine that doesn't have TypedArray support\n * Also, this is from a different Buffer polyfill implementation then we have, as instanceof check failed\n * Convert to our current Buffer implementation\n */\n bufferData = Buffer.from(data);\n } else {\n throw new Error('The \"data\" argument must be of type string or an instance of Buffer, TypedArray, or DataView.');\n }\n var outData = this._update(bufferData);\n if (this.hashMode) {\n return this;\n }\n if (outputEnc) {\n outData = this._toString(outData, outputEnc);\n }\n return outData;\n};\nCipherBase.prototype.setAutoPadding = function () {};\nCipherBase.prototype.getAuthTag = function () {\n throw new Error('trying to get auth tag in unsupported state');\n};\nCipherBase.prototype.setAuthTag = function () {\n throw new Error('trying to set auth tag in unsupported state');\n};\nCipherBase.prototype.setAAD = function () {\n throw new Error('trying to set aad in unsupported state');\n};\nCipherBase.prototype._transform = function (data, _, next) {\n var err;\n try {\n if (this.hashMode) {\n this._update(data);\n } else {\n this.push(this._update(data));\n }\n } catch (e) {\n err = e;\n } finally {\n next(err);\n }\n};\nCipherBase.prototype._flush = function (done) {\n var err;\n try {\n this.push(this.__final());\n } catch (e) {\n err = e;\n }\n done(err);\n};\nCipherBase.prototype._finalOrDigest = function (outputEnc) {\n var outData = this.__final() || Buffer.alloc(0);\n if (outputEnc) {\n outData = this._toString(outData, outputEnc, true);\n }\n return outData;\n};\nCipherBase.prototype._toString = function (value, enc, fin) {\n if (!this._decoder) {\n this._decoder = new StringDecoder(enc);\n this._encoding = enc;\n }\n if (this._encoding !== enc) {\n throw new Error('can’t switch encodings');\n }\n var out = this._decoder.write(value);\n if (fin) {\n out += this._decoder.end();\n }\n return out;\n};\nmodule.exports = CipherBase;","'use strict';\n\nvar inherits = require('inherits');\nvar MD5 = require('md5.js');\nvar RIPEMD160 = require('ripemd160');\nvar sha = require('sha.js');\nvar Base = require('cipher-base');\nfunction Hash(hash) {\n Base.call(this, 'digest');\n this._hash = hash;\n}\ninherits(Hash, Base);\nHash.prototype._update = function (data) {\n this._hash.update(data);\n};\nHash.prototype._final = function () {\n return this._hash.digest();\n};\nmodule.exports = function createHash(alg) {\n alg = alg.toLowerCase();\n if (alg === 'md5') return new MD5();\n if (alg === 'rmd160' || alg === 'ripemd160') return new RIPEMD160();\n return new Hash(sha(alg));\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rlphash = exports.ripemd160FromArray = exports.ripemd160FromString = exports.ripemd160 = exports.sha256FromArray = exports.sha256FromString = exports.sha256 = exports.keccakFromArray = exports.keccakFromHexString = exports.keccakFromString = exports.keccak256 = exports.keccak = void 0;\nvar keccak_1 = require(\"ethereum-cryptography/keccak\");\nvar createHash = require('create-hash');\nvar externals_1 = require(\"./externals\");\nvar bytes_1 = require(\"./bytes\");\nvar helpers_1 = require(\"./helpers\");\n/**\n * Creates Keccak hash of a Buffer input\n * @param a The input data (Buffer)\n * @param bits (number = 256) The Keccak width\n */\nvar keccak = function (a, bits) {\n if (bits === void 0) {\n bits = 256;\n }\n (0, helpers_1.assertIsBuffer)(a);\n switch (bits) {\n case 224:\n {\n return (0, keccak_1.keccak224)(a);\n }\n case 256:\n {\n return (0, keccak_1.keccak256)(a);\n }\n case 384:\n {\n return (0, keccak_1.keccak384)(a);\n }\n case 512:\n {\n return (0, keccak_1.keccak512)(a);\n }\n default:\n {\n throw new Error(\"Invald algorithm: keccak\".concat(bits));\n }\n }\n};\nexports.keccak = keccak;\n/**\n * Creates Keccak-256 hash of the input, alias for keccak(a, 256).\n * @param a The input data (Buffer)\n */\nvar keccak256 = function (a) {\n return (0, exports.keccak)(a);\n};\nexports.keccak256 = keccak256;\n/**\n * Creates Keccak hash of a utf-8 string input\n * @param a The input data (String)\n * @param bits (number = 256) The Keccak width\n */\nvar keccakFromString = function (a, bits) {\n if (bits === void 0) {\n bits = 256;\n }\n (0, helpers_1.assertIsString)(a);\n var buf = Buffer.from(a, 'utf8');\n return (0, exports.keccak)(buf, bits);\n};\nexports.keccakFromString = keccakFromString;\n/**\n * Creates Keccak hash of an 0x-prefixed string input\n * @param a The input data (String)\n * @param bits (number = 256) The Keccak width\n */\nvar keccakFromHexString = function (a, bits) {\n if (bits === void 0) {\n bits = 256;\n }\n (0, helpers_1.assertIsHexString)(a);\n return (0, exports.keccak)((0, bytes_1.toBuffer)(a), bits);\n};\nexports.keccakFromHexString = keccakFromHexString;\n/**\n * Creates Keccak hash of a number array input\n * @param a The input data (number[])\n * @param bits (number = 256) The Keccak width\n */\nvar keccakFromArray = function (a, bits) {\n if (bits === void 0) {\n bits = 256;\n }\n (0, helpers_1.assertIsArray)(a);\n return (0, exports.keccak)((0, bytes_1.toBuffer)(a), bits);\n};\nexports.keccakFromArray = keccakFromArray;\n/**\n * Creates SHA256 hash of an input.\n * @param a The input data (Buffer|Array|String)\n */\nvar _sha256 = function (a) {\n a = (0, bytes_1.toBuffer)(a);\n return createHash('sha256').update(a).digest();\n};\n/**\n * Creates SHA256 hash of a Buffer input.\n * @param a The input data (Buffer)\n */\nvar sha256 = function (a) {\n (0, helpers_1.assertIsBuffer)(a);\n return _sha256(a);\n};\nexports.sha256 = sha256;\n/**\n * Creates SHA256 hash of a string input.\n * @param a The input data (string)\n */\nvar sha256FromString = function (a) {\n (0, helpers_1.assertIsString)(a);\n return _sha256(a);\n};\nexports.sha256FromString = sha256FromString;\n/**\n * Creates SHA256 hash of a number[] input.\n * @param a The input data (number[])\n */\nvar sha256FromArray = function (a) {\n (0, helpers_1.assertIsArray)(a);\n return _sha256(a);\n};\nexports.sha256FromArray = sha256FromArray;\n/**\n * Creates RIPEMD160 hash of the input.\n * @param a The input data (Buffer|Array|String|Number)\n * @param padded Whether it should be padded to 256 bits or not\n */\nvar _ripemd160 = function (a, padded) {\n a = (0, bytes_1.toBuffer)(a);\n var hash = createHash('rmd160').update(a).digest();\n if (padded === true) {\n return (0, bytes_1.setLengthLeft)(hash, 32);\n } else {\n return hash;\n }\n};\n/**\n * Creates RIPEMD160 hash of a Buffer input.\n * @param a The input data (Buffer)\n * @param padded Whether it should be padded to 256 bits or not\n */\nvar ripemd160 = function (a, padded) {\n (0, helpers_1.assertIsBuffer)(a);\n return _ripemd160(a, padded);\n};\nexports.ripemd160 = ripemd160;\n/**\n * Creates RIPEMD160 hash of a string input.\n * @param a The input data (String)\n * @param padded Whether it should be padded to 256 bits or not\n */\nvar ripemd160FromString = function (a, padded) {\n (0, helpers_1.assertIsString)(a);\n return _ripemd160(a, padded);\n};\nexports.ripemd160FromString = ripemd160FromString;\n/**\n * Creates RIPEMD160 hash of a number[] input.\n * @param a The input data (number[])\n * @param padded Whether it should be padded to 256 bits or not\n */\nvar ripemd160FromArray = function (a, padded) {\n (0, helpers_1.assertIsArray)(a);\n return _ripemd160(a, padded);\n};\nexports.ripemd160FromArray = ripemd160FromArray;\n/**\n * Creates SHA-3 hash of the RLP encoded version of the input.\n * @param a The input data\n */\nvar rlphash = function (a) {\n return (0, exports.keccak)(externals_1.rlp.encode(a));\n};\nexports.rlphash = rlphash;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.toType = exports.TypeOutput = exports.bnToRlp = exports.bnToUnpaddedBuffer = exports.bnToHex = void 0;\nvar externals_1 = require(\"./externals\");\nvar internal_1 = require(\"./internal\");\nvar bytes_1 = require(\"./bytes\");\n/**\n * Convert BN to 0x-prefixed hex string.\n */\nfunction bnToHex(value) {\n return \"0x\".concat(value.toString(16));\n}\nexports.bnToHex = bnToHex;\n/**\n * Convert value from BN to an unpadded Buffer\n * (useful for RLP transport)\n * @param value value to convert\n */\nfunction bnToUnpaddedBuffer(value) {\n // Using `bn.toArrayLike(Buffer)` instead of `bn.toBuffer()`\n // for compatibility with browserify and similar tools\n return (0, bytes_1.unpadBuffer)(value.toArrayLike(Buffer));\n}\nexports.bnToUnpaddedBuffer = bnToUnpaddedBuffer;\n/**\n * Deprecated alias for {@link bnToUnpaddedBuffer}\n * @deprecated\n */\nfunction bnToRlp(value) {\n return bnToUnpaddedBuffer(value);\n}\nexports.bnToRlp = bnToRlp;\n/**\n * Type output options\n */\nvar TypeOutput;\n(function (TypeOutput) {\n TypeOutput[TypeOutput[\"Number\"] = 0] = \"Number\";\n TypeOutput[TypeOutput[\"BN\"] = 1] = \"BN\";\n TypeOutput[TypeOutput[\"Buffer\"] = 2] = \"Buffer\";\n TypeOutput[TypeOutput[\"PrefixedHexString\"] = 3] = \"PrefixedHexString\";\n})(TypeOutput = exports.TypeOutput || (exports.TypeOutput = {}));\nfunction toType(input, outputType) {\n if (input === null) {\n return null;\n }\n if (input === undefined) {\n return undefined;\n }\n if (typeof input === 'string' && !(0, internal_1.isHexString)(input)) {\n throw new Error(\"A string must be provided with a 0x-prefix, given: \".concat(input));\n } else if (typeof input === 'number' && !Number.isSafeInteger(input)) {\n throw new Error('The provided number is greater than MAX_SAFE_INTEGER (please use an alternative input type)');\n }\n var output = (0, bytes_1.toBuffer)(input);\n if (outputType === TypeOutput.Buffer) {\n return output;\n } else if (outputType === TypeOutput.BN) {\n return new externals_1.BN(output);\n } else if (outputType === TypeOutput.Number) {\n var bn = new externals_1.BN(output);\n var max = new externals_1.BN(Number.MAX_SAFE_INTEGER.toString());\n if (bn.gt(max)) {\n throw new Error('The provided number is greater than MAX_SAFE_INTEGER (please use an alternative output type)');\n }\n return bn.toNumber();\n } else {\n // outputType === TypeOutput.PrefixedHexString\n return \"0x\".concat(output.toString('hex'));\n }\n}\nexports.toType = toType;\n","\"use strict\";\n\nvar __read = this && this.__read || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n};\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isZeroAddress = exports.zeroAddress = exports.importPublic = exports.privateToAddress = exports.privateToPublic = exports.publicToAddress = exports.pubToAddress = exports.isValidPublic = exports.isValidPrivate = exports.generateAddress2 = exports.generateAddress = exports.isValidChecksumAddress = exports.toChecksumAddress = exports.isValidAddress = exports.Account = void 0;\nvar assert_1 = __importDefault(require(\"assert\"));\nvar externals_1 = require(\"./externals\");\nvar secp256k1_1 = require(\"ethereum-cryptography/secp256k1\");\nvar internal_1 = require(\"./internal\");\nvar constants_1 = require(\"./constants\");\nvar bytes_1 = require(\"./bytes\");\nvar hash_1 = require(\"./hash\");\nvar helpers_1 = require(\"./helpers\");\nvar types_1 = require(\"./types\");\nvar Account = /** @class */function () {\n /**\n * This constructor assigns and validates the values.\n * Use the static factory methods to assist in creating an Account from varying data types.\n */\n function Account(nonce, balance, stateRoot, codeHash) {\n if (nonce === void 0) {\n nonce = new externals_1.BN(0);\n }\n if (balance === void 0) {\n balance = new externals_1.BN(0);\n }\n if (stateRoot === void 0) {\n stateRoot = constants_1.KECCAK256_RLP;\n }\n if (codeHash === void 0) {\n codeHash = constants_1.KECCAK256_NULL;\n }\n this.nonce = nonce;\n this.balance = balance;\n this.stateRoot = stateRoot;\n this.codeHash = codeHash;\n this._validate();\n }\n Account.fromAccountData = function (accountData) {\n var nonce = accountData.nonce,\n balance = accountData.balance,\n stateRoot = accountData.stateRoot,\n codeHash = accountData.codeHash;\n return new Account(nonce ? new externals_1.BN((0, bytes_1.toBuffer)(nonce)) : undefined, balance ? new externals_1.BN((0, bytes_1.toBuffer)(balance)) : undefined, stateRoot ? (0, bytes_1.toBuffer)(stateRoot) : undefined, codeHash ? (0, bytes_1.toBuffer)(codeHash) : undefined);\n };\n Account.fromRlpSerializedAccount = function (serialized) {\n var values = externals_1.rlp.decode(serialized);\n if (!Array.isArray(values)) {\n throw new Error('Invalid serialized account input. Must be array');\n }\n return this.fromValuesArray(values);\n };\n Account.fromValuesArray = function (values) {\n var _a = __read(values, 4),\n nonce = _a[0],\n balance = _a[1],\n stateRoot = _a[2],\n codeHash = _a[3];\n return new Account(new externals_1.BN(nonce), new externals_1.BN(balance), stateRoot, codeHash);\n };\n Account.prototype._validate = function () {\n if (this.nonce.lt(new externals_1.BN(0))) {\n throw new Error('nonce must be greater than zero');\n }\n if (this.balance.lt(new externals_1.BN(0))) {\n throw new Error('balance must be greater than zero');\n }\n if (this.stateRoot.length !== 32) {\n throw new Error('stateRoot must have a length of 32');\n }\n if (this.codeHash.length !== 32) {\n throw new Error('codeHash must have a length of 32');\n }\n };\n /**\n * Returns a Buffer Array of the raw Buffers for the account, in order.\n */\n Account.prototype.raw = function () {\n return [(0, types_1.bnToUnpaddedBuffer)(this.nonce), (0, types_1.bnToUnpaddedBuffer)(this.balance), this.stateRoot, this.codeHash];\n };\n /**\n * Returns the RLP serialization of the account as a `Buffer`.\n */\n Account.prototype.serialize = function () {\n return externals_1.rlp.encode(this.raw());\n };\n /**\n * Returns a `Boolean` determining if the account is a contract.\n */\n Account.prototype.isContract = function () {\n return !this.codeHash.equals(constants_1.KECCAK256_NULL);\n };\n /**\n * Returns a `Boolean` determining if the account is empty complying to the definition of\n * account emptiness in [EIP-161](https://eips.ethereum.org/EIPS/eip-161):\n * \"An account is considered empty when it has no code and zero nonce and zero balance.\"\n */\n Account.prototype.isEmpty = function () {\n return this.balance.isZero() && this.nonce.isZero() && this.codeHash.equals(constants_1.KECCAK256_NULL);\n };\n return Account;\n}();\nexports.Account = Account;\n/**\n * Checks if the address is a valid. Accepts checksummed addresses too.\n */\nvar isValidAddress = function (hexAddress) {\n try {\n (0, helpers_1.assertIsString)(hexAddress);\n } catch (e) {\n return false;\n }\n return /^0x[0-9a-fA-F]{40}$/.test(hexAddress);\n};\nexports.isValidAddress = isValidAddress;\n/**\n * Returns a checksummed address.\n *\n * If an eip1191ChainId is provided, the chainId will be included in the checksum calculation. This\n * has the effect of checksummed addresses for one chain having invalid checksums for others.\n * For more details see [EIP-1191](https://eips.ethereum.org/EIPS/eip-1191).\n *\n * WARNING: Checksums with and without the chainId will differ and the EIP-1191 checksum is not\n * backwards compatible to the original widely adopted checksum format standard introduced in\n * [EIP-55](https://eips.ethereum.org/EIPS/eip-55), so this will break in existing applications.\n * Usage of this EIP is therefore discouraged unless you have a very targeted use case.\n */\nvar toChecksumAddress = function (hexAddress, eip1191ChainId) {\n (0, helpers_1.assertIsHexString)(hexAddress);\n var address = (0, internal_1.stripHexPrefix)(hexAddress).toLowerCase();\n var prefix = '';\n if (eip1191ChainId) {\n var chainId = (0, types_1.toType)(eip1191ChainId, types_1.TypeOutput.BN);\n prefix = chainId.toString() + '0x';\n }\n var hash = (0, hash_1.keccakFromString)(prefix + address).toString('hex');\n var ret = '0x';\n for (var i = 0; i < address.length; i++) {\n if (parseInt(hash[i], 16) >= 8) {\n ret += address[i].toUpperCase();\n } else {\n ret += address[i];\n }\n }\n return ret;\n};\nexports.toChecksumAddress = toChecksumAddress;\n/**\n * Checks if the address is a valid checksummed address.\n *\n * See toChecksumAddress' documentation for details about the eip1191ChainId parameter.\n */\nvar isValidChecksumAddress = function (hexAddress, eip1191ChainId) {\n return (0, exports.isValidAddress)(hexAddress) && (0, exports.toChecksumAddress)(hexAddress, eip1191ChainId) === hexAddress;\n};\nexports.isValidChecksumAddress = isValidChecksumAddress;\n/**\n * Generates an address of a newly created contract.\n * @param from The address which is creating this new address\n * @param nonce The nonce of the from account\n */\nvar generateAddress = function (from, nonce) {\n (0, helpers_1.assertIsBuffer)(from);\n (0, helpers_1.assertIsBuffer)(nonce);\n var nonceBN = new externals_1.BN(nonce);\n if (nonceBN.isZero()) {\n // in RLP we want to encode null in the case of zero nonce\n // read the RLP documentation for an answer if you dare\n return (0, hash_1.rlphash)([from, null]).slice(-20);\n }\n // Only take the lower 160bits of the hash\n return (0, hash_1.rlphash)([from, Buffer.from(nonceBN.toArray())]).slice(-20);\n};\nexports.generateAddress = generateAddress;\n/**\n * Generates an address for a contract created using CREATE2.\n * @param from The address which is creating this new address\n * @param salt A salt\n * @param initCode The init code of the contract being created\n */\nvar generateAddress2 = function (from, salt, initCode) {\n (0, helpers_1.assertIsBuffer)(from);\n (0, helpers_1.assertIsBuffer)(salt);\n (0, helpers_1.assertIsBuffer)(initCode);\n (0, assert_1.default)(from.length === 20);\n (0, assert_1.default)(salt.length === 32);\n var address = (0, hash_1.keccak256)(Buffer.concat([Buffer.from('ff', 'hex'), from, salt, (0, hash_1.keccak256)(initCode)]));\n return address.slice(-20);\n};\nexports.generateAddress2 = generateAddress2;\n/**\n * Checks if the private key satisfies the rules of the curve secp256k1.\n */\nvar isValidPrivate = function (privateKey) {\n return (0, secp256k1_1.privateKeyVerify)(privateKey);\n};\nexports.isValidPrivate = isValidPrivate;\n/**\n * Checks if the public key satisfies the rules of the curve secp256k1\n * and the requirements of Ethereum.\n * @param publicKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nvar isValidPublic = function (publicKey, sanitize) {\n if (sanitize === void 0) {\n sanitize = false;\n }\n (0, helpers_1.assertIsBuffer)(publicKey);\n if (publicKey.length === 64) {\n // Convert to SEC1 for secp256k1\n return (0, secp256k1_1.publicKeyVerify)(Buffer.concat([Buffer.from([4]), publicKey]));\n }\n if (!sanitize) {\n return false;\n }\n return (0, secp256k1_1.publicKeyVerify)(publicKey);\n};\nexports.isValidPublic = isValidPublic;\n/**\n * Returns the ethereum address of a given public key.\n * Accepts \"Ethereum public keys\" and SEC1 encoded keys.\n * @param pubKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nvar pubToAddress = function (pubKey, sanitize) {\n if (sanitize === void 0) {\n sanitize = false;\n }\n (0, helpers_1.assertIsBuffer)(pubKey);\n if (sanitize && pubKey.length !== 64) {\n pubKey = Buffer.from((0, secp256k1_1.publicKeyConvert)(pubKey, false).slice(1));\n }\n (0, assert_1.default)(pubKey.length === 64);\n // Only take the lower 160bits of the hash\n return (0, hash_1.keccak)(pubKey).slice(-20);\n};\nexports.pubToAddress = pubToAddress;\nexports.publicToAddress = exports.pubToAddress;\n/**\n * Returns the ethereum public key of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nvar privateToPublic = function (privateKey) {\n (0, helpers_1.assertIsBuffer)(privateKey);\n // skip the type flag and use the X, Y points\n return Buffer.from((0, secp256k1_1.publicKeyCreate)(privateKey, false)).slice(1);\n};\nexports.privateToPublic = privateToPublic;\n/**\n * Returns the ethereum address of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nvar privateToAddress = function (privateKey) {\n return (0, exports.publicToAddress)((0, exports.privateToPublic)(privateKey));\n};\nexports.privateToAddress = privateToAddress;\n/**\n * Converts a public key to the Ethereum format.\n */\nvar importPublic = function (publicKey) {\n (0, helpers_1.assertIsBuffer)(publicKey);\n if (publicKey.length !== 64) {\n publicKey = Buffer.from((0, secp256k1_1.publicKeyConvert)(publicKey, false).slice(1));\n }\n return publicKey;\n};\nexports.importPublic = importPublic;\n/**\n * Returns the zero address.\n */\nvar zeroAddress = function () {\n var addressLength = 20;\n var addr = (0, bytes_1.zeros)(addressLength);\n return (0, bytes_1.bufferToHex)(addr);\n};\nexports.zeroAddress = zeroAddress;\n/**\n * Checks if a given address is the zero address.\n */\nvar isZeroAddress = function (hexAddress) {\n try {\n (0, helpers_1.assertIsString)(hexAddress);\n } catch (e) {\n return false;\n }\n var zeroAddr = (0, exports.zeroAddress)();\n return zeroAddr === hexAddress;\n};\nexports.isZeroAddress = isZeroAddress;\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Address = void 0;\nvar assert_1 = __importDefault(require(\"assert\"));\nvar externals_1 = require(\"./externals\");\nvar bytes_1 = require(\"./bytes\");\nvar account_1 = require(\"./account\");\nvar Address = /** @class */function () {\n function Address(buf) {\n (0, assert_1.default)(buf.length === 20, 'Invalid address length');\n this.buf = buf;\n }\n /**\n * Returns the zero address.\n */\n Address.zero = function () {\n return new Address((0, bytes_1.zeros)(20));\n };\n /**\n * Returns an Address object from a hex-encoded string.\n * @param str - Hex-encoded address\n */\n Address.fromString = function (str) {\n (0, assert_1.default)((0, account_1.isValidAddress)(str), 'Invalid address');\n return new Address((0, bytes_1.toBuffer)(str));\n };\n /**\n * Returns an address for a given public key.\n * @param pubKey The two points of an uncompressed key\n */\n Address.fromPublicKey = function (pubKey) {\n (0, assert_1.default)(Buffer.isBuffer(pubKey), 'Public key should be Buffer');\n var buf = (0, account_1.pubToAddress)(pubKey);\n return new Address(buf);\n };\n /**\n * Returns an address for a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\n Address.fromPrivateKey = function (privateKey) {\n (0, assert_1.default)(Buffer.isBuffer(privateKey), 'Private key should be Buffer');\n var buf = (0, account_1.privateToAddress)(privateKey);\n return new Address(buf);\n };\n /**\n * Generates an address for a newly created contract.\n * @param from The address which is creating this new address\n * @param nonce The nonce of the from account\n */\n Address.generate = function (from, nonce) {\n (0, assert_1.default)(externals_1.BN.isBN(nonce));\n return new Address((0, account_1.generateAddress)(from.buf, nonce.toArrayLike(Buffer)));\n };\n /**\n * Generates an address for a contract created using CREATE2.\n * @param from The address which is creating this new address\n * @param salt A salt\n * @param initCode The init code of the contract being created\n */\n Address.generate2 = function (from, salt, initCode) {\n (0, assert_1.default)(Buffer.isBuffer(salt));\n (0, assert_1.default)(Buffer.isBuffer(initCode));\n return new Address((0, account_1.generateAddress2)(from.buf, salt, initCode));\n };\n /**\n * Is address equal to another.\n */\n Address.prototype.equals = function (address) {\n return this.buf.equals(address.buf);\n };\n /**\n * Is address zero.\n */\n Address.prototype.isZero = function () {\n return this.equals(Address.zero());\n };\n /**\n * True if address is in the address range defined\n * by EIP-1352\n */\n Address.prototype.isPrecompileOrSystemAddress = function () {\n var addressBN = new externals_1.BN(this.buf);\n var rangeMin = new externals_1.BN(0);\n var rangeMax = new externals_1.BN('ffff', 'hex');\n return addressBN.gte(rangeMin) && addressBN.lte(rangeMax);\n };\n /**\n * Returns hex encoding of address.\n */\n Address.prototype.toString = function () {\n return '0x' + this.buf.toString('hex');\n };\n /**\n * Returns Buffer representation of address.\n */\n Address.prototype.toBuffer = function () {\n return Buffer.from(this.buf);\n };\n return Address;\n}();\nexports.Address = Address;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hashPersonalMessage = exports.isValidSignature = exports.fromRpcSig = exports.toCompactSig = exports.toRpcSig = exports.ecrecover = exports.ecsign = void 0;\nvar secp256k1_1 = require(\"ethereum-cryptography/secp256k1\");\nvar externals_1 = require(\"./externals\");\nvar bytes_1 = require(\"./bytes\");\nvar hash_1 = require(\"./hash\");\nvar helpers_1 = require(\"./helpers\");\nvar types_1 = require(\"./types\");\nfunction ecsign(msgHash, privateKey, chainId) {\n var _a = (0, secp256k1_1.ecdsaSign)(msgHash, privateKey),\n signature = _a.signature,\n recovery = _a.recid;\n var r = Buffer.from(signature.slice(0, 32));\n var s = Buffer.from(signature.slice(32, 64));\n if (!chainId || typeof chainId === 'number') {\n // return legacy type ECDSASignature (deprecated in favor of ECDSASignatureBuffer to handle large chainIds)\n if (chainId && !Number.isSafeInteger(chainId)) {\n throw new Error('The provided number is greater than MAX_SAFE_INTEGER (please use an alternative input type)');\n }\n var v_1 = chainId ? recovery + (chainId * 2 + 35) : recovery + 27;\n return {\n r: r,\n s: s,\n v: v_1\n };\n }\n var chainIdBN = (0, types_1.toType)(chainId, types_1.TypeOutput.BN);\n var v = chainIdBN.muln(2).addn(35).addn(recovery).toArrayLike(Buffer);\n return {\n r: r,\n s: s,\n v: v\n };\n}\nexports.ecsign = ecsign;\nfunction calculateSigRecovery(v, chainId) {\n var vBN = (0, types_1.toType)(v, types_1.TypeOutput.BN);\n if (vBN.eqn(0) || vBN.eqn(1)) return (0, types_1.toType)(v, types_1.TypeOutput.BN);\n if (!chainId) {\n return vBN.subn(27);\n }\n var chainIdBN = (0, types_1.toType)(chainId, types_1.TypeOutput.BN);\n return vBN.sub(chainIdBN.muln(2).addn(35));\n}\nfunction isValidSigRecovery(recovery) {\n var rec = new externals_1.BN(recovery);\n return rec.eqn(0) || rec.eqn(1);\n}\n/**\n * ECDSA public key recovery from signature.\n * NOTE: Accepts `v == 0 | v == 1` for EIP1559 transactions\n * @returns Recovered public key\n */\nvar ecrecover = function (msgHash, v, r, s, chainId) {\n var signature = Buffer.concat([(0, bytes_1.setLengthLeft)(r, 32), (0, bytes_1.setLengthLeft)(s, 32)], 64);\n var recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n var senderPubKey = (0, secp256k1_1.ecdsaRecover)(signature, recovery.toNumber(), msgHash);\n return Buffer.from((0, secp256k1_1.publicKeyConvert)(senderPubKey, false).slice(1));\n};\nexports.ecrecover = ecrecover;\n/**\n * Convert signature parameters into the format of `eth_sign` RPC method.\n * NOTE: Accepts `v == 0 | v == 1` for EIP1559 transactions\n * @returns Signature\n */\nvar toRpcSig = function (v, r, s, chainId) {\n var recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n // geth (and the RPC eth_sign method) uses the 65 byte format used by Bitcoin\n return (0, bytes_1.bufferToHex)(Buffer.concat([(0, bytes_1.setLengthLeft)(r, 32), (0, bytes_1.setLengthLeft)(s, 32), (0, bytes_1.toBuffer)(v)]));\n};\nexports.toRpcSig = toRpcSig;\n/**\n * Convert signature parameters into the format of Compact Signature Representation (EIP-2098).\n * NOTE: Accepts `v == 0 | v == 1` for EIP1559 transactions\n * @returns Signature\n */\nvar toCompactSig = function (v, r, s, chainId) {\n var recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n var vn = (0, types_1.toType)(v, types_1.TypeOutput.Number);\n var ss = s;\n if (vn > 28 && vn % 2 === 1 || vn === 1 || vn === 28) {\n ss = Buffer.from(s);\n ss[0] |= 0x80;\n }\n return (0, bytes_1.bufferToHex)(Buffer.concat([(0, bytes_1.setLengthLeft)(r, 32), (0, bytes_1.setLengthLeft)(ss, 32)]));\n};\nexports.toCompactSig = toCompactSig;\n/**\n * Convert signature format of the `eth_sign` RPC method to signature parameters\n * NOTE: all because of a bug in geth: https://github.com/ethereum/go-ethereum/issues/2053\n * NOTE: After EIP1559, `v` could be `0` or `1` but this function assumes\n * it's a signed message (EIP-191 or EIP-712) adding `27` at the end. Remove if needed.\n */\nvar fromRpcSig = function (sig) {\n var buf = (0, bytes_1.toBuffer)(sig);\n var r;\n var s;\n var v;\n if (buf.length >= 65) {\n r = buf.slice(0, 32);\n s = buf.slice(32, 64);\n v = (0, bytes_1.bufferToInt)(buf.slice(64));\n } else if (buf.length === 64) {\n // Compact Signature Representation (https://eips.ethereum.org/EIPS/eip-2098)\n r = buf.slice(0, 32);\n s = buf.slice(32, 64);\n v = (0, bytes_1.bufferToInt)(buf.slice(32, 33)) >> 7;\n s[0] &= 0x7f;\n } else {\n throw new Error('Invalid signature length');\n }\n // support both versions of `eth_sign` responses\n if (v < 27) {\n v += 27;\n }\n return {\n v: v,\n r: r,\n s: s\n };\n};\nexports.fromRpcSig = fromRpcSig;\n/**\n * Validate a ECDSA signature.\n * NOTE: Accepts `v == 0 | v == 1` for EIP1559 transactions\n * @param homesteadOrLater Indicates whether this is being used on either the homestead hardfork or a later one\n */\nvar isValidSignature = function (v, r, s, homesteadOrLater, chainId) {\n if (homesteadOrLater === void 0) {\n homesteadOrLater = true;\n }\n var SECP256K1_N_DIV_2 = new externals_1.BN('7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a0', 16);\n var SECP256K1_N = new externals_1.BN('fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141', 16);\n if (r.length !== 32 || s.length !== 32) {\n return false;\n }\n if (!isValidSigRecovery(calculateSigRecovery(v, chainId))) {\n return false;\n }\n var rBN = new externals_1.BN(r);\n var sBN = new externals_1.BN(s);\n if (rBN.isZero() || rBN.gt(SECP256K1_N) || sBN.isZero() || sBN.gt(SECP256K1_N)) {\n return false;\n }\n if (homesteadOrLater && sBN.cmp(SECP256K1_N_DIV_2) === 1) {\n return false;\n }\n return true;\n};\nexports.isValidSignature = isValidSignature;\n/**\n * Returns the keccak-256 hash of `message`, prefixed with the header used by the `eth_sign` RPC call.\n * The output of this function can be fed into `ecsign` to produce the same signature as the `eth_sign`\n * call for a given `message`, or fed to `ecrecover` along with a signature to recover the public key\n * used to produce the signature.\n */\nvar hashPersonalMessage = function (message) {\n (0, helpers_1.assertIsBuffer)(message);\n var prefix = Buffer.from(\"\\u0019Ethereum Signed Message:\\n\".concat(message.length), 'utf-8');\n return (0, hash_1.keccak)(Buffer.concat([prefix, message]));\n};\nexports.hashPersonalMessage = hashPersonalMessage;\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.defineProperties = void 0;\nvar assert_1 = __importDefault(require(\"assert\"));\nvar internal_1 = require(\"./internal\");\nvar externals_1 = require(\"./externals\");\nvar bytes_1 = require(\"./bytes\");\n/**\n * Defines properties on a `Object`. It make the assumption that underlying data is binary.\n * @param self the `Object` to define properties on\n * @param fields an array fields to define. Fields can contain:\n * * `name` - the name of the properties\n * * `length` - the number of bytes the field can have\n * * `allowLess` - if the field can be less than the length\n * * `allowEmpty`\n * @param data data to be validated against the definitions\n * @deprecated\n */\nvar defineProperties = function (self, fields, data) {\n self.raw = [];\n self._fields = [];\n // attach the `toJSON`\n self.toJSON = function (label) {\n if (label === void 0) {\n label = false;\n }\n if (label) {\n var obj_1 = {};\n self._fields.forEach(function (field) {\n obj_1[field] = \"0x\".concat(self[field].toString('hex'));\n });\n return obj_1;\n }\n return (0, bytes_1.baToJSON)(self.raw);\n };\n self.serialize = function serialize() {\n return externals_1.rlp.encode(self.raw);\n };\n fields.forEach(function (field, i) {\n self._fields.push(field.name);\n function getter() {\n return self.raw[i];\n }\n function setter(v) {\n v = (0, bytes_1.toBuffer)(v);\n if (v.toString('hex') === '00' && !field.allowZero) {\n v = Buffer.allocUnsafe(0);\n }\n if (field.allowLess && field.length) {\n v = (0, bytes_1.unpadBuffer)(v);\n (0, assert_1.default)(field.length >= v.length, \"The field \".concat(field.name, \" must not have more \").concat(field.length, \" bytes\"));\n } else if (!(field.allowZero && v.length === 0) && field.length) {\n (0, assert_1.default)(field.length === v.length, \"The field \".concat(field.name, \" must have byte length of \").concat(field.length));\n }\n self.raw[i] = v;\n }\n Object.defineProperty(self, field.name, {\n enumerable: true,\n configurable: true,\n get: getter,\n set: setter\n });\n if (field.default) {\n self[field.name] = field.default;\n }\n // attach alias\n if (field.alias) {\n Object.defineProperty(self, field.alias, {\n enumerable: false,\n configurable: true,\n set: setter,\n get: getter\n });\n }\n });\n // if the constuctor is passed data\n if (data) {\n if (typeof data === 'string') {\n data = Buffer.from((0, internal_1.stripHexPrefix)(data), 'hex');\n }\n if (Buffer.isBuffer(data)) {\n data = externals_1.rlp.decode(data);\n }\n if (Array.isArray(data)) {\n if (data.length > self._fields.length) {\n throw new Error('wrong number of fields in data');\n }\n // make sure all the items are buffers\n data.forEach(function (d, i) {\n self[self._fields[i]] = (0, bytes_1.toBuffer)(d);\n });\n } else if (typeof data === 'object') {\n var keys_1 = Object.keys(data);\n fields.forEach(function (field) {\n if (keys_1.indexOf(field.name) !== -1) self[field.name] = data[field.name];\n if (keys_1.indexOf(field.alias) !== -1) self[field.alias] = data[field.alias];\n });\n } else {\n throw new Error('invalid data');\n }\n }\n};\nexports.defineProperties = defineProperties;\n","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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\", {\n value: true\n});\nexports.isHexString = exports.getKeys = exports.fromAscii = exports.fromUtf8 = exports.toAscii = exports.arrayContainsArray = exports.getBinarySize = exports.padToEven = exports.stripHexPrefix = exports.isHexPrefixed = void 0;\n/**\n * Constants\n */\n__exportStar(require(\"./constants\"), exports);\n/**\n * Account class and helper functions\n */\n__exportStar(require(\"./account\"), exports);\n/**\n * Address type\n */\n__exportStar(require(\"./address\"), exports);\n/**\n * Hash functions\n */\n__exportStar(require(\"./hash\"), exports);\n/**\n * ECDSA signature\n */\n__exportStar(require(\"./signature\"), exports);\n/**\n * Utilities for manipulating Buffers, byte arrays, etc.\n */\n__exportStar(require(\"./bytes\"), exports);\n/**\n * Function for definining properties on an object\n */\n__exportStar(require(\"./object\"), exports);\n/**\n * External exports (BN, rlp)\n */\n__exportStar(require(\"./externals\"), exports);\n/**\n * Helpful TypeScript types\n */\n__exportStar(require(\"./types\"), exports);\n/**\n * Export ethjs-util methods\n */\nvar internal_1 = require(\"./internal\");\nObject.defineProperty(exports, \"isHexPrefixed\", {\n enumerable: true,\n get: function () {\n return internal_1.isHexPrefixed;\n }\n});\nObject.defineProperty(exports, \"stripHexPrefix\", {\n enumerable: true,\n get: function () {\n return internal_1.stripHexPrefix;\n }\n});\nObject.defineProperty(exports, \"padToEven\", {\n enumerable: true,\n get: function () {\n return internal_1.padToEven;\n }\n});\nObject.defineProperty(exports, \"getBinarySize\", {\n enumerable: true,\n get: function () {\n return internal_1.getBinarySize;\n }\n});\nObject.defineProperty(exports, \"arrayContainsArray\", {\n enumerable: true,\n get: function () {\n return internal_1.arrayContainsArray;\n }\n});\nObject.defineProperty(exports, \"toAscii\", {\n enumerable: true,\n get: function () {\n return internal_1.toAscii;\n }\n});\nObject.defineProperty(exports, \"fromUtf8\", {\n enumerable: true,\n get: function () {\n return internal_1.fromUtf8;\n }\n});\nObject.defineProperty(exports, \"fromAscii\", {\n enumerable: true,\n get: function () {\n return internal_1.fromAscii;\n }\n});\nObject.defineProperty(exports, \"getKeys\", {\n enumerable: true,\n get: function () {\n return internal_1.getKeys;\n }\n});\nObject.defineProperty(exports, \"isHexString\", {\n enumerable: true,\n get: function () {\n return internal_1.isHexString;\n }\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.N_DIV_2 = exports.isAccessList = exports.isAccessListBuffer = exports.Capability = void 0;\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\n/**\n * Can be used in conjunction with {@link Transaction.supports}\n * to query on tx capabilities\n */\nvar Capability;\n(function (Capability) {\n /**\n * Tx supports EIP-155 replay protection\n * See: [155](https://eips.ethereum.org/EIPS/eip-155) Replay Attack Protection EIP\n */\n Capability[Capability[\"EIP155ReplayProtection\"] = 155] = \"EIP155ReplayProtection\";\n /**\n * Tx supports EIP-1559 gas fee market mechansim\n * See: [1559](https://eips.ethereum.org/EIPS/eip-1559) Fee Market EIP\n */\n Capability[Capability[\"EIP1559FeeMarket\"] = 1559] = \"EIP1559FeeMarket\";\n /**\n * Tx is a typed transaction as defined in EIP-2718\n * See: [2718](https://eips.ethereum.org/EIPS/eip-2718) Transaction Type EIP\n */\n Capability[Capability[\"EIP2718TypedTransaction\"] = 2718] = \"EIP2718TypedTransaction\";\n /**\n * Tx supports access list generation as defined in EIP-2930\n * See: [2930](https://eips.ethereum.org/EIPS/eip-2930) Access Lists EIP\n */\n Capability[Capability[\"EIP2930AccessLists\"] = 2930] = \"EIP2930AccessLists\";\n})(Capability = exports.Capability || (exports.Capability = {}));\nfunction isAccessListBuffer(input) {\n if (input.length === 0) {\n return true;\n }\n var firstItem = input[0];\n if (Array.isArray(firstItem)) {\n return true;\n }\n return false;\n}\nexports.isAccessListBuffer = isAccessListBuffer;\nfunction isAccessList(input) {\n return !isAccessListBuffer(input); // This is exactly the same method, except the output is negated.\n}\nexports.isAccessList = isAccessList;\n/**\n * A const defining secp256k1n/2\n */\nexports.N_DIV_2 = new ethereumjs_util_1.BN('7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a0', 16);\n","/*! crc32.js (C) 2014-present SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*exported CRC32 */\nvar CRC32;\n(function (factory) {\n /*jshint ignore:start */\n /*eslint-disable */\n if (typeof DO_NOT_EXPORT_CRC === 'undefined') {\n if ('object' === typeof exports) {\n factory(exports);\n } else if ('function' === typeof define && define.amd) {\n define(function () {\n var module = {};\n factory(module);\n return module;\n });\n } else {\n factory(CRC32 = {});\n }\n } else {\n factory(CRC32 = {});\n }\n /*eslint-enable */\n /*jshint ignore:end */\n})(function (CRC32) {\n CRC32.version = '1.2.2';\n /*global Int32Array */\n function signed_crc_table() {\n var c = 0,\n table = new Array(256);\n for (var n = 0; n != 256; ++n) {\n c = n;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1;\n table[n] = c;\n }\n return typeof Int32Array !== 'undefined' ? new Int32Array(table) : table;\n }\n var T0 = signed_crc_table();\n function slice_by_16_tables(T) {\n var c = 0,\n v = 0,\n n = 0,\n table = typeof Int32Array !== 'undefined' ? new Int32Array(4096) : new Array(4096);\n for (n = 0; n != 256; ++n) table[n] = T[n];\n for (n = 0; n != 256; ++n) {\n v = T[n];\n for (c = 256 + n; c < 4096; c += 256) v = table[c] = v >>> 8 ^ T[v & 0xFF];\n }\n var out = [];\n for (n = 1; n != 16; ++n) out[n - 1] = typeof Int32Array !== 'undefined' ? table.subarray(n * 256, n * 256 + 256) : table.slice(n * 256, n * 256 + 256);\n return out;\n }\n var TT = slice_by_16_tables(T0);\n var T1 = TT[0],\n T2 = TT[1],\n T3 = TT[2],\n T4 = TT[3],\n T5 = TT[4];\n var T6 = TT[5],\n T7 = TT[6],\n T8 = TT[7],\n T9 = TT[8],\n Ta = TT[9];\n var Tb = TT[10],\n Tc = TT[11],\n Td = TT[12],\n Te = TT[13],\n Tf = TT[14];\n function crc32_bstr(bstr, seed) {\n var C = seed ^ -1;\n for (var i = 0, L = bstr.length; i < L;) C = C >>> 8 ^ T0[(C ^ bstr.charCodeAt(i++)) & 0xFF];\n return ~C;\n }\n function crc32_buf(B, seed) {\n var C = seed ^ -1,\n L = B.length - 15,\n i = 0;\n for (; i < L;) C = Tf[B[i++] ^ C & 255] ^ Te[B[i++] ^ C >> 8 & 255] ^ Td[B[i++] ^ C >> 16 & 255] ^ Tc[B[i++] ^ C >>> 24] ^ Tb[B[i++]] ^ Ta[B[i++]] ^ T9[B[i++]] ^ T8[B[i++]] ^ T7[B[i++]] ^ T6[B[i++]] ^ T5[B[i++]] ^ T4[B[i++]] ^ T3[B[i++]] ^ T2[B[i++]] ^ T1[B[i++]] ^ T0[B[i++]];\n L += 15;\n while (i < L) C = C >>> 8 ^ T0[(C ^ B[i++]) & 0xFF];\n return ~C;\n }\n function crc32_str(str, seed) {\n var C = seed ^ -1;\n for (var i = 0, L = str.length, c = 0, d = 0; i < L;) {\n c = str.charCodeAt(i++);\n if (c < 0x80) {\n C = C >>> 8 ^ T0[(C ^ c) & 0xFF];\n } else if (c < 0x800) {\n C = C >>> 8 ^ T0[(C ^ (192 | c >> 6 & 31)) & 0xFF];\n C = C >>> 8 ^ T0[(C ^ (128 | c & 63)) & 0xFF];\n } else if (c >= 0xD800 && c < 0xE000) {\n c = (c & 1023) + 64;\n d = str.charCodeAt(i++) & 1023;\n C = C >>> 8 ^ T0[(C ^ (240 | c >> 8 & 7)) & 0xFF];\n C = C >>> 8 ^ T0[(C ^ (128 | c >> 2 & 63)) & 0xFF];\n C = C >>> 8 ^ T0[(C ^ (128 | d >> 6 & 15 | (c & 3) << 4)) & 0xFF];\n C = C >>> 8 ^ T0[(C ^ (128 | d & 63)) & 0xFF];\n } else {\n C = C >>> 8 ^ T0[(C ^ (224 | c >> 12 & 15)) & 0xFF];\n C = C >>> 8 ^ T0[(C ^ (128 | c >> 6 & 63)) & 0xFF];\n C = C >>> 8 ^ T0[(C ^ (128 | c & 63)) & 0xFF];\n }\n }\n return ~C;\n }\n CRC32.table = T0;\n // $FlowIgnore\n CRC32.bstr = crc32_bstr;\n // $FlowIgnore\n CRC32.buf = crc32_buf;\n // $FlowIgnore\n CRC32.str = crc32_str;\n});","{\n \"name\": \"mainnet\",\n \"chainId\": 1,\n \"networkId\": 1,\n \"defaultHardfork\": \"istanbul\",\n \"consensus\": {\n \"type\": \"pow\",\n \"algorithm\": \"ethash\",\n \"ethash\": {}\n },\n \"comment\": \"The Ethereum main chain\",\n \"url\": \"https://ethstats.net/\",\n \"genesis\": {\n \"hash\": \"0xd4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3\",\n \"timestamp\": null,\n \"gasLimit\": 5000,\n \"difficulty\": 17179869184,\n \"nonce\": \"0x0000000000000042\",\n \"extraData\": \"0x11bbe8db4e347b4e8c937c1c8370e4b5ed33adb3db69cbdb7a38e1e50b1b82fa\",\n \"stateRoot\": \"0xd7f8974fb5ac78d9ac099b9ad5018bedc2ce0a72dad1827a1709da30580f0544\"\n },\n \"hardforks\": [\n {\n \"name\": \"chainstart\",\n \"block\": 0,\n \"forkHash\": \"0xfc64ec04\"\n },\n {\n \"name\": \"homestead\",\n \"block\": 1150000,\n \"forkHash\": \"0x97c2c34c\"\n },\n {\n \"name\": \"dao\",\n \"block\": 1920000,\n \"forkHash\": \"0x91d1f948\"\n },\n {\n \"name\": \"tangerineWhistle\",\n \"block\": 2463000,\n \"forkHash\": \"0x7a64da13\"\n },\n {\n \"name\": \"spuriousDragon\",\n \"block\": 2675000,\n \"forkHash\": \"0x3edd5b10\"\n },\n {\n \"name\": \"byzantium\",\n \"block\": 4370000,\n \"forkHash\": \"0xa00bc324\"\n },\n {\n \"name\": \"constantinople\",\n \"block\": 7280000,\n \"forkHash\": \"0x668db0af\"\n },\n {\n \"name\": \"petersburg\",\n \"block\": 7280000,\n \"forkHash\": \"0x668db0af\"\n },\n {\n \"name\": \"istanbul\",\n \"block\": 9069000,\n \"forkHash\": \"0x879d6e30\"\n },\n {\n \"name\": \"muirGlacier\",\n \"block\": 9200000,\n \"forkHash\": \"0xe029e991\"\n },\n {\n \"name\": \"berlin\",\n \"block\": 12244000,\n \"forkHash\": \"0x0eb440f6\"\n },\n {\n \"name\": \"london\",\n \"block\": 12965000,\n \"forkHash\": \"0xb715077d\"\n },\n {\n \"name\": \"arrowGlacier\",\n \"block\": 13773000,\n \"forkHash\": \"0x20c327fc\"\n },\n {\n \"name\": \"grayGlacier\",\n \"block\": 15050000,\n \"forkHash\": \"0xf0afd0e3\"\n },\n {\n \"name\": \"mergeForkIdTransition\",\n \"block\": null,\n \"forkHash\": null\n },\n {\n \"name\": \"merge\",\n \"block\": null,\n \"forkHash\": null\n },\n {\n \"name\": \"shanghai\",\n \"block\": null,\n \"forkHash\": null\n }\n ],\n \"bootstrapNodes\": [\n {\n \"ip\": \"18.138.108.67\",\n \"port\": 30303,\n \"id\": \"d860a01f9722d78051619d1e2351aba3f43f943f6f00718d1b9baa4101932a1f5011f16bb2b1bb35db20d6fe28fa0bf09636d26a87d31de9ec6203eeedb1f666\",\n \"location\": \"ap-southeast-1-001\",\n \"comment\": \"bootnode-aws-ap-southeast-1-001\"\n },\n {\n \"ip\": \"3.209.45.79\",\n \"port\": 30303,\n \"id\": \"22a8232c3abc76a16ae9d6c3b164f98775fe226f0917b0ca871128a74a8e9630b458460865bab457221f1d448dd9791d24c4e5d88786180ac185df813a68d4de\",\n \"location\": \"us-east-1-001\",\n \"comment\": \"bootnode-aws-us-east-1-001\"\n },\n {\n \"ip\": \"34.255.23.113\",\n \"port\": 30303,\n \"id\": \"ca6de62fce278f96aea6ec5a2daadb877e51651247cb96ee310a318def462913b653963c155a0ef6c7d50048bba6e6cea881130857413d9f50a621546b590758\",\n \"location\": \"eu-west-1-001\",\n \"comment\": \"bootnode-aws-eu-west-1-001\"\n },\n {\n \"ip\": \"35.158.244.151\",\n \"port\": 30303,\n \"id\": \"279944d8dcd428dffaa7436f25ca0ca43ae19e7bcf94a8fb7d1641651f92d121e972ac2e8f381414b80cc8e5555811c2ec6e1a99bb009b3f53c4c69923e11bd8\",\n \"location\": \"eu-central-1-001\",\n \"comment\": \"bootnode-aws-eu-central-1-001\"\n },\n {\n \"ip\": \"52.187.207.27\",\n \"port\": 30303,\n \"id\": \"8499da03c47d637b20eee24eec3c356c9a2e6148d6fe25ca195c7949ab8ec2c03e3556126b0d7ed644675e78c4318b08691b7b57de10e5f0d40d05b09238fa0a\",\n \"location\": \"australiaeast-001\",\n \"comment\": \"bootnode-azure-australiaeast-001\"\n },\n {\n \"ip\": \"191.234.162.198\",\n \"port\": 30303,\n \"id\": \"103858bdb88756c71f15e9b5e09b56dc1be52f0a5021d46301dbbfb7e130029cc9d0d6f73f693bc29b665770fff7da4d34f3c6379fe12721b5d7a0bcb5ca1fc1\",\n \"location\": \"brazilsouth-001\",\n \"comment\": \"bootnode-azure-brazilsouth-001\"\n },\n {\n \"ip\": \"52.231.165.108\",\n \"port\": 30303,\n \"id\": \"715171f50508aba88aecd1250af392a45a330af91d7b90701c436b618c86aaa1589c9184561907bebbb56439b8f8787bc01f49a7c77276c58c1b09822d75e8e8\",\n \"location\": \"koreasouth-001\",\n \"comment\": \"bootnode-azure-koreasouth-001\"\n },\n {\n \"ip\": \"104.42.217.25\",\n \"port\": 30303,\n \"id\": \"5d6d7cd20d6da4bb83a1d28cadb5d409b64edf314c0335df658c1a54e32c7c4a7ab7823d57c39b6a757556e68ff1df17c748b698544a55cb488b52479a92b60f\",\n \"location\": \"westus-001\",\n \"comment\": \"bootnode-azure-westus-001\"\n }\n ],\n \"dnsNetworks\": [\n \"enrtree://AKA3AM6LPBYEUDMVNU3BSVQJ5AD45Y7YPOHJLEF6W26QOE4VTUDPE@all.mainnet.ethdisco.net\"\n ]\n}\n","{\n \"name\": \"ropsten\",\n \"chainId\": 3,\n \"networkId\": 3,\n \"defaultHardfork\": \"istanbul\",\n \"consensus\": {\n \"type\": \"pow\",\n \"algorithm\": \"ethash\",\n \"ethash\": {}\n },\n \"comment\": \"PoW test network\",\n \"url\": \"https://github.com/ethereum/ropsten\",\n \"genesis\": {\n \"hash\": \"0x41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d\",\n \"timestamp\": null,\n \"gasLimit\": 16777216,\n \"difficulty\": 1048576,\n \"nonce\": \"0x0000000000000042\",\n \"extraData\": \"0x3535353535353535353535353535353535353535353535353535353535353535\",\n \"stateRoot\": \"0x217b0bbcfb72e2d57e28f33cb361b9983513177755dc3f33ce3e7022ed62b77b\"\n },\n \"hardforks\": [\n {\n \"name\": \"chainstart\",\n \"block\": 0,\n \"forkHash\": \"0x30c7ddbc\"\n },\n {\n \"name\": \"homestead\",\n \"block\": 0,\n \"forkHash\": \"0x30c7ddbc\"\n },\n {\n \"name\": \"tangerineWhistle\",\n \"block\": 0,\n \"forkHash\": \"0x30c7ddbc\"\n },\n {\n \"name\": \"spuriousDragon\",\n \"block\": 10,\n \"forkHash\": \"0x63760190\"\n },\n {\n \"name\": \"byzantium\",\n \"block\": 1700000,\n \"forkHash\": \"0x3ea159c7\"\n },\n {\n \"name\": \"constantinople\",\n \"block\": 4230000,\n \"forkHash\": \"0x97b544f3\"\n },\n {\n \"name\": \"petersburg\",\n \"block\": 4939394,\n \"forkHash\": \"0xd6e2149b\"\n },\n {\n \"name\": \"istanbul\",\n \"block\": 6485846,\n \"forkHash\": \"0x4bc66396\"\n },\n {\n \"name\": \"muirGlacier\",\n \"block\": 7117117,\n \"forkHash\": \"0x6727ef90\"\n },\n {\n \"name\": \"berlin\",\n \"block\": 9812189,\n \"forkHash\": \"0xa157d377\"\n },\n {\n \"name\": \"london\",\n \"block\": 10499401,\n \"forkHash\": \"0x7119b6b3\"\n },\n {\n \"name\": \"merge\",\n \"block\": null,\n \"forkHash\": null\n },\n {\n \"name\": \"shanghai\",\n \"block\": null,\n \"forkHash\": null\n }\n ],\n \"bootstrapNodes\": [\n {\n \"ip\": \"52.176.7.10\",\n \"port\": 30303,\n \"id\": \"30b7ab30a01c124a6cceca36863ece12c4f5fa68e3ba9b0b51407ccc002eeed3b3102d20a88f1c1d3c3154e2449317b8ef95090e77b312d5cc39354f86d5d606\",\n \"location\": \"\",\n \"comment\": \"US-Azure geth\"\n },\n {\n \"ip\": \"52.176.100.77\",\n \"port\": 30303,\n \"id\": \"865a63255b3bb68023b6bffd5095118fcc13e79dcf014fe4e47e065c350c7cc72af2e53eff895f11ba1bbb6a2b33271c1116ee870f266618eadfc2e78aa7349c\",\n \"location\": \"\",\n \"comment\": \"US-Azure parity\"\n },\n {\n \"ip\": \"52.232.243.152\",\n \"port\": 30303,\n \"id\": \"6332792c4a00e3e4ee0926ed89e0d27ef985424d97b6a45bf0f23e51f0dcb5e66b875777506458aea7af6f9e4ffb69f43f3778ee73c81ed9d34c51c4b16b0b0f\",\n \"location\": \"\",\n \"comment\": \"Parity\"\n },\n {\n \"ip\": \"192.81.208.223\",\n \"port\": 30303,\n \"id\": \"94c15d1b9e2fe7ce56e458b9a3b672ef11894ddedd0c6f247e0f1d3487f52b66208fb4aeb8179fce6e3a749ea93ed147c37976d67af557508d199d9594c35f09\",\n \"location\": \"\",\n \"comment\": \"@gpip\"\n }\n ],\n \"dnsNetworks\": [\n \"enrtree://AKA3AM6LPBYEUDMVNU3BSVQJ5AD45Y7YPOHJLEF6W26QOE4VTUDPE@all.ropsten.ethdisco.net\"\n ]\n}\n","{\n \"name\": \"rinkeby\",\n \"chainId\": 4,\n \"networkId\": 4,\n \"defaultHardfork\": \"istanbul\",\n \"consensus\": {\n \"type\": \"poa\",\n \"algorithm\": \"clique\",\n \"clique\": {\n \"period\": 15,\n \"epoch\": 30000\n }\n },\n \"comment\": \"PoA test network\",\n \"url\": \"https://www.rinkeby.io\",\n \"genesis\": {\n \"hash\": \"0x6341fd3daf94b748c72ced5a5b26028f2474f5f00d824504e4fa37a75767e177\",\n \"timestamp\": \"0x58ee40ba\",\n \"gasLimit\": 4700000,\n \"difficulty\": 1,\n \"nonce\": \"0x0000000000000000\",\n \"extraData\": \"0x52657370656374206d7920617574686f7269746168207e452e436172746d616e42eb768f2244c8811c63729a21a3569731535f067ffc57839b00206d1ad20c69a1981b489f772031b279182d99e65703f0076e4812653aab85fca0f00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\",\n \"stateRoot\": \"0x53580584816f617295ea26c0e17641e0120cab2f0a8ffb53a866fd53aa8e8c2d\"\n },\n \"hardforks\": [\n {\n \"name\": \"chainstart\",\n \"block\": 0,\n \"forkHash\": \"0x3b8e0691\"\n },\n {\n \"name\": \"homestead\",\n \"block\": 1,\n \"forkHash\": \"0x60949295\"\n },\n {\n \"name\": \"tangerineWhistle\",\n \"block\": 2,\n \"forkHash\": \"0x8bde40dd\"\n },\n {\n \"name\": \"spuriousDragon\",\n \"block\": 3,\n \"forkHash\": \"0xcb3a64bb\"\n },\n {\n \"name\": \"byzantium\",\n \"block\": 1035301,\n \"forkHash\": \"0x8d748b57\"\n },\n {\n \"name\": \"constantinople\",\n \"block\": 3660663,\n \"forkHash\": \"0xe49cab14\"\n },\n {\n \"name\": \"petersburg\",\n \"block\": 4321234,\n \"forkHash\": \"0xafec6b27\"\n },\n {\n \"name\": \"istanbul\",\n \"block\": 5435345,\n \"forkHash\": \"0xcbdb8838\"\n },\n {\n \"name\": \"berlin\",\n \"block\": 8290928,\n \"forkHash\": \"0x6910c8bd\"\n },\n {\n \"name\": \"london\",\n \"block\": 8897988,\n \"forkHash\": \"0x8e29f2f3\"\n },\n {\n \"name\": \"merge\",\n \"block\": null,\n \"forkHash\": null\n },\n {\n \"name\": \"shanghai\",\n \"block\": null,\n \"forkHash\": null\n }\n ],\n \"bootstrapNodes\": [\n {\n \"ip\": \"52.169.42.101\",\n \"port\": 30303,\n \"id\": \"a24ac7c5484ef4ed0c5eb2d36620ba4e4aa13b8c84684e1b4aab0cebea2ae45cb4d375b77eab56516d34bfbd3c1a833fc51296ff084b770b94fb9028c4d25ccf\",\n \"location\": \"\",\n \"comment\": \"IE\"\n },\n {\n \"ip\": \"52.3.158.184\",\n \"port\": 30303,\n \"id\": \"343149e4feefa15d882d9fe4ac7d88f885bd05ebb735e547f12e12080a9fa07c8014ca6fd7f373123488102fe5e34111f8509cf0b7de3f5b44339c9f25e87cb8\",\n \"location\": \"\",\n \"comment\": \"INFURA\"\n },\n {\n \"ip\": \"159.89.28.211\",\n \"port\": 30303,\n \"id\": \"b6b28890b006743680c52e64e0d16db57f28124885595fa03a562be1d2bf0f3a1da297d56b13da25fb992888fd556d4c1a27b1f39d531bde7de1921c90061cc6\",\n \"location\": \"\",\n \"comment\": \"AKASHA\"\n }\n ],\n \"dnsNetworks\": [\n \"enrtree://AKA3AM6LPBYEUDMVNU3BSVQJ5AD45Y7YPOHJLEF6W26QOE4VTUDPE@all.rinkeby.ethdisco.net\"\n ]\n}\n","{\n \"name\": \"kovan\",\n \"chainId\": 42,\n \"networkId\": 42,\n \"defaultHardfork\": \"istanbul\",\n \"consensus\": {\n \"type\": \"poa\",\n \"algorithm\": \"aura\",\n \"aura\": {}\n },\n \"comment\": \"Parity PoA test network\",\n \"url\": \"https://kovan-testnet.github.io/website/\",\n \"genesis\": {\n \"hash\": \"0xa3c565fc15c7478862d50ccd6561e3c06b24cc509bf388941c25ea985ce32cb9\",\n \"timestamp\": null,\n \"gasLimit\": 6000000,\n \"difficulty\": 131072,\n \"nonce\": \"0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\",\n \"extraData\": \"0x\",\n \"stateRoot\": \"0x2480155b48a1cea17d67dbfdfaafe821c1d19cdd478c5358e8ec56dec24502b2\"\n },\n \"hardforks\": [\n {\n \"name\": \"chainstart\",\n \"block\": 0,\n \"forkHash\": \"0x010ffe56\"\n },\n {\n \"name\": \"homestead\",\n \"block\": 0,\n \"forkHash\": \"0x010ffe56\"\n },\n {\n \"name\": \"tangerineWhistle\",\n \"block\": 0,\n \"forkHash\": \"0x010ffe56\"\n },\n {\n \"name\": \"spuriousDragon\",\n \"block\": 0,\n \"forkHash\": \"0x010ffe56\"\n },\n {\n \"name\": \"byzantium\",\n \"block\": 5067000,\n \"forkHash\": \"0x7f83c620\"\n },\n {\n \"name\": \"constantinople\",\n \"block\": 9200000,\n \"forkHash\": \"0xa94e3dc4\"\n },\n {\n \"name\": \"petersburg\",\n \"block\": 10255201,\n \"forkHash\": \"0x186874aa\"\n },\n {\n \"name\": \"istanbul\",\n \"block\": 14111141,\n \"forkHash\": \"0x7f6599a6\"\n },\n {\n \"name\": \"berlin\",\n \"block\": 24770900,\n \"forkHash\": \"0x1a0f10d9\"\n },\n {\n \"name\": \"london\",\n \"block\": 26741100,\n \"forkHash\": \"0x1ed20b71\"\n },\n {\n \"name\": \"merge\",\n \"block\": null,\n \"forkHash\": null\n },\n {\n \"name\": \"shanghai\",\n \"block\": null,\n \"forkHash\": null\n }\n ],\n \"bootstrapNodes\": [\n {\n \"ip\": \"116.203.116.241\",\n \"port\": 30303,\n \"id\": \"16898006ba2cd4fa8bf9a3dfe32684c178fa861df144bfc21fe800dc4838a03e342056951fa9fd533dcb0be1219e306106442ff2cf1f7e9f8faa5f2fc1a3aa45\",\n \"location\": \"\",\n \"comment\": \"1\"\n },\n {\n \"ip\": \"3.217.96.11\",\n \"port\": 30303,\n \"id\": \"2909846f78c37510cc0e306f185323b83bb2209e5ff4fdd279d93c60e3f365e3c6e62ad1d2133ff11f9fd6d23ad9c3dad73bb974d53a22f7d1ac5b7dea79d0b0\",\n \"location\": \"\",\n \"comment\": \"2\"\n },\n {\n \"ip\": \"108.61.170.124\",\n \"port\": 30303,\n \"id\": \"740e1c8ea64e71762c71a463a04e2046070a0c9394fcab5891d41301dc473c0cff00ebab5a9bc87fbcb610ab98ac18225ff897bc8b7b38def5975d5ceb0a7d7c\",\n \"location\": \"\",\n \"comment\": \"3\"\n },\n {\n \"ip\": \"157.230.31.163\",\n \"port\": 30303,\n \"id\": \"2909846f78c37510cc0e306f185323b83bb2209e5ff4fdd279d93c60e3f365e3c6e62ad1d2133ff11f9fd6d23ad9c3dad73bb974d53a22f7d1ac5b7dea79d0b0\",\n \"location\": \"\",\n \"comment\": \"4\"\n }\n ]\n}\n","{\n \"name\": \"goerli\",\n \"chainId\": 5,\n \"networkId\": 5,\n \"defaultHardfork\": \"istanbul\",\n \"consensus\": {\n \"type\": \"poa\",\n \"algorithm\": \"clique\",\n \"clique\": {\n \"period\": 15,\n \"epoch\": 30000\n }\n },\n \"comment\": \"Cross-client PoA test network\",\n \"url\": \"https://github.com/goerli/testnet\",\n \"genesis\": {\n \"hash\": \"0xbf7e331f7f7c1dd2e05159666b3bf8bc7a8a3a9eb1d518969eab529dd9b88c1a\",\n \"timestamp\": \"0x5c51a607\",\n \"gasLimit\": 10485760,\n \"difficulty\": 1,\n \"nonce\": \"0x0000000000000000\",\n \"extraData\": \"0x22466c6578692069732061207468696e6722202d204166726900000000000000e0a2bd4258d2768837baa26a28fe71dc079f84c70000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\",\n \"stateRoot\": \"0x5d6cded585e73c4e322c30c2f782a336316f17dd85a4863b9d838d2d4b8b3008\"\n },\n \"hardforks\": [\n {\n \"name\": \"chainstart\",\n \"block\": 0,\n \"forkHash\": \"0xa3f5ab08\"\n },\n {\n \"name\": \"homestead\",\n \"block\": 0,\n \"forkHash\": \"0xa3f5ab08\"\n },\n {\n \"name\": \"tangerineWhistle\",\n \"block\": 0,\n \"forkHash\": \"0xa3f5ab08\"\n },\n {\n \"name\": \"spuriousDragon\",\n \"block\": 0,\n \"forkHash\": \"0xa3f5ab08\"\n },\n {\n \"name\": \"byzantium\",\n \"block\": 0,\n \"forkHash\": \"0xa3f5ab08\"\n },\n {\n \"name\": \"constantinople\",\n \"block\": 0,\n \"forkHash\": \"0xa3f5ab08\"\n },\n {\n \"name\": \"petersburg\",\n \"block\": 0,\n \"forkHash\": \"0xa3f5ab08\"\n },\n {\n \"name\": \"istanbul\",\n \"block\": 1561651,\n \"forkHash\": \"0xc25efa5c\"\n },\n {\n \"name\": \"berlin\",\n \"block\": 4460644,\n \"forkHash\": \"0x757a1c47\"\n },\n {\n \"name\": \"london\",\n \"block\": 5062605,\n \"forkHash\": \"0xb8c6299d\"\n },\n {\n \"name\": \"merge\",\n \"block\": null,\n \"forkHash\": null\n },\n {\n \"name\": \"shanghai\",\n \"block\": null,\n \"forkHash\": null\n }\n ],\n \"bootstrapNodes\": [\n {\n \"ip\": \"51.141.78.53\",\n \"port\": 30303,\n \"id\": \"011f758e6552d105183b1761c5e2dea0111bc20fd5f6422bc7f91e0fabbec9a6595caf6239b37feb773dddd3f87240d99d859431891e4a642cf2a0a9e6cbb98a\",\n \"location\": \"\",\n \"comment\": \"Upstream bootnode 1\"\n },\n {\n \"ip\": \"13.93.54.137\",\n \"port\": 30303,\n \"id\": \"176b9417f511d05b6b2cf3e34b756cf0a7096b3094572a8f6ef4cdcb9d1f9d00683bf0f83347eebdf3b81c3521c2332086d9592802230bf528eaf606a1d9677b\",\n \"location\": \"\",\n \"comment\": \"Upstream bootnode 2\"\n },\n {\n \"ip\": \"94.237.54.114\",\n \"port\": 30313,\n \"id\": \"46add44b9f13965f7b9875ac6b85f016f341012d84f975377573800a863526f4da19ae2c620ec73d11591fa9510e992ecc03ad0751f53cc02f7c7ed6d55c7291\",\n \"location\": \"\",\n \"comment\": \"Upstream bootnode 3\"\n },\n {\n \"ip\": \"18.218.250.66\",\n \"port\": 30313,\n \"id\": \"b5948a2d3e9d486c4d75bf32713221c2bd6cf86463302339299bd227dc2e276cd5a1c7ca4f43a0e9122fe9af884efed563bd2a1fd28661f3b5f5ad7bf1de5949\",\n \"location\": \"\",\n \"comment\": \"Upstream bootnode 4\"\n },\n {\n \"ip\": \"3.11.147.67\",\n \"port\": 30303,\n \"id\": \"a61215641fb8714a373c80edbfa0ea8878243193f57c96eeb44d0bc019ef295abd4e044fd619bfc4c59731a73fb79afe84e9ab6da0c743ceb479cbb6d263fa91\",\n \"location\": \"\",\n \"comment\": \"Ethereum Foundation bootnode\"\n },\n {\n \"ip\": \"51.15.116.226\",\n \"port\": 30303,\n \"id\": \"a869b02cec167211fb4815a82941db2e7ed2936fd90e78619c53eb17753fcf0207463e3419c264e2a1dd8786de0df7e68cf99571ab8aeb7c4e51367ef186b1dd\",\n \"location\": \"\",\n \"comment\": \"Goerli Initiative bootnode\"\n },\n {\n \"ip\": \"51.15.119.157\",\n \"port\": 30303,\n \"id\": \"807b37ee4816ecf407e9112224494b74dd5933625f655962d892f2f0f02d7fbbb3e2a94cf87a96609526f30c998fd71e93e2f53015c558ffc8b03eceaf30ee33\",\n \"location\": \"\",\n \"comment\": \"Goerli Initiative bootnode\"\n },\n {\n \"ip\": \"51.15.119.157\",\n \"port\": 40303,\n \"id\": \"a59e33ccd2b3e52d578f1fbd70c6f9babda2650f0760d6ff3b37742fdcdfdb3defba5d56d315b40c46b70198c7621e63ffa3f987389c7118634b0fefbbdfa7fd\",\n \"location\": \"\",\n \"comment\": \"Goerli Initiative bootnode\"\n }\n ],\n \"dnsNetworks\": [\n \"enrtree://AKA3AM6LPBYEUDMVNU3BSVQJ5AD45Y7YPOHJLEF6W26QOE4VTUDPE@all.goerli.ethdisco.net\"\n ]\n}\n","{\n \"name\": \"sepolia\",\n \"chainId\": 11155111,\n \"networkId\": 11155111,\n \"defaultHardfork\": \"istanbul\",\n \"consensus\": {\n \"type\": \"pow\",\n \"algorithm\": \"ethash\",\n \"ethash\": {}\n },\n \"comment\": \"PoW test network to replace Ropsten\",\n \"url\": \"https://github.com/ethereum/go-ethereum/pull/23730\",\n \"genesis\": {\n \"hash\": \"0x25a5cc106eea7138acab33231d7160d69cb777ee0c2c553fcddf5138993e6dd9\",\n \"timestamp\": \"0x6159af19\",\n \"gasLimit\": 30000000,\n \"difficulty\": 131072,\n \"nonce\": \"0x0000000000000000\",\n \"extraData\": \"0x5365706f6c69612c20417468656e732c204174746963612c2047726565636521\",\n \"stateRoot\": \"0x5eb6e371a698b8d68f665192350ffcecbbbf322916f4b51bd79bb6887da3f494\"\n },\n \"hardforks\": [\n {\n \"name\": \"chainstart\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"homestead\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"tangerineWhistle\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"spuriousDragon\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"byzantium\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"constantinople\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"petersburg\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"istanbul\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"muirGlacier\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"berlin\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"london\",\n \"block\": 0,\n \"forkHash\": \"0xfe3366e7\"\n },\n {\n \"name\": \"merge\",\n \"block\": null,\n \"forkHash\": null\n },\n {\n \"name\": \"shanghai\",\n \"block\": null,\n \"forkHash\": null\n }\n ],\n \"bootstrapNodes\": [\n {\n \"ip\": \"18.168.182.86\",\n \"port\": 30303,\n \"id\": \"9246d00bc8fd1742e5ad2428b80fc4dc45d786283e05ef6edbd9002cbc335d40998444732fbe921cb88e1d2c73d1b1de53bae6a2237996e9bfe14f871baf7066\",\n \"location\": \"\",\n \"comment\": \"geth\"\n },\n {\n \"ip\": \"52.14.151.177\",\n \"port\": 30303,\n \"id\": \"ec66ddcf1a974950bd4c782789a7e04f8aa7110a72569b6e65fcd51e937e74eed303b1ea734e4d19cfaec9fbff9b6ee65bf31dcb50ba79acce9dd63a6aca61c7\",\n \"location\": \"\",\n \"comment\": \"besu\"\n }\n ],\n \"dnsNetworks\": []\n}\n","\"use strict\";\n\nvar __values = this && this.__values || function (o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.chains = exports._getInitializedChains = void 0;\nvar mainnet_json_1 = __importDefault(require(\"./mainnet.json\"));\nvar ropsten_json_1 = __importDefault(require(\"./ropsten.json\"));\nvar rinkeby_json_1 = __importDefault(require(\"./rinkeby.json\"));\nvar kovan_json_1 = __importDefault(require(\"./kovan.json\"));\nvar goerli_json_1 = __importDefault(require(\"./goerli.json\"));\nvar sepolia_json_1 = __importDefault(require(\"./sepolia.json\"));\n/**\n * @hidden\n */\nfunction _getInitializedChains(customChains) {\n var e_1, _a;\n var names = {\n '1': 'mainnet',\n '3': 'ropsten',\n '4': 'rinkeby',\n '42': 'kovan',\n '5': 'goerli',\n '11155111': 'sepolia'\n };\n var chains = {\n mainnet: mainnet_json_1.default,\n ropsten: ropsten_json_1.default,\n rinkeby: rinkeby_json_1.default,\n kovan: kovan_json_1.default,\n goerli: goerli_json_1.default,\n sepolia: sepolia_json_1.default\n };\n if (customChains) {\n try {\n for (var customChains_1 = __values(customChains), customChains_1_1 = customChains_1.next(); !customChains_1_1.done; customChains_1_1 = customChains_1.next()) {\n var chain = customChains_1_1.value;\n var name_1 = chain.name;\n names[chain.chainId.toString()] = name_1;\n chains[name_1] = chain;\n }\n } catch (e_1_1) {\n e_1 = {\n error: e_1_1\n };\n } finally {\n try {\n if (customChains_1_1 && !customChains_1_1.done && (_a = customChains_1.return)) _a.call(customChains_1);\n } finally {\n if (e_1) throw e_1.error;\n }\n }\n }\n chains['names'] = names;\n return chains;\n}\nexports._getInitializedChains = _getInitializedChains;\n/**\n * @deprecated this constant will be internalized (removed)\n * on next major version update\n */\nexports.chains = _getInitializedChains();\n","{\n \"name\": \"chainstart\",\n \"comment\": \"Start of the Ethereum main chain\",\n \"url\": \"\",\n \"status\": \"\",\n \"gasConfig\": {\n \"minGasLimit\": {\n \"v\": 5000,\n \"d\": \"Minimum the gas limit may ever be\"\n },\n \"gasLimitBoundDivisor\": {\n \"v\": 1024,\n \"d\": \"The bound divisor of the gas limit, used in update calculations\"\n },\n \"maxRefundQuotient\": {\n \"v\": 2,\n \"d\": \"Maximum refund quotient; max tx refund is min(tx.gasUsed/maxRefundQuotient, tx.gasRefund)\"\n }\n },\n \"gasPrices\": {\n \"base\": {\n \"v\": 2,\n \"d\": \"Gas base cost, used e.g. for ChainID opcode (Istanbul)\"\n },\n \"tierStep\": {\n \"v\": [\n 0,\n 2,\n 3,\n 5,\n 8,\n 10,\n 20\n ],\n \"d\": \"Once per operation, for a selection of them\"\n },\n \"exp\": {\n \"v\": 10,\n \"d\": \"Base fee of the EXP opcode\"\n },\n \"expByte\": {\n \"v\": 10,\n \"d\": \"Times ceil(log256(exponent)) for the EXP instruction\"\n },\n \"sha3\": {\n \"v\": 30,\n \"d\": \"Base fee of the SHA3 opcode\"\n },\n \"sha3Word\": {\n \"v\": 6,\n \"d\": \"Once per word of the SHA3 operation's data\"\n },\n \"sload\": {\n \"v\": 50,\n \"d\": \"Base fee of the SLOAD opcode\"\n },\n \"sstoreSet\": {\n \"v\": 20000,\n \"d\": \"Once per SSTORE operation if the zeroness changes from zero\"\n },\n \"sstoreReset\": {\n \"v\": 5000,\n \"d\": \"Once per SSTORE operation if the zeroness does not change from zero\"\n },\n \"sstoreRefund\": {\n \"v\": 15000,\n \"d\": \"Once per SSTORE operation if the zeroness changes to zero\"\n },\n \"jumpdest\": {\n \"v\": 1,\n \"d\": \"Base fee of the JUMPDEST opcode\"\n },\n \"log\": {\n \"v\": 375,\n \"d\": \"Base fee of the LOG opcode\"\n },\n \"logData\": {\n \"v\": 8,\n \"d\": \"Per byte in a LOG* operation's data\"\n },\n \"logTopic\": {\n \"v\": 375,\n \"d\": \"Multiplied by the * of the LOG*, per LOG transaction. e.g. LOG0 incurs 0 * c_txLogTopicGas, LOG4 incurs 4 * c_txLogTopicGas\"\n },\n \"create\": {\n \"v\": 32000,\n \"d\": \"Base fee of the CREATE opcode\"\n },\n \"call\": {\n \"v\": 40,\n \"d\": \"Base fee of the CALL opcode\"\n },\n \"callStipend\": {\n \"v\": 2300,\n \"d\": \"Free gas given at beginning of call\"\n },\n \"callValueTransfer\": {\n \"v\": 9000,\n \"d\": \"Paid for CALL when the value transfor is non-zero\"\n },\n \"callNewAccount\": {\n \"v\": 25000,\n \"d\": \"Paid for CALL when the destination address didn't exist prior\"\n },\n \"selfdestructRefund\": {\n \"v\": 24000,\n \"d\": \"Refunded following a selfdestruct operation\"\n },\n \"memory\": {\n \"v\": 3,\n \"d\": \"Times the address of the (highest referenced byte in memory + 1). NOTE: referencing happens on read, write and in instructions such as RETURN and CALL\"\n },\n \"quadCoeffDiv\": {\n \"v\": 512,\n \"d\": \"Divisor for the quadratic particle of the memory cost equation\"\n },\n \"createData\": {\n \"v\": 200,\n \"d\": \"\"\n },\n \"tx\": {\n \"v\": 21000,\n \"d\": \"Per transaction. NOTE: Not payable on data of calls between transactions\"\n },\n \"txCreation\": {\n \"v\": 32000,\n \"d\": \"The cost of creating a contract via tx\"\n },\n \"txDataZero\": {\n \"v\": 4,\n \"d\": \"Per byte of data attached to a transaction that equals zero. NOTE: Not payable on data of calls between transactions\"\n },\n \"txDataNonZero\": {\n \"v\": 68,\n \"d\": \"Per byte of data attached to a transaction that is not equal to zero. NOTE: Not payable on data of calls between transactions\"\n },\n \"copy\": {\n \"v\": 3,\n \"d\": \"Multiplied by the number of 32-byte words that are copied (round up) for any *COPY operation and added\"\n },\n \"ecRecover\": {\n \"v\": 3000,\n \"d\": \"\"\n },\n \"sha256\": {\n \"v\": 60,\n \"d\": \"\"\n },\n \"sha256Word\": {\n \"v\": 12,\n \"d\": \"\"\n },\n \"ripemd160\": {\n \"v\": 600,\n \"d\": \"\"\n },\n \"ripemd160Word\": {\n \"v\": 120,\n \"d\": \"\"\n },\n \"identity\": {\n \"v\": 15,\n \"d\": \"\"\n },\n \"identityWord\": {\n \"v\": 3,\n \"d\": \"\"\n },\n \"stop\": {\n \"v\": 0,\n \"d\": \"Base fee of the STOP opcode\"\n },\n \"add\": {\n \"v\": 3,\n \"d\": \"Base fee of the ADD opcode\"\n },\n \"mul\": {\n \"v\": 5,\n \"d\": \"Base fee of the MUL opcode\"\n },\n \"sub\": {\n \"v\": 3,\n \"d\": \"Base fee of the SUB opcode\"\n },\n \"div\": {\n \"v\": 5,\n \"d\": \"Base fee of the DIV opcode\"\n },\n \"sdiv\": {\n \"v\": 5,\n \"d\": \"Base fee of the SDIV opcode\"\n },\n \"mod\": {\n \"v\": 5,\n \"d\": \"Base fee of the MOD opcode\"\n },\n \"smod\": {\n \"v\": 5,\n \"d\": \"Base fee of the SMOD opcode\"\n },\n \"addmod\": {\n \"v\": 8,\n \"d\": \"Base fee of the ADDMOD opcode\"\n },\n \"mulmod\": {\n \"v\": 8,\n \"d\": \"Base fee of the MULMOD opcode\"\n },\n \"signextend\": {\n \"v\": 5,\n \"d\": \"Base fee of the SIGNEXTEND opcode\"\n },\n \"lt\": {\n \"v\": 3,\n \"d\": \"Base fee of the LT opcode\"\n },\n \"gt\": {\n \"v\": 3,\n \"d\": \"Base fee of the GT opcode\"\n },\n \"slt\": {\n \"v\": 3,\n \"d\": \"Base fee of the SLT opcode\"\n },\n \"sgt\": {\n \"v\": 3,\n \"d\": \"Base fee of the SGT opcode\"\n },\n \"eq\": {\n \"v\": 3,\n \"d\": \"Base fee of the EQ opcode\"\n },\n \"iszero\": {\n \"v\": 3,\n \"d\": \"Base fee of the ISZERO opcode\"\n },\n \"and\": {\n \"v\": 3,\n \"d\": \"Base fee of the AND opcode\"\n },\n \"or\": {\n \"v\": 3,\n \"d\": \"Base fee of the OR opcode\"\n },\n \"xor\": {\n \"v\": 3,\n \"d\": \"Base fee of the XOR opcode\"\n },\n \"not\": {\n \"v\": 3,\n \"d\": \"Base fee of the NOT opcode\"\n },\n \"byte\": {\n \"v\": 3,\n \"d\": \"Base fee of the BYTE opcode\"\n },\n \"address\": {\n \"v\": 2,\n \"d\": \"Base fee of the ADDRESS opcode\"\n },\n \"balance\": {\n \"v\": 20,\n \"d\": \"Base fee of the BALANCE opcode\"\n },\n \"origin\": {\n \"v\": 2,\n \"d\": \"Base fee of the ORIGIN opcode\"\n },\n \"caller\": {\n \"v\": 2,\n \"d\": \"Base fee of the CALLER opcode\"\n },\n \"callvalue\": {\n \"v\": 2,\n \"d\": \"Base fee of the CALLVALUE opcode\"\n },\n \"calldataload\": {\n \"v\": 3,\n \"d\": \"Base fee of the CALLDATALOAD opcode\"\n },\n \"calldatasize\": {\n \"v\": 2,\n \"d\": \"Base fee of the CALLDATASIZE opcode\"\n },\n \"calldatacopy\": {\n \"v\": 3,\n \"d\": \"Base fee of the CALLDATACOPY opcode\"\n },\n \"codesize\": {\n \"v\": 2,\n \"d\": \"Base fee of the CODESIZE opcode\"\n },\n \"codecopy\": {\n \"v\": 3,\n \"d\": \"Base fee of the CODECOPY opcode\"\n },\n \"gasprice\": {\n \"v\": 2,\n \"d\": \"Base fee of the GASPRICE opcode\"\n },\n \"extcodesize\": {\n \"v\": 20,\n \"d\": \"Base fee of the EXTCODESIZE opcode\"\n },\n \"extcodecopy\": {\n \"v\": 20,\n \"d\": \"Base fee of the EXTCODECOPY opcode\"\n },\n \"blockhash\": {\n \"v\": 20,\n \"d\": \"Base fee of the BLOCKHASH opcode\"\n },\n \"coinbase\": {\n \"v\": 2,\n \"d\": \"Base fee of the COINBASE opcode\"\n },\n \"timestamp\": {\n \"v\": 2,\n \"d\": \"Base fee of the TIMESTAMP opcode\"\n },\n \"number\": {\n \"v\": 2,\n \"d\": \"Base fee of the NUMBER opcode\"\n },\n \"difficulty\": {\n \"v\": 2,\n \"d\": \"Base fee of the DIFFICULTY opcode\"\n },\n \"gaslimit\": {\n \"v\": 2,\n \"d\": \"Base fee of the GASLIMIT opcode\"\n },\n \"pop\": {\n \"v\": 2,\n \"d\": \"Base fee of the POP opcode\"\n },\n \"mload\": {\n \"v\": 3,\n \"d\": \"Base fee of the MLOAD opcode\"\n },\n \"mstore\": {\n \"v\": 3,\n \"d\": \"Base fee of the MSTORE opcode\"\n },\n \"mstore8\": {\n \"v\": 3,\n \"d\": \"Base fee of the MSTORE8 opcode\"\n },\n \"sstore\": {\n \"v\": 0,\n \"d\": \"Base fee of the SSTORE opcode\"\n },\n \"jump\": {\n \"v\": 8,\n \"d\": \"Base fee of the JUMP opcode\"\n },\n \"jumpi\": {\n \"v\": 10,\n \"d\": \"Base fee of the JUMPI opcode\"\n },\n \"pc\": {\n \"v\": 2,\n \"d\": \"Base fee of the PC opcode\"\n },\n \"msize\": {\n \"v\": 2,\n \"d\": \"Base fee of the MSIZE opcode\"\n },\n \"gas\": {\n \"v\": 2,\n \"d\": \"Base fee of the GAS opcode\"\n },\n \"push\": {\n \"v\": 3,\n \"d\": \"Base fee of the PUSH opcode\"\n },\n \"dup\": {\n \"v\": 3,\n \"d\": \"Base fee of the DUP opcode\"\n },\n \"swap\": {\n \"v\": 3,\n \"d\": \"Base fee of the SWAP opcode\"\n },\n \"callcode\": {\n \"v\": 40,\n \"d\": \"Base fee of the CALLCODE opcode\"\n },\n \"return\": {\n \"v\": 0,\n \"d\": \"Base fee of the RETURN opcode\"\n },\n \"invalid\": {\n \"v\": 0,\n \"d\": \"Base fee of the INVALID opcode\"\n },\n \"selfdestruct\": {\n \"v\": 0,\n \"d\": \"Base fee of the SELFDESTRUCT opcode\"\n }\n },\n \"vm\": {\n \"stackLimit\": {\n \"v\": 1024,\n \"d\": \"Maximum size of VM stack allowed\"\n },\n \"callCreateDepth\": {\n \"v\": 1024,\n \"d\": \"Maximum depth of call/create stack\"\n },\n \"maxExtraDataSize\": {\n \"v\": 32,\n \"d\": \"Maximum size extra data may be after Genesis\"\n }\n },\n \"pow\": {\n \"minimumDifficulty\": {\n \"v\": 131072,\n \"d\": \"The minimum that the difficulty may ever be\"\n },\n \"difficultyBoundDivisor\": {\n \"v\": 2048,\n \"d\": \"The bound divisor of the difficulty, used in the update calculations\"\n },\n \"durationLimit\": {\n \"v\": 13,\n \"d\": \"The decision boundary on the blocktime duration used to determine whether difficulty should go up or not\"\n },\n \"epochDuration\": {\n \"v\": 30000,\n \"d\": \"Duration between proof-of-work epochs\"\n },\n \"timebombPeriod\": {\n \"v\": 100000,\n \"d\": \"Exponential difficulty timebomb period\"\n },\n \"minerReward\": {\n \"v\": \"5000000000000000000\",\n \"d\": \"the amount a miner get rewarded for mining a block\"\n },\n \"difficultyBombDelay\": {\n \"v\": 0,\n \"d\": \"the amount of blocks to delay the difficulty bomb with\"\n }\n }\n}\n","{\n \"name\": \"homestead\",\n \"comment\": \"Homestead hardfork with protocol and network changes\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-606\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"delegatecall\": {\n \"v\": 40,\n \"d\": \"Base fee of the DELEGATECALL opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"dao\",\n \"comment\": \"DAO rescue hardfork\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-779\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"tangerineWhistle\",\n \"comment\": \"Hardfork with gas cost changes for IO-heavy operations\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-608\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"sload\": {\n \"v\": 200,\n \"d\": \"Once per SLOAD operation\"\n },\n \"call\": {\n \"v\": 700,\n \"d\": \"Once per CALL operation & message call transaction\"\n },\n \"extcodesize\": {\n \"v\": 700,\n \"d\": \"Base fee of the EXTCODESIZE opcode\"\n },\n \"extcodecopy\": {\n \"v\": 700,\n \"d\": \"Base fee of the EXTCODECOPY opcode\"\n },\n \"balance\": {\n \"v\": 400,\n \"d\": \"Base fee of the BALANCE opcode\"\n },\n \"delegatecall\": {\n \"v\": 700,\n \"d\": \"Base fee of the DELEGATECALL opcode\"\n },\n \"callcode\": {\n \"v\": 700,\n \"d\": \"Base fee of the CALLCODE opcode\"\n },\n \"selfdestruct\": {\n \"v\": 5000,\n \"d\": \"Base fee of the SELFDESTRUCT opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"spuriousDragon\",\n \"comment\": \"HF with EIPs for simple replay attack protection, EXP cost increase, state trie clearing, contract code size limit\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-607\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"expByte\": {\n \"v\": 50,\n \"d\": \"Times ceil(log256(exponent)) for the EXP instruction\"\n }\n },\n \"vm\": {\n \"maxCodeSize\": {\n \"v\": 24576,\n \"d\": \"Maximum length of contract code\"\n }\n },\n \"pow\": {}\n}\n","{\n \"name\": \"byzantium\",\n \"comment\": \"Hardfork with new precompiles, instructions and other protocol changes\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-609\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"modexpGquaddivisor\": {\n \"v\": 20,\n \"d\": \"Gquaddivisor from modexp precompile for gas calculation\"\n },\n \"ecAdd\": {\n \"v\": 500,\n \"d\": \"Gas costs for curve addition precompile\"\n },\n \"ecMul\": {\n \"v\": 40000,\n \"d\": \"Gas costs for curve multiplication precompile\"\n },\n \"ecPairing\": {\n \"v\": 100000,\n \"d\": \"Base gas costs for curve pairing precompile\"\n },\n \"ecPairingWord\": {\n \"v\": 80000,\n \"d\": \"Gas costs regarding curve pairing precompile input length\"\n },\n \"revert\": {\n \"v\": 0,\n \"d\": \"Base fee of the REVERT opcode\"\n },\n \"staticcall\": {\n \"v\": 700,\n \"d\": \"Base fee of the STATICCALL opcode\"\n },\n \"returndatasize\": {\n \"v\": 2,\n \"d\": \"Base fee of the RETURNDATASIZE opcode\"\n },\n \"returndatacopy\": {\n \"v\": 3,\n \"d\": \"Base fee of the RETURNDATACOPY opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {\n \"minerReward\": {\n \"v\": \"3000000000000000000\",\n \"d\": \"the amount a miner get rewarded for mining a block\"\n },\n \"difficultyBombDelay\": {\n \"v\": 3000000,\n \"d\": \"the amount of blocks to delay the difficulty bomb with\"\n }\n }\n}\n","{\n \"name\": \"constantinople\",\n \"comment\": \"Postponed hardfork including EIP-1283 (SSTORE gas metering changes)\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-1013\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"netSstoreNoopGas\": {\n \"v\": 200,\n \"d\": \"Once per SSTORE operation if the value doesn't change\"\n },\n \"netSstoreInitGas\": {\n \"v\": 20000,\n \"d\": \"Once per SSTORE operation from clean zero\"\n },\n \"netSstoreCleanGas\": {\n \"v\": 5000,\n \"d\": \"Once per SSTORE operation from clean non-zero\"\n },\n \"netSstoreDirtyGas\": {\n \"v\": 200,\n \"d\": \"Once per SSTORE operation from dirty\"\n },\n \"netSstoreClearRefund\": {\n \"v\": 15000,\n \"d\": \"Once per SSTORE operation for clearing an originally existing storage slot\"\n },\n \"netSstoreResetRefund\": {\n \"v\": 4800,\n \"d\": \"Once per SSTORE operation for resetting to the original non-zero value\"\n },\n \"netSstoreResetClearRefund\": {\n \"v\": 19800,\n \"d\": \"Once per SSTORE operation for resetting to the original zero value\"\n },\n \"shl\": {\n \"v\": 3,\n \"d\": \"Base fee of the SHL opcode\"\n },\n \"shr\": {\n \"v\": 3,\n \"d\": \"Base fee of the SHR opcode\"\n },\n \"sar\": {\n \"v\": 3,\n \"d\": \"Base fee of the SAR opcode\"\n },\n \"extcodehash\": {\n \"v\": 400,\n \"d\": \"Base fee of the EXTCODEHASH opcode\"\n },\n \"create2\": {\n \"v\": 32000,\n \"d\": \"Base fee of the CREATE2 opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {\n \"minerReward\": {\n \"v\": \"2000000000000000000\",\n \"d\": \"The amount a miner gets rewarded for mining a block\"\n },\n \"difficultyBombDelay\": {\n \"v\": 5000000,\n \"d\": \"the amount of blocks to delay the difficulty bomb with\"\n }\n }\n}\n","{\n \"name\": \"petersburg\",\n \"comment\": \"Aka constantinopleFix, removes EIP-1283, activate together with or after constantinople\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-1716\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"netSstoreNoopGas\": {\n \"v\": null,\n \"d\": \"Removed along EIP-1283\"\n },\n \"netSstoreInitGas\": {\n \"v\": null,\n \"d\": \"Removed along EIP-1283\"\n },\n \"netSstoreCleanGas\": {\n \"v\": null,\n \"d\": \"Removed along EIP-1283\"\n },\n \"netSstoreDirtyGas\": {\n \"v\": null,\n \"d\": \"Removed along EIP-1283\"\n },\n \"netSstoreClearRefund\": {\n \"v\": null,\n \"d\": \"Removed along EIP-1283\"\n },\n \"netSstoreResetRefund\": {\n \"v\": null,\n \"d\": \"Removed along EIP-1283\"\n },\n \"netSstoreResetClearRefund\": {\n \"v\": null,\n \"d\": \"Removed along EIP-1283\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"istanbul\",\n \"comment\": \"HF targeted for December 2019 following the Constantinople/Petersburg HF\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-1679\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"blake2Round\": {\n \"v\": 1,\n \"d\": \"Gas cost per round for the Blake2 F precompile\"\n },\n \"ecAdd\": {\n \"v\": 150,\n \"d\": \"Gas costs for curve addition precompile\"\n },\n \"ecMul\": {\n \"v\": 6000,\n \"d\": \"Gas costs for curve multiplication precompile\"\n },\n \"ecPairing\": {\n \"v\": 45000,\n \"d\": \"Base gas costs for curve pairing precompile\"\n },\n \"ecPairingWord\": {\n \"v\": 34000,\n \"d\": \"Gas costs regarding curve pairing precompile input length\"\n },\n \"txDataNonZero\": {\n \"v\": 16,\n \"d\": \"Per byte of data attached to a transaction that is not equal to zero. NOTE: Not payable on data of calls between transactions\"\n },\n \"sstoreSentryGasEIP2200\": {\n \"v\": 2300,\n \"d\": \"Minimum gas required to be present for an SSTORE call, not consumed\"\n },\n \"sstoreNoopGasEIP2200\": {\n \"v\": 800,\n \"d\": \"Once per SSTORE operation if the value doesn't change\"\n },\n \"sstoreDirtyGasEIP2200\": {\n \"v\": 800,\n \"d\": \"Once per SSTORE operation if a dirty value is changed\"\n },\n \"sstoreInitGasEIP2200\": {\n \"v\": 20000,\n \"d\": \"Once per SSTORE operation from clean zero to non-zero\"\n },\n \"sstoreInitRefundEIP2200\": {\n \"v\": 19200,\n \"d\": \"Once per SSTORE operation for resetting to the original zero value\"\n },\n \"sstoreCleanGasEIP2200\": {\n \"v\": 5000,\n \"d\": \"Once per SSTORE operation from clean non-zero to something else\"\n },\n \"sstoreCleanRefundEIP2200\": {\n \"v\": 4200,\n \"d\": \"Once per SSTORE operation for resetting to the original non-zero value\"\n },\n \"sstoreClearRefundEIP2200\": {\n \"v\": 15000,\n \"d\": \"Once per SSTORE operation for clearing an originally existing storage slot\"\n },\n \"balance\": {\n \"v\": 700,\n \"d\": \"Base fee of the BALANCE opcode\"\n },\n \"extcodehash\": {\n \"v\": 700,\n \"d\": \"Base fee of the EXTCODEHASH opcode\"\n },\n \"chainid\": {\n \"v\": 2,\n \"d\": \"Base fee of the CHAINID opcode\"\n },\n \"selfbalance\": {\n \"v\": 5,\n \"d\": \"Base fee of the SELFBALANCE opcode\"\n },\n \"sload\": {\n \"v\": 800,\n \"d\": \"Base fee of the SLOAD opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"muirGlacier\",\n \"comment\": \"HF to delay the difficulty bomb\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2384\",\n \"status\": \"Final\",\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {\n \"difficultyBombDelay\": {\n \"v\": 9000000,\n \"d\": \"the amount of blocks to delay the difficulty bomb with\"\n }\n }\n}\n","{\n \"name\": \"berlin\",\n \"comment\": \"HF targeted for July 2020 following the Muir Glacier HF\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2070\",\n \"status\": \"Final\",\n \"eips\": [2565, 2929, 2718, 2930]\n}\n","{\n \"name\": \"london\",\n \"comment\": \"HF targeted for July 2021 following the Berlin fork\",\n \"url\": \"https://github.com/ethereum/eth1.0-specs/blob/master/network-upgrades/mainnet-upgrades/london.md\",\n \"status\": \"Final\",\n \"eips\": [1559, 3198, 3529, 3541]\n}\n","{\n \"name\": \"shanghai\",\n \"comment\": \"Next feature hardfork after the merge hardfork\",\n \"url\": \"https://github.com/ethereum/pm/issues/356\",\n \"status\": \"Pre-Draft\",\n \"eips\": []\n}\n","{\n \"name\": \"arrowGlacier\",\n \"comment\": \"HF to delay the difficulty bomb\",\n \"url\": \"https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/arrow-glacier.md\",\n \"status\": \"Final\",\n \"eips\": [4345],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"grayGlacier\",\n \"comment\": \"Delaying the difficulty bomb to Mid September 2022\",\n \"url\": \"https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/gray-glacier.md\",\n \"status\": \"Draft\",\n \"eips\": [5133],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"mergeForkIdTransition\",\n \"comment\": \"Pre-merge hardfork to fork off non-upgraded clients\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3675\",\n \"status\": \"Draft\",\n \"eips\": []\n}\n","{\n \"name\": \"merge\",\n \"comment\": \"Hardfork to upgrade the consensus mechanism to Proof-of-Stake\",\n \"url\": \"https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/merge.md\",\n \"status\": \"Draft\",\n \"consensus\": {\n \"type\": \"pos\",\n \"algorithm\": \"casper\",\n \"casper\": {}\n },\n \"eips\": [3675, 4399]\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hardforks = void 0;\nexports.hardforks = [['chainstart', require('./chainstart.json')], ['homestead', require('./homestead.json')], ['dao', require('./dao.json')], ['tangerineWhistle', require('./tangerineWhistle.json')], ['spuriousDragon', require('./spuriousDragon.json')], ['byzantium', require('./byzantium.json')], ['constantinople', require('./constantinople.json')], ['petersburg', require('./petersburg.json')], ['istanbul', require('./istanbul.json')], ['muirGlacier', require('./muirGlacier.json')], ['berlin', require('./berlin.json')], ['london', require('./london.json')], ['shanghai', require('./shanghai.json')], ['arrowGlacier', require('./arrowGlacier.json')], ['grayGlacier', require('./grayGlacier.json')], ['mergeForkIdTransition', require('./mergeForkIdTransition.json')], ['merge', require('./merge.json')]];\n","{\n \"name\": \"EIP-1153\",\n \"number\": 1153,\n \"comment\": \"Transient Storage\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-1153\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"chainstart\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {\n \"tstore\": {\n \"v\": 100,\n \"d\": \"Base fee of the TSTORE opcode\"\n },\n \"tload\": {\n \"v\": 100,\n \"d\": \"Base fee of the TLOAD opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-1559\",\n \"number\": 1559,\n \"comment\": \"Fee market change for ETH 1.0 chain\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-1559\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"berlin\",\n \"requiredEIPs\": [2930],\n \"gasConfig\": {\n \"baseFeeMaxChangeDenominator\": {\n \"v\": 8,\n \"d\": \"Maximum base fee change denominator\"\n },\n \"elasticityMultiplier\": {\n \"v\": 2,\n \"d\": \"Maximum block gas target elasticity\"\n },\n \"initialBaseFee\": {\n \"v\": 1000000000,\n \"d\": \"Initial base fee on first EIP1559 block\"\n }\n },\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-2315\",\n \"number\": 2315,\n \"comment\": \"Simple subroutines for the EVM\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2315\",\n \"status\": \"Draft\",\n \"minimumHardfork\": \"istanbul\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"beginsub\": {\n \"v\": 2,\n \"d\": \"Base fee of the BEGINSUB opcode\"\n },\n \"returnsub\": {\n \"v\": 5,\n \"d\": \"Base fee of the RETURNSUB opcode\"\n },\n \"jumpsub\": {\n \"v\": 10,\n \"d\": \"Base fee of the JUMPSUB opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-2537\",\n \"number\": 2537,\n \"comment\": \"BLS12-381 precompiles\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2537\",\n \"status\": \"Draft\",\n \"minimumHardfork\": \"chainstart\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"Bls12381G1AddGas\": {\n \"v\": 600,\n \"d\": \"Gas cost of a single BLS12-381 G1 addition precompile-call\"\n },\n \"Bls12381G1MulGas\": {\n \"v\": 12000,\n \"d\": \"Gas cost of a single BLS12-381 G1 multiplication precompile-call\"\n },\n \"Bls12381G2AddGas\": {\n \"v\": 4500,\n \"d\": \"Gas cost of a single BLS12-381 G2 addition precompile-call\"\n },\n \"Bls12381G2MulGas\": {\n \"v\": 55000,\n \"d\": \"Gas cost of a single BLS12-381 G2 multiplication precompile-call\"\n },\n \"Bls12381PairingBaseGas\": {\n \"v\": 115000,\n \"d\": \"Base gas cost of BLS12-381 pairing check\"\n },\n \"Bls12381PairingPerPairGas\": {\n \"v\": 23000,\n \"d\": \"Per-pair gas cost of BLS12-381 pairing check\"\n },\n \"Bls12381MapG1Gas\": {\n \"v\": 5500,\n \"d\": \"Gas cost of BLS12-381 map field element to G1\"\n },\n \"Bls12381MapG2Gas\": {\n \"v\": 110000,\n \"d\": \"Gas cost of BLS12-381 map field element to G2\"\n },\n \"Bls12381MultiExpGasDiscount\": {\n \"v\": [[1, 1200], [2, 888], [3, 764], [4, 641], [5, 594], [6, 547], [7, 500], [8, 453], [9, 438], [10, 423], [11, 408], [12, 394], [13, 379], [14, 364], [15, 349], [16, 334], [17, 330], [18, 326], [19, 322], [20, 318], [21, 314], [22, 310], [23, 306], [24, 302], [25, 298], [26, 294], [27, 289], [28, 285], [29, 281], [30, 277], [31, 273], [32, 269], [33, 268], [34, 266], [35, 265], [36, 263], [37, 262], [38, 260], [39, 259], [40, 257], [41, 256], [42, 254], [43, 253], [44, 251], [45, 250], [46, 248], [47, 247], [48, 245], [49, 244], [50, 242], [51, 241], [52, 239], [53, 238], [54, 236], [55, 235], [56, 233], [57, 232], [58, 231], [59, 229], [60, 228], [61, 226], [62, 225], [63, 223], [64, 222], [65, 221], [66, 220], [67, 219], [68, 219], [69, 218], [70, 217], [71, 216], [72, 216], [73, 215], [74, 214], [75, 213], [76, 213], [77, 212], [78, 211], [79, 211], [80, 210], [81, 209], [82, 208], [83, 208], [84, 207], [85, 206], [86, 205], [87, 205], [88, 204], [89, 203], [90, 202], [91, 202], [92, 201], [93, 200], [94, 199], [95, 199], [96, 198], [97, 197], [98, 196], [99, 196], [100, 195], [101, 194], [102, 193], [103, 193], [104, 192], [105, 191], [106, 191], [107, 190], [108, 189], [109, 188], [110, 188], [111, 187], [112, 186], [113, 185], [114, 185], [115, 184], [116, 183], [117, 182], [118, 182], [119, 181], [120, 180], [121, 179], [122, 179], [123, 178], [124, 177], [125, 176], [126, 176], [127, 175], [128, 174]],\n \"d\": \"Discount gas costs of calls to the MultiExp precompiles with `k` (point, scalar) pair\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-2565\",\n \"number\": 2565,\n \"comment\": \"ModExp gas cost\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2565\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"byzantium\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"modexpGquaddivisor\": {\n \"v\": 3,\n \"d\": \"Gquaddivisor from modexp precompile for gas calculation\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-2718\",\n \"comment\": \"Typed Transaction Envelope\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2718\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"chainstart\",\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-2929\",\n \"comment\": \"Gas cost increases for state access opcodes\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2929\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"chainstart\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"coldsload\": {\n \"v\": 2100,\n \"d\": \"Gas cost of the first read of storage from a given location (per transaction)\"\n },\n \"coldaccountaccess\": {\n \"v\": 2600,\n \"d\": \"Gas cost of the first read of a given address (per transaction)\"\n },\n \"warmstorageread\": {\n \"v\": 100,\n \"d\": \"Gas cost of reading storage locations which have already loaded 'cold'\"\n },\n \"sstoreCleanGasEIP2200\": {\n \"v\": 2900,\n \"d\": \"Once per SSTORE operation from clean non-zero to something else\"\n },\n \"sstoreNoopGasEIP2200\": {\n \"v\": 100,\n \"d\": \"Once per SSTORE operation if the value doesn't change\"\n },\n \"sstoreDirtyGasEIP2200\": {\n \"v\": 100,\n \"d\": \"Once per SSTORE operation if a dirty value is changed\"\n },\n \"sstoreInitRefundEIP2200\": {\n \"v\": 19900,\n \"d\": \"Once per SSTORE operation for resetting to the original zero value\"\n },\n \"sstoreCleanRefundEIP2200\": {\n \"v\": 4900,\n \"d\": \"Once per SSTORE operation for resetting to the original non-zero value\"\n },\n \"call\": {\n \"v\": 0,\n \"d\": \"Base fee of the CALL opcode\"\n },\n \"callcode\": {\n \"v\": 0,\n \"d\": \"Base fee of the CALLCODE opcode\"\n },\n \"delegatecall\": {\n \"v\": 0,\n \"d\": \"Base fee of the DELEGATECALL opcode\"\n },\n \"staticcall\": {\n \"v\": 0,\n \"d\": \"Base fee of the STATICCALL opcode\"\n },\n \"balance\": {\n \"v\": 0,\n \"d\": \"Base fee of the BALANCE opcode\"\n },\n \"extcodesize\": {\n \"v\": 0,\n \"d\": \"Base fee of the EXTCODESIZE opcode\"\n },\n \"extcodecopy\": {\n \"v\": 0,\n \"d\": \"Base fee of the EXTCODECOPY opcode\"\n },\n \"extcodehash\": {\n \"v\": 0,\n \"d\": \"Base fee of the EXTCODEHASH opcode\"\n },\n \"sload\": {\n \"v\": 0,\n \"d\": \"Base fee of the SLOAD opcode\"\n },\n \"sstore\": {\n \"v\": 0,\n \"d\": \"Base fee of the SSTORE opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-2930\",\n \"comment\": \"Optional access lists\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-2930\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"istanbul\",\n \"requiredEIPs\": [2718, 2929],\n \"gasConfig\": {},\n \"gasPrices\": {\n \"accessListStorageKeyCost\": {\n \"v\": 1900,\n \"d\": \"Gas cost per storage key in an Access List transaction\"\n },\n \"accessListAddressCost\": {\n \"v\": 2400,\n \"d\": \"Gas cost per storage key in an Access List transaction\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3198\",\n \"number\": 3198,\n \"comment\": \"BASEFEE opcode\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3198\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"london\",\n \"gasConfig\": {},\n \"gasPrices\": {\n \"basefee\": {\n \"v\": 2,\n \"d\": \"Gas cost of the BASEFEE opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3529\",\n \"comment\": \"Reduction in refunds\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3529\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"berlin\",\n \"requiredEIPs\": [2929],\n \"gasConfig\": {\n \"maxRefundQuotient\": {\n \"v\": 5,\n \"d\": \"Maximum refund quotient; max tx refund is min(tx.gasUsed/maxRefundQuotient, tx.gasRefund)\"\n }\n },\n \"gasPrices\": {\n \"selfdestructRefund\": {\n \"v\": 0,\n \"d\": \"Refunded following a selfdestruct operation\"\n },\n \"sstoreClearRefundEIP2200\": {\n \"v\": 4800,\n \"d\": \"Once per SSTORE operation for clearing an originally existing storage slot\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3540\",\n \"number\": 3540,\n \"comment\": \"EVM Object Format (EOF) v1\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3540\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"london\",\n \"requiredEIPs\": [\n 3541\n ],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3541\",\n \"comment\": \"Reject new contracts starting with the 0xEF byte\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3541\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"berlin\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3554\",\n \"comment\": \"Reduction in refunds\",\n \"url\": \"Difficulty Bomb Delay to December 1st 2021\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"muirGlacier\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {\n \"difficultyBombDelay\": {\n \"v\": 9500000,\n \"d\": \"the amount of blocks to delay the difficulty bomb with\"\n }\n }\n}\n","{\n \"name\": \"EIP-3607\",\n \"number\": 3607,\n \"comment\": \"Reject transactions from senders with deployed code\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3607\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"chainstart\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3651\",\n \"number\": 3198,\n \"comment\": \"Warm COINBASE\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3651\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"london\",\n \"requiredEIPs\": [2929],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3670\",\n \"number\": 3670,\n \"comment\": \"EOF - Code Validation\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3670\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"london\",\n \"requiredEIPs\": [\n 3540\n ],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3675\",\n \"number\": 3675,\n \"comment\": \"Upgrade consensus to Proof-of-Stake\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3675\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"london\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3855\",\n \"number\": 3855,\n \"comment\": \"PUSH0 instruction\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3855\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"chainstart\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {\n \"push0\": {\n \"v\": 2,\n \"d\": \"Base fee of the PUSH0 opcode\"\n }\n },\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-3860\",\n \"number\": 3860,\n \"comment\": \"Limit and meter initcode\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-3860\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"spuriousDragon\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {\n \"initCodeWordCost\": {\n \"v\": 2,\n \"d\": \"Gas to pay for each word (32 bytes) of initcode when creating a contract\"\n }\n },\n \"vm\": {\n \"maxInitCodeSize\": {\n \"v\": 49152,\n \"d\": \"Maximum length of initialization code when creating a contract\"\n }\n },\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-4345\",\n \"number\": 4345,\n \"comment\": \"Difficulty Bomb Delay to June 2022\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-4345\",\n \"status\": \"Final\",\n \"minimumHardfork\": \"london\",\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {\n \"difficultyBombDelay\": {\n \"v\": 10700000,\n \"d\": \"the amount of blocks to delay the difficulty bomb with\"\n }\n }\n}\n","{\n \"name\": \"EIP-4399\",\n \"number\": 4399,\n \"comment\": \"Supplant DIFFICULTY opcode with PREVRANDAO\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-4399\",\n \"status\": \"Review\",\n \"minimumHardfork\": \"london\",\n \"requiredEIPs\": [],\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {}\n}\n","{\n \"name\": \"EIP-5133\",\n \"number\": 5133,\n \"comment\": \"Delaying Difficulty Bomb to mid-September 2022\",\n \"url\": \"https://eips.ethereum.org/EIPS/eip-5133\",\n \"status\": \"Draft\",\n \"minimumHardfork\": \"grayGlacier\",\n \"gasConfig\": {},\n \"gasPrices\": {},\n \"vm\": {},\n \"pow\": {\n \"difficultyBombDelay\": {\n \"v\": 11400000,\n \"d\": \"the amount of blocks to delay the difficulty bomb with\"\n }\n }\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.EIPs = void 0;\nexports.EIPs = {\n 1153: require('./1153.json'),\n 1559: require('./1559.json'),\n 2315: require('./2315.json'),\n 2537: require('./2537.json'),\n 2565: require('./2565.json'),\n 2718: require('./2718.json'),\n 2929: require('./2929.json'),\n 2930: require('./2930.json'),\n 3198: require('./3198.json'),\n 3529: require('./3529.json'),\n 3540: require('./3540.json'),\n 3541: require('./3541.json'),\n 3554: require('./3554.json'),\n 3607: require('./3607.json'),\n 3651: require('./3651.json'),\n 3670: require('./3670.json'),\n 3675: require('./3675.json'),\n 3855: require('./3855.json'),\n 3860: require('./3860.json'),\n 4345: require('./4345.json'),\n 4399: require('./4399.json'),\n 5133: require('./5133.json')\n};\n","{\n \"0x000d836201318ec6899a67540690382780743280\": \"0xad78ebc5ac6200000\",\n \"0x001762430ea9c3a26e5749afdb70da5f78ddbb8c\": \"0xad78ebc5ac6200000\",\n \"0x001d14804b399c6ef80e64576f657660804fec0b\": \"0xe3aeb5737240a00000\",\n \"0x0032403587947b9f15622a68d104d54d33dbd1cd\": \"0x433874f632cc60000\",\n \"0x00497e92cdc0e0b963d752b2296acb87da828b24\": \"0xa8f649fe7c6180000\",\n \"0x004bfbe1546bc6c65b5c7eaa55304b38bbfec6d3\": \"0x6c6b935b8bbd400000\",\n \"0x005a9c03f69d17d66cbb8ad721008a9ebbb836fb\": \"0x6c6b935b8bbd400000\",\n \"0x005d0ee8155ec0a6ff6808552ca5f16bb5be323a\": \"0xaadec983fcff40000\",\n \"0x007622d84a234bb8b078230fcf84b67ae9a8acae\": \"0x25e1cc519952f80000\",\n \"0x007b9fc31905b4994b04c9e2cfdc5e2770503f42\": \"0x6c5db2a4d815dc0000\",\n \"0x007f4a23ca00cd043d25c2888c1aa5688f81a344\": \"0x29f0a95bfbf7290000\",\n \"0x008639dabbe3aeac887b5dc0e43e13bcd287d76c\": \"0x10d0e3c87d6e2c0000\",\n \"0x0089508679abf8c71bf6781687120e3e6a84584d\": \"0x6194049f30f7200000\",\n \"0x008fc7cbadffbd0d7fe44f8dfd60a79d721a1c9c\": \"0x3635c9adc5dea00000\",\n \"0x009560a3de627868f91fa8bfe1c1b7afaf08186b\": \"0x1c67f5f7baa0b00000\",\n \"0x00969747f7a5b30645fe00e44901435ace24cc37\": \"0x5c283d410394100000\",\n \"0x009a6d7db326679b77c90391a7476d238f3ba33e\": \"0xada55474b81340000\",\n \"0x009eef0a0886056e3f69211853b9b7457f3782e4\": \"0xa2a878069b28e00000\",\n \"0x009fdbf44e1f4a6362b769c39a475f95a96c2bc7\": \"0x1e931283ccc8500000\",\n \"0x00a5797f52c9d58f189f36b1d45d1bf6041f2f6b\": \"0x127d1b3461acd1a0000\",\n \"0x00aa5381b2138ebeffc191d5d8c391753b7098d2\": \"0x35abb09ffedeb68000\",\n \"0x00aada25ea2286709abb422d41923fd380cd04c7\": \"0x233df3299f61720000\",\n \"0x00acbfb2f25a5485c739ef70a44eeeeb7c65a66f\": \"0x56bc75e2d63100000\",\n \"0x00acc6f082a442828764d11f58d6894ae408f073\": \"0xcb49b44ba602d800000\",\n \"0x00b277b099a8e866ca0ec65bcb87284fd142a582\": \"0x6acb3df27e1f880000\",\n \"0x00bdd4013aa31c04616c2bc9785f2788f915679b\": \"0xb9f65d00f63c0000\",\n \"0x00c27d63fde24b92ee8a1e7ed5d26d8dc5c83b03\": \"0x6c6b935b8bbd400000\",\n \"0x00c40fe2095423509b9fd9b754323158af2310f3\": \"0x0\",\n \"0x00d75ed60c774f8b3a5a5173fb1833ad7105a2d9\": \"0x6cb7e74867d5e60000\",\n \"0x00d78d89b35f472716eceafebf600527d3a1f969\": \"0x5e0549c9632e1d80000\",\n \"0x00dae27b350bae20c5652124af5d8b5cba001ec1\": \"0x22b1c8c1227a00000\",\n \"0x00dc01cbf44978a42e8de8e436edf94205cfb6ec\": \"0x4f0febbcda8cb40000\",\n \"0x00e681bc2d10db62de85848324492250348e90bf\": \"0x43c33c1937564800000\",\n \"0x00f463e137dcf625fbf3bca39eca98d2b968cf7f\": \"0x14061b9d77a5e980000\",\n \"0x010007394b8b7565a1658af88ce463499135d6b7\": \"0x56bc75e2d63100000\",\n \"0x010df1df4bed23760d2d1c03781586ddf7918e54\": \"0x340aad21b3b700000\",\n \"0x010f4a98dfa1d9799bf5c796fb550efbe7ecd877\": \"0x1b2f292236292c70000\",\n \"0x01155057002f6b0d18acb9388d3bc8129f8f7a20\": \"0x48a43c54602f700000\",\n \"0x01226e0ad8d62277b162621c62c928e96e0b9a8c\": \"0x6c6b935b8bbd400000\",\n \"0x0126e12ebc17035f35c0e9d11dd148393c405d7a\": \"0x6c660645aa47180000\",\n \"0x012f396a2b5eb83559bac515e5210df2c8c362ba\": \"0xad78ebc5ac6200000\",\n \"0x0134ff38155fabae94fd35c4ffe1d79de7ef9c59\": \"0x35659ef93f0fc40000\",\n \"0x0136a5af6c3299c6b5f005fdaddb148c070b299b\": \"0x11aa9ac15f1280000\",\n \"0x01488ad3da603c4cdd6cb0b7a1e30d2a30c8fc38\": \"0xad78ebc5ac6200000\",\n \"0x014974a1f46bf204944a853111e52f1602617def\": \"0x6c6b935b8bbd400000\",\n \"0x014b7f67b14f5d983d87014f570c8b993b9872b5\": \"0xad78ebc5ac6200000\",\n \"0x0151fa5d17a2dce2d7f1eb39ef7fe2ad213d5d89\": \"0xd8d726b7177a800000\",\n \"0x01577afd4e50890247c9b10d44af73229aec884f\": \"0x24dce54d34a1a00000\",\n \"0x015f097d9acddcddafaf2a107eb93a40fc94b04c\": \"0x43c33c1937564800000\",\n \"0x0169c1c210eae845e56840412e1f65993ea90fb4\": \"0x6c6b935b8bbd400000\",\n \"0x016b60bb6d67928c29fd0313c666da8f1698d9c5\": \"0x6c6b935b8bbd400000\",\n \"0x016c85e1613b900fa357b8283b120e65aefcdd08\": \"0x2b5d9784a97cd50000\",\n \"0x018492488ba1a292342247b31855a55905fef269\": \"0x796e3ea3f8ab00000\",\n \"0x018f20a27b27ec441af723fd9099f2cbb79d6263\": \"0x75792a8abdef7c0000\",\n \"0x0191eb547e7bf6976b9b1b577546761de65622e2\": \"0x6c6b4c4da6ddbe0000\",\n \"0x019d709579ff4bc09fdcdde431dc1447d2c260bc\": \"0x1158e460913d00000\",\n \"0x01a25a5f5af0169b30864c3be4d7563ccd44f09e\": \"0x4d853c8f8908980000\",\n \"0x01a7d9fa7d0eb1185c67e54da83c2e75db69e39f\": \"0x19d4addd0d8bc960000\",\n \"0x01a818135a414210c37c62b625aca1a54611ac36\": \"0xe18398e7601900000\",\n \"0x01b1cae91a3b9559afb33cdc6d689442fdbfe037\": \"0xad78ebc5ac6200000\",\n \"0x01b5b5bc5a117fa08b34ed1db9440608597ac548\": \"0xad78ebc5ac6200000\",\n \"0x01bbc14f67af0639aab1441e6a08d4ce7162090f\": \"0x46fcf68ff8be060000\",\n \"0x01d03815c61f416b71a2610a2daba59ff6a6de5b\": \"0x205dfe50b81c82e0000\",\n \"0x01d599ee0d5f8c38ab2d392e2c65b74c3ce31820\": \"0x1ba5abf9e779380000\",\n \"0x01e40521122530d9ac91113c06a0190b6d63850b\": \"0x487a9a304539440000\",\n \"0x01e6415d587b065490f1ed7f21d6e0f386ee6747\": \"0x6c6b935b8bbd400000\",\n \"0x01e864d354741b423e6f42851724468c74f5aa9c\": \"0x43c33c1937564800000\",\n \"0x01ed5fba8d2eab673aec042d30e4e8a611d8c55a\": \"0x6c6b935b8bbd400000\",\n \"0x01fb8ec12425a04f813e46c54c05748ca6b29aa9\": \"0xe15730385467c0000\",\n \"0x01ff1eb1dead50a7f2f9638fdee6eccf3a7b2ac8\": \"0x2086ac351052600000\",\n \"0x020362c3ade878ca90d6b2d889a4cc5510eed5f3\": \"0x3888e8b311adb38000\",\n \"0x0203ae01d4c41cae1865e04b1f5b53cdfaecae31\": \"0x3689cdceb28cd70000\",\n \"0x02089361a3fe7451fb1f87f01a2d866653dc0b07\": \"0x22ac74832b5040000\",\n \"0x021f69043de88c4917ca10f1842897eec0589c7c\": \"0x6b44cfb81487f40000\",\n \"0x02290fb5f9a517f82845acdeca0fc846039be233\": \"0x6c6b935b8bbd400000\",\n \"0x0239b4f21f8e05cd01512b2be7a0e18a6d974607\": \"0x3635c9adc5dea00000\",\n \"0x02477212ffdd75e5155651b76506b1646671a1eb\": \"0x5f68e8131ecf800000\",\n \"0x024a098ae702bef5406c9c22b78bd4eb2cc7a293\": \"0xd8d726b7177a800000\",\n \"0x024bdd2c7bfd500ee7404f7fb3e9fb31dd20fbd1\": \"0x9c2007651b2500000\",\n \"0x025367960304beee34591118e9ac2d1358d8021a\": \"0x6c6b935b8bbd400000\",\n \"0x0256149f5b5063bea14e15661ffb58f9b459a957\": \"0x2629f66e0c53000000\",\n \"0x02603d7a3bb297c67c877e5d34fbd5b913d4c63a\": \"0x1158e460913d00000\",\n \"0x0261ad3a172abf1315f0ffec3270986a8409cb25\": \"0xb08213bcf8ffe0000\",\n \"0x026432af37dc5113f1f46d480a4de0b28052237e\": \"0x1349b786e40bfc0000\",\n \"0x0266ab1c6b0216230b9395443d5fa75e684568c6\": \"0x3635c9adc5dea00000\",\n \"0x02751dc68cb5bd737027abf7ddb77390cd77c16b\": \"0x1158e460913d00000\",\n \"0x02778e390fa17510a3428af2870c4273547d386c\": \"0x36c3c66170c0d720000\",\n \"0x02ade5db22f8b758ee1443626c64ec2f32aa0a15\": \"0x43c33c1937564800000\",\n \"0x02af2459a93d0b3f4d062636236cd4b29e3bcecf\": \"0x678a932062e4180000\",\n \"0x02b1af72339b2a2256389fd64607de24f0de600a\": \"0x6c6b935b8bbd400000\",\n \"0x02b643d6fabd437a851accbe79abb7fde126dccf\": \"0x18650127cc3dc800000\",\n \"0x02b6d65cb00b7b36e1fb5ed3632c4cb20a894130\": \"0x43c33c1937564800000\",\n \"0x02b7b1d6b34ce053a40eb65cd4a4f7dddd0e9f30\": \"0x252248deb6e6940000\",\n \"0x02c9f7940a7b8b7a410bf83dc9c22333d4275dd3\": \"0x10f0cf064dd59200000\",\n \"0x02d4a30968a39e2b3498c3a6a4ed45c1c6646822\": \"0x6c6b935b8bbd400000\",\n \"0x02dfcb17a1b87441036374b762a5d3418b1cb4d4\": \"0x48b02ba9d1ba460000\",\n \"0x02e4cb22be46258a40e16d4338d802fffd00c151\": \"0x149696eaceba810000\",\n \"0x02e816afc1b5c0f39852131959d946eb3b07b5ad\": \"0x3635c9adc5dea00000\",\n \"0x02f7f67209b16a17550c694c72583819c80b54ad\": \"0x5559306a78a700000\",\n \"0x030973807b2f426914ad00181270acd27b8ff61f\": \"0x121ea68c114e5100000\",\n \"0x03097923ba155e16d82f3ad3f6b815540884b92c\": \"0x62a992e53a0af00000\",\n \"0x030fb3401f72bd3418b7d1da75bf8c519dd707dc\": \"0xa2a15d09519be00000\",\n \"0x031e25db516b0f099faebfd94f890cf96660836b\": \"0x6c6b935b8bbd400000\",\n \"0x0328510c09dbcd85194a98d67c33ac49f2f94d60\": \"0x2544faa778090e00000\",\n \"0x0329188f080657ab3a2afa522467178279832085\": \"0xbbf510ddfcb260000\",\n \"0x03317826d1f70aa4bddfa09be0c4105552d2358b\": \"0x21a754a6dc5280000\",\n \"0x03337012ae1d7ff3ee7f697c403e7780188bf0ef\": \"0xad78ebc5ac6200000\",\n \"0x03377c0e556b640103289a6189e1aeae63493467\": \"0x43c33c1937564800000\",\n \"0x0349634dc2a9e80c3f7721ee2b5046aeaaedfbb5\": \"0xd8d726b7177a800000\",\n \"0x0355bcacbd21441e95adeedc30c17218c8a408ce\": \"0x15af1d78b58c400000\",\n \"0x036eeff5ba90a6879a14dff4c5043b18ca0460c9\": \"0x56bc75e2d63100000\",\n \"0x03714b41d2a6f751008ef8dd4d2b29aecab8f36e\": \"0x14542ba12a337c00000\",\n \"0x0372e852582e0934344a0fed2178304df25d4628\": \"0x43c33c1937564800000\",\n \"0x0372ee5508bf8163ed284e5eef94ce4d7367e522\": \"0x56bc75e2d63100000\",\n \"0x037dd056e7fdbd641db5b6bea2a8780a83fae180\": \"0x796e3ea3f8ab00000\",\n \"0x038323b184cff7a82ae2e1bda7793fe4319ca0bf\": \"0x43c33c1937564800000\",\n \"0x038779ca2dbe663e63db3fe75683ea0ec62e2383\": \"0x5a87e7d7f5f6580000\",\n \"0x038e45eadd3d88b87fe4dab066680522f0dfc8f9\": \"0x21e19e0c9bab2400000\",\n \"0x0392549a727f81655429cb928b529f25df4d1385\": \"0x16c43a0eea0740000\",\n \"0x0394b90fadb8604f86f43fc1e35d3124b32a5989\": \"0x296aa140278e700000\",\n \"0x039e7a4ebc284e2ccd42b1bdd60bd6511c0f7706\": \"0xf015f25736420000\",\n \"0x039ef1ce52fe7963f166d5a275c4b1069fe3a832\": \"0x15af39e4aab2740000\",\n \"0x03a26cfc4c18316f70d59e9e1a79ee3e8b962f4c\": \"0x6c6b935b8bbd400000\",\n \"0x03aa622881236dd0f4940c24c324ff8b7b7e2186\": \"0xad78ebc5ac62000000\",\n \"0x03af7ad9d5223cf7c8c13f20df67ebe5ffc5bb41\": \"0xad78ebc5ac6200000\",\n \"0x03b0f17cd4469ddccfb7da697e82a91a5f9e7774\": \"0x1158e460913d00000\",\n \"0x03b41b51f41df20dd279bae18c12775f77ad771c\": \"0x3635c9adc5dea00000\",\n \"0x03be5b4629aefbbcab9de26d39576cb7f691d764\": \"0xadf30ba70c8970000\",\n \"0x03c647a9f929b0781fe9ae01caa3e183e876777e\": \"0x182ab7c20ce5240000\",\n \"0x03c91d92943603e752203e05340e566013b90045\": \"0x2b7cc2e9c3225c0000\",\n \"0x03cb4c4f4516c4ff79a1b6244fbf572e1c7fea79\": \"0x9489237adb9a500000\",\n \"0x03cb98d7acd817de9d886d22fab3f1b57d92a608\": \"0x56bc75e2d631000000\",\n \"0x03cc9d2d21f86b84ac8ceaf971dba78a90e62570\": \"0x57473d05dabae80000\",\n \"0x03d1724fd00e54aabcd2de2a91e8462b1049dd3a\": \"0x8f1d5c1cae37400000\",\n \"0x03dedfcd0b3c2e17c705da248790ef98a6bd5751\": \"0x487a9a304539440000\",\n \"0x03e8b084537557e709eae2e1e1a5a6bce1ef8314\": \"0x1158e460913d00000\",\n \"0x03ea6d26d080e57aee3926b18e8ed73a4e5b2826\": \"0xad78ebc5ac6200000\",\n \"0x03eb3cb860f6028da554d344a2bb5a500ae8b86f\": \"0x6c6b935b8bbd400000\",\n \"0x03ebc63fda6660a465045e235fbe6e5cf195735f\": \"0x7b06ce87fdd680000\",\n \"0x03ef6ad20ff7bd4f002bac58d47544cf879ae728\": \"0x175c758d0b96e5c0000\",\n \"0x03f7b92008813ae0a676eb212814afab35221069\": \"0x6c6b935b8bbd400000\",\n \"0x041170f581de80e58b2a045c8f7c1493b001b7cb\": \"0x303c74a1a336940000\",\n \"0x0413d0cf78c001898a378b918cd6e498ea773c4d\": \"0xf2dc7d47f15600000\",\n \"0x04241b41ecbd0bfdf1295e9d4fa59ea09e6c6186\": \"0x655f769450bc780000\",\n \"0x043707071e2ae21eed977891dc79cd5d8ee1c2da\": \"0x6c6b935b8bbd400000\",\n \"0x044e853144e3364495e7a69fa1d46abea3ac0964\": \"0x2ab2254b1dc9a8000\",\n \"0x0455dcec8a7fc4461bfd7f37456fce3f4c3caac7\": \"0x15af1d78b58c400000\",\n \"0x045ed7f6d9ee9f252e073268db022c6326adfc5b\": \"0x56bc75e2d63100000\",\n \"0x046377f864b0143f282174a892a73d3ec8ec6132\": \"0xa5aa85009e39c0000\",\n \"0x0469e8c440450b0e512626fe817e6754a8152830\": \"0x6c6b935b8bbd400000\",\n \"0x046d274b1af615fb505a764ad8dda770b1db2f3d\": \"0x6c6b935b8bbd400000\",\n \"0x047d5a26d7ad8f8e70600f70a398ddaa1c2db26f\": \"0x14542ba12a337c00000\",\n \"0x047e87c8f7d1fce3b01353a85862a948ac049f3e\": \"0x50c5e761a444080000\",\n \"0x047f9bf1529daf87d407175e6f171b5e59e9ff3e\": \"0x233c8fe42703e80000\",\n \"0x04852732b4c652f6c2e58eb36587e60a62da14db\": \"0x43c33c1937564800000\",\n \"0x048a8970ea4145c64d5517b8de5b46d0595aad06\": \"0x43c33c1937564800000\",\n \"0x049c5d4bc6f25d4e456c697b52a07811ccd19fb1\": \"0x104400a2470e680000\",\n \"0x04a1cada1cc751082ff8da928e3cfa000820a9e9\": \"0x22b1c8c1227a00000\",\n \"0x04a80afad53ef1f84165cfd852b0fdf1b1c24ba8\": \"0x324e964b3eca80000\",\n \"0x04aafc8ae5ce6f4903c89d7fac9cb19512224777\": \"0x1b1ae4d6e2ef500000\",\n \"0x04ba4bb87140022c214a6fac42db5a16dd954045\": \"0x3635c9adc5dea00000\",\n \"0x04ba8a3f03f08b895095994dda619edaacee3e7a\": \"0x6c6b935b8bbd400000\",\n \"0x04c2c64bb54c3eccd05585e10ec6f99a0cdb01a3\": \"0x56bc75e2d63100000\",\n \"0x04ce45f600db18a9d0851b29d9393ebdaafe3dc5\": \"0x1158e460913d00000\",\n \"0x04d6b8d4da867407bb997749debbcdc0b358538a\": \"0x3635c9adc5dea00000\",\n \"0x04d73896cf6593a691972a13a6e4871ff2c42b13\": \"0x6c6b935b8bbd400000\",\n \"0x04d82af9e01a936d97f8f85940b970f9d4db9936\": \"0xad78ebc5ac6200000\",\n \"0x04e5f5bc7c923fd1e31735e72ef968fd67110c6e\": \"0x57551dbc8e624c0000\",\n \"0x04eca501630abce35218b174956b891ba25efb23\": \"0x36369ed7747d260000\",\n \"0x0505a08e22a109015a22f685305354662a5531d5\": \"0x8cf23f909c0fa00000\",\n \"0x0514954c3c2fb657f9a06f510ea22748f027cdd3\": \"0x15af1d78b58c400000\",\n \"0x051633080d07a557adde319261b074997f14692d\": \"0x13a6b2b564871a00000\",\n \"0x0517448dada761cc5ba4033ee881c83037036400\": \"0x6c4fd1ee246e780000\",\n \"0x051d424276b21239665186133d653bb8b1862f89\": \"0x3635c9adc5dea00000\",\n \"0x0521bc3a9f8711fecb10f50797d71083e341eb9d\": \"0x1158e460913d00000\",\n \"0x05236d4c90d065f9e3938358aaffd777b86aec49\": \"0x1b1ae4d6e2ef500000\",\n \"0x052a58e035f1fe9cdd169bcf20970345d12b9c51\": \"0x50c5e761a444080000\",\n \"0x052eab1f61b6d45517283f41d1441824878749d0\": \"0xd8d726b7177a800000\",\n \"0x05336e9a722728d963e7a1cf2759fd0274530fca\": \"0x31a2443f888a798000\",\n \"0x053471cd9a41925b3904a5a8ffca3659e034be23\": \"0xad201a6794ff80000\",\n \"0x05361d8eb6941d4e90fb7e1418a95a32d5257732\": \"0x1158e460913d00000\",\n \"0x05423a54c8d0f9707e704173d923b946edc8e700\": \"0x6ea03c2bf8ba58000\",\n \"0x05440c5b073b529b4829209dff88090e07c4f6f5\": \"0x45d29737e22f200000\",\n \"0x055ab658c6f0ed4f875ed6742e4bc7292d1abbf0\": \"0x486cb9799191e0000\",\n \"0x055bd02caf19d6202bbcdc836d187bd1c01cf261\": \"0x56bc75e2d63100000\",\n \"0x055eac4f1ad3f58f0bd024d68ea60dbe01c6afb3\": \"0x56bc75e2d63100000\",\n \"0x05665155cc49cbf6aabdd5ae92cbfaad82b8c0c1\": \"0x15af1d78b58c400000\",\n \"0x056686078fb6bcf9ba0a8a8dc63a906f5feac0ea\": \"0x1b181e4bf2343c0000\",\n \"0x05696b73916bd3033e05521e3211dfec026e98e4\": \"0x6c6b935b8bbd400000\",\n \"0x056b1546894f9a85e203fb336db569b16c25e04f\": \"0x92edb09ff08d88000\",\n \"0x057949e1ca0570469e4ce3c690ae613a6b01c559\": \"0xad78ebc5ac6200000\",\n \"0x057dd29f2d19aa3da42327ea50bce86ff5c911d9\": \"0xd8d726b7177a800000\",\n \"0x057f7f81cd7a406fc45994408b5049912c566463\": \"0x5c283d410394100000\",\n \"0x05915d4e225a668162aee7d6c25fcfc6ed18db03\": \"0x398c37279259e0000\",\n \"0x0596a27dc3ee115fce2f94b481bc207a9e261525\": \"0x3635c9adc5dea00000\",\n \"0x05a830724302bc0f6ebdaa1ebeeeb46e6ce00b39\": \"0x556f64c1fe7fa0000\",\n \"0x05ae7fd4bbcc80ca11a90a1ec7a301f7cccc83db\": \"0x3154c9729d05780000\",\n \"0x05bb64a916be66f460f5e3b64332110d209e19ae\": \"0xe3aeb5737240a00000\",\n \"0x05bf4fcfe772e45b826443852e6c351350ce72a2\": \"0x1b1ae4d6e2ef5000000\",\n \"0x05c64004a9a826e94e5e4ee267fa2a7632dd4e6f\": \"0x36dc42ebff90b7f8000\",\n \"0x05c736d365aa37b5c0be9c12c8ad5cd903c32cf9\": \"0x1455e7b800a86880000\",\n \"0x05cb6c3b0072d3116761b532b218443b53e8f6c5\": \"0x1e02c3d7fca9b6280000\",\n \"0x05d0f4d728ebe82e84bf597515ad41b60bf28b39\": \"0xe3aeb5737240a00000\",\n \"0x05d68dad61d3bbdfb3f779265c49474aff3fcd30\": \"0x222c55dc1519d8000\",\n \"0x05e671de55afec964b074de574d5158d5d21b0a3\": \"0xd5967be4fc3f100000\",\n \"0x05e97b09492cd68f63b12b892ed1d11d152c0eca\": \"0x3708baed3d68900000\",\n \"0x05f3631f5664bdad5d0132c8388d36d7d8920918\": \"0x1158e460913d00000\",\n \"0x0609d83a6ce1ffc9b690f3e9a81e983e8bdc4d9d\": \"0xed2b525841adfc00000\",\n \"0x061ea4877cd08944eb64c2966e9db8dedcfec06b\": \"0x3635c9adc5dea00000\",\n \"0x0625d06056968b002206ff91980140242bfaa499\": \"0x3635c9adc5dea00000\",\n \"0x0628bfbe5535782fb588406bc96660a49b011af5\": \"0x52663ccab1e1c00000\",\n \"0x0631d18bbbbd30d9e1732bf36edae2ce8901ab80\": \"0xa3f98855ec39900000\",\n \"0x0631dc40d74e5095e3729eddf49544ecd4396f67\": \"0x8ac7230489e800000\",\n \"0x063759dd1c4e362eb19398951ff9f8fad1d31068\": \"0x21e19e0c9bab2400000\",\n \"0x065ff575fd9c16d3cb6fd68ffc8f483fc32ec835\": \"0xad78ebc5ac6200000\",\n \"0x06618e9d5762df62028601a81d4487d6a0ecb80e\": \"0x487a9a304539440000\",\n \"0x066647cfc85d23d37605573d208ca154b244d76c\": \"0x21e19e0c9bab2400000\",\n \"0x0678654ac6761db904a2f7e8595ec1eaac734308\": \"0x2f98b29c2818f80000\",\n \"0x06860a93525955ff624940fadcffb8e149fd599c\": \"0x6c68ccd09b022c0000\",\n \"0x068ce8bd6e902a45cb83b51541b40f39c4469712\": \"0x11c0f9bad4a46e00000\",\n \"0x068e29b3f191c812a6393918f71ab933ae6847f2\": \"0x6c6acc67d7b1d40000\",\n \"0x068e655766b944fb263619658740b850c94afa31\": \"0x1e87f85809dc00000\",\n \"0x06964e2d17e9189f88a8203936b40ac96e533c06\": \"0xfc936392801c0000\",\n \"0x06994cd83aa2640a97b2600b41339d1e0d3ede6c\": \"0xd8d726b7177a80000\",\n \"0x069ed0ab7aa77de571f16106051d92afe195f2d0\": \"0xad78ebc5ac6200000\",\n \"0x06ac26ad92cb859bd5905ddce4266aa0ec50a9c5\": \"0x2a034919dfbfbc0000\",\n \"0x06b0c1e37f5a5ec4bbf50840548f9d3ac0288897\": \"0xd8d882e1928e7d0000\",\n \"0x06b0ff834073cce1cbc9ea557ea87b605963e8b4\": \"0x1043561a8829300000\",\n \"0x06b106649aa8c421ddcd1b8c32cd0418cf30da1f\": \"0x878678326eac9000000\",\n \"0x06b5ede6fdf1d6e9a34721379aeaa17c713dd82a\": \"0x6c6b935b8bbd400000\",\n \"0x06cbfa08cdd4fba737bac407be8224f4eef35828\": \"0x202be5e8382e8b8000\",\n \"0x06d6cb308481c336a6e1a225a912f6e6355940a1\": \"0x5f68e8131ecf800000\",\n \"0x06dc7f18cee7edab5b795337b1df6a9e8bd8ae59\": \"0x15af1d78b58c400000\",\n \"0x06f68de3d739db41121eacf779aada3de8762107\": \"0x18493fba64ef00000\",\n \"0x06f7dc8d1b9462cef6feb13368a7e3974b097f9f\": \"0x6c6b935b8bbd400000\",\n \"0x0701f9f147ec486856f5e1b71de9f117e99e2105\": \"0x965da717fd5b80000\",\n \"0x070d5d364cb7bbf822fc2ca91a35bdd441b215d5\": \"0x6c6b935b8bbd400000\",\n \"0x071dd90d14d41f4ff7c413c24238d3359cd61a07\": \"0x7b53f79e888dac00000\",\n \"0x0726c42e00f45404836eb1e280d073e7059687f5\": \"0x58003e3fb947a38000\",\n \"0x0727be0a2a00212048b5520fbefb953ebc9d54a0\": \"0x21e19e0c9bab2400000\",\n \"0x0729a8a4a5ba23f579d0025b1ad0f8a0d35cdfd2\": \"0x20dd68aaf3289100000\",\n \"0x0729b4b47c09eb16158464c8aa7fd9690b438839\": \"0x6c68ccd09b022c0000\",\n \"0x0734a0a81c9562f4d9e9e10a8503da15db46d76e\": \"0xfc936392801c0000\",\n \"0x073c67e09b5c713c5221c8a0c7f3f74466c347b0\": \"0x41bad155e6512200000\",\n \"0x073f1ed1c9c3e9c52a9b0249a5c1caa0571fdf05\": \"0x3d0ff0b013b800000\",\n \"0x0748713145ef83c3f0ef4d31d823786f7e9cc689\": \"0xf3f20b8dfa69d00000\",\n \"0x075d15e2d33d8b4fa7dba8b9e607f04a261e340b\": \"0x678a932062e4180000\",\n \"0x076561a856455d7ef86e63f87c73dbb628a55f45\": \"0x30ca024f987b900000\",\n \"0x076ee99d3548623a03b5f99859d2d785a1778d48\": \"0xad78ebc5ac6200000\",\n \"0x0770b43dbae4b1f35a927b4fa8124d3866caf97b\": \"0x37193ea7ef5b470000\",\n \"0x0770c61be78772230cb5a3bb2429a72614a0b336\": \"0x16ee0a299b713418000\",\n \"0x07723e3c30e8b731ee456a291ee0e798b0204a77\": \"0x6c6b935b8bbd400000\",\n \"0x0773eeacc050f74720b4a1bd57895b1cceeb495d\": \"0x21e19e0c9bab2400000\",\n \"0x07800d2f8068e448c79a4f69b1f15ef682aae5f6\": \"0x41bad155e6512200000\",\n \"0x07a8dadec142571a7d53a4297051786d072cba55\": \"0x13b6da1139bda8000\",\n \"0x07af938c1237a27c9030094dcf240750246e3d2c\": \"0x1b1ae4d6e2ef500000\",\n \"0x07b1a306cb4312df66482c2cae72d1e061400fcd\": \"0x43c33c1937564800000\",\n \"0x07b7a57033f8f11330e4665e185d234e83ec140b\": \"0xea7ee92a0c9a0b8000\",\n \"0x07bc2cc8eedc01970700efc9c4fb36735e98cd71\": \"0xd8d726b7177a800000\",\n \"0x07d41217badca5e0e60327d845a3464f0f27f84a\": \"0xd8d726b7177a800000\",\n \"0x07d4334ec385e8aa54eedaeadb30022f0cdfa4ab\": \"0x8e91d520f2eb790000\",\n \"0x07dae622630d1136381933d2ad6b22b839d82102\": \"0xad78ebc5ac6200000\",\n \"0x07dc2bf83bc6af19a842ffea661af5b41b67fda1\": \"0x5150ae84a8cdf00000\",\n \"0x07dc8c8b927adbedfa8f5d639b4352351f2f36d2\": \"0x110aed3b5530db0000\",\n \"0x07ddd0422c86ef65bf0c7fc3452862b1228b08b8\": \"0x6ff5d2aa8f9fcf0000\",\n \"0x07e1162ceae3cf21a3f62d105990302e307f4e3b\": \"0x52f103edb66ba80000\",\n \"0x07e2b4cdeed9d087b12e556d9e770c13c099615f\": \"0x243d4d18229ca20000\",\n \"0x07feef54c136850829badc4b49c3f2a73c89fb9e\": \"0x6685ac1bfe32c0000\",\n \"0x080546508a3d2682c8b9884f13637b8847b44db3\": \"0x6c6b935b8bbd400000\",\n \"0x08090876baadfee65c3d363ba55312748cfa873d\": \"0x5c2a99371cffe10000\",\n \"0x08166f02313feae18bb044e7877c808b55b5bf58\": \"0x6acb3df27e1f880000\",\n \"0x0829d0f7bb7c446cfbb0deadb2394d9db7249a87\": \"0x22ca3587cf4eb0000\",\n \"0x08306de51981e7aca1856859b7c778696a6b69f9\": \"0xad78ebc5ac62000000\",\n \"0x0837539b5f6a522a482cdcd3a9bb7043af39bdd2\": \"0x14542ba12a337c00000\",\n \"0x0838a7768d9c2aca8ba279adfee4b1f491e326f1\": \"0xad78ebc5ac6200000\",\n \"0x08411652c871713609af0062a8a1281bf1bbcfd9\": \"0x4be4e7267b6ae00000\",\n \"0x084d103254759b343cb2b9c2d8ff9e1ac5f14596\": \"0x19bff2ff57968c00000\",\n \"0x08504f05643fab5919f5eea55925d7a3ed7d807a\": \"0x1158e460913d00000\",\n \"0x085b4ab75d8362d914435cedee1daa2b1ee1a23b\": \"0xd255d112e103a00000\",\n \"0x085ba65febe23eefc2c802666ab1262382cfc494\": \"0x15af1d78b58c400000\",\n \"0x087498c0464668f31150f4d3c4bcdda5221ba102\": \"0x1158e460913d00000\",\n \"0x0877eeaeab78d5c00e83c32b2d98fa79ad51482f\": \"0x17d22d71da62260000\",\n \"0x08936a37df85b3a158cafd9de021f58137681347\": \"0xfc936392801c0000\",\n \"0x08a9a44e1f41de3dbba7a363a3ab412c124cd15e\": \"0xad78ebc5ac6200000\",\n \"0x08b7bdcf944d5570838be70460243a8694485858\": \"0x6c6b935b8bbd400000\",\n \"0x08b84536b74c8c01543da88b84d78bb95747d822\": \"0xad78ebc5ac6200000\",\n \"0x08c2f236ac4adcd3fda9fbc6e4532253f9da3bec\": \"0x1158e460913d00000\",\n \"0x08c802f87758349fa03e6bc2e2fd0791197eea9a\": \"0x6c6b935b8bbd400000\",\n \"0x08c9f1bfb689fdf804d769f82123360215aff93b\": \"0x6acb3df27e1f880000\",\n \"0x08cac8952641d8fc526ec1ab4f2df826a5e7710f\": \"0x1043561a8829300000\",\n \"0x08ccda50e4b26a0ffc0ef92e9205310706bec2c7\": \"0x149756c3857c6000000\",\n \"0x08d0864dc32f9acb36bf4ea447e8dd6726906a15\": \"0x6c6e59e67c78540000\",\n \"0x08d4267feb15da9700f7ccc3c84a8918bf17cfde\": \"0x61093d7c2c6d380000\",\n \"0x08d4311c9c1bbaf87fabe1a1d01463828d5d98ce\": \"0x130ee8e7179044400000\",\n \"0x08d54e83ad486a934cfaeae283a33efd227c0e99\": \"0x38530583245edc0000\",\n \"0x08d97eadfcb7b064e1ccd9c8979fbee5e77a9719\": \"0xe6c5da8d67ac18000\",\n \"0x08da3a7a0f452161cfbcec311bb68ebfdee17e88\": \"0x6c6b935b8bbd400000\",\n \"0x08e38ee0ce48c9ca645c1019f73b5355581c56e6\": \"0x56bc75e2d631000000\",\n \"0x08ef3fa4c43ccdc57b22a4b9b2331a82e53818f2\": \"0xd8d726b7177a800000\",\n \"0x0909648c18a3ce5bae7a047ec2f868d24cdda81d\": \"0xcf152640c5c8300000\",\n \"0x090cd67b60e81d54e7b5f6078f3e021ba65b9a1e\": \"0x3635c9adc5dea00000\",\n \"0x090cebef292c3eb081a05fd8aaf7d39bf07b89d4\": \"0xd8d726b7177a800000\",\n \"0x090fa9367bda57d0d3253a0a8ff76ce0b8e19a73\": \"0x3635c9adc5dea00000\",\n \"0x09146ea3885176f07782e1fe30dce3ce24c49e1f\": \"0x1158e460913d00000\",\n \"0x0921605f99164e3bcc28f31caece78973182561d\": \"0x2b07692a9065a80000\",\n \"0x09261f9acb451c3788844f0c1451a35bad5098e3\": \"0x1d5ad27502920600000\",\n \"0x0927220492194b2eda9fc4bbe38f25d681dfd36c\": \"0x14542ba12a337c00000\",\n \"0x092acb624b08c05510189bbbe21e6524d644ccad\": \"0xfc936392801c0000\",\n \"0x092e815558402d67f90d6bfe6da0b2fffa91455a\": \"0x340aad21b3b700000\",\n \"0x095030e4b82692dcf8b8d0912494b9b378ec9328\": \"0x48a43c54602f700000\",\n \"0x095270cc42141dd998ad2862dbd1fe9b44e7e650\": \"0x410d586a20a4c00000\",\n \"0x095457f8ef8e2bdc362196b9a9125da09c67e3ab\": \"0xad78ebc5ac6200000\",\n \"0x0954a8cb5d321fc3351a7523a617d0f58da676a7\": \"0x87d9bc7aa498e80000\",\n \"0x095b0ea2b218d82e0aea7c2889238a39c9bf9077\": \"0x43c33c1937564800000\",\n \"0x095b949de3333a377d5019d893754a5e4656ff97\": \"0x126e72a69a50d00000\",\n \"0x095e0174829f34c3781be1a5e38d1541ea439b7f\": \"0x14542ba12a337c00000\",\n \"0x095f5a51d06f6340d80b6d29ea2e88118ad730fe\": \"0x6c6e59e67c78540000\",\n \"0x0968ee5a378f8cadb3bafdbed1d19aaacf936711\": \"0x3635c9adc5dea00000\",\n \"0x0977bfba038a44fb49b03970d8d8cf2cb61f8b25\": \"0x16c4abbebea0100000\",\n \"0x097da12cfc1f7c1a2464def08c29bed5e2f851e9\": \"0x1158e460913d00000\",\n \"0x097ecda22567c2d91cb03f8c5215c22e9dcda949\": \"0x11651ac3e7a758000\",\n \"0x0989c200440b878991b69d6095dfe69e33a22e70\": \"0x678a932062e4180000\",\n \"0x0990e81cd785599ea236bd1966cf526302c35b9c\": \"0x3635c9adc5dea00000\",\n \"0x0998d8273115b56af43c505e087aff0676ed3659\": \"0xd8d6eddf2d2e180000\",\n \"0x09a025316f967fa8b9a1d60700063f5a68001caa\": \"0x21221a99b93ec0000\",\n \"0x09a928d528ec1b3e25ffc83e218c1e0afe8928c7\": \"0xfc936392801c0000\",\n \"0x09ae49e37f121df5dc158cfde806f173a06b0c7f\": \"0xd8309e26aba1d00000\",\n \"0x09afa73bc047ef46b977fd9763f87286a6be68c6\": \"0x1b2fb5e8f06a660000\",\n \"0x09b4668696f86a080f8bebb91db8e6f87015915a\": \"0x238ff7b34f60010000\",\n \"0x09b59b8698a7fbd3d2f8c73a008988de3e406b2b\": \"0x878678326eac9000000\",\n \"0x09b7a988d13ff89186736f03fdf46175b53d16e0\": \"0x14542ba12a337c00000\",\n \"0x09c177f1ae442411ddacf187d46db956148360e7\": \"0x1e52e336cde22180000\",\n \"0x09c88f917e4d6ad473fa12e98ea3c4472a5ed6da\": \"0x21e19e0c9bab2400000\",\n \"0x09d0b8cd077c69d9f32d9cca43b3c208a21ed48b\": \"0x821d221b5291f8000\",\n \"0x09d6cefd75b0c4b3f8f1d687a522c96123f1f539\": \"0x14542ba12a337c00000\",\n \"0x09e437d448861228a232b62ee8d37965a904ed9c\": \"0x498cf401df8842e8000\",\n \"0x09ee12b1b42b05af9cf207d5fcac255b2ec411f2\": \"0x331cddd47e0fe8000\",\n \"0x09f3f601f605441140586ce0656fa24aa5b1d9ae\": \"0x5373776fe8c4540000\",\n \"0x09f9575be57d004793c7a4eb84b71587f97cbb6a\": \"0xad78ebc5ac6200000\",\n \"0x0a0650861f785ed8e4bf1005c450bbd06eb48fb6\": \"0xa6413b79144e7e0000\",\n \"0x0a06fad7dcd7a492cbc053eeabde6934b39d8637\": \"0x1158e460913d00000\",\n \"0x0a077db13ffeb09484c217709d5886b8bf9c5a8b\": \"0xd8d726b7177a800000\",\n \"0x0a0ecda6636f7716ef1973614687fd89a820a706\": \"0x155bd9307f9fe80000\",\n \"0x0a29a8a4d5fd950075ffb34d77afeb2d823bd689\": \"0xad78ebc5ac6200000\",\n \"0x0a2ade95b2e8c66d8ae6f0ba64ca57d783be6d44\": \"0xd8d726b7177a800000\",\n \"0x0a2b4fc5d81ace67dc4bba03f7b455413d46fe3d\": \"0xaadec983fcff40000\",\n \"0x0a2dcb7a671701dbb8f495728088265873356c8e\": \"0x83f16ce08a06c0000\",\n \"0x0a3de155d5ecd8e81c1ff9bbf0378301f8d4c623\": \"0xd8d726b7177a800000\",\n \"0x0a47ad9059a249fc936b2662353da6905f75c2b9\": \"0x6c6b935b8bbd400000\",\n \"0x0a48296f7631708c95d2b74975bc4ab88ac1392a\": \"0x10f0cf064dd59200000\",\n \"0x0a4a011995c681bc999fdd79754e9a324ae3b379\": \"0x8c19ab06eb89af60000\",\n \"0x0a58fddd71898de773a74fdae45e7bd84ef43646\": \"0x1158e460913d00000\",\n \"0x0a5b79d8f23b6483dbe2bdaa62b1064cc76366ae\": \"0x6ac882100952c78000\",\n \"0x0a652e2a8b77bd97a790d0e91361c98890dbb04e\": \"0x3635c9adc5dea00000\",\n \"0x0a6ebe723b6ed1f9a86a69ddda68dc47465c2b1b\": \"0x403d2db599d5e40000\",\n \"0x0a77e7f72b437b574f00128b21f2ac265133528c\": \"0x6c6b935b8bbd400000\",\n \"0x0a917f3b5cb0b883047fd9b6593dbcd557f453b9\": \"0x3635c9adc5dea00000\",\n \"0x0a931b449ea8f12cdbd5e2c8cc76bad2c27c0639\": \"0x13f9e8c79fe058000\",\n \"0x0a9804137803ba6868d93a55f9985fcd540451e4\": \"0xb98bc829a6f90000\",\n \"0x0a9ab2638b1cfd654d25dab018a0aebddf85fd55\": \"0x12e8cb5fe4c4a8000\",\n \"0x0ab366e6e7d5abbce6b44a438d69a1cabb90d133\": \"0x1158e460913d000000\",\n \"0x0ab4281ebb318590abb89a81df07fa3af904258a\": \"0x1b1ae4d6e2ef500000\",\n \"0x0ab59d390702c9c059db148eb4f3fcfa7d04c7e7\": \"0xfc936392801c0000\",\n \"0x0abfb39b11486d79572866195ba26c630b6784db\": \"0x19ba8737f96928f00000\",\n \"0x0aca9a5626913b08cfc9a66d40508dce52b60f87\": \"0x678a932062e4180000\",\n \"0x0ad3e44d3c001fa290b393617030544108ac6eb9\": \"0x6abda0bc30b2df8000\",\n \"0x0aec2e426ed6cc0cf3c249c1897eac47a7faa9bd\": \"0xad78ebc5ac6200000\",\n \"0x0af65f14784e55a6f95667fd73252a1c94072d2a\": \"0xa763b8e02d44f8000\",\n \"0x0af6c8d539c96d50259e1ba6719e9c8060f388c2\": \"0x3635c9adc5dea00000\",\n \"0x0b06390f2437b20ec4a3d3431b3279c6583e5ed7\": \"0xa844a7424d9c80000\",\n \"0x0b0b3862112aeec3a03492b1b05f440eca54256e\": \"0xd8d726b7177a800000\",\n \"0x0b0e055b28cbd03dc5ff44aa64f3dce04f5e63fb\": \"0x6c6b935b8bbd400000\",\n \"0x0b119df99c6b8de58a1e2c3f297a6744bf552277\": \"0x6c6b935b8bbd400000\",\n \"0x0b14891999a65c9ef73308efe3100ca1b20e8192\": \"0x2b5e3af16b18800000\",\n \"0x0b2113504534642a1daf102eee10b9ebde76e261\": \"0x942cdd7c95f2bd8000\",\n \"0x0b288a5a8b75f3dc4191eb0457e1c83dbd204d25\": \"0x10714e77bb43ab40000\",\n \"0x0b369e002e1b4c7913fcf00f2d5e19c58165478f\": \"0x37f6516288c340000\",\n \"0x0b43bd2391025581d8956ce42a072579cbbfcb14\": \"0x104e70464b1580000\",\n \"0x0b507cf553568daaf65504ae4eaa17a8ea3cdbf5\": \"0x6c6b935b8bbd400000\",\n \"0x0b5d66b13c87b392e94d91d5f76c0d450a552843\": \"0x6c6b935b8bbd400000\",\n \"0x0b5e2011ebc25a007f21362960498afb8af280fb\": \"0x6c6b935b8bbd400000\",\n \"0x0b649da3b96a102cdc6db652a0c07d65b1e443e6\": \"0x6c6b935b8bbd400000\",\n \"0x0b6920a64b363b8d5d90802494cf564b547c430d\": \"0x410d586a20a4c00000\",\n \"0x0b701101a4109f9cb360dc57b77442673d5e5983\": \"0x6c6b935b8bbd400000\",\n \"0x0b71f554122469ef978e2f1fefd7cbb410982772\": \"0xd255d112e103a00000\",\n \"0x0b7bb342f01bc9888e6a9af4a887cbf4c2dd2caf\": \"0x3635c9adc5dea000000\",\n \"0x0b7d339371e5be6727e6e331b5821fa24bdb9d5a\": \"0x2e7f81868262010000\",\n \"0x0b7fc9ddf70576f6330669eaaa71b6a831e99528\": \"0x796e3ea3f8ab00000\",\n \"0x0b80fc70282cbdd5fde35bf78984db3bdb120188\": \"0x3638021cecdab00000\",\n \"0x0b924df007e9c0878417cfe63b976ea1a382a897\": \"0x22b1c8c1227a00000\",\n \"0x0b93fca4a4f09cac20db60e065edcccc11e0a5b6\": \"0xad78ebc5ac6200000\",\n \"0x0b9df80fbe232009dacf0aa8cac59376e2476203\": \"0x6c6b935b8bbd400000\",\n \"0x0ba6e46af25a13f57169255a34a4dac7ce12be04\": \"0x1b1ae4d6e2ef500000\",\n \"0x0ba8705bf55cf219c0956b5e3fc01c4474a6cdc1\": \"0x525e0595d4d6b8000\",\n \"0x0baf6ecdb91acb3606a8357c0bc4f45cfd2d7e6f\": \"0x3635c9adc5dea00000\",\n \"0x0bb05f7224bb5804856556c07eeadbed87ba8f7c\": \"0x15be6174e1912e0000\",\n \"0x0bb0c12682a2f15c9b5741b2385cbe41f034068e\": \"0x5150ae84a8cdf00000\",\n \"0x0bb25ca7d188e71e4d693d7b170717d6f8f0a70a\": \"0x124302a82fadd70000\",\n \"0x0bb2650ea01aca755bc0c017b64b1ab5a66d82e3\": \"0x487a9a304539440000\",\n \"0x0bb54c72fd6610bfa4363397e020384b022b0c49\": \"0x487a9a304539440000\",\n \"0x0bb7160aba293762f8734f3e0326ffc9a4cac190\": \"0x3635c9adc5dea00000\",\n \"0x0bc95cb32dbb574c832fa8174a81356d38bc92ac\": \"0x6c6b935b8bbd400000\",\n \"0x0bd67dbde07a856ebd893b5edc4f3a5be4202616\": \"0x6c6b935b8bbd400000\",\n \"0x0bdbc54cc8bdbbb402a08911e2232a5460ce866b\": \"0xa2a15d09519be00000\",\n \"0x0bdd58b96e7c916dd2fb30356f2aebfaaf1d8630\": \"0x6c6b935b8bbd400000\",\n \"0x0be1bcb90343fae5303173f461bd914a4839056c\": \"0x14542ba12a337c00000\",\n \"0x0be1fdf626ee6189102d70d13b31012c95cd1cd6\": \"0x6c6b935b8bbd400000\",\n \"0x0be2b94ad950a2a62640c35bfccd6c67dae450f6\": \"0x692ae8897081d00000\",\n \"0x0be6a09e4307fe48d412b8d1a1a8284dce486261\": \"0x40fbff85c0138300000\",\n \"0x0befb54707f61b2c9fb04715ab026e1bb72042bd\": \"0xd8d726b7177a800000\",\n \"0x0bf064428f83626722a7b5b26a9ab20421a7723e\": \"0x73f75d1a085ba0000\",\n \"0x0bfbb6925dc75e52cf2684224bbe0550fea685d3\": \"0x6acb3df27e1f880000\",\n \"0x0c088006c64b30c4ddafbc36cb5f05469eb62834\": \"0x6c6b935b8bbd400000\",\n \"0x0c2073ba44d3ddbdb639c04e191039a71716237f\": \"0x4d853c8f8908980000\",\n \"0x0c222c7c41c9b048efcce0a232434362e12d673b\": \"0x21e8359697677380000\",\n \"0x0c2808b951ed9e872d7b32790fcc5994ae41ffdc\": \"0x15996e5b3cd6b3c00000\",\n \"0x0c28847e4f09dfce5f9b25af7c4e530f59c880fe\": \"0x3635c9adc5dea00000\",\n \"0x0c2d5c920538e953caaf24f0737f554cc6927742\": \"0x3635c9adc5dea00000\",\n \"0x0c30cacc3f72269f8b4f04cf073d2b05a83d9ad1\": \"0x6c7974123f64a40000\",\n \"0x0c3239e2e841242db989a61518c22247e8c55208\": \"0xe4af6471734640000\",\n \"0x0c480de9f7461002908b49f60fc61e2b62d3140b\": \"0x21e19e0c9bab2400000\",\n \"0x0c48ae62d1539788eba013d75ea60b64eeba4e80\": \"0x77fbdc43e030998000\",\n \"0x0c5589a7a89b9ad15b02751930415948a875fbef\": \"0x6d499ec6c63380000\",\n \"0x0c67033dd8ee7f0c8ae534d42a51f7d9d4f7978f\": \"0xad78ebc5ac6200000\",\n \"0x0c6845bf41d5ee273c3ee6b5b0d69f6fd5eabbf7\": \"0xa2a1b9682e58090000\",\n \"0x0c7f869f8e90d53fdc03e8b2819b016b9d18eb26\": \"0x43c33c1937564800000\",\n \"0x0c8692eeff2a53d6d1688ed56a9ddbbd68dabba1\": \"0x6c6b935b8bbd400000\",\n \"0x0c8f66c6017bce5b20347204b602b743bad78d60\": \"0x6c6b935b8bbd400000\",\n \"0x0c8fd7775e54a6d9c9a3bf890e761f6577693ff0\": \"0x215f835bc769da80000\",\n \"0x0c925ad5eb352c8ef76d0c222d115b0791b962a1\": \"0xac635d7fa34e300000\",\n \"0x0c967e3061b87a753e84507eb60986782c8f3013\": \"0x56bc75e2d63100000\",\n \"0x0ca12ab0b9666cf0cec6671a15292f2653476ab2\": \"0x2c7827c42d22d07c0000\",\n \"0x0ca670eb2c8b96cba379217f5929c2b892f39ef6\": \"0x6c6b935b8bbd400000\",\n \"0x0cae108e6db99b9e637876b064c6303eda8a65c8\": \"0xa2a15d09519be00000\",\n \"0x0cbd921dbe121563b98a6871fecb14f1cc7e88d7\": \"0xad78ebc5ac6200000\",\n \"0x0cbf8770f0d1082e5c20c5aead34e5fca9ae7ae2\": \"0x3635c9adc5dea00000\",\n \"0x0cc67f8273e1bae0867fd42e8b8193d72679dbf8\": \"0x1b1ae4d6e2ef500000\",\n \"0x0cd6a141918d126b106d9f2ebf69e102de4d3277\": \"0x1158e460913d00000\",\n \"0x0cda12bf72d461bbc479eb92e6491d057e6b5ad1\": \"0x21e19e0c9bab2400000\",\n \"0x0cdc960b998c141998160dc179b36c15d28470ed\": \"0x1b1b6bd7af64c70000\",\n \"0x0cfb172335b16c87d519cd1475530d20577f5e0e\": \"0x152d02c7e14af6800000\",\n \"0x0d1f2a57713ebc6e94de29846e8844d376665763\": \"0x10f0cf064dd59200000\",\n \"0x0d3265d3e7bdb93d5e8e8b1ca47f210a793ecc8e\": \"0xad78ebc5ac6200000\",\n \"0x0d35408f226566116fb8acdaa9e2c9d59b76683f\": \"0x32f51edbaaa3300000\",\n \"0x0d551ec1a2133c981d5fc6a8c8173f9e7c4f47af\": \"0x6c6b935b8bbd400000\",\n \"0x0d5d98565c647ca5f177a2adb9d3022fac287f21\": \"0xad78ebc5ac6200000\",\n \"0x0d658014a199061cf6b39433140303c20ffd4e5a\": \"0x1bc85dc2a89bb200000\",\n \"0x0d678706d037187f3e22e6f69b99a592d11ebc59\": \"0x55a6e79ccd1d300000\",\n \"0x0d69100c395ce6c5eaadf95d05d872837ededd21\": \"0x15af1d78b58c400000\",\n \"0x0d747ee5969bf79d57381d6fe3a2406cd0d8ce27\": \"0x152d02c7e14af6800000\",\n \"0x0d8023929d917234ae40512b1aabb5e8a4512771\": \"0x805e99fdcc5d00000\",\n \"0x0d8aab8f74ea862cdf766805009d3f3e42d8d00b\": \"0x13b80b99c5185700000\",\n \"0x0d8c40a79e18994ff99ec251ee10d088c3912e80\": \"0x63664fcd2bbc40000\",\n \"0x0d8ed7d0d15638330ed7e4eaccab8a458d75737e\": \"0x6c6b935b8bbd400000\",\n \"0x0d92582fdba05eabc3e51538c56db8813785b328\": \"0xa5aa85009e39c0000\",\n \"0x0d9443a79468a5bbf7c13c6e225d1de91aee07df\": \"0x3cb71f51fc5580000\",\n \"0x0d9a825ff2bcd397cbad5b711d9dcc95f1cc112d\": \"0x2b5e3af16b188000000\",\n \"0x0d9d3f9bc4a4c6efbd59679b69826bc1f63d9916\": \"0x2086ac351052600000\",\n \"0x0da532c910e3ac0dfb14db61cd739a93353fd05f\": \"0x4878be1ffaf95d0000\",\n \"0x0da7401262384e2e8b4b26dd154799b55145efa0\": \"0x1043561a8829300000\",\n \"0x0dae3ee5b915b36487f9161f19846d101433318a\": \"0x678a932062e4180000\",\n \"0x0dbd417c372b8b0d01bcd944706bd32e60ae28d1\": \"0x126e72a69a50d00000\",\n \"0x0dc100b107011c7fc0a1339612a16ccec3285208\": \"0x6c6b935b8bbd400000\",\n \"0x0dcf9d8c9804459f647c14138ed50fad563b4154\": \"0x960db77681e940000\",\n \"0x0dcfe837ea1cf28c65fccec3bef1f84e59d150c0\": \"0xad78ebc5ac6200000\",\n \"0x0dd4e674bbadb1b0dc824498713dce3b5156da29\": \"0x93739534d28680000\",\n \"0x0dfbd4817050d91d9d625c02053cf61a3ee28572\": \"0x126e72a69a50d00000\",\n \"0x0e024e7f029c6aaf3a8b910f5e080873b85795aa\": \"0x3635c9adc5dea00000\",\n \"0x0e09646c99af438e99fa274cb2f9c856cb65f736\": \"0x678a932062e4180000\",\n \"0x0e0c9d005ea016c295cd795cc9213e87febc33eb\": \"0xabbcd4ef377580000\",\n \"0x0e0d6633db1e0c7f234a6df163a10e0ab39c200f\": \"0xad78ebc5ac6200000\",\n \"0x0e11d77a8977fac30d268445e531149b31541a24\": \"0x6c6b935b8bbd400000\",\n \"0x0e123d7da6d1e6fac2dcadd27029240bb39052fe\": \"0x3635c9adc5dea00000\",\n \"0x0e1801e70b6262861b1134ccbc391f568afc92f7\": \"0xd8d726b7177a800000\",\n \"0x0e2094ac1654a46ba1c4d3a40bb8c17da7f39688\": \"0x13683f7f3c15d80000\",\n \"0x0e21af1b8dbf27fcf63f37e047b87a825cbe7c27\": \"0xa2a15d09519be00000\",\n \"0x0e2e504a2d1122b5a9feee5cb1451bf4c2ace87b\": \"0xd5967be4fc3f100000\",\n \"0x0e2f8e28a681f77c583bd0ecde16634bdd7e00cd\": \"0x52738f659bca20000\",\n \"0x0e320219838e859b2f9f18b72e3d4073ca50b37d\": \"0x6c6b935b8bbd400000\",\n \"0x0e33fcbbc003510be35785b52a9c5d216bc005f4\": \"0x65ea3db75546600000\",\n \"0x0e3696cf1f4217b163d1bc12a5ea730f1c32a14a\": \"0xd8d726b7177a800000\",\n \"0x0e390f44053ddfcef0d608b35e4d9c2cbe9871bb\": \"0x6acb3df27e1f880000\",\n \"0x0e3a28c1dfafb0505bdce19fe025f506a6d01ceb\": \"0x6c6b935b8bbd400000\",\n \"0x0e3dd7d4e429fe3930a6414035f52bdc599d784d\": \"0x22ca3587cf4eb0000\",\n \"0x0e4765790352656bc656682c24fc5ef3e76a23c7\": \"0x286d7fc0cb4f50000\",\n \"0x0e498800447177b8c8afc3fdfa7f69f4051bb629\": \"0x7405b69b8de5610000\",\n \"0x0e6baaa3deb989f289620076668618e9ac332865\": \"0xad78ebc5ac6200000\",\n \"0x0e6cd664ad9c1ed64bf98749f40644b626e3792c\": \"0xcb49b44ba602d800000\",\n \"0x0e6dfd553b2e873d2aec15bd5fbb3f8472d8d394\": \"0x28a857425466f800000\",\n \"0x0e6ec313376271dff55423ab5422cc3a8b06b22b\": \"0xd8d726b7177a800000\",\n \"0x0e6ece99111cad1961c748ed3df51edd69d2a3b1\": \"0x152d02c7e14af6800000\",\n \"0x0e83b850481ab44d49e0a229a2e464902c69539b\": \"0x56bc75e2d63100000\",\n \"0x0e89eddd3fa0d71d8ab0ff8da5580686e3d4f74f\": \"0x6c6b935b8bbd400000\",\n \"0x0e9096d343c060db581a120112b278607ec6e52b\": \"0x1158e460913d00000\",\n \"0x0e9c511864a177f49be78202773f60489fe04e52\": \"0x14542ba12a337c00000\",\n \"0x0ea2a210312b3e867ee0d1cc682ce1d666f18ed5\": \"0x21e19e0c9bab2400000\",\n \"0x0eb189ef2c2d5762a963d6b7bdf9698ea8e7b48a\": \"0x487a9a304539440000\",\n \"0x0eb5b662a1c718608fd52f0c25f9378830178519\": \"0x14a37281a612e740000\",\n \"0x0ec46696ffac1f58005fa8439824f08eed1df89b\": \"0x21e19e0c9bab2400000\",\n \"0x0ec50aa823f465b9464b0bc0c4a57724a555f5d6\": \"0xc83d1426ac7b1f00000\",\n \"0x0ec5308b31282e218fc9e759d4fec5db3708cec4\": \"0x3643aa647986040000\",\n \"0x0eccf617844fd61fba62cb0e445b7ac68bcc1fbe\": \"0x14fe4fe63565c60000\",\n \"0x0ed3bb3a4eb554cfca97947d575507cdfd6d21d8\": \"0x1db3205fcc23d58000\",\n \"0x0ed76c2c3b5d50ff8fb50b3eeacd681590be1c2d\": \"0x56bc75e2d63100000\",\n \"0x0eda80f4ed074aea697aeddf283b63dbca3dc4da\": \"0x6c6b935b8bbd400000\",\n \"0x0edd4b580ff10fe06c4a03116239ef96622bae35\": \"0xaadec983fcff40000\",\n \"0x0ee391f03c765b11d69026fd1ab35395dc3802a0\": \"0xad78ebc5ac6200000\",\n \"0x0ee414940487fd24e390378285c5d7b9334d8b65\": \"0x914878a8c05ee00000\",\n \"0x0ef54ac7264d2254abbb5f8b41adde875157db7c\": \"0x22b1c8c1227a00000\",\n \"0x0ef85b49d08a75198692914eddb4b22cf5fa4450\": \"0x6cae30621d47200000\",\n \"0x0efd1789eb1244a3dede0f5de582d8963cb1f39f\": \"0x5150ae84a8cdf00000\",\n \"0x0f042c9c2fb18766f836bb59f735f27dc329fe3c\": \"0x21e19e0c9bab2400000\",\n \"0x0f049a8bdfd761de8ec02cee2829c4005b23c06b\": \"0xda933d8d8c6700000\",\n \"0x0f05f120c89e9fbc93d4ab0c5e2b4a0df092b424\": \"0x65a4da25d3016c00000\",\n \"0x0f127bbf8e311caea2ba502a33feced3f730ba42\": \"0xa31062beeed700000\",\n \"0x0f1c249cd962b00fd114a9349f6a6cc778d76c4d\": \"0x6c6b935b8bbd400000\",\n \"0x0f206e1a1da7207ea518b112418baa8b06260328\": \"0x2086ac351052600000\",\n \"0x0f24105abbdaa03fa6309ef6c188e51f714a6e59\": \"0xad78ebc5ac6200000\",\n \"0x0f26480a150961b8e30750713a94ee6f2e47fc00\": \"0x3635c9adc5dea00000\",\n \"0x0f2d8daf04b5414a0261f549ff6477b80f2f1d07\": \"0x2a5a058fc295ed000000\",\n \"0x0f2fb884c8aaff6f543ac6228bd08e4f60b0a5fd\": \"0xaa7da485136b840000\",\n \"0x0f32d9cb4d0fdaa0150656bb608dcc43ed7d9301\": \"0x28df8bf440db790000\",\n \"0x0f3665d48e9f1419cd984fc7fa92788710c8f2e4\": \"0x6c6b935b8bbd400000\",\n \"0x0f3a1023cac04dbf44f5a5fa6a9cf8508cd4fddf\": \"0x62a992e53a0af00000\",\n \"0x0f4073c1b99df60a1549d69789c7318d9403a814\": \"0x43c33c1937564800000\",\n \"0x0f46c81db780c1674ac73d314f06539ee56ebc83\": \"0x215f835bc769da80000\",\n \"0x0f4f94b9191bb7bb556aaad7c74ddb288417a50b\": \"0x4be4e7267b6ae00000\",\n \"0x0f6000de1578619320aba5e392706b131fb1de6f\": \"0x1b1ab319f5ec750000\",\n \"0x0f6e840a3f2a24647d8e43e09d45c7c335df4248\": \"0x878678326eac900000\",\n \"0x0f7515ff0e808f695e0c20485ff96ed2f7b79310\": \"0x3638221660a5aa8000\",\n \"0x0f789e30397c53bf256fc364e6ef39f853504114\": \"0xc55325ca7415e00000\",\n \"0x0f7b61c59b016322e8226cafaee9d9e76d50a1b3\": \"0xd8d726b7177a800000\",\n \"0x0f7bea4ef3f73ae0233df1e100718cbe29310bb0\": \"0x6c6b935b8bbd400000\",\n \"0x0f7bf6373f771a4601762c4dae5fbbf4fedd9cc9\": \"0x6c6b935b8bbd400000\",\n \"0x0f832a93df9d7f74cd0fb8546b7198bf5377d925\": \"0x7c0860e5a80dc0000\",\n \"0x0f83461ba224bb1e8fdd9dae535172b735acb4e0\": \"0xad78ebc5ac6200000\",\n \"0x0f85e42b1df321a4b3e835b50c00b06173968436\": \"0x35659ef93f0fc40000\",\n \"0x0f88aac9346cb0e7347fba70905475ba8b3e5ece\": \"0x21e19e0c9bab2400000\",\n \"0x0f929cf895db017af79f3ead2216b1bd69c37dc7\": \"0x6c6b935b8bbd400000\",\n \"0x0fa010ce0c731d3b628e36b91f571300e49dbeab\": \"0x36330322d5238c0000\",\n \"0x0fa5d8c5b3f294efd495ab69d768f81872508548\": \"0x6c6b935b8bbd400000\",\n \"0x0fa6c7b0973d0bae2940540e247d3627e37ca347\": \"0x3635c9adc5dea00000\",\n \"0x0fad05507cdc8f24b2be4cb7fa5d927ddb911b88\": \"0xa2df13f441f0098000\",\n \"0x0fb5d2c673bfb1ddca141b9894fd6d3f05da6720\": \"0x56bc75e2d63100000\",\n \"0x0fc9a0e34145fbfdd2c9d2a499b617d7a02969b9\": \"0x9c2007651b2500000\",\n \"0x0fcfc4065008cfd323305f6286b57a4dd7eee23b\": \"0x43c33c1937564800000\",\n \"0x0fdd65402395df9bd19fee4507ef5345f745104c\": \"0x10f0cf064dd59200000\",\n \"0x0fec4ee0d7ca180290b6bd20f9992342f60ff68d\": \"0x12207f0edce9718000\",\n \"0x0fee81ac331efd8f81161c57382bb4507bb9ebec\": \"0x15af880d8cdb830000\",\n \"0x0ffea06d7113fb6aec2869f4a9dfb09007facef4\": \"0xc384681b1e1740000\",\n \"0x10097198b4e7ee91ff82cc2f3bd95fed73c540c0\": \"0x6c6b935b8bbd400000\",\n \"0x100b4d0977fcbad4debd5e64a0497aeae5168fab\": \"0x110c9073b5245a0000\",\n \"0x101a0a64f9afcc448a8a130d4dfcbee89537d854\": \"0x337fe5feaf2d1800000\",\n \"0x102c477d69aadba9a0b0f62b7459e17fbb1c1561\": \"0x6c6b935b8bbd400000\",\n \"0x1031e0ecb54985ae21af1793950dc811888fde7c\": \"0x1158e460913d00000\",\n \"0x10346414bec6d3dcc44e50e54d54c2b8c3734e3e\": \"0xd8d726b7177a800000\",\n \"0x10389858b800e8c0ec32f51ed61a355946cc409b\": \"0xad78ebc5ac6200000\",\n \"0x1059cbc63e36c43e88f30008aca7ce058eeaa096\": \"0x152d02c7e14af6800000\",\n \"0x106ed5c719b5261477890425ae7551dc59bd255c\": \"0x2896a58c95be5880000\",\n \"0x10711c3dda32317885f0a2fd8ae92e82069b0d0b\": \"0xd8d726b7177a800000\",\n \"0x107379d4c467464f235bc18e55938aad3e688ad7\": \"0x2b5e3af16b1880000\",\n \"0x1076212d4f758c8ec7121c1c7d74254926459284\": \"0x7695b59b5c17b4c0000\",\n \"0x1078d7f61b0e56c74ee6635b2e1819ef1e3d8785\": \"0x3635c9adc5dea00000\",\n \"0x107a03cf0842dbdeb0618fb587ca69189ec92ff5\": \"0x6acb3df27e1f880000\",\n \"0x1080c1d8358a15bc84dac8253c6883319020df2c\": \"0x90f534608a72880000\",\n \"0x108a2b7c336f784779d8b54d02a8d31d9a139c0a\": \"0x21e19e0c9bab2400000\",\n \"0x108ba7c2895c50e072dc6f964932d50c282d3034\": \"0x1b1ae4d6e2ef500000\",\n \"0x108fe8ee2a13da487b22c6ab6d582ea71064d98c\": \"0x15ac56edc4d12c0000\",\n \"0x1091176be19b9964a8f72e0ece6bf8e3cfad6e9c\": \"0x21f2f6f0fc3c6100000\",\n \"0x1098c774c20ca1daac5ddb620365316d353f109c\": \"0x56bc75e2d63100000\",\n \"0x1098cc20ef84bad5146639c4cd1ca6c3996cb99b\": \"0xfc936392801c0000\",\n \"0x10a1c42dc1ba746986b985a522a73c93eae64c63\": \"0x3635c9adc5dea00000\",\n \"0x10a93457496f1108cd98e140a1ecdbae5e6de171\": \"0x15a99062d416180000\",\n \"0x10b5b34d1248fcf017f8c8ffc408ce899ceef92f\": \"0xe7eeba3410b740000\",\n \"0x10cf560964ff83c1c9674c783c0f73fcd89943fc\": \"0x878678326eac9000000\",\n \"0x10d32416722ca4e648630548ead91edd79c06aff\": \"0x56bc75e2d63100000\",\n \"0x10d945334ecde47beb9ca3816c173dfbbd0b5333\": \"0x4be4e7267b6ae00000\",\n \"0x10df681506e34930ac7a5c67a54c3e89ce92b981\": \"0x74c1fab8adb4540000\",\n \"0x10e1e3377885c42d7df218522ee7766887c05e6a\": \"0x1043c43cde1d398000\",\n \"0x10e390ad2ba33d82b37388d09c4544c6b0225de5\": \"0xad78ebc5ac6200000\",\n \"0x10f4bff0caa5027c0a6a2dcfc952824de2940909\": \"0x6c6b935b8bbd400000\",\n \"0x11001b89ed873e3aaec1155634b4681643986323\": \"0x3635c9adc5dea00000\",\n \"0x110237cf9117e767922fc4a1b78d7964da82df20\": \"0xd5967be4fc3f100000\",\n \"0x1111e5dbf45e6f906d62866f1708101788ddd571\": \"0x467be6533ec2e40000\",\n \"0x11172b278ddd44eea2fdf4cb1d16962391c453d9\": \"0xc62f3d9bfd4895f00000\",\n \"0x112634b4ec30ff786e024159f796a57939ea144e\": \"0x6c6acc67d7b1d40000\",\n \"0x11306c7d57588637780fc9fde8e98ecb008f0164\": \"0x6c6acc67d7b1d40000\",\n \"0x113612bc3ba0ee4898b49dd20233905f2f458f62\": \"0x2f6f10780d22cc00000\",\n \"0x11415fab61e0dfd4b90676141a557a869ba0bde9\": \"0x6f05b59d3b20000000\",\n \"0x114cbbbf6fb52ac414be7ec61f7bb71495ce1dfa\": \"0xa2a15d09519be00000\",\n \"0x114cfefe50170dd97ae08f0a44544978c599548d\": \"0x2ec887e7a14a1c0000\",\n \"0x116108c12084612eeda7a93ddcf8d2602e279e5c\": \"0x6c6b935b8bbd400000\",\n \"0x1164caaa8cc5977afe1fad8a7d6028ce2d57299b\": \"0x15af1d78b58c400000\",\n \"0x11675a25554607a3b6c92a9ee8f36f75edd3e336\": \"0x8a9aba557e36c0000\",\n \"0x116a09df66cb150e97578e297fb06e13040c893c\": \"0x6c6b935b8bbd400000\",\n \"0x116fef5e601642c918cb89160fc2293ba71da936\": \"0x2b7cc2e9c3225c0000\",\n \"0x1178501ff94add1c5881fe886136f6dfdbe61a94\": \"0x890b0c2e14fb80000\",\n \"0x1179c60dbd068b150b074da4be23033b20c68558\": \"0x24dce54d34a1a00000\",\n \"0x117d9aa3c4d13bee12c7500f09f5dd1c66c46504\": \"0xb2ad30490b2780000\",\n \"0x117db836377fe15455e02c2ebda40b1ceb551b19\": \"0x14542ba12a337c00000\",\n \"0x118c18b2dce170e8f445753ba5d7513cb7636d2d\": \"0x1dd0c885f9a0d800000\",\n \"0x118fbd753b9792395aef7a4d78d263cdcaabd4f7\": \"0x36330322d5238c0000\",\n \"0x11928378d27d55c520ceedf24ceb1e822d890df0\": \"0x1b1ae4d6e2ef5000000\",\n \"0x119aa64d5b7d181dae9d3cb449955c89c1f963fa\": \"0x25f273933db5700000\",\n \"0x11c0358aa6479de21866fe21071924b65e70f8b9\": \"0x7b53f79e888dac00000\",\n \"0x11d2247a221e70c2d66d17ee138d38c55ffb8640\": \"0x21e19e0c9bab2400000\",\n \"0x11d7844a471ef89a8d877555583ceebd1439ea26\": \"0x22369e6ba80c6880000\",\n \"0x11dd6185d9a8d73ddfdaa71e9b7774431c4dfec2\": \"0x3635c9adc5dea00000\",\n \"0x11e7997edd904503d77da6038ab0a4c834bbd563\": \"0x150894e849b3900000\",\n \"0x11ec00f849b6319cf51aa8dd8f66b35529c0be77\": \"0x6c6b935b8bbd400000\",\n \"0x11efb8a20451161b644a8ccebbc1d343a3bbcb52\": \"0xad78ebc5ac62000000\",\n \"0x11fefb5dc1a4598aa712640c517775dfa1d91f8c\": \"0x21e19e0c9bab2400000\",\n \"0x120f9de6e0af7ec02a07c609ca8447f157e6344c\": \"0xe7eeba3410b740000\",\n \"0x1210f80bdb826c175462ab0716e69e46c24ad076\": \"0x56bc75e2d63100000\",\n \"0x12134e7f6b017bf48e855a399ca58e2e892fa5c8\": \"0x3635c9adc5dea00000\",\n \"0x12173074980153aeaa4b0dcbc7132eadcec21b64\": \"0xd02ab486cedc00000\",\n \"0x121f855b70149ac83473b9706fb44d47828b983b\": \"0x4be4e7267b6ae00000\",\n \"0x1227e10a4dbf9caca31b1780239f557615fc35c1\": \"0xad78ebc5ac6200000\",\n \"0x122dcfd81addb97d1a0e4925c4b549806e9f3beb\": \"0x522035cc6e01210000\",\n \"0x122f56122549d168a5c5e267f52662e5c5cce5c8\": \"0xa076407d3f7440000\",\n \"0x12316fc7f178eac22eb2b25aedeadf3d75d00177\": \"0x43c33be05f6bfb98000\",\n \"0x123759f333e13e3069e2034b4f05398918119d36\": \"0x43c33c1937564800000\",\n \"0x125cc5e4d56b2bcc2ee1c709fb9e68fb177440bd\": \"0x6c6b935b8bbd400000\",\n \"0x12632388b2765ee4452b50161d1fffd91ab81f4a\": \"0x281d901f4fdd100000\",\n \"0x126897a311a14ad43b78e0920100c4426bfd6bdd\": \"0x34c726893f2d948000\",\n \"0x126d91f7ad86debb0557c612ca276eb7f96d00a1\": \"0x56bc75e2d63100000\",\n \"0x127d3fc5003bf63c0d83e93957836515fd279045\": \"0x610c9222e6e750000\",\n \"0x127db1cadf1b771cbd7475e1b272690f558c8565\": \"0x2f6f10780d22cc00000\",\n \"0x1284f0cee9d2ff2989b65574d06ffd9ab0f7b805\": \"0x15af1d78b58c400000\",\n \"0x128b908fe743a434203de294c441c7e20a86ea67\": \"0x26ab14e0c0e13c0000\",\n \"0x1293c78c7d6a443b9d74b0ba5ee7bb47fd418588\": \"0x16a6502f15a1e540000\",\n \"0x1296acded1e063af39fe8ba0b4b63df789f70517\": \"0x56bf91b1a65eb0000\",\n \"0x12aa7d86ddfbad301692feac8a08f841cb215c37\": \"0x76d41c62494840000\",\n \"0x12afbcba1427a6a39e7ba4849f7ab1c4358ac31b\": \"0x43c33c1937564800000\",\n \"0x12b5e28945bb2969f9c64c63cc05b6f1f8d6f4d5\": \"0x1a29e86913b74050000\",\n \"0x12cf8b0e465213211a5b53dfb0dd271a282c12c9\": \"0xd2f13f7789f00000\",\n \"0x12d20790b7d3dbd88c81a279b812039e8a603bd0\": \"0x56f985d38644b80000\",\n \"0x12d60d65b7d9fc48840be5f891c745ce76ee501e\": \"0x485e5388d0c76840000\",\n \"0x12d91a92d74fc861a729646db192a125b79f5374\": \"0xfc936392801c0000\",\n \"0x12e9a4ad2ad57484dd700565bddb46423bd9bd31\": \"0x43c30fb0884a96c0000\",\n \"0x12f32c0a1f2daab676fe69abd9e018352d4ccd45\": \"0x2b5e3af16b1880000\",\n \"0x12f460ae646cd2780fd35c50a6af4b9accfa85c6\": \"0x3635c9adc5dea00000\",\n \"0x12ffc1128605cb0c13709a7290506f2690977193\": \"0xb50fcfafebecb00000\",\n \"0x13032446e7d610aa00ec8c56c9b574d36ca1c016\": \"0x6c6b935b8bbd400000\",\n \"0x131c792c197d18bd045d7024937c1f84b60f4438\": \"0xd8d726b7177a800000\",\n \"0x131df8d330eb7cc7147d0a55576f05de8d26a8b7\": \"0xa31062beeed700000\",\n \"0x131faed12561bb7aee04e5185af802b1c3438d9b\": \"0xbdf3c4bb0328c0000\",\n \"0x1321b605026f4ffb296a3e0edcb390c9c85608b7\": \"0x6c6b935b8bbd400000\",\n \"0x1321ccf29739b974e5a516f18f3a843671e39642\": \"0xd8d726b7177a800000\",\n \"0x1327d759d56e0ab87af37ecf63fe01f310be100a\": \"0x23bc3cdb68a1800000\",\n \"0x1329dd19cd4baa9fc64310efeceab22117251f12\": \"0xad78ebc5ac6200000\",\n \"0x13371f92a56ea8381e43059a95128bdc4d43c5a6\": \"0x3635c9adc5dea00000\",\n \"0x133c490fa5bf7f372888e607d958fab7f955bae1\": \"0x55a6e79ccd1d300000\",\n \"0x133e4f15e1e39c53435930aaedf3e0fe56fde843\": \"0x1158e460913d00000\",\n \"0x134163be9fbbe1c5696ee255e90b13254395c318\": \"0xad78ebc5ac6200000\",\n \"0x135cecd955e5798370769230159303d9b1839f66\": \"0x10f0cf064dd59200000\",\n \"0x135d1719bf03e3f866312479fe338118cd387e70\": \"0x6c6b935b8bbd400000\",\n \"0x135eb8c0e9e101deedec11f2ecdb66ae1aae8867\": \"0x43c33c1937564800000\",\n \"0x1360e87df24c69ee6d51c76e73767ffe19a2131c\": \"0x4fcc1a89027f00000\",\n \"0x136c834bf111326d207395295b2e583ea7f33572\": \"0x56bc75e2d63100000\",\n \"0x136d4b662bbd1080cfe4445b0fa213864435b7f1\": \"0xd8d726b7177a800000\",\n \"0x136f4907cab41e27084b9845069ff2fd0c9ade79\": \"0xd8d726b7177a800000\",\n \"0x1374facd7b3f8d68649d60d4550ee69ff0484133\": \"0xe9ed6e11172da0000\",\n \"0x137cf341e8516c815814ebcd73e6569af14cf7bc\": \"0x3635c9adc5dea00000\",\n \"0x13848b46ea75beb7eaa85f59d866d77fd24cf21a\": \"0xa968163f0a57b400000\",\n \"0x139d3531c9922ad56269f6309aa789fb2485f98c\": \"0xd8d726b7177a800000\",\n \"0x139e479764b499d666208c4a8a047a97043163dd\": \"0x2077212aff6df00000\",\n \"0x13a5eecb38305df94971ef2d9e179ae6cebab337\": \"0x11e3ab8395c6e80000\",\n \"0x13acada8980affc7504921be84eb4944c8fbb2bd\": \"0x56d2aa3a5c09a00000\",\n \"0x13b9b10715714c09cfd610cf9c9846051cb1d513\": \"0x6acb3df27e1f880000\",\n \"0x13ce332dff65a6ab933897588aa23e000980fa82\": \"0xe020536f028f00000\",\n \"0x13d67a7e25f2b12cdb85585009f8acc49b967301\": \"0x6c6acc67d7b1d40000\",\n \"0x13dee03e3799952d0738843d4be8fc0a803fb20e\": \"0x6c6b935b8bbd400000\",\n \"0x13e02fb448d6c84ae17db310ad286d056160da95\": \"0x6c6b935b8bbd400000\",\n \"0x13e321728c9c57628058e93fc866a032dd0bda90\": \"0x26bcca23fe2ea20000\",\n \"0x13ec812284026e409bc066dfebf9d5a4a2bf801e\": \"0x57473d05dabae80000\",\n \"0x140129eaa766b5a29f5b3af2574e4409f8f6d3f1\": \"0x15af1d78b58c4000000\",\n \"0x140518a3194bad1350b8949e650565debe6db315\": \"0x6c6b935b8bbd400000\",\n \"0x1406854d149e081ac09cb4ca560da463f3123059\": \"0x487a9a304539440000\",\n \"0x140ca28ff33b9f66d7f1fc0078f8c1eef69a1bc0\": \"0x56bc75e2d631000000\",\n \"0x140fba58dbc04803d84c2130f01978f9e0c73129\": \"0x15af1d78b58c400000\",\n \"0x141a5e39ee2f680a600fbf6fa297de90f3225cdd\": \"0x21e19e0c9bab2400000\",\n \"0x14254ea126b52d0142da0a7e188ce255d8c47178\": \"0x2a034919dfbfbc0000\",\n \"0x142b87c5043ffb5a91df18c2e109ced6fe4a71db\": \"0xad78ebc5ac6200000\",\n \"0x143c639752caeecf6a997d39709fc8f19878c7e8\": \"0x6acb3df27e1f880000\",\n \"0x143d536b8b1cb84f56a39e0bc81fd5442bcacce1\": \"0x56bc75e2d63100000\",\n \"0x143f5f1658d9e578f4f3d95f80c0b1bd3933cbda\": \"0x50c5e761a444080000\",\n \"0x14410fb310711be074a80883c635d0ef6afb2539\": \"0x6c6b935b8bbd400000\",\n \"0x144b19f1f66cbe318347e48d84b14039466c5909\": \"0x6c6b935b8bbd400000\",\n \"0x145250b06e4fa7cb2749422eb817bdda8b54de5f\": \"0xbdf3c4bb0328c0000\",\n \"0x145e0600e2a927b2dd8d379356b45a2e7d51d3ae\": \"0x8a02ab400bb2cb8000\",\n \"0x145e1de0147911ccd880875fbbea61f6a142d11d\": \"0xd8d726b7177a800000\",\n \"0x1463a873555bc0397e575c2471cf77fa9db146e0\": \"0x21e19e0c9bab2400000\",\n \"0x1479a9ec7480b74b5db8fc499be352da7f84ee9c\": \"0x3635c9adc5dea00000\",\n \"0x147af46ae9ccd18bb35ca01b353b51990e49dce1\": \"0xd8d726b7177a800000\",\n \"0x147f4210ab5804940a0b7db8c14c28396b62a6bf\": \"0x6c6b935b8bbd400000\",\n \"0x14830704e99aaad5c55e1f502b27b22c12c91933\": \"0x219c3a7b1966300000\",\n \"0x149b6dbde632c19f5af47cb493114bebd9b03c1f\": \"0x28a857425466f800000\",\n \"0x149ba10f0da2725dc704733e87f5a524ca88515e\": \"0x1ab2cf7c9f87e200000\",\n \"0x14a7352066364404db50f0d0d78d754a22198ef4\": \"0x65ea3db75546600000\",\n \"0x14ab164b3b524c82d6abfbc0de831126ae8d1375\": \"0x6c6b935b8bbd400000\",\n \"0x14b1603ec62b20022033eec4d6d6655ac24a015a\": \"0x2b5e3af16b1880000\",\n \"0x14c63ba2dcb1dd4df33ddab11c4f0007fa96a62d\": \"0x34841b6057afab00000\",\n \"0x14cdddbc8b09e6675a9e9e05091cb92238c39e1e\": \"0x11478b7c30abc300000\",\n \"0x14d00aad39a0a7d19ca05350f7b03727f08dd82e\": \"0x1b1ae4d6e2ef500000\",\n \"0x14eec09bf03e352bd6ff1b1e876be664ceffd0cf\": \"0x116dc3a8994b30000\",\n \"0x14f221159518783bc4a706676fc4f3c5ee405829\": \"0xad78ebc5ac6200000\",\n \"0x14fcd1391e7d732f41766cdacd84fa1deb9ffdd2\": \"0x6c6b935b8bbd400000\",\n \"0x150e3dbcbcfc84ccf89b73427763a565c23e60d0\": \"0x22b1c8c1227a00000\",\n \"0x1518627b88351fede796d3f3083364fbd4887b0c\": \"0x3635c9adc5dea000000\",\n \"0x15224ad1c0face46f9f556e4774a3025ad06bd52\": \"0xb98bc829a6f90000\",\n \"0x152f2bd229ddf3cb0fdaf455c183209c0e1e39a2\": \"0x6c6b935b8bbd400000\",\n \"0x152f4e860ef3ee806a502777a1b8dbc91a907668\": \"0x2086ac351052600000\",\n \"0x153c08aa8b96a611ef63c0253e2a4334829e579d\": \"0x155bd9307f9fe80000\",\n \"0x153cf2842cb9de876c276fa64767d1a8ecf573bb\": \"0x6c6b935b8bbd400000\",\n \"0x153ef58a1e2e7a3eb6b459a80ab2a547c94182a2\": \"0x14542ba12a337c000000\",\n \"0x154459fa2f21318e3434449789d826cdc1570ce5\": \"0x6c6b935b8bbd400000\",\n \"0x1547b9bf7ad66274f3413827231ba405ee8c88c1\": \"0x3a9d5baa4abf1d00000\",\n \"0x1548b770a5118ede87dba2f690337f616de683ab\": \"0x1c995685e0bf870000\",\n \"0x15528350e0d9670a2ea27f7b4a33b9c0f9621d21\": \"0xd8d8583fa2d52f0000\",\n \"0x155b3779bb6d56342e2fda817b5b2d81c7f41327\": \"0x2b8aa3a076c9c0000\",\n \"0x1565af837ef3b0bd4e2b23568d5023cd34b16498\": \"0x1551e9724ac4ba0000\",\n \"0x15669180dee29598869b08a721c7d24c4c0ee63f\": \"0x3635c9adc5dea00000\",\n \"0x1572cdfab72a01ce968e78f5b5448da29853fbdd\": \"0x112626c49060fa60000\",\n \"0x157559adc55764cc6df79323092534e3d6645a66\": \"0x14542ba12a337c00000\",\n \"0x1578bdbc371b4d243845330556fff2d5ef4dff67\": \"0x56bc75e2d63100000\",\n \"0x157eb3d3113bd3b597714d3a954edd018982a5cb\": \"0x6c6b935b8bbd400000\",\n \"0x1584a2c066b7a455dbd6ae2807a7334e83c35fa5\": \"0x70c1cc73b00c80000\",\n \"0x15874686b6733d10d703c9f9bec6c52eb8628d67\": \"0x6c6b935b8bbd400000\",\n \"0x158a0d619253bf4432b5cd02c7b862f7c2b75636\": \"0x75bac7c5b12188000\",\n \"0x1598127982f2f8ad3b6b8fc3cf27bf617801ba2b\": \"0x960db77681e940000\",\n \"0x159adce27aa10b47236429a34a5ac42cad5b6416\": \"0x6bf90a96edbfa718000\",\n \"0x15a0aec37ff9ff3d5409f2a4f0c1212aaccb0296\": \"0x3635c9adc5dea00000\",\n \"0x15aa530dc36958b4edb38eee6dd9e3c77d4c9145\": \"0x6c6b935b8bbd400000\",\n \"0x15acb61568ec4af7ea2819386181b116a6c5ee70\": \"0x690836c0af5f5600000\",\n \"0x15b96f30c23b8664e7490651066b00c4391fbf84\": \"0x1642e9df4876290000\",\n \"0x15c7edb8118ee27b342285eb5926b47a855bc7a5\": \"0x1158e460913d00000\",\n \"0x15d99468507aa0413fb60dca2adc7f569cb36b54\": \"0x6c6b935b8bbd400000\",\n \"0x15dbb48c98309764f99ced3692dcca35ee306bac\": \"0x1fc3842bd1f071c00000\",\n \"0x15dcafcc2bace7b55b54c01a1c514626bf61ebd8\": \"0x1fd933494aa5fe00000\",\n \"0x15e3b584056b62c973cf5eb096f1733e54c15c91\": \"0x32c75a0223ddf30000\",\n \"0x15ebd1c7cad2aff19275c657c4d808d010efa0f5\": \"0xadf30ba70c8970000\",\n \"0x15ee0fc63ebf1b1fc49d7bb38f8863823a2e17d2\": \"0x678a932062e4180000\",\n \"0x15f1b352110d68901d8f67aac46a6cfafe031477\": \"0xad78ebc5ac6200000\",\n \"0x15f2b7b16432ee50a5f55b41232f6334ed58bdc0\": \"0x15af1d78b58c400000\",\n \"0x16019a4dafab43f4d9bf4163fae0847d848afca2\": \"0x15bc70139f74a0000\",\n \"0x160226efe7b53a8af462d117a0108089bdecc2d1\": \"0xadf30ba70c8970000\",\n \"0x160ceb6f980e04315f53c4fc988b2bf69e284d7d\": \"0x10910d4cdc9f60000\",\n \"0x161caf5a972ace8379a6d0a04ae6e163fe21df2b\": \"0x152d02c7e14af6800000\",\n \"0x161d26ef6759ba5b9f20fdcd66f16132c352415e\": \"0x6c6b935b8bbd400000\",\n \"0x162110f29eac5f7d02b543d8dcd5bb59a5e33b73\": \"0x6c6b935b8bbd400000\",\n \"0x162ba503276214b509f97586bd842110d103d517\": \"0x1e7ffd8895c22680000\",\n \"0x162d76c2e6514a3afb6fe3d3cb93a35c5ae783f1\": \"0x6c6b935b8bbd400000\",\n \"0x163bad4a122b457d64e8150a413eae4d07023e6b\": \"0x104e70464b1580000\",\n \"0x163cc8be227646cb09719159f28ed09c5dc0dce0\": \"0x487a9a304539440000\",\n \"0x163dca73d7d6ea3f3e6062322a8734180c0b78ef\": \"0x9f742003cb7dfc0000\",\n \"0x164d7aac3eecbaeca1ad5191b753f173fe12ec33\": \"0x285652b8a468690000\",\n \"0x16526c9edf943efa4f6d0f0bae81e18b31c54079\": \"0x35659ef93f0fc40000\",\n \"0x165305b787322e25dc6ad0cefe6c6f334678d569\": \"0x6c6b935b8bbd400000\",\n \"0x1665ab1739d71119ee6132abbd926a279fe67948\": \"0x56bc75e2d63100000\",\n \"0x166bf6dab22d841b486c38e7ba6ab33a1487ed8c\": \"0x43c33c1937564800000\",\n \"0x167699f48a78c615512515739958993312574f07\": \"0x21d3bd55e803c0000\",\n \"0x1678c5f2a522393225196361894f53cc752fe2f3\": \"0x68f365aea1e4400000\",\n \"0x167ce7de65e84708595a525497a3eb5e5a665073\": \"0x1f314773666fc40000\",\n \"0x167e3e3ae2003348459392f7dfce44af7c21ad59\": \"0x1b1ae4d6e2ef500000\",\n \"0x1680cec5021ee93050f8ae127251839e74c1f1fd\": \"0x2c61461e5d743d68000\",\n \"0x16816aac0ede0d2d3cd442da79e063880f0f1d67\": \"0x6c6b935b8bbd400000\",\n \"0x168b5019b818691644835fe69bf229e17112d52c\": \"0x5ede20f01a459800000\",\n \"0x168bdec818eafc6d2992e5ef54aa0e1601e3c561\": \"0x3637507a30abeb0000\",\n \"0x168d30e53fa681092b52e9bae15a0dcb41a8c9bb\": \"0x56bc75e2d63100000\",\n \"0x169bbefc41cfd7d7cbb8dfc63020e9fb06d49546\": \"0x6c6b935b8bbd400000\",\n \"0x16a58e985dccd707a594d193e7cca78b5d027849\": \"0x49b9ca9a6943400000\",\n \"0x16a9e9b73ae98b864d1728798b8766dbc6ea8d12\": \"0x33e7b44b0db5040000\",\n \"0x16aa52cb0b554723e7060f21f327b0a68315fea3\": \"0xd8d726b7177a80000\",\n \"0x16abb8b021a710bdc78ea53494b20614ff4eafe8\": \"0x890b0c2e14fb80000\",\n \"0x16afa787fc9f94bdff6976b1a42f430a8bf6fb0f\": \"0x6c6b935b8bbd400000\",\n \"0x16bae5d24eff91778cd98b4d3a1cc3162f44aa77\": \"0x15be6174e1912e0000\",\n \"0x16bc40215abbd9ae5d280b95b8010b4514ff1292\": \"0xad78ebc5ac6200000\",\n \"0x16be75e98a995a395222d00bd79ff4b6e638e191\": \"0x79f905c6fd34e800000\",\n \"0x16c1bf5b7dc9c83c179efacbcf2eb174e3561cb3\": \"0x3635c9adc5dea00000\",\n \"0x16c7b31e8c376282ac2271728c31c95e35d952c3\": \"0x6c6b935b8bbd400000\",\n \"0x16f313cf8ad000914a0a176dc6a4342b79ec2538\": \"0x6c6b935b8bbd400000\",\n \"0x16ffac84032940f0121a09668b858a7e79ffa3bb\": \"0xd24ada6e1087110000\",\n \"0x1703b4b292b8a9deddede81bb25d89179f6446b6\": \"0x42b65a455e8b1680000\",\n \"0x17049311101d817efb1d65910f663662a699c98c\": \"0x6c68ccd09b022c0000\",\n \"0x1704cefcfb1331ec7a78388b29393e85c1af7916\": \"0x15af1d78b58c400000\",\n \"0x170a88a8997f92d238370f1affdee6347050b013\": \"0xa2ac77351488300000\",\n \"0x17108dab2c50f99de110e1b3b3b4cd82f5df28e7\": \"0x35203b67bccad00000\",\n \"0x17125b59ac51cee029e4bd78d7f5947d1ea49bb2\": \"0x4a89f54ef0121c00000\",\n \"0x171ad9a04bedc8b861e8ed4bddf5717813b1bb48\": \"0x15af1d78b58c400000\",\n \"0x171ca02a8b6d62bf4ca47e906914079861972cb2\": \"0xad78ebc5ac6200000\",\n \"0x1722c4cbe70a94b6559d425084caeed4d6e66e21\": \"0xd8d726b7177a800000\",\n \"0x17580b766f7453525ca4c6a88b01b50570ea088c\": \"0x56bc75e2d63100000\",\n \"0x17589a6c006a54cad70103123aae0a82135fdeb4\": \"0xd8d726b7177a800000\",\n \"0x175a183a3a235ffbb03ba835675267229417a091\": \"0x3635c9adc5dea000000\",\n \"0x175feeea2aa4e0efda12e1588d2f483290ede81a\": \"0xad78ebc5ac6200000\",\n \"0x1765361c2ec2f83616ce8363aae21025f2566f40\": \"0x10f0cf064dd59200000\",\n \"0x1767525c5f5a22ed80e9d4d7710f0362d29efa33\": \"0x15af1d78b58c400000\",\n \"0x17762560e82a93b3f522e0e524adb8612c3a7470\": \"0x3635c9adc5dea00000\",\n \"0x177dae78bc0113d8d39c4402f2a641ae2a105ab8\": \"0x6292425620b4480000\",\n \"0x1784948bf99848c89e445638504dd698271b5924\": \"0x1474c410d87baee0000\",\n \"0x1788da9b57fd05edc4ff99e7fef301519c8a0a1e\": \"0x6c6b935b8bbd400000\",\n \"0x178eaf6b8554c45dfde16b78ce0c157f2ee31351\": \"0x1158e460913d000000\",\n \"0x17961d633bcf20a7b029a7d94b7df4da2ec5427f\": \"0xc6ff070f1938b8000\",\n \"0x1796bcc97b8abc717f4b4a7c6b1036ea2182639f\": \"0x1341f91cd8e3510000\",\n \"0x17993d312aa1106957868f6a55a5e8f12f77c843\": \"0x1865e814f4142e8000\",\n \"0x179a825e0f1f6e985309668465cffed436f6aea9\": \"0x1158e460913d00000\",\n \"0x17b2d6cf65c6f4a347ddc6572655354d8a412b29\": \"0x6c6b935b8bbd400000\",\n \"0x17b807afa3ddd647e723542e7b52fee39527f306\": \"0x15af40ffa7fc010000\",\n \"0x17c0478657e1d3d17aaa331dd429cecf91f8ae5d\": \"0x3634fb9f1489a70000\",\n \"0x17c0fef6986cfb2e4041f9979d9940b69dff3de2\": \"0xd8d726b7177a800000\",\n \"0x17d4918dfac15d77c47f9ed400a850190d64f151\": \"0x6c6b935b8bbd400000\",\n \"0x17d521a8d9779023f7164d233c3b6420ffd223ed\": \"0x1158e460913d00000\",\n \"0x17d931d4c56294dcbe77c8655be4695f006d4a3c\": \"0x6c6b935b8bbd400000\",\n \"0x17df49518d73b129f0da36b1c9b40cb66420fdc7\": \"0x21e19e0c9bab2400000\",\n \"0x17e4a0e52bac3ee44efe0954e753d4b85d644e05\": \"0x6c6b935b8bbd400000\",\n \"0x17e584e810e567702c61d55d434b34cdb5ee30f6\": \"0x10f0cf064dd59200000\",\n \"0x17e82e7078dc4fd9e879fb8a50667f53a5c54591\": \"0xad78ebc5ac6200000\",\n \"0x17e86f3b5b30c0ba59f2b2e858425ba89f0a10b0\": \"0x6c6b935b8bbd400000\",\n \"0x17ee9f54d4ddc84d670eff11e54a659fd72f4455\": \"0x3635c9adc5dea000000\",\n \"0x17ef4acc1bf147e326749d10e677dcffd76f9e06\": \"0x87751f4e0e1b5300000\",\n \"0x17f14632a7e2820be6e8f6df823558283dadab2d\": \"0x6c6b935b8bbd400000\",\n \"0x17f523f117bc9fe978aa481eb4f5561711371bc8\": \"0x6c69f73e29134e0000\",\n \"0x17fd9b551a98cb61c2e07fbf41d3e8c9a530cba5\": \"0x1768c308193048000\",\n \"0x180478a655d78d0f3b0c4f202b61485bc4002fd5\": \"0x6c6b935b8bbd400000\",\n \"0x18136c9df167aa17b6f18e22a702c88f4bc28245\": \"0xd8d726b7177a800000\",\n \"0x1815279dff9952da3be8f77249dbe22243377be7\": \"0x1017cb76e7b26640000\",\n \"0x181fbba852a7f50178b1c7f03ed9e58d54162929\": \"0x241a9b4f617a280000\",\n \"0x1827039f09570294088fddf047165c33e696a492\": \"0x205b4dfa1ee74780000\",\n \"0x182db85293f606e88988c3704cb3f0c0bbbfca5a\": \"0x73f75d1a085ba0000\",\n \"0x1848003c25bfd4aa90e7fcb5d7b16bcd0cffc0d8\": \"0x3635c9adc5dea00000\",\n \"0x184a4f0beb71ffd558a6b6e8f228b78796c4cf3e\": \"0x28a857425466f800000\",\n \"0x184d86f3466ae6683b19729982e7a7e1a48347b2\": \"0x21e19e0c9bab2400000\",\n \"0x1851a063ccdb30549077f1d139e72de7971197d5\": \"0x6c6b935b8bbd400000\",\n \"0x185546e8768d506873818ac9751c1f12116a3bef\": \"0xad78ebc5ac6200000\",\n \"0x1858cf11aea79f5398ad2bb22267b5a3c952ea74\": \"0x215f835bc769da80000\",\n \"0x185a7fc4ace368d233e620b2a45935661292bdf2\": \"0x43c33c1937564800000\",\n \"0x1864a3c7b48155448c54c88c708f166709736d31\": \"0x73f75d1a085ba0000\",\n \"0x186afdc085f2a3dce4615edffbadf71a11780f50\": \"0xad78ebc5ac6200000\",\n \"0x186b95f8e5effddcc94f1a315bf0295d3b1ea588\": \"0x6c6acc67d7b1d40000\",\n \"0x187d9f0c07f8eb74faaad15ebc7b80447417f782\": \"0x1158e460913d00000\",\n \"0x1895a0eb4a4372722fcbc5afe6936f289c88a419\": \"0x3154c9729d05780000\",\n \"0x1899f69f653b05a5a6e81f480711d09bbf97588c\": \"0x69fb133df750ac0000\",\n \"0x18a6d2fc52be73084023c91802f05bc24a4be09f\": \"0x6c6b935b8bbd400000\",\n \"0x18b0407cdad4ce52600623bd5e1f6a81ab61f026\": \"0x1151ccf0c654c68000\",\n \"0x18b8bcf98321da61fb4e3eacc1ec5417272dc27e\": \"0x2fb474098f67c00000\",\n \"0x18c6723a6753299cb914477d04a3bd218df8c775\": \"0x3635c9adc5dea00000\",\n \"0x18e113d8177c691a61be785852fa5bb47aeebdaf\": \"0x487a9a304539440000\",\n \"0x18e4ce47483b53040adbab35172c01ef64506e0c\": \"0x1e7e4171bf4d3a00000\",\n \"0x18e53243981aabc8767da10c73449f1391560eaa\": \"0x14542ba12a337c00000\",\n \"0x18fa8625c9dc843c78c7ab259ff87c9599e07f10\": \"0x3635c9adc5dea00000\",\n \"0x18fb09188f27f1038e654031924f628a2106703d\": \"0x6c6b935b8bbd400000\",\n \"0x18fccf62d2c3395453b7587b9e26f5cff9eb7482\": \"0x3635c9adc5dea00000\",\n \"0x191313525238a21c767457a91374f02200c55448\": \"0x64f5fdf494f780000\",\n \"0x1914f1eb95d1277e93b6e61b668b7d77f13a11a1\": \"0x34957444b840e80000\",\n \"0x1923cfc68b13ea7e2055803645c1e320156bd88d\": \"0x487a9a304539440000\",\n \"0x19336a236ded755872411f2e0491d83e3e00159e\": \"0x32f51edbaaa3300000\",\n \"0x1933e334c40f3acbad0c0b851158206924beca3a\": \"0x1995eaf01b896188000\",\n \"0x1937c5c515057553ccbd46d5866455ce66290284\": \"0xd3c21bcecceda1000000\",\n \"0x193ac65183651800e23580f8f0ead3bb597eb8a4\": \"0x2b62abcfb910a0000\",\n \"0x193d37ed347d1c2f4e35350d9a444bc57ca4db43\": \"0x340aad21b3b700000\",\n \"0x1940dc9364a852165f47414e27f5002445a4f143\": \"0x24c2dff6a3c7c480000\",\n \"0x1945fe377fe6d4b71e3e791f6f17db243c9b8b0f\": \"0x7679e7beb988360000\",\n \"0x194a6bb302b8aba7a5b579df93e0df1574967625\": \"0x1b1ae4d6e2ef500000\",\n \"0x194cebb4929882bf3b4bf9864c2b1b0f62c283f9\": \"0x1ef861531f74aa0000\",\n \"0x194ff44aefc17bd20efd7a204c47d1620c86db5d\": \"0xa29909687f6aa40000\",\n \"0x194ffe78bbf5d20dd18a1f01da552e00b7b11db1\": \"0x17b7883c06916600000\",\n \"0x1953313e2ad746239cb2270f48af34d8bb9c4465\": \"0x6c6b935b8bbd400000\",\n \"0x19571a2b8f81c6bcf66ab3a10083295617150003\": \"0x1ab2cf7c9f87e20000\",\n \"0x19687daa39c368139b6e7be60dc1753a9f0cbea3\": \"0x1b1ae4d6e2ef5000000\",\n \"0x196c02210a450ab0b36370655f717aa87bd1c004\": \"0xe10ace157dbc00000\",\n \"0x196e85df7e732b4a8f0ed03623f4db9db0b8fa31\": \"0x125b92f5cef248000\",\n \"0x19732bf973055dbd91a4533adaa2149a91d38380\": \"0x6c6b935b8bbd400000\",\n \"0x197672fd39d6f246ce66a790d13aa922d70ea109\": \"0x3635c9adc5dea00000\",\n \"0x19798cbda715ea9a9b9d6aab942c55121e98bf91\": \"0x410d586a20a4c00000\",\n \"0x198bfcf1b07ae308fa2c02069ac9dafe7135fb47\": \"0x1158e460913d00000\",\n \"0x198ef1ec325a96cc354c7266a038be8b5c558f67\": \"0x80d1e4373e7f21da0000\",\n \"0x19918aa09e7d494e98ffa5db50350892f7156ac6\": \"0x21e19e0c9bab2400000\",\n \"0x19b36b0c87ea664ed80318dc77b688dde87d95a5\": \"0x699f499802303d0000\",\n \"0x19df9445a81c1b3d804aeaeb6f6e204e4236663f\": \"0x206d94e6a49878000\",\n \"0x19e5dea3370a2c746aae34a37c531f41da264e83\": \"0xad78ebc5ac6200000\",\n \"0x19e7f3eb7bf67f3599209ebe08b62ad3327f8cde\": \"0x6c6b935b8bbd400000\",\n \"0x19e94e620050aad766b9e1bad931238312d4bf49\": \"0x81e32df972abf00000\",\n \"0x19ecf2abf40c9e857b252fe1dbfd3d4c5d8f816e\": \"0x6c6b935b8bbd400000\",\n \"0x19f5caf4c40e6908813c0745b0aea9586d9dd931\": \"0x23fed9e1fa2b600000\",\n \"0x19f643e1a8fa04ae16006028138333a59a96de87\": \"0x1158e460913d00000\",\n \"0x19f99f2c0b46ce8906875dc9f90ae104dae35594\": \"0xf4575a5d4d162a0000\",\n \"0x19ff244fcfe3d4fa2f4fd99f87e55bb315b81eb6\": \"0xad78ebc5ac6200000\",\n \"0x1a04cec420ad432215246d77fe178d339ed0b595\": \"0x11216185c29f700000\",\n \"0x1a04d5389eb006f9ce880c30d15353f8d11c4b31\": \"0x39d84b2186dc9100000\",\n \"0x1a0841b92a7f7075569dc4627e6b76cab05ade91\": \"0x52663ccab1e1c00000\",\n \"0x1a085d43ec92414ea27b914fe767b6d46b1eef44\": \"0x641e8a13563d8f80000\",\n \"0x1a09fdc2c7a20e23574b97c69e93deba67d37220\": \"0x6c4fd1ee246e780000\",\n \"0x1a0a1ddfb031e5c8cc1d46cf05842d50fddc7130\": \"0x3635c9adc5dea00000\",\n \"0x1a1c9a26e0e02418a5cf687da75a275c622c9440\": \"0x10f0cf064dd59200000\",\n \"0x1a201b4327cea7f399046246a3c87e6e03a3cda8\": \"0x3635c9adc5dea00000\",\n \"0x1a2434cc774422d48d53d59c5d562cce8407c94b\": \"0x1a055690d9db80000\",\n \"0x1a25e1c5bc7e5f50ec16f8885f210ea1b938800e\": \"0xd8d726b7177a800000\",\n \"0x1a2694ec07cf5e4d68ba40f3e7a14c53f3038c6e\": \"0x3636cd06e2db3a8000\",\n \"0x1a3520453582c718a21c42375bc50773255253e1\": \"0x2ad373ce668e980000\",\n \"0x1a376e1b2d2f590769bb858d4575320d4e149970\": \"0x106712576391d180000\",\n \"0x1a3a330e4fcb69dbef5e6901783bf50fd1c15342\": \"0xe3aeb5737240a00000\",\n \"0x1a4ec6a0ae7f5a9427d23db9724c0d0cffb2ab2f\": \"0x9b41fbf9e0aec0000\",\n \"0x1a505e62a74e87e577473e4f3afa16bedd3cfa52\": \"0x1b1ae4d6e2ef500000\",\n \"0x1a5ee533acbfb3a2d76d5b685277b796c56a052b\": \"0x6c6b935b8bbd400000\",\n \"0x1a644a50cbc2aee823bd2bf243e825be4d47df02\": \"0x56be03ca3e47d8000\",\n \"0x1a7044e2383f8708305b495bd1176b92e7ef043a\": \"0xad78ebc5ac6200000\",\n \"0x1a79c7f4039c67a39d7513884cdc0e2c34222490\": \"0x1158e460913d00000\",\n \"0x1a89899cbebdbb64bb26a195a63c08491fcd9eee\": \"0x6c6b935b8bbd400000\",\n \"0x1a8a5ce414de9cd172937e37f2d59cff71ce57a0\": \"0x21e19e0c9bab2400000\",\n \"0x1a95a8a8082e4652e4170df9271cb4bb4305f0b2\": \"0x2b5e3af16b1880000\",\n \"0x1a95c9b7546b5d1786c3858fb1236446bc0ca4ce\": \"0x6acb3df27e1f880000\",\n \"0x1a987e3f83de75a42f1bde7c997c19217b4a5f24\": \"0x6c6b935b8bbd400000\",\n \"0x1a9e702f385dcd105e8b9fa428eea21c57ff528a\": \"0x4be4e7267b6ae00000\",\n \"0x1aa1021f550af158c747668dd13b463160f95a40\": \"0x4fb0591b9b30380000\",\n \"0x1aa27699cada8dc3a76f7933aa66c71919040e88\": \"0x15af1d78b58c400000\",\n \"0x1aa40270d21e5cde86b6316d1ac3c533494b79ed\": \"0x1158e460913d00000\",\n \"0x1ab53a11bcc63ddfaa40a02b9e186496cdbb8aff\": \"0x6c3f2aac800c000000\",\n \"0x1abc4e253b080aeb437984ab05bca0979aa43e1c\": \"0x3635c9adc5dea00000\",\n \"0x1ac089c3bc4d82f06a20051a9d732dc0e734cb61\": \"0x25f69d63a6ce0e0000\",\n \"0x1ad4563ea5786be1159935abb0f1d5879c3e7372\": \"0x14542ba12a337c00000\",\n \"0x1ad72d20a76e7fcc6b764058f48d417d496fa6cd\": \"0x6c6b935b8bbd400000\",\n \"0x1adaf4abfa867db17f99af6abebf707a3cf55df6\": \"0x14542ba12a337c00000\",\n \"0x1af60343360e0b2d75255210375720df21db5c7d\": \"0x3635c9adc5dea00000\",\n \"0x1afcc585896cd0ede129ee2de5c19ea811540b64\": \"0xaf2aba0c8e5bef8000\",\n \"0x1b05ea6a6ac8af7cb6a8b911a8cce8fe1a2acfc8\": \"0x6c6b935b8bbd400000\",\n \"0x1b0b31afff4b6df3653a94d7c87978ae35f34aae\": \"0x133910453fa9840000\",\n \"0x1b0d076817e8d68ee2df4e1da1c1142d198c4435\": \"0x54069233bf7f780000\",\n \"0x1b130d6fa51d5c48ec8d1d52dc8a227be8735c8a\": \"0x6c6b935b8bbd400000\",\n \"0x1b23cb8663554871fbbe0d9e60397efb6faedc3e\": \"0xad78ebc5ac6200000\",\n \"0x1b2639588b55c344b023e8de5fd4087b1f040361\": \"0x5150ae84a8cdf00000\",\n \"0x1b3920d001c43e72b24e7ca46f0fd6e0c20a5ff2\": \"0x6c6b935b8bbd400000\",\n \"0x1b3cb81e51011b549d78bf720b0d924ac763a7c2\": \"0x7695a92c20d6fe000000\",\n \"0x1b43232ccd4880d6f46fa751a96cd82473315841\": \"0x4563918244f400000\",\n \"0x1b4bbcb18165211b265b280716cb3f1f212176e8\": \"0x199ad37d03d0608000\",\n \"0x1b4d07acd38183a61bb2783d2b7b178dd502ac8d\": \"0xad78ebc5ac6200000\",\n \"0x1b636b7a496f044d7359596e353a104616436f6b\": \"0x1388ea95c33f1d0000\",\n \"0x1b6495891240e64e594493c2662171db5e30ce13\": \"0x95887d695ed580000\",\n \"0x1b6610fb68bad6ed1cfaa0bbe33a24eb2e96fafb\": \"0x83d6c7aab63600000\",\n \"0x1b799033ef6dc7127822f74542bb22dbfc09a308\": \"0x56bc75e2d63100000\",\n \"0x1b7ed974b6e234ce81247498429a5bd4a0a2d139\": \"0x6c6b935b8bbd400000\",\n \"0x1b826fb3c012b0d159e294ba5b8a499ff3c0e03c\": \"0x6c6b935b8bbd400000\",\n \"0x1b8aa0160cd79f005f88510a714913d70ad3be33\": \"0xaeffb83079ad00000\",\n \"0x1b8bd6d2eca20185a78e7d98e8e185678dac4830\": \"0x3894f0e6f9b9f700000\",\n \"0x1b9b2dc2960e4cb9408f7405827c9b59071612fd\": \"0x3635c9adc5dea00000\",\n \"0x1ba9228d388727f389150ea03b73c82de8eb2e09\": \"0x18974fbe177c9280000\",\n \"0x1ba9f7997e5387b6b2aa0135ac2452fe36b4c20d\": \"0x2e141ea081ca080000\",\n \"0x1bba03ff6b4ad5bf18184acb21b188a399e9eb4a\": \"0x61093d7c2c6d380000\",\n \"0x1bbc199e586790be87afedc849c04726745c5d7b\": \"0xd8d726b7177a800000\",\n \"0x1bbc60bcc80e5cdc35c5416a1f0a40a83dae867b\": \"0x6c6b935b8bbd400000\",\n \"0x1bc44c8761231ba1f11f5faa40fa669a013e12ce\": \"0xb0952c45aeaad0000\",\n \"0x1bcf3441a866bdbe963009ce33c81cbb0261b02c\": \"0x9ddc1e3b901180000\",\n \"0x1bd28cd5c78aee51357c95c1ef9235e7c18bc854\": \"0x6c6b935b8bbd400000\",\n \"0x1bd8ebaa7674bb18e19198db244f570313075f43\": \"0x821ab0d4414980000\",\n \"0x1bd909ac0d4a1102ec98dcf2cca96a0adcd7a951\": \"0x11651ac3e7a758000\",\n \"0x1be3542c3613687465f15a70aeeb81662b65cca8\": \"0x6c6b935b8bbd400000\",\n \"0x1bea4df5122fafdeb3607eddda1ea4ffdb9abf2a\": \"0x12c1b6eed03d280000\",\n \"0x1bec4d02ce85fc48feb62489841d85b170586a9b\": \"0x821ab0d44149800000\",\n \"0x1bf974d9904f45ce81a845e11ef4cbcf27af719e\": \"0x56bc75e2d63100000\",\n \"0x1c045649cd53dc23541f8ed4d341812808d5dd9c\": \"0x17b7883c06916600000\",\n \"0x1c128bd6cda5fca27575e4b43b3253c8c4172afe\": \"0x6c6b935b8bbd400000\",\n \"0x1c13d38637b9a47ce79d37a86f50fb409c060728\": \"0x487a9a304539440000\",\n \"0x1c2010bd662df417f2a271879afb13ef4c88a3ae\": \"0xd8d726b7177a800000\",\n \"0x1c257ad4a55105ea3b58ed374b198da266c85f63\": \"0x21e19e0c9bab2400000\",\n \"0x1c2e3607e127caca0fbd5c5948adad7dd830b285\": \"0x42bf06b78ed3b500000\",\n \"0x1c356cfdb95febb714633b28d5c132dd84a9b436\": \"0x15af1d78b58c40000\",\n \"0x1c35aab688a0cd8ef82e76541ba7ac39527f743b\": \"0x1b1ae4d6e2ef500000\",\n \"0x1c3ef05dae9dcbd489f3024408669de244c52a02\": \"0x43c33c1937564800000\",\n \"0x1c4af0e863d2656c8635bc6ffec8dd9928908cb5\": \"0x6c6b935b8bbd400000\",\n \"0x1c601993789207f965bb865cbb4cd657cce76fc0\": \"0x5541a7037503f0000\",\n \"0x1c63fa9e2cbbf23c49fcdef1cbabfe6e0d1e14c1\": \"0x3635c9adc5dea00000\",\n \"0x1c6702b3b05a5114bdbcaeca25531aeeb34835f4\": \"0x58556bead45dcae0000\",\n \"0x1c68a66138783a63c98cc675a9ec77af4598d35e\": \"0x2b746f48f0f120000\",\n \"0x1c73d00b6e25d8eb9c1ff4ad827b6b9e9cf6d20c\": \"0xad78ebc5ac6200000\",\n \"0x1c751e7f24df9d94a637a5dedeffc58277b5db19\": \"0xae8e7a0bb575d00000\",\n \"0x1c7cb2fe6bf3e09cbcdc187af38fa8f5053a70b6\": \"0x21c84f742d0cead8000\",\n \"0x1c89060f987c518fa079ec2c0a5ebfa30f5d20f7\": \"0x80bfbefcb5f0bc00000\",\n \"0x1c94d636e684eb155895ce6db4a2588fba1d001b\": \"0x6c6b935b8bbd400000\",\n \"0x1c99fe9bb6c6d1066d912099547fd1f4809eacd9\": \"0x6c6b935b8bbd400000\",\n \"0x1cb450920078aab2317c7db3b38af7dd298b2d41\": \"0x126e72a69a50d00000\",\n \"0x1cb5f33b4d488936d13e3161da33a1da7df70d1b\": \"0xad78ebc5ac6200000\",\n \"0x1cb6b2d7cfc559b7f41e6f56ab95c7c958cd0e4c\": \"0x487a9a304539440000\",\n \"0x1cc1d3c14f0fb8640e36724dc43229d2ea7a1e48\": \"0x5c283d410394100000\",\n \"0x1cc90876004109cd79a3dea866cb840ac364ba1b\": \"0x6c6b935b8bbd400000\",\n \"0x1cd1f0a314cbb200de0a0cb1ef97e920709d97c2\": \"0x6c6b935b8bbd400000\",\n \"0x1cda411bd5163baeca1e558563601ce720e24ee1\": \"0xfc936392801c0000\",\n \"0x1ce81d31a7923022e125bf48a3e03693b98dc9dd\": \"0x6c6b935b8bbd400000\",\n \"0x1cebf0985d7f680aaa915c44cc62edb49eab269e\": \"0x3635c9adc5dea00000\",\n \"0x1ced6715f862b1ff86058201fcce5082b36e62b2\": \"0x16a5e60bee273b10000\",\n \"0x1cf04cb14380059efd3f238b65d5beb86afa14d8\": \"0x1158e460913d00000\",\n \"0x1cf105ab23023b554c583e86d7921179ee83169f\": \"0x6acb3df27e1f880000\",\n \"0x1cf2eb7a8ccac2adeaef0ee87347d535d3b94058\": \"0x6c6b935b8bbd400000\",\n \"0x1cfcf7517f0c08459720942b647ad192aa9c8828\": \"0x2b5e3af16b18800000\",\n \"0x1d09ad2412691cc581c1ab36b6f9434cd4f08b54\": \"0x17b7883c06916600000\",\n \"0x1d157c5876c5cad553c912caf6ce2d5277e05c73\": \"0x6c6b935b8bbd400000\",\n \"0x1d2615f8b6ca5012b663bdd094b0c5137c778ddf\": \"0x21e19e0c9bab2400000\",\n \"0x1d29c7aab42b2048d2b25225d498dba67a03fbb2\": \"0xad78ebc5ac6200000\",\n \"0x1d341fa5a3a1bd051f7db807b6db2fc7ba4f9b45\": \"0xfc936392801c0000\",\n \"0x1d344e962567cb27e44db9f2fac7b68df1c1e6f7\": \"0x692ae8897081d00000\",\n \"0x1d36683063b7e9eb99462dabd569bddce71686f2\": \"0x3635c9adc5dea00000\",\n \"0x1d37616b793f94911838ac8e19ee9449df921ec4\": \"0x5150ae84a8cdf00000\",\n \"0x1d395b30adda1cf21f091a4f4a7b753371189441\": \"0x152d02c7e14af6800000\",\n \"0x1d45586eb803ca2190650bf748a2b174312bb507\": \"0x4be4e7267b6ae00000\",\n \"0x1d572edd2d87ca271a6714c15a3b37761dcca005\": \"0x6ebd52a8ddd390000\",\n \"0x1d633097a85225a1ff4321b12988fdd55c2b3844\": \"0xd8d726b7177a800000\",\n \"0x1d69c83d28ff0474ceebeacb3ad227a144ece7a3\": \"0x128cc03920a62d28000\",\n \"0x1d96bcd58457bbf1d3c2a46ffaf16dbf7d836859\": \"0x9497209d8467e8000\",\n \"0x1d9e6aaf8019a05f230e5def05af5d889bd4d0f2\": \"0x73f75d1a085ba0000\",\n \"0x1dab172effa6fbee534c94b17e794edac54f55f8\": \"0x6acb3df27e1f880000\",\n \"0x1db9ac9a9eaeec0a523757050c71f47278c72d50\": \"0x487a9a304539440000\",\n \"0x1dbe8e1c2b8a009f85f1ad3ce80d2e05350ee39c\": \"0x7570d6e9ebbe40000\",\n \"0x1dc7f7dad85df53f1271152403f4e1e4fdb3afa0\": \"0xad78ebc5ac6200000\",\n \"0x1dcebcb7656df5dcaa3368a055d22f9ed6cdd940\": \"0x1b181e4bf2343c0000\",\n \"0x1dd77441844afe9cc18f15d8c77bccfb655ee034\": \"0x106eb45579944880000\",\n \"0x1ddefefd35ab8f658b2471e54790bc17af98dea4\": \"0x3635c9adc5dea00000\",\n \"0x1deec01abe5c0d952de9106c3dc30639d85005d6\": \"0x6c6b935b8bbd400000\",\n \"0x1df6911672679bb0ef3509038c0c27e394fdfe30\": \"0x1d460162f516f00000\",\n \"0x1dfaee077212f1beaf0e6f2f1840537ae154ad86\": \"0x3635c9adc5dea00000\",\n \"0x1e060dc6c5f1cb8cc7e1452e02ee167508b56542\": \"0x2b14f02c864c77e0000\",\n \"0x1e13ec51142cebb7a26083412c3ce35144ba56a1\": \"0x10f0cf064dd59200000\",\n \"0x1e1a4828119be309bd88236e4d482b504dc55711\": \"0xa030dcebbd2f4c0000\",\n \"0x1e1aed85b86c6562cb8fa1eb6f8f3bc9dcae6e79\": \"0xf4d2dd84259b240000\",\n \"0x1e1c6351776ac31091397ecf16002d979a1b2d51\": \"0x4be4e7267b6ae00000\",\n \"0x1e1d7a5f2468b94ea826982dbf2125793c6e4a5a\": \"0x3634f48417401a0000\",\n \"0x1e210e7047886daa52aaf70f4b991dac68e3025e\": \"0xad78ebc5ac6200000\",\n \"0x1e2bf4ba8e5ef18d37de6d6ad636c4cae489d0cc\": \"0x6c6b935b8bbd400000\",\n \"0x1e2fe4e4a77d141ff49a0c7fbc95b0a2b283eeeb\": \"0x6c6b935b8bbd400000\",\n \"0x1e33d1c2fb5e084f2f1d54bc5267727fec3f985d\": \"0x1b1ae4d6e2ef500000\",\n \"0x1e381adcf801a3bf9fd7bfac9ccc2b8482ad5e66\": \"0x208972c0010d740000\",\n \"0x1e3badb1b6e1380e27039c576ae6222e963a5b53\": \"0x43c33c1937564800000\",\n \"0x1e484d0621f0f5331b35d5408d9aae4eb1acf21e\": \"0x1158e460913d00000\",\n \"0x1e5800227d4dcf75e30f5595c5bed3f72e341e3b\": \"0xd75dace73417e0000\",\n \"0x1e596a81b357c6f24970cc313df6dbdaabd0d09e\": \"0x6c6b935b8bbd400000\",\n \"0x1e6915ebd9a19c81b692ad99b1218a592c1ac7b1\": \"0xd8d726b7177a800000\",\n \"0x1e6e0153fc161bc05e656bbb144c7187bf4fe84d\": \"0x6c6b935b8bbd400000\",\n \"0x1e706655e284dcf0bb37fe075d613a18dc12ff4a\": \"0xed43bf1eee82ac0000\",\n \"0x1e783e522ab7df0acaac9eeed3593039e5ac7579\": \"0x2b1446dd6aefe41c0000\",\n \"0x1e7b5e4d1f572becf2c00fc90cb4767b4a6e33d4\": \"0x61fc6107593e10000\",\n \"0x1e8e689b02917cdc29245d0c9c68b094b41a9ed6\": \"0x6c6b935b8bbd400000\",\n \"0x1ea334b5750807ea74aac5ab8694ec5f28aa77cf\": \"0x1ab2cf7c9f87e20000\",\n \"0x1ea4715504c6af107b0194f4f7b1cb6fcccd6f4b\": \"0x20043197e0b0270000\",\n \"0x1ea492bce1ad107e337f4bd4a7ac9a7babcccdab\": \"0x56bc75e2d63100000\",\n \"0x1ea6bf2f15ae9c1dbc64daa7f8ea4d0d81aad3eb\": \"0xe3aeb5737240a00000\",\n \"0x1eb4bf73156a82a0a6822080c6edf49c469af8b9\": \"0x678a932062e4180000\",\n \"0x1ebacb7844fdc322f805904fbf1962802db1537c\": \"0x21e19e0c9bab2400000\",\n \"0x1ec4ec4b77bf19d091a868e6f49154180541f90e\": \"0x6c6b935b8bbd400000\",\n \"0x1ed06ee51662a86c634588fb62dc43c8f27e7c17\": \"0xad78ebc5ac6200000\",\n \"0x1ed8bb3f06778b039e9961d81cb71a73e6787c8e\": \"0x6c6b935b8bbd400000\",\n \"0x1eda084e796500ba14c5121c0d90846f66e4be62\": \"0x1cfdd7468216e80000\",\n \"0x1eee6cbee4fe96ad615a9cf5857a647940df8c78\": \"0x10d3aa536e2940000\",\n \"0x1ef2dcbfe0a500411d956eb8c8939c3d6cfe669d\": \"0x2a1129d09367200000\",\n \"0x1ef5c9c73650cfbbde5c885531d427c7c3fe5544\": \"0x14542ba12a337c00000\",\n \"0x1f0412bfedcd964e837d092c71a5fcbaf30126e2\": \"0x1158e460913d00000\",\n \"0x1f174f40a0447234e66653914d75bc003e5690dc\": \"0x8ac7230489e800000\",\n \"0x1f2186ded23e0cf9521694e4e164593e690a9685\": \"0x1043561a8829300000\",\n \"0x1f2afc0aed11bfc71e77a907657b36ea76e3fb99\": \"0xd8d726b7177a800000\",\n \"0x1f3959fc291110e88232c36b7667fc78a379613f\": \"0xfc936392801c0000\",\n \"0x1f3da68fe87eaf43a829ab6d7ec5a6e009b204fb\": \"0x1e1601758c2c7e0000\",\n \"0x1f49b86d0d3945590698a6aaf1673c37755ca80d\": \"0x25f273933db5700000\",\n \"0x1f5f3b34bd134b2781afe5a0424ac5846cdefd11\": \"0x55de6a779bbac0000\",\n \"0x1f6f0030349752061c96072bc3d6eb3549208d6b\": \"0x14b8de1eb88db8000\",\n \"0x1f7d8e86d6eeb02545aad90e91327bd369d7d2f3\": \"0x1158e460913d00000\",\n \"0x1f8116bd0af5570eaf0c56c49c7ab5e37a580458\": \"0x6c6b935b8bbd400000\",\n \"0x1f88f8a1338fc7c10976abcd3fb8d38554b5ec9c\": \"0xb9f65d00f63c0000\",\n \"0x1f9c3268458da301a2be5ab08257f77bb5a98aa4\": \"0xad78ebc5ac6200000\",\n \"0x1fa2319fed8c2d462adf2e17feec6a6f30516e95\": \"0x6cae30621d4720000\",\n \"0x1fb463a0389983df7d593f7bdd6d78497fed8879\": \"0x1158e460913d00000\",\n \"0x1fb7bd310d95f2a6d9baaf8a8a430a9a04453a8b\": \"0xa2a15d09519be00000\",\n \"0x1fcc7ce6a8485895a3199e16481f72e1f762defe\": \"0x3635c9adc5dea00000\",\n \"0x1fcfd1d57f872290560cb62d600e1defbefccc1c\": \"0x50c5e761a444080000\",\n \"0x1fd296be03ad737c92f9c6869e8d80a71c5714aa\": \"0xb98bc829a6f90000\",\n \"0x1fddd85fc98be9c4045961f40f93805ecc4549e5\": \"0x8e3f50b173c100000\",\n \"0x2001bef77b66f51e1599b02fb110194a0099b78d\": \"0x6c6b935b8bbd400000\",\n \"0x200264a09f8c68e3e6629795280f56254f8640d0\": \"0x1158e460913d00000\",\n \"0x2003717907a72560f4307f1beecc5436f43d21e7\": \"0x1b1ae4d6e2ef500000\",\n \"0x200dfc0b71e359b2b465440a36a6cdc352773007\": \"0x5150ae84a8cdf00000\",\n \"0x20134cbff88bfadc466b52eceaa79857891d831e\": \"0x3635c9adc5dea00000\",\n \"0x2014261f01089f53795630ba9dd24f9a34c2d942\": \"0x487a9a304539440000\",\n \"0x2016895df32c8ed5478269468423aea7b7fbce50\": \"0x1158e460913d00000\",\n \"0x20181c4b41f6f972b66958215f19f570c15ddff1\": \"0x56bc75e2d631000000\",\n \"0x201864a8f784c2277b0b7c9ee734f7b377eab648\": \"0xf2281400d1d5ec0000\",\n \"0x2020b81ae53926ace9f7d7415a050c031d585f20\": \"0x127f19e83eb3480000\",\n \"0x203c6283f20df7bc86542fdfb4e763ecdbbbeef5\": \"0x54b40b1f852bda00000\",\n \"0x204ac98867a7c9c7ed711cb82f28a878caf69b48\": \"0x14542ba12a337c00000\",\n \"0x205237c4be146fba99478f3a7dad17b09138da95\": \"0x6c6b935b8bbd400000\",\n \"0x2053ac97548a0c4e8b80bc72590cd6a098fe7516\": \"0xa2325753b460c0000\",\n \"0x205f5166f12440d85762c967d3ae86184f8f4d98\": \"0x177224aa844c720000\",\n \"0x205fc843e19a4913d1881eb69b69c0fa3be5c50b\": \"0x20dd68aaf3289100000\",\n \"0x206482ee6f138a778fe1ad62b180ce856fbb23e6\": \"0x6c6b935b8bbd400000\",\n \"0x2066774d822793ff25f1760909479cf62491bf88\": \"0xbae3ac685cb72e00000\",\n \"0x206d55d5792a514ec108e090599f2a065e501185\": \"0xadf30ba70c8970000\",\n \"0x20707e425d2a11d2c89f391b2b809f556c592421\": \"0x6c6b935b8bbd400000\",\n \"0x207ef80b5d60b6fbffc51f3a64b8c72036a5abbd\": \"0x16a6502f15a1e540000\",\n \"0x20824ba1dbebbef9846ef3d0f6c1b017e6912ec4\": \"0x184b26e4daf1d350000\",\n \"0x2084fce505d97bebf1ad8c5ff6826fc645371fb2\": \"0x1a055690d9db80000\",\n \"0x208c45732c0a378f17ac8324926d459ba8b658b4\": \"0xa030dcebbd2f4c0000\",\n \"0x209377b6ad3fe101c9685b3576545c6b1684e73c\": \"0x62a992e53a0af00000\",\n \"0x209e8e29d33beae8fb6baa783d133e1d9ec1bc0b\": \"0x2d43f3ebfafb2c0000\",\n \"0x20a15256d50ce058bf0eac43aa533aa16ec9b380\": \"0x1158e460913d00000\",\n \"0x20a29c5079e26b3f18318bb2e50e8e8b346e5be8\": \"0x1b1ab319f5ec750000\",\n \"0x20a81680e465f88790f0074f60b4f35f5d1e6aa5\": \"0x456180278f0c778000\",\n \"0x20b9a9e6bd8880d9994ae00dd0b9282a0beab816\": \"0x1b1ae4d6e2ef500000\",\n \"0x20c284ba10a20830fc3d699ec97d2dfa27e1b95e\": \"0x6c6b935b8bbd400000\",\n \"0x20d1417f99c569e3beb095856530fe12d0fceaaa\": \"0x4015f94b1183698000\",\n \"0x20dd8fcbb46ea46fe381a68b8ca0ea5be21fe9a5\": \"0x6c6b935b8bbd400000\",\n \"0x20ff3ede8cadb5c37b48cb14580fb65e23090a7b\": \"0x8e4d316827686400000\",\n \"0x2100381d60a5b54adc09d19683a8f6d5bb4bfbcb\": \"0x21e19e0c9bab2400000\",\n \"0x2118c116ab0cdf6fd11d54a4309307b477c3fc0f\": \"0x21e19e0c9bab2400000\",\n \"0x211b29cefc79ae976744fdebcebd3cbb32c51303\": \"0x2f6f10780d22cc00000\",\n \"0x21206ce22ea480e85940d31314e0d64f4e4d3a04\": \"0x3635c9adc5dea00000\",\n \"0x2132c0516a2e17174ac547c43b7b0020d1eb4c59\": \"0x35659ef93f0fc40000\",\n \"0x21408b4d7a2c0e6eca4143f2cacdbbccba121bd8\": \"0x43c33c1937564800000\",\n \"0x214b743955a512de6e0d886a8cbd0282bee6d2a2\": \"0x6c6b935b8bbd400000\",\n \"0x214c89c5bd8e7d22bc574bb35e48950211c6f776\": \"0x10654f258fd358000\",\n \"0x21546914dfd3af2add41b0ff3e83ffda7414e1e0\": \"0x14395e7385a502e0000\",\n \"0x21582e99e502cbf3d3c23bdffb76e901ac6d56b2\": \"0x56bc75e2d63100000\",\n \"0x2159240813a73095a7ebf7c3b3743e8028ae5f09\": \"0x6c6b935b8bbd400000\",\n \"0x2160b4c02cac0a81de9108de434590a8bfe68735\": \"0x6acb3df27e1f880000\",\n \"0x216e41864ef98f060da08ecae19ad1166a17d036\": \"0x1369fb96128ac480000\",\n \"0x21846f2fdf5a41ed8df36e5ed8544df75988ece3\": \"0x6c6acc67d7b1d40000\",\n \"0x21a6db6527467bc6dad54bc16e9fe2953b6794ed\": \"0x2f6f10780d22cc00000\",\n \"0x21a6feb6ab11c766fdd977f8df4121155f47a1c0\": \"0x319cf38f100580000\",\n \"0x21b182f2da2b384493cf5f35f83d9d1ee14f2a21\": \"0x6c6b935b8bbd400000\",\n \"0x21bfe1b45cacde6274fd8608d9a178bf3eeb6edc\": \"0x6cee06ddbe15ec0000\",\n \"0x21c07380484f6cbc8724ad32bc864c3b5ad500b7\": \"0x3635c9adc5dea00000\",\n \"0x21c3a8bba267c8cca27b1a9afabad86f607af708\": \"0x1e4a36c49d998300000\",\n \"0x21ce6d5b9018cec04ad6967944bea39e8030b6b8\": \"0x1158e460913d00000\",\n \"0x21d02705f3f64905d80ed9147913ea8c7307d695\": \"0x49edb1c09887360000\",\n \"0x21d13f0c4024e967d9470791b50f22de3afecf1b\": \"0xf15ad35e2e31e50000\",\n \"0x21dbdb817a0d8404c6bdd61504374e9c43c9210e\": \"0x21e18b9e9ab45e48000\",\n \"0x21df1ec24b4e4bfe79b0c095cebae198f291fbd1\": \"0x43c33c1937564800000\",\n \"0x21df2dcdaf74b2bf803404dd4de6a35eabec1bbd\": \"0x177224aa844c7200000\",\n \"0x21e219c89ca8ac14ae4cba6130eeb77d9e6d3962\": \"0x2acd9faaa038ee0000\",\n \"0x21e5d2bae995ccfd08a5c16bb524e1f630448f82\": \"0x97c9ce4cf6d5c00000\",\n \"0x21e5d77320304c201c1e53b261a123d0a1063e81\": \"0x4b6fa9d33dd460000\",\n \"0x21eae6feffa9fbf4cd874f4739ace530ccbe5937\": \"0x10f0cf064dd59200000\",\n \"0x21ecb2dfa65779c7592d041cd2105a81f4fd4e46\": \"0x3635c9adc5dea00000\",\n \"0x21efbca09b3580b98e73f5b2f7f4dc0bf02c529c\": \"0x6c6b935b8bbd400000\",\n \"0x21fd0bade5f4ef7474d058b7f3d854cb1300524e\": \"0x1158e460913d00000\",\n \"0x21fd47c5256012198fa5abf131c06d6aa1965f75\": \"0x1ab2cf7c9f87e200000\",\n \"0x21fd6c5d97f9c600b76821ddd4e776350fce2be0\": \"0x6c6ad382d4fb610000\",\n \"0x220dc68df019b6b0ccbffb784b5a5ab4b15d4060\": \"0xd5967be4fc3f100000\",\n \"0x220e2b92c0f6c902b513d9f1e6fab6a8b0def3d7\": \"0x2b5e3af16b18800000\",\n \"0x22561c5931143536309c17e832587b625c390b9a\": \"0xd8d726b7177a800000\",\n \"0x2257fca16a6e5c2a647c3c29f36ce229ab93b17e\": \"0xd8d726b7177a800000\",\n \"0x225d35faedb391c7bc2db7fa9071160405996d00\": \"0x91854fc1862630000\",\n \"0x225f9eb3fb6ff3e9e3c8447e14a66e8d4f3779f6\": \"0x6c6b935b8bbd400000\",\n \"0x2272186ef27dcbe2f5fc373050fdae7f2ace2316\": \"0x368c8623a8b4d100000\",\n \"0x2273bad7bc4e487622d175ef7a66988b6a93c4ee\": \"0x1158e460913d00000\",\n \"0x2276264bec8526c0c0f270677abaf4f0e441e167\": \"0x3635c9adc5dea00000\",\n \"0x228242f8336eecd8242e1f000f41937e71dffbbf\": \"0x10f0cf064dd59200000\",\n \"0x22842ab830da509913f81dd1f04f10af9edd1c55\": \"0x6c6b935b8bbd400000\",\n \"0x22944fbca9b57963084eb84df7c85fb9bcdfb856\": \"0xfc118fef90ba388000\",\n \"0x229cc4711b62755ea296445ac3b77fc633821cf2\": \"0x223e8b05219328000\",\n \"0x229e430de2b74f442651ddcdb70176bc054cad54\": \"0xbbf981bc4aaa8000\",\n \"0x229f4f1a2a4f540774505b4707a81de44410255b\": \"0x6c6b935b8bbd400000\",\n \"0x229ff80bf5708009a9f739e0f8b560914016d5a6\": \"0x1211ecb56d13488000\",\n \"0x22a25812ab56dcc423175ed1d8adacce33cd1810\": \"0x6449e84e47a8a80000\",\n \"0x22b96ab2cad55db100b53001f9e4db378104c807\": \"0x21e19e0c9bab2400000\",\n \"0x22bdffc240a88ff7431af3bff50e14da37d5183e\": \"0x3635c9adc5dea00000\",\n \"0x22ce349159eeb144ef06ff2636588aef79f62832\": \"0xa31062beeed700000\",\n \"0x22db559f2c3c1475a2e6ffe83a5979599196a7fa\": \"0x3635c9adc5dea00000\",\n \"0x22e15158b5ee3e86eb0332e3e6a9ac6cd9b55ecd\": \"0x8ac7230489e800000\",\n \"0x22e2488e2da26a49ae84c01bd54b21f2947891c6\": \"0x5dc892aa1131c80000\",\n \"0x22e512149a18d369b73c71efa43e86c9edabaf1d\": \"0x4ee02e6714615c0000\",\n \"0x22eb7db0ba56b0f8b816ccb206e615d929185b0d\": \"0x45d29737e22f20000\",\n \"0x22eed327f8eb1d1338a3cb7b0f8a4baa5907cd95\": \"0x1455d5f4877088000\",\n \"0x22f004df8de9e6ebf523ccace457accb26f97281\": \"0x21e19e0c9bab2400000\",\n \"0x22f2dcff5ad78c3eb6850b5cb951127b659522e6\": \"0xbe202d6a0eda0000\",\n \"0x22f3c779dd79023ea92a78b65c1a1780f62d5c4a\": \"0x6acb3df27e1f880000\",\n \"0x22fe884d9037291b4d52e6285ae68dea0be9ffb5\": \"0x6c6b935b8bbd400000\",\n \"0x2306df931a940d58c01665fa4d0800802c02edfe\": \"0x3635c9adc5dea00000\",\n \"0x2309d34091445b3232590bd70f4f10025b2c9509\": \"0x21e19e0c9bab2400000\",\n \"0x23120046f6832102a752a76656691c863e17e59c\": \"0x11e0e4f8a50bd40000\",\n \"0x231a15acc199c89fa9cb22441cc70330bdcce617\": \"0x1b1ae4d6e2ef500000\",\n \"0x231d94155dbcfe2a93a319b6171f63b20bd2b6fa\": \"0xcf147bb906e2f80000\",\n \"0x232832cd5977e00a4c30d0163f2e24f088a6cb09\": \"0xa2a15d09519be00000\",\n \"0x232c6d03b5b6e6711efff190e49c28eef36c82b0\": \"0x487a9a304539440000\",\n \"0x232cb1cd49993c144a3f88b3611e233569a86bd6\": \"0x34c606c42d0ac600000\",\n \"0x232ce782506225fd9860a2edc14a7a3047736da2\": \"0x1158e460913d00000\",\n \"0x232f525d55859b7d4e608d20487faadb00293135\": \"0xd8d726b7177a800000\",\n \"0x2334c590c7a48769103045c5b6534c8a3469f44a\": \"0x3b199073df72dc00000\",\n \"0x23376ecabf746ce53321cf42c86649b92b67b2ff\": \"0x6c6b935b8bbd400000\",\n \"0x23378f42926d0184b793b0c827a6dd3e3d334fcd\": \"0x30927f74c9de00000\",\n \"0x233842b1d0692fd11140cf5acda4bf9630bae5f8\": \"0x6c6b935b8bbd400000\",\n \"0x2339e9492870afea2537f389ac2f838302a33c06\": \"0x6c6b935b8bbd400000\",\n \"0x233bdddd5da94852f4ade8d212885682d9076bc6\": \"0xd8d726b7177a800000\",\n \"0x234f46bab73fe45d31bf87f0a1e0466199f2ebac\": \"0x1a4aba225c20740000\",\n \"0x23551f56975fe92b31fa469c49ea66ee6662f41e\": \"0x678a932062e4180000\",\n \"0x23569542c97d566018c907acfcf391d14067e87e\": \"0x6c6b935b8bbd400000\",\n \"0x235fa66c025ef5540070ebcf0d372d8177c467ab\": \"0x7129e1cdf373ee00000\",\n \"0x2372c4c1c9939f7aaf6cfac04090f00474840a09\": \"0x21e19e0c9bab2400000\",\n \"0x23730c357a91026e44b1d0e2fc2a51d071d8d77b\": \"0xd8d726b7177a800000\",\n \"0x2376ada90333b1d181084c97e645e810aa5b76f1\": \"0x28a857425466f80000\",\n \"0x2378fd4382511e968ed192106737d324f454b535\": \"0x3635c9adc5dea00000\",\n \"0x2382a9d48ec83ea3652890fd0ee79c907b5b2dc1\": \"0x73f75d1a085ba0000\",\n \"0x2383c222e67e969190d3219ef14da37850e26c55\": \"0x6c6b935b8bbd400000\",\n \"0x238a6b7635252f5244486c0af0a73a207385e039\": \"0x4a4491bd6dcd280000\",\n \"0x239a733e6b855ac592d663156186a8a174d2449e\": \"0x58be3758b241f60000\",\n \"0x23ab09e73f87aa0f3be0139df0c8eb6be5634f95\": \"0x1b1ae4d6e2ef5000000\",\n \"0x23abd9e93e7957e5b636be6579051c15e5ce0b0e\": \"0x3a3c8f7cbf42c380000\",\n \"0x23b1c4917fbd93ee3d48389306957384a5496cbf\": \"0xd8d8583fa2d52f0000\",\n \"0x23ba3864da583dab56f420873c37679690e02f00\": \"0x21342520d5fec200000\",\n \"0x23c55aeb5739876f0ac8d7ebea13be729685f000\": \"0x487a9a304539440000\",\n \"0x23c99ba087448e19c9701df66e0cab52368331fa\": \"0x6c6b935b8bbd400000\",\n \"0x23ccc3c6acd85c2e460c4ffdd82bc75dc849ea14\": \"0xd8d726b7177a800000\",\n \"0x23cd2598a20e149ead2ad69379576ecedb60e38e\": \"0x6c6b935b8bbd400000\",\n \"0x23df8f48ee009256ea797e1fa369beebcf6bc663\": \"0x7cd3fac26d19818000\",\n \"0x23e2c6a8be8e0acfa5c4df5e36058bb7cbac5a81\": \"0x6c6b935b8bbd400000\",\n \"0x23ea669e3564819a83b0c26c00a16d9e826f6c46\": \"0x4d8d6ca968ca130000\",\n \"0x23eb6fd85671a9063ab7678ebe265a20f61a02b3\": \"0x6c6b935b8bbd400000\",\n \"0x23f9ecf3e5dddca38815d3e59ed34b5b90b4a353\": \"0xb1781a3f0bb200000\",\n \"0x23fa7eb51a48229598f97e762be0869652dffc66\": \"0x3635c9adc5dea00000\",\n \"0x240305727313d01e73542c775ff59d11cd35f819\": \"0x141885666807f5c8000\",\n \"0x24046b91da9b61b629cb8b8ec0c351a07e0703e4\": \"0x6c6b935b8bbd400000\",\n \"0x240e559e274aaef0c258998c979f671d1173b88b\": \"0xd8d726b7177a800000\",\n \"0x241361559feef80ef137302153bd9ed2f25db3ef\": \"0x43c33c1937564800000\",\n \"0x243b3bca6a299359e886ce33a30341fafe4d573d\": \"0x43c33c1937564800000\",\n \"0x243c84d12420570cc4ef3baba1c959c283249520\": \"0x7f1f6993a853040000\",\n \"0x24434a3e32e54ecf272fe3470b5f6f512f675520\": \"0x14061b9d77a5e980000\",\n \"0x2448596f91c09baa30bc96106a2d37b5705e5d28\": \"0x6c6b935b8bbd400000\",\n \"0x24586ec5451735eeaaeb470dc8736aae752f82e5\": \"0xf43fc2c04ee00000\",\n \"0x2458d6555ff98a129cce4037953d00206eff4287\": \"0xaadec983fcff40000\",\n \"0x246291165b59332df5f18ce5c98856fae95897d6\": \"0x5c283d410394100000\",\n \"0x2467c6a5c696ede9a1e542bf1ad06bcc4b06aca0\": \"0x100bd33fb98ba0000\",\n \"0x2476b2bb751ce748e1a4c4ff7b230be0c15d2245\": \"0xd8d726b7177a800000\",\n \"0x247a0a11c57f0383b949de540b66dee68604b0a1\": \"0x39fbae8d042dd00000\",\n \"0x2487c3c4be86a2723d917c06b458550170c3edba\": \"0x3635c9adc5dea00000\",\n \"0x2489ac126934d4d6a94df08743da7b7691e9798e\": \"0x3635c9adc5dea00000\",\n \"0x249db29dbc19d1235da7298a04081c315742e9ac\": \"0x61acff81a78ad40000\",\n \"0x24a4eb36a7e498c36f99975c1a8d729fd6b305d7\": \"0xdfc78210eb2c80000\",\n \"0x24a750eae5874711116dd7d47b7186ce990d3103\": \"0xad78ebc5ac6200000\",\n \"0x24aa1151bb765fa3a89ca50eb6e1b1c706417fd4\": \"0xa80d24677efef00000\",\n \"0x24aca08d5be85ebb9f3132dfc1b620824edfedf9\": \"0xfc936392801c0000\",\n \"0x24b2be118b16d8b2174769d17b4cf84f07ca946d\": \"0x6c6b935b8bbd400000\",\n \"0x24b8b446debd1947955dd084f2c544933346d3ad\": \"0xea696d904039bd8000\",\n \"0x24b95ebef79500baa0eda72e77f877415df75c33\": \"0x3154c9729d05780000\",\n \"0x24b9e6644f6ba4cde126270d81f6ab60f286dff4\": \"0x73f75d1a085ba0000\",\n \"0x24bd5904059091d2f9e12d6a26a010ca22ab14e8\": \"0x65ea3db75546600000\",\n \"0x24c0c88b54a3544709828ab4ab06840559f6c5e2\": \"0x90f534608a72880000\",\n \"0x24c117d1d2b3a97ab11a4679c99a774a9eade8d1\": \"0x3635c9adc5dea00000\",\n \"0x24cff0e9336a9f80f9b1cb968caf6b1d1c4932a4\": \"0xada55474b81340000\",\n \"0x24daaaddf7b06bbcea9b80590085a88567682b4e\": \"0x114b2015d2bbd00000\",\n \"0x24dcc24bd9c7210ceacfb30da98ae04a4d7b8ab9\": \"0x3635c9adc5dea00000\",\n \"0x24f7450ddbf18b020feb1a2032d9d54b633edf37\": \"0x2b5e3af16b1880000\",\n \"0x24fc73d20793098e09ddab5798506224fa1e1850\": \"0xad78ebc5ac6200000\",\n \"0x24fd9a6c874c2fab3ff36e9afbf8ce0d32c7de92\": \"0x487a9a304539440000\",\n \"0x250a40cef3202397f240469548beb5626af4f23c\": \"0x503b203e9fba20000\",\n \"0x250a69430776f6347703f9529783955a6197b682\": \"0x692ae8897081d00000\",\n \"0x250eb7c66f869ddf49da85f3393e980c029aa434\": \"0xd8d726b7177a800000\",\n \"0x25106ab6755df86d6b63a187703b0cfea0e594a0\": \"0x17c405ad41db40000\",\n \"0x25185f325acf2d64500698f65c769ddf68301602\": \"0x10f0cf064dd59200000\",\n \"0x251c12722c6879227992a304eb3576cd18434ea5\": \"0x6c6b935b8bbd400000\",\n \"0x251e6838f7cec5b383c1d90146341274daf8e502\": \"0x7ff1ccb7561df0000\",\n \"0x25259d975a21d83ae30e33f800f53f37dfa01938\": \"0x1158e460913d00000\",\n \"0x25287b815f5c82380a73b0b13fbaf982be24c4d3\": \"0x22b1c8c1227a00000\",\n \"0x252b6555afdc80f2d96d972d17db84ea5ad521ac\": \"0x1ab2cf7c9f87e200000\",\n \"0x2538532936813c91e653284f017c80c3b8f8a36f\": \"0x6c8754c8f30c080000\",\n \"0x253e32b74ea4490ab92606fda0aa257bf23dcb8b\": \"0x21e19e0c9bab2400000\",\n \"0x253f1e742a2cec86b0d7b306e5eacb6ccb2f8554\": \"0x43e5ede1f878c200000\",\n \"0x2541314a0b408e95a694444977712a50713591ab\": \"0x589e1a5df4d7b50000\",\n \"0x254c1ecc630c2877de8095f0a8dba1e8bf1f550c\": \"0x5c283d410394100000\",\n \"0x255abc8d08a096a88f3d6ab55fbc7352bddcb9ce\": \"0x4743682313ede8000\",\n \"0x255bdd6474cc8262f26a22c38f45940e1ceea69b\": \"0xd8d726b7177a800000\",\n \"0x2560b09b89a4ae6849ed5a3c9958426631714466\": \"0x5c283d410394100000\",\n \"0x2561a138dcf83bd813e0e7f108642be3de3d6f05\": \"0x3634f48417401a0000\",\n \"0x2561ec0f379218fe5ed4e028a3f744aa41754c72\": \"0xb98bc829a6f90000\",\n \"0x256292a191bdda34c4da6b6bd69147bf75e2a9ab\": \"0xc2ff2e0dfb038000\",\n \"0x25697ef20cccaa70d32d376f8272d9c1070c3d78\": \"0xad78ebc5ac6200000\",\n \"0x256fa150cc87b5056a07d004efc84524739e62b5\": \"0xad78ebc5ac6200000\",\n \"0x25721c87b0dc21377c7200e524b14a22f0af69fb\": \"0xd8d726b7177a800000\",\n \"0x258939bbf00c9de9af5338f5d714abf6d0c1c671\": \"0x54069233bf7f780000\",\n \"0x2590126870e0bde8a663ab040a72a5573d8d41c2\": \"0x10f0cf064dd59200000\",\n \"0x259ec4d265f3ab536b7c70fa97aca142692c13fc\": \"0x11b1b5bea89f80000\",\n \"0x25a500eeec7a662a841552b5168b707b0de21e9e\": \"0x21f2f6f0fc3c6100000\",\n \"0x25a5a44d38a2f44c6a9db9cdbc6b1e2e97abb509\": \"0x39992648a23c8a00000\",\n \"0x25a74c2ac75dc8baa8b31a9c7cb4b7829b2456da\": \"0x6c6b935b8bbd400000\",\n \"0x25adb8f96f39492c9bb47c5edc88624e46075697\": \"0x5a9940bc56879500000\",\n \"0x25aee68d09afb71d8817f3f184ec562f7897b734\": \"0x6c6b935b8bbd400000\",\n \"0x25b0533b81d02a617b9229c7ec5d6f2f672e5b5a\": \"0x3635c9adc5dea00000\",\n \"0x25b78c9fad85b43343f0bfcd0fac11c9949ca5eb\": \"0x6c6b935b8bbd400000\",\n \"0x25bc49ef288cd165e525c661a812cf84fbec8f33\": \"0x125921aebda9d00000\",\n \"0x25bdfa3ee26f3849617b230062588a97e3cae701\": \"0x3635e619bb04d40000\",\n \"0x25c1a37ee5f08265a1e10d3d90d5472955f97806\": \"0x62a992e53a0af00000\",\n \"0x25c6e74ff1d928df98137af4df8430df24f07cd7\": \"0x15245655b102580000\",\n \"0x25cfc4e25c35c13b69f7e77dbfb08baf58756b8d\": \"0x878678326eac9000000\",\n \"0x25dad495a11a86b9eeece1eeec805e57f157faff\": \"0x3635c9adc5dea000000\",\n \"0x25e037f00a18270ba5ec3420229ddb0a2ce38fa2\": \"0x21e19e0c9bab2400000\",\n \"0x25e661c939863acc044e6f17b5698cce379ec3cc\": \"0x4a4491bd6dcd280000\",\n \"0x26048fe84d9b010a62e731627e49bc2eb73f408f\": \"0xd8d726b7177a800000\",\n \"0x2606c3b3b4ca1b091498602cb1978bf3b95221c0\": \"0x15af1d78b58c400000\",\n \"0x260a230e4465077e0b14ee4442a482d5b0c914bf\": \"0x5af606a06b5b118000\",\n \"0x260df8943a8c9a5dba7945327fd7e0837c11ad07\": \"0xad78ebc5ac6200000\",\n \"0x2614f42d5da844377578e6b448dc24305bef2b03\": \"0x6c6b935b8bbd400000\",\n \"0x2615100ea7e25bba9bca746058afbbb4ffbe4244\": \"0x1b1ae4d6e2ef500000\",\n \"0x261575e9cf59c8226fa7aaf91de86fb70f5ac3ae\": \"0x1043a4436a523f0000\",\n \"0x261e0fa64c51137465eecf5b90f197f7937fdb05\": \"0x3cfc82e37e9a7400000\",\n \"0x262a8bfd7d9dc5dd3ad78161b6bb560824373655\": \"0x3f6a8384072b760000\",\n \"0x262aed4bc0f4a4b2c6fb35793e835a49189cdfec\": \"0x21e19e0c9bab2400000\",\n \"0x262dc1364ccf6df85c43268ee182554dae692e29\": \"0x10b202fec74ced80000\",\n \"0x263814309de4e635cf585e0d365477fc40e66cf7\": \"0x7ea28327577080000\",\n \"0x2639eee9873ceec26fcc9454b548b9e7c54aa65c\": \"0x3635c9adc5dea00000\",\n \"0x263e57dacbe0149f82fe65a2664898866ff5b463\": \"0x80bfbefcb5f0bc00000\",\n \"0x26475419c06d5f147aa597248eb46cf7befa64a5\": \"0x58e7926ee858a00000\",\n \"0x264cc8086a8710f91b21720905912cd7964ae868\": \"0x1731790534df20000\",\n \"0x265383d68b52d034161bfab01ae1b047942fbc32\": \"0x47271dee20d745c0000\",\n \"0x2659facb1e83436553b5b42989adb8075f9953ed\": \"0x1976576771a5e0000\",\n \"0x266f2da7f0085ef3f3fa09baee232b93c744db2e\": \"0xcb49b44ba602d800000\",\n \"0x267148fd72c54f620a592fb92799319cc4532b5c\": \"0x1639e49bba16280000\",\n \"0x26784ade91c8a83a8e39658c8d8277413ccc9954\": \"0x14542ba12a337c00000\",\n \"0x267a7e6e82e1b91d51deddb644f0e96dbb1f7f7e\": \"0x1158e460913d00000\",\n \"0x2680713d40808e2a50ed013150a2a694b96a7f1d\": \"0x61093d7c2c6d380000\",\n \"0x2697b339813b0c2d964b2471eb1c606f4ecb9616\": \"0x3e8ef795d890c80000\",\n \"0x26a68eab905a8b3dce00e317308225dab1b9f6b8\": \"0x6b56051582a9700000\",\n \"0x26b11d066588ce74a572a85a6328739212aa8b40\": \"0x6c6b935b8bbd400000\",\n \"0x26babf42b267fdcf3861fdd4236a5e474848b358\": \"0x3635c9adc5dea00000\",\n \"0x26c0054b700d3a7c2dcbe275689d4f4cad16a335\": \"0x6c6b935b8bbd400000\",\n \"0x26c2ffc30efdc5273e76183a16c2698d6e531286\": \"0x2a1129d09367200000\",\n \"0x26c99f8849c9802b83c861217fd07a9e84cdb79d\": \"0x1043561a8829300000\",\n \"0x26cfffd052152bb3f957b478d5f98b233a7c2b92\": \"0xd8d726b7177a800000\",\n \"0x26d4a16891f52922789217fcd886f7fce296d400\": \"0x6c6b935b8bbd400000\",\n \"0x26d4ec17d5ceb2c894bdc59d0a6a695dad2b43cc\": \"0x9f1f78761d341a0000\",\n \"0x26e801b62c827191dd68d31a011990947fd0ebe0\": \"0x1158e460913d00000\",\n \"0x26e9e2ad729702626417ef25de0dc800f7a779b3\": \"0x3635c9adc5dea00000\",\n \"0x26f9f7cefd7e394b9d3924412bf2c2831faf1f85\": \"0xd8d726b7177a800000\",\n \"0x26fe174cbf526650e0cd009bd6126502ce8e684d\": \"0x277017338a30ae00000\",\n \"0x26ff0a51e7cece8400276978dbd6236ef162c0e6\": \"0x152e185627540a500000\",\n \"0x27101a0f56d39a88c5a84f9b324cdde33e5cb68c\": \"0x6c6b935b8bbd400000\",\n \"0x27144ca9a7771a836ad50f803f64d869b2ae2b20\": \"0xd8d726b7177a800000\",\n \"0x27146913563aa745e2588430d9348e86ea7c3510\": \"0x15af1d78b58c400000\",\n \"0x271d3d481cb88e7671ad216949b6365e06303de0\": \"0xd8d726b7177a800000\",\n \"0x2720f9ca426ef2f2cbd2fecd39920c4f1a89e16d\": \"0x6c6b935b8bbd400000\",\n \"0x272a131a5a656a7a3aca35c8bd202222a7592258\": \"0x90f534608a72880000\",\n \"0x2744ff67464121e35afc2922177164fa2fcb0267\": \"0x56bc75e2d63100000\",\n \"0x274a3d771a3d709796fbc4d5f48fce2fe38c79d6\": \"0x1158e460913d00000\",\n \"0x274d69170fe7141401882b886ac4618c6ae40edb\": \"0x33c5499031720c0000\",\n \"0x27521deb3b6ef1416ea4c781a2e5d7b36ee81c61\": \"0x6c6b935b8bbd400000\",\n \"0x275875ff4fbb0cf3a430213127487f7608d04cba\": \"0x1b1c010e766d580000\",\n \"0x276a006e3028ecd44cdb62ba0a77ce94ebd9f10f\": \"0x6194049f30f7200000\",\n \"0x276b0521b0e68b277df0bb32f3fd48326350bfb2\": \"0x2b5e3af16b1880000\",\n \"0x276fd7d24f8f883f5a7a28295bf17151c7a84b03\": \"0x6c6b935b8bbd400000\",\n \"0x2770f14efb165ddeba79c10bb0af31c31e59334c\": \"0xa2a15d09519be00000\",\n \"0x277677aba1e52c3b53bfa2071d4e859a0af7e8e1\": \"0x3635c9adc5dea00000\",\n \"0x27824666d278d70423f03dfe1dc7a3f02f43e2b5\": \"0x3636c25e66ece70000\",\n \"0x27830c5f6023afaaf79745676c204a0faccda0ba\": \"0xd02ab486cedc00000\",\n \"0x2784903f1d7c1b5cd901f8875d14a79b3cbe2a56\": \"0x4bda7e9d74ad5500000\",\n \"0x278c0bde630ec393b1e7267fc9d7d97019e4145b\": \"0x6c6b935b8bbd400000\",\n \"0x27987110221a880826adb2e7ab5eca78c6e31aec\": \"0xd8d726b7177a800000\",\n \"0x27ac073be79ce657a93aa693ee43bf0fa41fef04\": \"0xa968163f0a57b400000\",\n \"0x27b1694eafa165ebd7cc7bc99e74814a951419dc\": \"0x2b5e3af16b18800000\",\n \"0x27b62816e1e3b8d19b79d1513d5dfa855b0c3a2a\": \"0x56af5c1fd69508000\",\n \"0x27bf943c1633fe32f8bcccdb6302b407a5724e44\": \"0x32f84c6df408c08000\",\n \"0x27bf9f44ba7d05c33540c3a53bb02cbbffe7c3c6\": \"0x6c6b935b8bbd400000\",\n \"0x27c2d7ca504daa3d9066dc09137dc42f3aaab452\": \"0x2086ac351052600000\",\n \"0x27d158ac3d3e1109ab6e570e90e85d3892cd7680\": \"0x56bc75e2d63100000\",\n \"0x27e63989ca1e903bc620cf1b9c3f67b9e2ae6581\": \"0x487a9a304539440000\",\n \"0x27f03cf1abc5e1b51dbc444b289e542c9ddfb0e6\": \"0x10f0cf064dd59200000\",\n \"0x27fc85a49cff90dbcfdadc9ddd40d6b9a2210a6c\": \"0x56bc75e2d63100000\",\n \"0x2805415e1d7fdec6dedfb89e521d10592d743c10\": \"0x56bc75e2d63100000\",\n \"0x28073efc17d05cab3195c2db332b61984777a612\": \"0x3635c9adc5dea00000\",\n \"0x281250a29121270a4ee5d78d24feafe82c70ba3a\": \"0x3635c9adc5dea00000\",\n \"0x2813d263fc5ff2479e970595d6b6b560f8d6d6d1\": \"0x6c6b935b8bbd400000\",\n \"0x282e80a554875a56799fa0a97f5510e795974c4e\": \"0x3635c9adc5dea00000\",\n \"0x283396ce3cac398bcbe7227f323e78ff96d08767\": \"0x15af1d78b58c400000\",\n \"0x28349f7ef974ea55fe36a1583b34cec3c45065f0\": \"0xcb633d49e65590000\",\n \"0x2836123046b284e5ef102bfd22b1765e508116ad\": \"0x1653fbb5c427e40000\",\n \"0x283c2314283c92d4b064f0aef9bb5246a7007f39\": \"0xad78ebc5ac6200000\",\n \"0x283e11203749b1fa4f32febb71e49d135919382a\": \"0x3635c9adc5dea00000\",\n \"0x283e6252b4efcf4654391acb75f903c59b78c5fb\": \"0x28a857425466f800000\",\n \"0x28510e6eff1fc829b6576f4328bc3938ec7a6580\": \"0x21e19e0c9bab2400000\",\n \"0x2858acacaf21ea81cab7598fdbd86b452e9e8e15\": \"0x241a9b4f617a280000\",\n \"0x285ae51b9500c58d541365d97569f14bb2a3709b\": \"0x6c6b935b8bbd400000\",\n \"0x2866b81decb02ee70ae250cee5cdc77b59d7b679\": \"0x6c6b935b8bbd400000\",\n \"0x286906b6bd4972e3c71655e04baf36260c7cb153\": \"0x126e72a69a50d00000\",\n \"0x286b186d61ea1fd78d9930fe12b06537b05c3d51\": \"0x3635c9adc5dea00000\",\n \"0x2874f3e2985d5f7b406627e17baa772b01abcc9e\": \"0x146050410765f380000\",\n \"0x287cf9d0902ef819a7a5f149445bf1775ee8c47c\": \"0x3635c9adc5dea000000\",\n \"0x28818e18b610001321b31df6fe7d2815cdadc9f5\": \"0x3635c9adc5dea00000\",\n \"0x28868324337e11ba106cb481da962f3a8453808d\": \"0x6c6b935b8bbd400000\",\n \"0x28904bb7c4302943b709b14d7970e42b8324e1a1\": \"0x21f97846a072d7e0000\",\n \"0x2895e80999d406ad592e2b262737d35f7db4b699\": \"0x692ae8897081d00000\",\n \"0x28967280214e218a120c5dda37041b111ea36d74\": \"0xad78ebc5ac6200000\",\n \"0x28a3da09a8194819ae199f2e6d9d1304817e28a5\": \"0x6c6b935b8bbd400000\",\n \"0x28ab165ffb69eda0c549ae38e9826f5f7f92f853\": \"0x464df6d7c844590000\",\n \"0x28b77585cb3d55a199ab291d3a18c68fe89a848a\": \"0x6a4076cf7995a00000\",\n \"0x28d4ebf41e3d3c451e943bdd7e1f175fae932a3d\": \"0x14542ba12a337c00000\",\n \"0x28d7e5866f1d85fd1ceb32bfbe1dfc36db434566\": \"0x1864231c610351c0000\",\n \"0x28d8c35fb7eea622582135e3ad47a227c9a663bd\": \"0xfc936392801c0000\",\n \"0x28e4af30cd93f686a122ad7bb19f8a8785eee342\": \"0x71e53b706cc7b40000\",\n \"0x28eaea78cd4d95faecfb68836eafe83520f3bbb7\": \"0xad78ebc5ac6200000\",\n \"0x28efae6356509edface89fc61a7fdcdb39eea8e5\": \"0x121ea68c114e5100000\",\n \"0x28fa2580f9ebe420f3e5eefdd371638e3b7af499\": \"0x14542ba12a337c00000\",\n \"0x2901f8077f34190bb47a8e227fa29b30ce113b31\": \"0x56bc75e2d63100000\",\n \"0x2905b192e83ce659aa355b9d0c204e3e95f9bb9a\": \"0x75235c1d00393e8000\",\n \"0x290a56d41f6e9efbdcea0342e0b7929a8cdfcb05\": \"0x12a5f58168ee600000\",\n \"0x2915624bcb679137b8dae9ab57d11b4905eaee4b\": \"0x1158e460913d00000\",\n \"0x291efe0081dce8c14799f7b2a43619c0c3b3fc1f\": \"0x410d586a20a4c00000\",\n \"0x291f929ca59b54f8443e3d4d75d95dee243cef78\": \"0x1b1a089237073d0000\",\n \"0x29298ccbdff689f87fe41aa6e98fdfb53deaf37a\": \"0x4315c32d71a9e600000\",\n \"0x292f228b0a94748c8eec612d246f989363e08f08\": \"0xa076407d3f7440000\",\n \"0x293384c42b6f8f2905ce52b7205c2274376c612b\": \"0x4be4e7267b6ae00000\",\n \"0x2934c0df7bbc172b6c186b0b72547ace8bf75454\": \"0x340aad21b3b700000\",\n \"0x293c2306df3604ae4fda0d207aba736f67de0792\": \"0xad78ebc5ac6200000\",\n \"0x2949fd1def5c76a286b3872424809a07db3966f3\": \"0x11bd906daa0c9438000\",\n \"0x294f494b3f2e143c2ffc9738cbfd9501850b874e\": \"0x796e3ea3f8ab000000\",\n \"0x2955c357fd8f75d5159a3dfa69c5b87a359dea8c\": \"0x6c6b935b8bbd400000\",\n \"0x2961fb391c61957cb5c9e407dda29338d3b92c80\": \"0x3634fb9f1489a70000\",\n \"0x29681d9912ddd07eaabb88d05d90f766e862417d\": \"0x3635c9adc5dea00000\",\n \"0x296b71c0015819c242a7861e6ff7eded8a5f71e3\": \"0x6c68ccd09b022c0000\",\n \"0x296d66b521571a4e4103a7f562c511e6aa732d81\": \"0x243d4d18229ca20000\",\n \"0x296f00de1dc3bb01d47a8ccd1e5d1dd9a1eb7791\": \"0x3635c9adc5dea00000\",\n \"0x297385e88634465685c231a314a0d5dcd146af01\": \"0x54069233bf7f780000\",\n \"0x29763dd6da9a7c161173888321eba6b63c8fb845\": \"0x11c7ea162e78200000\",\n \"0x2979741174a8c1ea0b7f9edf658177859417f512\": \"0x1901966c8496838000\",\n \"0x297a88921b5fca10e5bb9ded60025437ae221694\": \"0xad78ebc5ac6200000\",\n \"0x297d5dbe222f2fb52531acbd0b013dc446ac7368\": \"0x43c33c1937564800000\",\n \"0x29824e94cc4348bc963279dcdf47391715324cd3\": \"0x692ae8897081d00000\",\n \"0x2982d76a15f847dd41f1922af368fe678d0e681e\": \"0x56bc75e2d63100000\",\n \"0x298887bab57c5ba4f0615229d7525fa113b7ea89\": \"0x22b1c8c1227a00000\",\n \"0x298ec76b440d8807b3f78b5f90979bee42ed43db\": \"0x65a4da25d3016c00000\",\n \"0x299368609042a858d1ecdf1fc0ada5eaceca29cf\": \"0x6c6b935b8bbd400000\",\n \"0x299e0bca55e069de8504e89aca6eca21d38a9a5d\": \"0x302379bf2ca2e0000\",\n \"0x29ac2b458454a36c7e96c73a8667222a12242c71\": \"0xd8d726b7177a800000\",\n \"0x29adcf83b6b20ac6a434abb1993cbd05c60ea2e4\": \"0x21e19e0c9bab2400000\",\n \"0x29aef48de8c9fbad4b9e4ca970797a5533eb722d\": \"0x21e19e0c9bab2400000\",\n \"0x29b3f561ee7a6e25941e98a5325b78adc79785f3\": \"0x56bc75e2d63100000\",\n \"0x29bdc4f28de0180f433c2694eb74f5504ce94337\": \"0x6c6b935b8bbd400000\",\n \"0x29cc804d922be91f5909f348b0aaa5d21b607830\": \"0xd8d726b7177a800000\",\n \"0x29da3e35b23bb1f72f8e2258cf7f553359d24bac\": \"0x43c33c1937564800000\",\n \"0x29e67990e1b6d52e1055ffe049c53195a81542cf\": \"0x43c33c1937564800000\",\n \"0x29eaae82761762f4d2db53a9c68b0f6b0b6d4e66\": \"0x6c6b935b8bbd400000\",\n \"0x29eb7eefdae9feb449c63ff5f279d67510eb1422\": \"0x10d3aa536e2940000\",\n \"0x29f0edc60338e7112085a1d114da8c42ce8f55d6\": \"0xa05a7f0fd825780000\",\n \"0x29f8fba4c30772b057edbbe62ae7420c390572e1\": \"0x3635c9adc5dea00000\",\n \"0x29f9286c0e738d1721a691c6b95ab3d9a797ede8\": \"0x2a5a058fc295ed000000\",\n \"0x2a085e25b64862f5e68d768e2b0f7a8529858eee\": \"0x6b883acd5766cd0000\",\n \"0x2a2ab6b74c7af1d9476bb5bcb4524797bedc3552\": \"0x3635c9adc5dea00000\",\n \"0x2a39190a4fde83dfb3ddcb4c5fbb83ac6c49755c\": \"0x3635c9adc5dea00000\",\n \"0x2a400dff8594de7228b4fd15c32322b75bb87da8\": \"0x531a17f607a2d0000\",\n \"0x2a44a7218fe44d65a1b4b7a7d9b1c2c52c8c3e34\": \"0xd2d06c305a1eb578000\",\n \"0x2a46d353777176ff8e83ffa8001f4f70f9733aa5\": \"0x5bf0ba6634f680000\",\n \"0x2a595f16eee4cb0c17d9a2d939b3c10f6c677243\": \"0x3ba1910bf341b00000\",\n \"0x2a59e47ea5d8f0e7c028a3e8e093a49c1b50b9a3\": \"0x6c6b935b8bbd400000\",\n \"0x2a5ba9e34cd58da54c9a2712663a3be274c8e47b\": \"0xaadec983fcff40000\",\n \"0x2a5e3a40d2cd0325766de73a3d671896b362c73b\": \"0x152d02c7e14af6800000\",\n \"0x2a63590efe9986c3fee09b0a0a338b15bed91f21\": \"0x15e1c4e05ee26d00000\",\n \"0x2a67660a1368efcd626ef36b2b1b601980941c05\": \"0x73f75d1a085ba0000\",\n \"0x2a742b8910941e0932830a1d9692cfd28494cf40\": \"0x1b1ab319f5ec750000\",\n \"0x2a746cd44027af3ebd37c378c85ef7f754ab5f28\": \"0x155bd9307f9fe80000\",\n \"0x2a81d27cb6d4770ff4f3c4a3ba18e5e57f07517c\": \"0x6c6b935b8bbd400000\",\n \"0x2a91a9fed41b7d0e5cd2d83158d3e8a41a9a2d71\": \"0x692ae8897081d00000\",\n \"0x2a9c57fe7b6b138a920d676f3c76b6c2a0eef699\": \"0x1fd933494aa5fe00000\",\n \"0x2a9c96c19151ffcbe29a4616d0c52b3933b4659f\": \"0x3c1379b8765e18000\",\n \"0x2aa192777ca5b978b6b2c2ff800ac1860f753f47\": \"0x12290f15180bdc0000\",\n \"0x2aaa35274d742546670b7426264521032af4f4c3\": \"0x21e19e0c9bab2400000\",\n \"0x2aaea1f1046f30f109faec1c63ef5c7594eb08da\": \"0xd8d726b7177a800000\",\n \"0x2ab97e8d59eee648ab6caf8696f89937143864d6\": \"0xcf152640c5c8300000\",\n \"0x2abce1808940cd4ef5b5e05285f82df7a9ab5e03\": \"0x21342520d5fec200000\",\n \"0x2abdf1a637ef6c42a7e2fe217773d677e804ebdd\": \"0x10f0cf064dd59200000\",\n \"0x2ac1f8d7bf721f3cfe74d20fea9b87a28aaa982c\": \"0x8ba52e6fc45e40000\",\n \"0x2acc9c1a32240b4d5b2f777a2ea052b42fc1271c\": \"0x8d807ee14d836100000\",\n \"0x2ad6c9d10c261819a1a0ca2c48d8c7b2a71728df\": \"0x3635c9adc5dea00000\",\n \"0x2ae53866fc2d14d572ab73b4a065a1188267f527\": \"0x1b1ae4d6e2ef5000000\",\n \"0x2ae73a79aea0278533accf21070922b1613f8f32\": \"0xa7e94bbeae701a8000\",\n \"0x2ae82dab92a66389eea1abb901d1d57f5a7cca0b\": \"0x6c6b935b8bbd400000\",\n \"0x2aec809df9325b9f483996e99f7331097f08aa0e\": \"0xd8d726b7177a800000\",\n \"0x2aed2ce531c056b0097efc3c6de10c4762004ed9\": \"0x2356953ab7ddc380000\",\n \"0x2afb058c3d31032b353bf24f09ae20d54de57dbe\": \"0x3ba1910bf341b00000\",\n \"0x2b0362633614bfcb583569438ecc4ea57b1d337e\": \"0x43c33c1937564800000\",\n \"0x2b101e822cd962962a06800a2c08d3b15d82b735\": \"0x83d6c7aab63600000\",\n \"0x2b129c26b75dde127f8320bd0f63410c92a9f876\": \"0x77432217e683600000\",\n \"0x2b241f037337eb4acc61849bd272ac133f7cdf4b\": \"0x500b6bca962ab8400000\",\n \"0x2b3a68db6b0cae8a7c7a476bdfcfbd6205e10687\": \"0x821ab0d44149800000\",\n \"0x2b3cf97311ff30f460945a9d8099f4a88e26d456\": \"0x6c6b935b8bbd400000\",\n \"0x2b49fba29830360fcdb6da23bbfea5c0bbac5281\": \"0x1158e460913d00000\",\n \"0x2b4f4507bb6b9817942ce433781b708fbcd166fd\": \"0xfc936392801c0000\",\n \"0x2b5016e2457387956562587115aa8759d8695fdf\": \"0x2a5a058fc295ed000000\",\n \"0x2b5c60e84535eeb4d580de127a12eb2677ccb392\": \"0x43c33c1937564800000\",\n \"0x2b5ced9987c0765f900e49cf9da2d9f9c1138855\": \"0x15af1d78b58c400000\",\n \"0x2b5f4b3f1e11707a227aa5e69fa49dded33fb321\": \"0x14542ba12a337c00000\",\n \"0x2b68306ba7f8daaf73f4c644ef7d2743c0f26856\": \"0x2ee182ca17ddd00000\",\n \"0x2b6ed29a95753c3ad948348e3e7b1a251080ffb9\": \"0x34f086f3b33b68400000\",\n \"0x2b701d16c0d3cc1e4cd85445e6ad02eea4ac012d\": \"0x2086ac351052600000\",\n \"0x2b717cd432a323a4659039848d3b87de26fc9546\": \"0x69e10de76676d0800000\",\n \"0x2b74c373d04bfb0fd60a18a01a88fbe84770e58c\": \"0x22b1c8c1227a00000\",\n \"0x2b77a4d88c0d56a3dbe3bae04a05f4fcd1b757e1\": \"0x1043561a8829300000\",\n \"0x2b8488bd2d3c197a3d26151815b5a798d27168dc\": \"0x16a1f9f5fd7d9600000\",\n \"0x2b8a0dee5cb0e1e97e15cfca6e19ad21f995efad\": \"0x1b55438d9a249b0000\",\n \"0x2b8fe4166e23d11963c0932b8ade8e0145ea0770\": \"0x92896529baddc880000\",\n \"0x2b99b42e4f42619ee36baa7e4af2d65eacfcba35\": \"0x878678326eac9000000\",\n \"0x2bab0fbe28d58420b52036770a12f9952aea6911\": \"0xcf152640c5c8300000\",\n \"0x2bade91d154517620fd4b439ac97157a4102a9f7\": \"0xd8d726b7177a800000\",\n \"0x2baf8d6e221174124820ee492b9459ec4fadafbb\": \"0x6c6b935b8bbd400000\",\n \"0x2bafbf9e9ed2c219f7f2791374e7d05cb06777e7\": \"0xbed1d0263d9f00000\",\n \"0x2bb366b9edcb0da680f0e10b3b6e28748190d6c3\": \"0x13a62d7b57640640000\",\n \"0x2bb6f578adfbe7b2a116b3554facf9969813c319\": \"0x19127a1391ea2a00000\",\n \"0x2bbe62eac80ca7f4d6fdee7e7d8e28b63acf770e\": \"0x81e32df972abf00000\",\n \"0x2bbe672a1857508f630f2a5edb563d9e9de92815\": \"0x6c6b935b8bbd400000\",\n \"0x2bc429d618a66a4cf82dbb2d824e9356effa126a\": \"0x6c6acc67d7b1d40000\",\n \"0x2bd252e0d732ff1d7c78f0a02e6cb25423cf1b1a\": \"0x90f534608a72880000\",\n \"0x2bdd03bebbee273b6ca1059b34999a5bbd61bb79\": \"0x1158e460913d00000\",\n \"0x2c04115c3e52961b0dc0b0bf31fba4546f5966fd\": \"0xad78ebc5ac6200000\",\n \"0x2c06dd922b61514aafedd84488c0c28e6dcf0e99\": \"0x152d02c7e14af6800000\",\n \"0x2c0cc3f951482cc8a2925815684eb9f94e060200\": \"0x14542ba12a337c00000\",\n \"0x2c0ee134d8b36145b47beee7af8d2738dbda08e8\": \"0xae56f730e6d840000\",\n \"0x2c0f5b9df43625798e7e03c1a5fd6a6d091af82b\": \"0x1b0fcaab200300000\",\n \"0x2c128c95d957215101f043dd8fc582456d41016d\": \"0x2d43f3ebfafb2c0000\",\n \"0x2c1800f35fa02d3eb6ff5b25285f5e4add13b38d\": \"0x3122d3adafde100000\",\n \"0x2c1c19114e3d6de27851484b8d2715e50f8a1065\": \"0x56bc75e2d63100000\",\n \"0x2c1cc6e18c152488ba11c2cc1bcefa2df306abd1\": \"0x5a87e7d7f5f6580000\",\n \"0x2c1df8a76f48f6b54bcf9caf56f0ee1cf57ab33d\": \"0x2247f750089da580000\",\n \"0x2c2147947ae33fb098b489a5c16bfff9abcd4e2a\": \"0xad78ebc5ac6200000\",\n \"0x2c234f505ca8dcc77d9b7e01d257c318cc19396d\": \"0x56bc75e2d63100000\",\n \"0x2c2428e4a66974edc822d5dbfb241b2728075158\": \"0x6c6b935b8bbd400000\",\n \"0x2c2d15ff39561c1b72eda1cc027ffef23743a144\": \"0xd480ed9ef32b400000\",\n \"0x2c2db28c3309375eea3c6d72cd6d0eec145afcc0\": \"0x6c6b935b8bbd400000\",\n \"0x2c424ee47f583cdce07ae318b6fad462381d4d2b\": \"0xd8d726b7177a800000\",\n \"0x2c4b470307a059854055d91ec3794d80b53d0f4a\": \"0x43c33c1937564800000\",\n \"0x2c52c984102ee0cd3e31821b84d408930efa1ac7\": \"0x6c6b935b8bbd400000\",\n \"0x2c5a2d0abda03bbe215781b4ff296c8c61bdbaf6\": \"0x1a8e56f48c0228000\",\n \"0x2c5b7d7b195a371bf9abddb42fe04f2f1d9a9910\": \"0xad78ebc5ac6200000\",\n \"0x2c5df866666a194b26cebb407e4a1fd73e208d5e\": \"0x3635c9adc5dea00000\",\n \"0x2c603ff0fe93616c43573ef279bfea40888d6ae7\": \"0x100f4b6d66757900000\",\n \"0x2c6846a1aa999a2246a287056000ba4dcba8e63d\": \"0x21f2f6f0fc3c6100000\",\n \"0x2c6afcd4037c1ed14fa74ff6758e0945a185a8e8\": \"0xf43fc2c04ee00000\",\n \"0x2c6b699d9ead349f067f45711a074a641db6a897\": \"0x1158e460913d00000\",\n \"0x2c6f5c124cc789f8bb398e3f889751bc4b602d9e\": \"0x159f20bed00f00000\",\n \"0x2c83aeb02fcf067d65a47082fd977833ab1cec91\": \"0x8273823258ac00000\",\n \"0x2c89f5fdca3d155409b638b98a742e55eb4652b7\": \"0x14dbb2195ca228900000\",\n \"0x2c964849b1f69cc7cea4442538ed87fdf16cfc8f\": \"0x6c6b935b8bbd400000\",\n \"0x2c9fa72c95f37d08e9a36009e7a4b07f29bad41a\": \"0xdf6eb0b2d3ca0000\",\n \"0x2caf6bf4ec7d5a19c5e0897a5eeb011dcece4210\": \"0x7934835a031160000\",\n \"0x2cb4c3c16bb1c55e7c6b7a19b127a1ac9390cc09\": \"0xb82794a9244f0c8000\",\n \"0x2cb5495a505336c2465410d1cae095b8e1ba5cdd\": \"0x43c33c1937564800000\",\n \"0x2cb615073a40dcdb99faa848572e987b3b056efb\": \"0x2b58addb89a2580000\",\n \"0x2cba6d5d0dc204ea8a25ada2e26f5675bd5f2fdc\": \"0x4823ef7ddb9af38000\",\n \"0x2cbb0c73df91b91740b6693b774a7d05177e8e58\": \"0x6449e84e47a8a80000\",\n \"0x2ccb66494d0af689abf9483d365d782444e7dead\": \"0x3635c9adc5dea00000\",\n \"0x2ccc1f1cb5f4a8002e186b20885d9dbc030c0894\": \"0x6c6b935b8bbd400000\",\n \"0x2ccf80e21898125eb4e807cd82e09b9d28592f6e\": \"0x6c6b935b8bbd400000\",\n \"0x2cd19694d1926a0fa9189edebafc671cf1b2caa5\": \"0x3635c9adc5dea00000\",\n \"0x2cd39334ac7eac797257abe3736195f5b4b5ce0f\": \"0x56b47785e37260000\",\n \"0x2cd79eb52027b12c18828e3eaab2969bfcd287e9\": \"0x1158e460913d00000\",\n \"0x2cd87866568dd81ad47d9d3ad0846e5a65507373\": \"0x15af1d78b58c400000\",\n \"0x2cdb3944650616e47cb182e060322fa1487978ce\": \"0x62a992e53a0af00000\",\n \"0x2ce11a92fad024ff2b3e87e3b542e6c60dcbd996\": \"0xd8d726b7177a800000\",\n \"0x2d0326b23f0409c0c0e9236863a133075a94ba18\": \"0xb679be75be6ae0000\",\n \"0x2d0dec51a6e87330a6a8fa2a0f65d88d4abcdf73\": \"0xa076407d3f7440000\",\n \"0x2d23766b6f6b05737dad80a419c40eda4d77103e\": \"0xcf152640c5c8300000\",\n \"0x2d2b032359b363964fc11a518263bfd05431e867\": \"0x81c1df7629e700000\",\n \"0x2d3480bf0865074a72c7759ee5137b4d70c51ce9\": \"0xad78ebc5ac6200000\",\n \"0x2d35a9df62757f7ffad1049afb06ca4afc464c51\": \"0x1158e460913d00000\",\n \"0x2d40558b06f90a3923145592123b6774e46e31f4\": \"0x3635c9adc5dea00000\",\n \"0x2d426912d059fad9740b2e390a2eeac0546ff01b\": \"0x4be4e7267b6ae00000\",\n \"0x2d532df4c63911d1ce91f6d1fcbff7960f78a885\": \"0x5a85968a5878da8000\",\n \"0x2d5391e938b34858cf965b840531d5efda410b09\": \"0x4be4e7267b6ae00000\",\n \"0x2d5b42fc59ebda0dfd66ae914bc28c1b0a6ef83a\": \"0x2bc8b59fdcd836638000\",\n \"0x2d5d7335acb0362b47dfa3a8a4d3f5949544d380\": \"0xad78ebc5ac6200000\",\n \"0x2d61bfc56873923c2b00095dc3eaa0f590d8ae0f\": \"0x46566dff8ce55600000\",\n \"0x2d6511fd7a3800b26854c7ec39c0dcb5f4c4e8e8\": \"0x15adddba2f9e770000\",\n \"0x2d7d5c40ddafc450b04a74a4dabc2bb5d665002e\": \"0x6c6b935b8bbd400000\",\n \"0x2d89a8006a4f137a20dc2bec46fe2eb312ea9654\": \"0xad78ebc5ac6200000\",\n \"0x2d8c52329f38d2a2fa9cbaf5c583daf1490bb11c\": \"0x1158e460913d00000\",\n \"0x2d8e061892a5dcce21966ae1bb0788fd3e8ba059\": \"0xd8e5ce617f2d50000\",\n \"0x2d8e5bb8d3521695c77e7c834e0291bfacee7408\": \"0x6acb3df27e1f880000\",\n \"0x2d90b415a38e2e19cdd02ff3ad81a97af7cbf672\": \"0x5f3c7f64131e40000\",\n \"0x2d9bad6f1ee02a70f1f13def5cccb27a9a274031\": \"0x61093d7c2c6d380000\",\n \"0x2d9c5fecd2b44fbb6a1ec732ea059f4f1f9d2b5c\": \"0x36ca32661d1aa70000\",\n \"0x2da617695009cc57d26ad490b32a5dfbeb934e5e\": \"0x43c33c1937564800000\",\n \"0x2da76b7c39b420e388ba2c1020b0856b0270648a\": \"0x6c6b935b8bbd400000\",\n \"0x2dc79d6e7f55bce2e2d0c02ad07ceca8bb529354\": \"0x55a6e79ccd1d300000\",\n \"0x2dca0e449ab646dbdfd393a96662960bcab5ae1e\": \"0x878678326eac9000000\",\n \"0x2dd325fdffb97b19995284afa5abdb574a1df16a\": \"0x1b1ae4d6e2ef500000\",\n \"0x2dd578f7407dfbd548d05e95ccc39c485429626a\": \"0xe3aeb5737240a00000\",\n \"0x2dd8eeef87194abc2ce7585da1e35b7cea780cb7\": \"0x3635c6204739d98000\",\n \"0x2ddf40905769bcc426cb2c2938ffe077e1e89d98\": \"0xa2a15d09519be00000\",\n \"0x2de0964400c282bdd78a919c6bf77c6b5f796179\": \"0xad78ebc5ac6200000\",\n \"0x2de31afd189a13a76ff6fe73ead9f74bb5c4a629\": \"0x14542ba12a337c00000\",\n \"0x2dec98329d1f96c3a59caa7981755452d4da49d5\": \"0xad78ebc5ac6200000\",\n \"0x2dee90a28f192d676a8773232b56f18f239e2fad\": \"0x3efa7e747b6d1ad0000\",\n \"0x2e0880a34596230720f05ac8f065af8681dcb6c2\": \"0x152d02c7e14af6800000\",\n \"0x2e0c57b47150f95aa6a7e16ab9b1cbf54328979a\": \"0x56bc75e2d63100000\",\n \"0x2e10910ba6e0bc17e055556614cb87090f4d7e5b\": \"0xad78ebc5ac6200000\",\n \"0x2e24b597873bb141bdb237ea8a5ab747799af02d\": \"0x43c33c1937564800000\",\n \"0x2e2810dee44ae4dff3d86342ab126657d653c336\": \"0xad78ebc5ac6200000\",\n \"0x2e2cbd7ad82547b4f5ff8b3ab56f942a6445a3b0\": \"0xad78ebc5ac6200000\",\n \"0x2e2d7ea66b9f47d8cc52c01c52b6e191bc7d4786\": \"0xd8d4602c26bf6c0000\",\n \"0x2e439348df8a4277b22a768457d1158e97c40904\": \"0x2a1e9ff26fbf410000\",\n \"0x2e46fcee6a3bb145b594a243a3913fce5dad6fba\": \"0x21e19e0c9bab2400000\",\n \"0x2e47f287f498233713850d3126823cc67dcee255\": \"0xca9d9ea558b40000\",\n \"0x2e4ee1ae996aa0a1d92428d06652a6bea6d2d15d\": \"0x6c6b935b8bbd400000\",\n \"0x2e52912bc10ea39d54e293f7aed6b99a0f4c73be\": \"0x15af1d78b58c400000\",\n \"0x2e619f57abc1e987aa936ae3a2264962e7eb2d9a\": \"0x28fb9b8a8a53500000\",\n \"0x2e64a8d71111a22f4c5de1e039b336f68d398a7c\": \"0x6c6b935b8bbd400000\",\n \"0x2e6933543d4f2cc00b5350bd8068ba9243d6beb0\": \"0x6c6b935b8bbd400000\",\n \"0x2e7e05e29edda7e4ae25c5173543efd71f6d3d80\": \"0x14542ba12a337c00000\",\n \"0x2e7f465520ec35cc23d68e75651bb6689544a196\": \"0x38ec5b721a1a268000\",\n \"0x2e8eb30a716e5fe15c74233e039bfb1106e81d12\": \"0x56bc75e2d63100000\",\n \"0x2e9824b5c132111bca24ddfba7e575a5cd7296c1\": \"0x3a484516e6d7ffe0000\",\n \"0x2ea5fee63f337a376e4b918ea82148f94d48a626\": \"0x650f8e0dd293c50000\",\n \"0x2eaf4e2a46b789ccc288c8d1d9294e3fb0853896\": \"0x6c6b935b8bbd400000\",\n \"0x2eaff9f8f8113064d3957ac6d6e11eee42c8195d\": \"0x6acb3df27e1f880000\",\n \"0x2eba0c6ee5a1145c1c573984963a605d880a7a20\": \"0x1b1ae4d6e2ef500000\",\n \"0x2ec95822eb887bc113b4712a4dfd7f13b097b5e7\": \"0x3635c9adc5dea00000\",\n \"0x2eca6a3c5d9f449d0956bd43fa7b4d7be8435958\": \"0x6c6bda69709cc20000\",\n \"0x2ecac504b233866eb5a4a99e7bd2901359e43b3d\": \"0x43c33c1937564800000\",\n \"0x2eebf59432b52892f9380bd140aa99dcf8ad0c0f\": \"0x83d6c7aab63600000\",\n \"0x2eeed50471a1a2bf53ee30b1232e6e9d80ef866d\": \"0x1158e460913d00000\",\n \"0x2eef6b1417d7b10ecfc19b123a8a89e73e526c58\": \"0x2086ac351052600000\",\n \"0x2ef869f0350b57d53478d701e3fee529bc911c75\": \"0x2b5e3af16b1880000\",\n \"0x2ef9e465716acacfb8c8252fa8e7bc7969ebf6e4\": \"0x959eb1c0e4ae200000\",\n \"0x2efc4c647dac6acac35577ad221758fef6616faa\": \"0x1b1ae4d6e2ef5000000\",\n \"0x2f13657526b177cad547c3908c840eff647b45d9\": \"0x3f76849cf1ee2c8000\",\n \"0x2f187d5a704d5a338c5b2876a090dce964284e29\": \"0xd8d726b7177a800000\",\n \"0x2f2523cc834f0086052402626296675186a8e582\": \"0x3635c9adc5dea000000\",\n \"0x2f282abbb6d4a3c3cd3b5ca812f7643e80305f06\": \"0x6449e84e47a8a80000\",\n \"0x2f2bba1b1796821a766fce64b84f28ec68f15aea\": \"0x1158e460913d00000\",\n \"0x2f315d9016e8ee5f536681202f9084b032544d4d\": \"0x383cd12b9e863c0000\",\n \"0x2f4da753430fc09e73acbccdcde9da647f2b5d37\": \"0xad78ebc5ac6200000\",\n \"0x2f5080b83f7e2dc0a1dd11b092ad042bff788f4c\": \"0xb4f8fb79231d2b8000\",\n \"0x2f61efa5819d705f2b1e4ee754aeb8a819506a75\": \"0x4f2591f896a6500000\",\n \"0x2f66bfbf2262efcc8d2bd0444fc5b0696298ff1e\": \"0x21ad935f79f76d00000\",\n \"0x2f6dce1330c59ef921602154572d4d4bacbd048a\": \"0x3635c9adc5dea00000\",\n \"0x2f7d3290851be5c6b4b43f7d4574329f61a792c3\": \"0x56bc75e2d63100000\",\n \"0x2f853817afd3b8f3b86e9f60ee77b5d97773c0e3\": \"0x4eaeea44e368b90000\",\n \"0x2fa491fb5920a6574ebd289f39c1b2430d2d9a6a\": \"0x6c6b935b8bbd400000\",\n \"0x2fb566c94bbba4e3cb67cdda7d5fad7131539102\": \"0x6c6b935b8bbd400000\",\n \"0x2fbb504a5dc527d3e3eb0085e2fc3c7dd538cb7a\": \"0x43c2b18aec3c0a8000\",\n \"0x2fbc85798a583598b522166d6e9dda121d627dbc\": \"0xad78ebc5ac6200000\",\n \"0x2fbcef3384d420e4bf61a0669990bc7054f1a5af\": \"0x6c6b935b8bbd400000\",\n \"0x2fc82ef076932341264f617a0c80dd571e6ae939\": \"0x18424f5f0b1b4e00000\",\n \"0x2fdd9b79df8df530ad63c20e62af431ae99216b8\": \"0x1236efcbcbb340000\",\n \"0x2fe0023f5722650f3a8ac01009125e74e3f82e9b\": \"0xa2a15d09519be00000\",\n \"0x2fe0cc424b53a31f0916be08ec81c50bf8eab0c1\": \"0x2086ac351052600000\",\n \"0x2fe13a8d0785de8758a5e41876c36e916cf75074\": \"0xd8d726b7177a800000\",\n \"0x2fea1b2f834f02fc54333f8a809f0438e5870aa9\": \"0x11854d0f9cee40000\",\n \"0x2fee36a49ee50ecf716f1047915646779f8ba03f\": \"0x394222c4da86d70000\",\n \"0x2fef81478a4b2e8098db5ff387ba2153f4e22b79\": \"0x3627e8f712373c0000\",\n \"0x2ff160c44f72a299b5ec2d71e28ce5446d2fcbaf\": \"0x138400eca364a00000\",\n \"0x2ff1ca55fd9cec1b1fe9f0a9abb74c513c1e2aaa\": \"0xa2a15d09519be00000\",\n \"0x2ff5cab12c0d957fd333f382eeb75107a64cb8e8\": \"0x21e19e0c9bab2400000\",\n \"0x2ff830cf55fb00d5a0e03514fecd44314bd6d9f1\": \"0x21e19e0c9bab2400000\",\n \"0x2ffe93ec1a5636e9ee34af70dff52682e6ff7079\": \"0x6c6b935b8bbd400000\",\n \"0x30037988702671acbe892c03fe5788aa98af287a\": \"0x97c9ce4cf6d5c00000\",\n \"0x30248d58e414b20fed3a6c482b59d9d8f5a4b7e2\": \"0x340aad21b3b700000\",\n \"0x303139bc596403d5d3931f774c66c4ba467454db\": \"0x5c25e14aea283f0000\",\n \"0x30380087786965149e81423b15e313ba32c5c783\": \"0xfc936392801c0000\",\n \"0x303a30ac4286ae17cf483dad7b870c6bd64d7b4a\": \"0x1b1ae4d6e2ef500000\",\n \"0x303fbaebbe46b35b6e5b74946a5f99bc1585cae7\": \"0x2f9ac0695f5bba0000\",\n \"0x3041445a33ba158741160d9c344eb88e5c306f94\": \"0x340aad21b3b700000\",\n \"0x30480164bcd84974ebc0d90c9b9afab626cd1c73\": \"0x2b5e3af16b18800000\",\n \"0x304ec69a74545721d7316aef4dcfb41ac59ee2f0\": \"0xad78ebc5ac6200000\",\n \"0x30511832918d8034a7bee72ef2bfee440ecbbcf6\": \"0x368c8623a8b4d100000\",\n \"0x30513fca9f36fd788cfea7a340e86df98294a244\": \"0x183b5f03b1479c0000\",\n \"0x3055efd26029e0d11b930df4f53b162c8c3fd2ce\": \"0x1b1a089237073d0000\",\n \"0x305d26c10bdc103f6b9c21272eb7cb2d9108c47e\": \"0x1b1ae4d6e2ef500000\",\n \"0x305f78d618b990b4295bac8a2dfa262884f804ea\": \"0xd8d726b7177a800000\",\n \"0x3064899a963c4779cbf613cd6980846af1e6ec65\": \"0x17b773ce6e5df0a0000\",\n \"0x30730466b8eb6dc90d5496aa76a3472d7dbe0bbe\": \"0x6c68ccd09b022c0000\",\n \"0x30742ccdf4abbcd005681f8159345c9e79054b1a\": \"0x243d4d18229ca20000\",\n \"0x3083ef0ed4c4401196774a95cf4edc83edc1484f\": \"0x23ffb7ed6565d6400000\",\n \"0x308dd21cebe755126704b48c0f0dc234c60ba9b1\": \"0xad78ebc5ac6200000\",\n \"0x3090f8130ec44466afadb36ed3c926133963677b\": \"0xd8d726b7177a800000\",\n \"0x309544b6232c3dd737f945a03193d19b5f3f65b9\": \"0x3af342f67ef6c80000\",\n \"0x3096dca34108085bcf04ae72b94574a13e1a3e1d\": \"0xad78ebc5ac6200000\",\n \"0x3098b65db93ecacaf7353c48808390a223d57684\": \"0x186484cf7bb6a48000\",\n \"0x30a9da72574c51e7ee0904ba1f73a6b7b83b9b9d\": \"0x11854d0f9cee40000\",\n \"0x30acd858875fa24eef0d572fc7d62aad0ebddc35\": \"0x15af1d78b58c400000\",\n \"0x30b66150f1a63457023fdd45d0cc6cb54e0c0f06\": \"0x3635c9adc5dea00000\",\n \"0x30bb4357cd6910c86d2238bf727cbe8156680e62\": \"0x56bf91b1a65eb0000\",\n \"0x30bf61b2d877fe10635126326fa189e4b0b1c3b0\": \"0x37b48985a5d7e60000\",\n \"0x30c01142907acb1565f70438b9980ae731818738\": \"0x6c6b935b8bbd400000\",\n \"0x30c26a8e971baa1855d633ba703f028cc7873140\": \"0x21e19e0c9bab2400000\",\n \"0x30db6b9b107e62102f434a9dd0960c2021f5ce4c\": \"0x2083179b6e42530000\",\n \"0x30e33358fc21c85006e40f32357dc8895940aaf0\": \"0x678a932062e4180000\",\n \"0x30e60900cacc7203f314dc604347255167fc2a0f\": \"0x6c6b935b8bbd400000\",\n \"0x30e789b3d2465e946e6210fa5b35de4e8c93085f\": \"0x6c6b935b8bbd400000\",\n \"0x30e9698cf1e08a9d048bd8d8048f28be7ed9409f\": \"0x16a6502f15a1e540000\",\n \"0x30e9d5a0088f1ddb2fd380e2a049192266c51cbf\": \"0xaacacd9b9e22b0000\",\n \"0x30eac740e4f02cb56eef0526e5d300322600d03e\": \"0x6acb3df27e1f880000\",\n \"0x30ec9392244a2108c987bc5cdde0ed9f837a817b\": \"0x549925f6c9c5250000\",\n \"0x30ed11b77bc17e5e6694c8bc5b6e4798f68d9ca7\": \"0x1e6fb3421fe0299e0000\",\n \"0x30f7d025d16f7bee105580486f9f561c7bae3fef\": \"0x1b1ae4d6e2ef500000\",\n \"0x30fbe5885f9fcce9ea5edb82ed4a1196dd259aed\": \"0x119e47f21381f400000\",\n \"0x31047d703f63b93424fbbd6e2f1f9e74de13e709\": \"0x9a8166f7e6b2a78000\",\n \"0x31313ffd635bf2f3324841a88c07ed146144ceeb\": \"0x6acb3df27e1f880000\",\n \"0x3159e90c48a915904adfe292b22fa5fd5e72796b\": \"0x36afe98f2606100000\",\n \"0x315db7439fa1d5b423afa7dd7198c1cf74c918bc\": \"0x2086ac351052600000\",\n \"0x315ef2da620fd330d12ee55de5f329a696e0a968\": \"0x821ab0d4414980000\",\n \"0x316e92a91bbda68b9e2f98b3c048934e3cc0b416\": \"0x6c6b935b8bbd400000\",\n \"0x316eb4e47df71b42e16d6fe46825b7327baf3124\": \"0xd8d726b7177a800000\",\n \"0x3171877e9d820cc618fc0919b29efd333fda4934\": \"0x3635c9adc5dea00000\",\n \"0x317cf4a23cb191cdc56312c29d15e210b3b9b784\": \"0x7ce66c50e28400000\",\n \"0x318b2ea5f0aaa879c4d5e548ac9d92a0c67487b7\": \"0xad78ebc5ac6200000\",\n \"0x318c76ecfd8af68d70555352e1f601e35988042d\": \"0x1b31192e68c7f00000\",\n \"0x318f1f8bd220b0558b95fb33100ffdbb640d7ca6\": \"0xd8d726b7177a800000\",\n \"0x31aa3b1ebe8c4dbcb6a708b1d74831e60e497660\": \"0x15af1d78b58c400000\",\n \"0x31ab088966ecc7229258f6098fce68cf39b38485\": \"0x3635c9adc5dea00000\",\n \"0x31ad4d9946ef09d8e988d946b1227f9141901736\": \"0x4d853c8f89089800000\",\n \"0x31b43b015d0081643c6cda46a7073a6dfdbca825\": \"0xa97916520cd18e80000\",\n \"0x31ccc616b3118268e75d9ab8996c8858ebd7f3c3\": \"0x15ae0f771ca1520000\",\n \"0x31d81d526c195e3f10b5c6db52b5e59afbe0a995\": \"0xe4fbc69449f200000\",\n \"0x31e9c00f0c206a4e4e7e0522170dc81e88f3eb70\": \"0x918ddc3a42a3d40000\",\n \"0x31ea12d49a35a740780ddeeaece84c0835b26270\": \"0xad78ebc5ac6200000\",\n \"0x31ea6eab19d00764e9a95e183f2b1b22fc7dc40f\": \"0x1158e460913d00000\",\n \"0x31eb123c95c82bf685ace7a75a1881a289efca10\": \"0x31e009607371bd0000\",\n \"0x31ed858788bda4d5270992221cc04206ec62610d\": \"0x3fc0474948f3600000\",\n \"0x31f006f3494ed6c16eb92aaf9044fa8abb5fd5a3\": \"0x1b1ae4d6e2ef500000\",\n \"0x3201259caf734ad7581c561051ba0bca7fd6946b\": \"0x261dd1ce2f2088800000\",\n \"0x32034e8581d9484e8af42a28df190132ec29c466\": \"0xbb9125542263900000\",\n \"0x322021022678a0166d204b3aaa7ad4ec4b88b7d0\": \"0x15af1d78b58c400000\",\n \"0x3225c1ca5f2a9c88156bb7d9cdc44a326653c214\": \"0x15af1d78b58c400000\",\n \"0x322788b5e29bf4f5f55ae1ddb32085fda91b8ebe\": \"0xad78ebc5ac6200000\",\n \"0x322d6f9a140d213f4c80cd051afe25c620bf4c7d\": \"0x1158e460913d00000\",\n \"0x322e5c43b0f524389655a9b3ff24f2d4db3da10f\": \"0xfc13b69b3e7e680000\",\n \"0x323486ca64b375474fb2b759a9e7a135859bd9f6\": \"0x15af1d78b58c400000\",\n \"0x323749a3b971959e46c8b4822dcafaf7aaf9bd6e\": \"0x11671a5b245700000\",\n \"0x323aad41df4b6fc8fece8c93958aa901fa680843\": \"0x34957444b840e80000\",\n \"0x323b3cfe3ee62bbde2a261e53cb3ecc05810f2c6\": \"0x2eb8eb1a172dcb80000\",\n \"0x323fca5ed77f699f9d9930f5ceeff8e56f59f03c\": \"0x487a9a304539440000\",\n \"0x32485c818728c197fea487fbb6e829159eba8370\": \"0x3921b413bc4ec08000\",\n \"0x3250e3e858c26adeccadf36a5663c22aa84c4170\": \"0x10f0cf064dd59200000\",\n \"0x3259bd2fddfbbc6fbad3b6e874f0bbc02cda18b5\": \"0x2846056495b0d188000\",\n \"0x3275496fd4dd8931fd69fb0a0b04c4d1ff879ef5\": \"0x182d7e4cfda0380000\",\n \"0x327bb49e754f6fb4f733c6e06f3989b4f65d4bee\": \"0x1158e460913d00000\",\n \"0x3282791d6fd713f1e94f4bfd565eaa78b3a0599d\": \"0x487a9a304539440000\",\n \"0x3283eb7f9137dd39bed55ffe6b8dc845f3e1a079\": \"0x3970ae92155780000\",\n \"0x32860997d730b2d83b73241a25d3667d51c908ef\": \"0x1b1a089237073d0000\",\n \"0x3286d1bc657a312c8847d93cb3cb7950f2b0c6e3\": \"0x43c33c1937564800000\",\n \"0x32a20d028e2c6218b9d95b445c771524636a22ef\": \"0x202fefbf2d7c2f00000\",\n \"0x32a70691255c9fc9791a4f75c8b81f388e0a2503\": \"0x35659ef93f0fc40000\",\n \"0x32b7feebc5c59bf65e861c4c0be42a7611a5541a\": \"0x77e9aaa8525c100000\",\n \"0x32ba9a7d0423e03a525fe2ebeb661d2085778bd8\": \"0x43c33c1937564800000\",\n \"0x32bb2e9693e4e085344d2f0dbd46a283e3a087fd\": \"0x15af1d78b58c400000\",\n \"0x32c2fde2b6aabb80e5aea2b949a217f3cb092283\": \"0x1306160afdf20378000\",\n \"0x32d950d5e93ea1d5b48db4714f867b0320b31c0f\": \"0x3708baed3d68900000\",\n \"0x32dbb6716c54e83165829a4abb36757849b6e47d\": \"0x3635c9adc5dea00000\",\n \"0x32eb64be1b5dede408c6bdefbe6e405c16b7ed02\": \"0x6acb3df27e1f880000\",\n \"0x32ef5cdc671df5562a901aee5db716b9be76dcf6\": \"0x6c6b935b8bbd400000\",\n \"0x32f29e8727a74c6b4301e3ffff0687c1b870dae9\": \"0x3635c9adc5dea00000\",\n \"0x32fa0e86cd087dd68d693190f32d93310909ed53\": \"0xd8d726b7177a800000\",\n \"0x32fbeed6f626fcdfd51acafb730b9eeff612f564\": \"0x6c6b935b8bbd400000\",\n \"0x3300fb149aded65bcba6c04e9cd6b7a03b893bb1\": \"0xfc936392801c0000\",\n \"0x3301d9ca2f3bfe026279cd6819f79a293d98156e\": \"0xa968163f0a57b400000\",\n \"0x3308b03466c27a17dfe1aafceb81e16d2934566f\": \"0x39992648a23c8a00000\",\n \"0x331a1c26cc6994cdd3c14bece276ffff4b9df77c\": \"0xfa7aeddf4f068000\",\n \"0x3326b88de806184454c40b27f309d9dd6dcfb978\": \"0x3ca5c66d9bc44300000\",\n \"0x3329eb3baf4345d600ced40e6e9975656f113742\": \"0x10f08eda8e555098000\",\n \"0x33320dd90f2baa110dd334872a998f148426453c\": \"0x36356633ebd8ea0000\",\n \"0x3336c3ef6e8b50ee90e037b164b7a8ea5faac65d\": \"0xec8a3a71c22540000\",\n \"0x33380c6fff5acd2651309629db9a71bf3f20c5ba\": \"0x368c8623a8b4d100000\",\n \"0x333ad1596401e05aea2d36ca47318ef4cd2cb3df\": \"0x9dc05cce28c2b80000\",\n \"0x334340ee4b9cdc81f850a75116d50ee9b69825bf\": \"0x6c6b935b8bbd400000\",\n \"0x33481e856ebed48ea708a27426ef28e867f57cd1\": \"0xad78ebc5ac6200000\",\n \"0x33565ba9da2c03e778ce12294f081dfe81064d24\": \"0x3635c9adc5dea000000\",\n \"0x33581cee233088c0860d944e0cf1ceabb8261c2e\": \"0xb98bc829a6f90000\",\n \"0x335858f749f169cabcfe52b796e3c11ec47ea3c2\": \"0xad78ebc5ac6200000\",\n \"0x335e22025b7a77c3a074c78b8e3dfe071341946e\": \"0x227ca730ab3f6ac0000\",\n \"0x33629bd52f0e107bc071176c64df108f64777d49\": \"0x1cfdd7468216e8000\",\n \"0x337b3bdf86d713dbd07b5dbfcc022b7a7b1946ae\": \"0xd7c198710e66b00000\",\n \"0x337cfe1157a5c6912010dd561533791769c2b6a6\": \"0x3635c9adc5dea00000\",\n \"0x33b336f5ba5edb7b1ccc7eb1a0d984c1231d0edc\": \"0x6c6b935b8bbd400000\",\n \"0x33c407133b84b3ca4c3ded1f4658900c38101624\": \"0x97c9ce4cf6d5c00000\",\n \"0x33d172ab075c51db1cd40a8ca8dbff0d93b843bb\": \"0x136780510d12de38000\",\n \"0x33e9b71823952e1f66958c278fc28b1196a6c5a4\": \"0x56bc75e2d63100000\",\n \"0x33ea6b7855e05b07ab80dab1e14de9b649e99b6c\": \"0x1cd6fbad57dbd00000\",\n \"0x33f15223310d44de8b6636685f3a4c3d9c5655a5\": \"0xd9462c6cb4b5a0000\",\n \"0x33f4a6471eb1bca6a9f85b3b4872e10755c82be1\": \"0x6c6b935b8bbd400000\",\n \"0x33fb577a4d214fe010d32cca7c3eeda63f87ceef\": \"0x3635c9adc5dea00000\",\n \"0x33fd718f0b91b5cec88a5dc15eecf0ecefa4ef3d\": \"0x177224aa844c720000\",\n \"0x341480cc8cb476f8d01ff30812e7c70e05afaf5d\": \"0x6c6b935b8bbd400000\",\n \"0x34272d5e7574315dcae9abbd317bac90289d4765\": \"0x62a992e53a0af00000\",\n \"0x3430a16381f869f6ea5423915855e800883525a9\": \"0x3ca5c66d9bc44300000\",\n \"0x34318625818ec13f11835ae97353ce377d6f590a\": \"0x52663ccab1e1c00000\",\n \"0x34393c5d91b9de597203e75bac4309b5fa3d28c3\": \"0xa844a7424d9c80000\",\n \"0x3439998b247cb4bf8bc80a6d2b3527f1dfe9a6d2\": \"0x796e3ea3f8ab00000\",\n \"0x34437d1465640b136cb5841c3f934f9ba0b7097d\": \"0x960db77681e940000\",\n \"0x344a8db086faed4efc37131b3a22b0782dad7095\": \"0x1b1ae4d6e2ef500000\",\n \"0x34664d220fa7f37958024a3332d684bcc6d4c8bd\": \"0x21e19e0c9bab2400000\",\n \"0x3466f67e39636c01f43b3a21a0e8529325c08624\": \"0x2db1167650acd80000\",\n \"0x3485361ee6bf06ef6508ccd23d94641f814d3e2f\": \"0x6c6b935b8bbd400000\",\n \"0x3485f621256433b98a4200dad857efe55937ec98\": \"0x6c6b935b8bbd400000\",\n \"0x34958a46d30e30b273ecc6e5d358a212e5307e8c\": \"0x6c6b935b8bbd400000\",\n \"0x3497dd66fd118071a78c2cb36e40b6651cc82598\": \"0x5f1016b5076d00000\",\n \"0x349a816b17ab3d27bbc0ae0051f6a070be1ff29d\": \"0x21e19e0c9bab2400000\",\n \"0x349d2c918fd09e2807318e66ce432909176bd50b\": \"0x3cb71f51fc55800000\",\n \"0x34a0431fff5ead927f3c69649616dc6e97945f6f\": \"0x15af1d78b58c400000\",\n \"0x34a85d6d243fb1dfb7d1d2d44f536e947a4cee9e\": \"0x43c33c1937564800000\",\n \"0x34a901a69f036bcf9f7843c0ba01b426e8c3dc2b\": \"0xd8d726b7177a800000\",\n \"0x34b454416e9fb4274e6addf853428a0198d62ee1\": \"0x161042779f1ffc0000\",\n \"0x34c8e5f1330fcb4b14ca75cb2580a4b93d204e36\": \"0x6c6b935b8bbd400000\",\n \"0x34e2849bea583ab0cc37975190f322b395055582\": \"0x1a5c5e857fdf2b20000\",\n \"0x34fa7792bad8bbd7ff64056214a33eb6600c1ea8\": \"0x2b5e3af16b1880000\",\n \"0x34ff26eb60a8d1a95a489fae136ee91d4e58084c\": \"0x2086ac351052600000\",\n \"0x34ff582952ff24458f7b13d51f0b4f987022c1fe\": \"0x9806de3da6e9780000\",\n \"0x35106ba94e8563d4b3cb3c5c692c10e604b7ced8\": \"0x6c6b935b8bbd400000\",\n \"0x35145f620397c69cb8e00962961f0f4886643989\": \"0x14542ba12a337c00000\",\n \"0x35147430c3106500e79fa2f502462e94703c23b1\": \"0x6c6acc67d7b1d40000\",\n \"0x351787843505f8e4eff46566cce6a59f4d1c5fe7\": \"0x1f5718987664b480000\",\n \"0x351f16e5e0735af56751b0e225b2421171394090\": \"0x2d4ca05e2b43ca80000\",\n \"0x3524a000234ebaaf0789a134a2a417383ce5282a\": \"0x1317955947d8e2c0000\",\n \"0x3526eece1a6bdc3ee7b400fe935b48463f31bed7\": \"0x477879b6d14300000\",\n \"0x352a785f4a921632504ce5d015f83c49aa838d6d\": \"0xe9e7e0fb35b7780000\",\n \"0x352d29a26e8a41818181746467f582e6e84012e0\": \"0x14542ba12a337c00000\",\n \"0x352e77c861696ef96ad54934f894aa8ea35151dd\": \"0x3635c9adc5dea00000\",\n \"0x352f25babf4a690673e35195efa8f79d05848aad\": \"0xe253c39be6e7dc00000\",\n \"0x3536453322c1466cb905af5c335ca8db74bff1e6\": \"0x183b5f03b1479c0000\",\n \"0x353dbec42f92b50f975129b93c4c997375f09073\": \"0x6c5db2a4d815dc0000\",\n \"0x3540c7bd7a8442d5bee21a2180a1c4edff1649e0\": \"0x432eac4c6f05b98000\",\n \"0x3549bd40bbbc2b30095cac8be2c07a0588e0aed6\": \"0x1158e460913d00000\",\n \"0x3552a496eba67f12be6eedab360cd13661dc7480\": \"0x1043561a8829300000\",\n \"0x3554947b7b947b0040da52ca180925c6d3b88ffe\": \"0x39fbae8d042dd0000\",\n \"0x355c0c39f5d5700b41d375b3f17851dcd52401f9\": \"0xd7b3b7ba5abf4c0000\",\n \"0x355ccfe0e77d557b971be1a558bc02df9eee0594\": \"0x5f5cb1afc865280000\",\n \"0x3571cf7ad304ecaee595792f4bbfa484418549d6\": \"0x13bcd0d892d9e160000\",\n \"0x3575c770668a9d179f1ef768c293f80166e2aa3d\": \"0x19b21248a3ef280000\",\n \"0x357a02c0a9dfe287de447fb67a70ec5b62366647\": \"0x1731790534df20000\",\n \"0x35855ec641ab9e081ed0c2a6dcd81354d0244a87\": \"0x4127abe993a7aa8000\",\n \"0x3588895ac9fbafec012092dc05c0c302d90740fa\": \"0xa2a15d09519be00000\",\n \"0x3599493ce65772cf93e98af1195ec0955dc98002\": \"0x5151590c67b3280000\",\n \"0x35a08081799173e001cc5bd46a02406dc95d1787\": \"0x21e19e0c9bab2400000\",\n \"0x35a549e8fd6c368d6dcca6d2e7d18e4db95f5284\": \"0x1b1a089237073d0000\",\n \"0x35a6885083c899dabbf530ed6c12f4dd3a204cf5\": \"0xad78ebc5ac6200000\",\n \"0x35aaa0465d1c260c420fa30e2629869fb6559207\": \"0x263781e0e087c80000\",\n \"0x35ac1d3ed7464fa3db14e7729213ceaa378c095e\": \"0x52663ccab1e1c00000\",\n \"0x35af040a0cc2337a76af288154c7561e1a233349\": \"0x3635c9adc5dea00000\",\n \"0x35b03ea4245736f57b85d2eb79628f036ddcd705\": \"0xd8d726b7177a800000\",\n \"0x35bd246865fab490ac087ac1f1d4f2c10d0cda03\": \"0x15af1d78b58c400000\",\n \"0x35bf6688522f35467a7f75302314c02ba176800e\": \"0x3af418202d954e00000\",\n \"0x35c8adc11125432b3b77acd64625fe58ebee9d66\": \"0x6c6b935b8bbd400000\",\n \"0x35d2970f49dcc81ea9ee707e9c8a0ab2a8bb7463\": \"0x4e1003b28d92800000\",\n \"0x35e096120deaa5c1ecb1645e2ccb8b4edbd9299a\": \"0x1b1ae4d6e2ef500000\",\n \"0x35ea2163a38cdf9a123f82a5ec00258dae0bc767\": \"0xd8d726b7177a800000\",\n \"0x35f1da127b83376f1b88c82a3359f67a5e67dd50\": \"0x678a932062e4180000\",\n \"0x35f2949cf78bc219bb4f01907cf3b4b3d3865482\": \"0xfb5c86c92e4340000\",\n \"0x35f5860149e4bbc04b8ac5b272be55ad1aca58e0\": \"0xad78ebc5ac6200000\",\n \"0x3602458da86f6d6a9d9eb03daf97fe5619d442fa\": \"0x6c6b935b8bbd400000\",\n \"0x3605372d93a9010988018f9f315d032ed1880fa1\": \"0x1b1bcf51896a7d0000\",\n \"0x3616d448985f5d32aefa8b93a993e094bd854986\": \"0xb227f63be813c0000\",\n \"0x3616fb46c81578c9c8eb4d3bf880451a88379d7d\": \"0xad78ebc5ac6200000\",\n \"0x361c75931696bc3d427d93e76c77fd13b241f6f4\": \"0x1dc5d8fc266dd60000\",\n \"0x361d9ed80b5bd27cf9f1226f26753258ee5f9b3f\": \"0xbf6914ba7d72c20000\",\n \"0x361f3ba9ed956b770f257d3672fe1ff9f7b0240c\": \"0x2086ac351052600000\",\n \"0x36227cdfa0fd3b9d7e6a744685f5be9aa366a7f0\": \"0xac2730ee9c6c18000\",\n \"0x362fbcb10662370a068fc2652602a2577937cce6\": \"0xad78ebc5ac6200000\",\n \"0x3630c5e565ceaa8a0f0ffe32875eae2a6ce63c19\": \"0x937722b3774d00000\",\n \"0x36339f84a5c2b44ce53dfdb6d4f97df78212a7df\": \"0x116f18b81715a00000\",\n \"0x36343aeca07b6ed58a0e62fa4ecb498a124fc971\": \"0x1043561a8829300000\",\n \"0x366175403481e0ab15bb514615cbb989ebc68f82\": \"0x6c6b935b8bbd400000\",\n \"0x36726f3b885a24f92996da81625ec8ad16d8cbe6\": \"0x53af75d18148578000\",\n \"0x3673954399f6dfbe671818259bb278e2e92ee315\": \"0x2a5a058fc295ed000000\",\n \"0x36758e049cd98bcea12277a676f9297362890023\": \"0xd8d726b7177a800000\",\n \"0x367f59cc82795329384e41e1283115e791f26a01\": \"0x6c6b935b8bbd400000\",\n \"0x36810ff9d213a271eda2b8aa798be654fa4bbe06\": \"0x6c6b935b8bbd400000\",\n \"0x368c5414b56b8455171fbf076220c1cba4b5ca31\": \"0x1e3ef911e83d720000\",\n \"0x3690246ba3c80679e22eac4412a1aefce6d7cd82\": \"0x43c33c1937564800000\",\n \"0x36928b55bc861509d51c8cf1d546bfec6e3e90af\": \"0x6acb3df27e1f880000\",\n \"0x369822f5578b40dd1f4471706b22cd971352da6b\": \"0x12c1b6eed03d280000\",\n \"0x369ef761195f3a373e24ece6cd22520fe0b9e86e\": \"0x1cffafc94db2088000\",\n \"0x36a08fd6fd1ac17ce15ed57eefb12a2be28188bf\": \"0x487a9a304539440000\",\n \"0x36a0e61e1be47fa87e30d32888ee0330901ca991\": \"0x1158e460913d00000\",\n \"0x36b2c85e3aeeebb70d63c4a4730ce2e8e88a3624\": \"0x21e19e0c9bab2400000\",\n \"0x36bf43ff35df90908824336c9b31ce33067e2f50\": \"0x49721510c1c1e9480000\",\n \"0x36bfe1fa3b7b70c172eb042f6819a8972595413e\": \"0x3635c9adc5dea00000\",\n \"0x36c510bf8d6e569bf2f37d47265dbcb502ff2bce\": \"0x65a4da25d3016c00000\",\n \"0x36d85dc3683156e63bf880a9fab7788cf8143a27\": \"0x43c33c1937564800000\",\n \"0x36df8f883c1273ec8a171f7a33cfd649b1fe6075\": \"0xc52484ac416890000\",\n \"0x36e156610cd8ff64e780d89d0054385ca76755aa\": \"0x2f6f10780d22cc00000\",\n \"0x36fec62c2c425e219b18448ad757009d8c54026f\": \"0x15af1d78b58c400000\",\n \"0x3700e3027424d939dbde5d42fb78f6c4dbec1a8f\": \"0x22b1c8c1227a00000\",\n \"0x3702e704cc21617439ad4ea27a5714f2fda1e932\": \"0x3635c9adc5dea00000\",\n \"0x3703350c4d6fe337342cddc65bf1e2386bf3f9b2\": \"0x6d8121a194d1100000\",\n \"0x3708e59de6b4055088782902e0579c7201a8bf50\": \"0x2a5a058fc295ed000000\",\n \"0x3712367e5e55a96d5a19168f6eb2bc7e9971f869\": \"0x3635c9adc5dea00000\",\n \"0x37195a635dcc62f56a718049d47e8f9f96832891\": \"0x6acb3df27e1f880000\",\n \"0x3727341f26c12001e378405ee38b2d8464ec7140\": \"0x6c6b935b8bbd400000\",\n \"0x372e453a6b629f27678cc8aeb5e57ce85ec0aef9\": \"0xad78ebc5ac6200000\",\n \"0x3734cb187491ede713ae5b3b2d12284af46b8101\": \"0xa2a15d09519be00000\",\n \"0x3737216ee91f177732fb58fa4097267207e2cf55\": \"0x52663ccab1e1c00000\",\n \"0x373c547e0cb5ce632e1c5ad66155720c01c40995\": \"0xfe54dcdce6c55a0000\",\n \"0x376cd7577383e902951b60a2017ba7ea29e33576\": \"0x6c6b935b8bbd400000\",\n \"0x378ea1dc8edc19bae82638029ea8752ce98bcfcd\": \"0x6c6b935b8bbd400000\",\n \"0x378f37243f3ff0bef5e1dc85eb4308d9340c29f9\": \"0x6c6e59e67c78540000\",\n \"0x37959c20b7e9931d72f5a8ae869dafddad3b6d5c\": \"0xad78ebc5ac6200000\",\n \"0x379a7f755a81a17edb7daaa28afc665dfa6be63a\": \"0x15af1d78b58c40000\",\n \"0x379c7166849bc24a02d6535e2def13daeef8aa8d\": \"0x56bc75e2d63100000\",\n \"0x37a05aceb9395c8635a39a7c5d266ae610d10bf2\": \"0x65a4da25d3016c00000\",\n \"0x37a10451f36166cf643dd2de6c1cbba8a011cfa3\": \"0x14998f32ac78700000\",\n \"0x37a7a6ff4ea3d60ec307ca516a48d3053bb79cbb\": \"0x6c6b935b8bbd400000\",\n \"0x37ab66083a4fa23848b886f9e66d79cdc150cc70\": \"0x12be22ffb5ec00380000\",\n \"0x37ac29bda93f497bc4aeaab935452c431510341e\": \"0x35659ef93f0fc40000\",\n \"0x37b8beac7b1ca38829d61ab552c766f48a10c32f\": \"0x15af1d78b58c400000\",\n \"0x37bbc47212d82fcb5ee08f5225ecc2041ad2da7d\": \"0xb1cf24ddd0b1400000\",\n \"0x37cb868d2c3f95b257611eb34a4188d58b749802\": \"0x6c6b935b8bbd400000\",\n \"0x37d980a12ee3bf23cc5cdb63b4ae45691f74c837\": \"0x6c6b935b8bbd400000\",\n \"0x37e169a93808d8035698f815c7235613c1e659f2\": \"0x3635c9adc5dea00000\",\n \"0x37eada93c475ded2f7e15e7787d400470fa52062\": \"0xad78ebc5ac6200000\",\n \"0x37fac1e6bc122e936dfb84de0c4bef6e0d60c2d7\": \"0x6c6b935b8bbd400000\",\n \"0x3807eff43aa97c76910a19752dd715ee0182d94e\": \"0xd90156f6fc2fb0000\",\n \"0x3815b0743f94fc8cc8654fd9d597ed7d8b77c57e\": \"0x2809d429d896750000\",\n \"0x381db4c8465df446a4ce15bf81d47e2f17c980bf\": \"0x6c6b935b8bbd4000000\",\n \"0x38202c5cd7078d4f887673ab07109ad8ada89720\": \"0x3635c9adc5dea00000\",\n \"0x3821862493242c0aeb84b90de05d250c1e50c074\": \"0x11776c58e946dc0000\",\n \"0x382591e7217b435e8e884cdbf415fe377a6fe29e\": \"0x1b2df9d219f57980000\",\n \"0x382ba76db41b75606dd48a48f0137e9174e031b6\": \"0x1158e460913d00000\",\n \"0x3831757eae7557cb8a37a4b10644b63e4d3b3c75\": \"0xad78ebc5ac6200000\",\n \"0x383304dd7a5720b29c1a10f60342219f48032f80\": \"0x12f939c99edab800000\",\n \"0x383a7c899ee18bc214969870bc7482f6d8f3570e\": \"0x21e19e0c9bab2400000\",\n \"0x38430e931d93be01b4c3ef0dc535f1e0a9610063\": \"0x21e19e0c9bab2400000\",\n \"0x38439aaa24e3636f3a18e020ea1da7e145160d86\": \"0x8cf23f909c0fa00000\",\n \"0x38458e0685573cb4d28f53098829904570179266\": \"0x22b1c8c1227a00000\",\n \"0x3847667038f33b01c1cc795d8daf5475eff5a0d4\": \"0x277b9bf4246c410000\",\n \"0x38643babea6011316cc797d9b093c897a17bdae7\": \"0x1220bb7445daa00000\",\n \"0x38695fc7e1367ceb163ebb053751f9f68ddb07a0\": \"0x6c6b935b8bbd400000\",\n \"0x3872f48dc5e3f817bc6b2ad2d030fc5e0471193d\": \"0xd8d726b7177a800000\",\n \"0x387eeafd6b4009deaf8bd5b85a72983a8dcc3487\": \"0xd8d726b7177a800000\",\n \"0x3881defae1c07b3ce04c78abe26b0cdc8d73f010\": \"0xad78ebc5ac6200000\",\n \"0x3883becc08b9be68ad3b0836aac3b620dc0017ef\": \"0x6c6b935b8bbd400000\",\n \"0x3885fee67107dc3a3c741ee290c98918c9b99397\": \"0x1158e460913d00000\",\n \"0x3887192c7f705006b630091276b39ac680448d6b\": \"0x340aad21b3b700000\",\n \"0x38898bbb4553e00bbfd0cf268b2fc464d154add5\": \"0x1158e460913d000000\",\n \"0x388bdcdae794fc44082e667501344118ea96cd96\": \"0x5a87e7d7f5f6580000\",\n \"0x388c85a9b9207d8146033fe38143f6d34b595c47\": \"0xad78ebc5ac6200000\",\n \"0x3896ad743579d38e2302454d1fb6e2ab69e01bfd\": \"0x65ea3db75546600000\",\n \"0x38a3dccf2fcfe0c91a2624bd0cbf88ee4a076c33\": \"0x6c6b935b8bbd400000\",\n \"0x38a744efa6d5c2137defef8ef9187b649eee1c78\": \"0xd8d726b7177a800000\",\n \"0x38ac664ee8e0795e4275cb852bcba6a479ad9c8d\": \"0x1158e460913d00000\",\n \"0x38b2197106123387a0d4de368431a8bacdda30e2\": \"0x1158e460913d00000\",\n \"0x38b3965c21fa893931079beacfffaf153678b6eb\": \"0x93c6a0a51e2670000\",\n \"0x38b403fb1fb7c14559a2d6f6564a5552bca39aff\": \"0x6c6b935b8bbd400000\",\n \"0x38b50146e71916a5448de12a4d742135dcf39833\": \"0x6d190c475169a200000\",\n \"0x38bf2a1f7a69de0e2546adb808b36335645da9ff\": \"0x6c700439d9b5600000\",\n \"0x38c10b90c859cbb7815692f99dae520ab5febf5e\": \"0x2c9e4966fa5cf240000\",\n \"0x38c7851f5ffd4cee98df30f3b25597af8a6ca263\": \"0x8ead3a2f7d7e180000\",\n \"0x38d2e9154964b41c8d50a7487d391e7ee2c3d3c2\": \"0xbdbc41e0348b300000\",\n \"0x38da1ba2de9e2c954b092dd9d81204fd016ba016\": \"0x2268ed01f34b3300000\",\n \"0x38df0c4abe7ded5fe068eadf154ac691774324a4\": \"0x61093d7c2c6d380000\",\n \"0x38e2af73393ea98a1d993a74df5cd754b98d529a\": \"0x61093d7c2c6d380000\",\n \"0x38e46de4453c38e941e7930f43304f94bb7b2be8\": \"0x6cb7e74867d5e60000\",\n \"0x38e7dba8fd4f1f850dbc2649d8e84f0952e3eb3c\": \"0x2b5e3af16b1880000\",\n \"0x38e8a31af2d265e31a9fff2d8f46286d1245a467\": \"0x1158e460913d00000\",\n \"0x38ea6f5b5a7b88417551b4123dc127dfe9342da6\": \"0x15af1d78b58c400000\",\n \"0x38eec6e217f4d41aa920e424b9525197041cd4c6\": \"0xf00d25eb922e670000\",\n \"0x38f387e1a4ed4a73106ef2b462e474e2e3143ad0\": \"0x14542ba12a337c00000\",\n \"0x391161b0e43c302066e8a68d2ce7e199ecdb1d57\": \"0xd8d726b7177a800000\",\n \"0x3915eab5ab2e5977d075dec47d96b68b4b5cf515\": \"0xd07018185120f400000\",\n \"0x391a77405c09a72b5e8436237aaaf95d68da1709\": \"0x2a9264af3d1b90000\",\n \"0x391f20176d12360d724d51470a90703675594a4d\": \"0x56bc75e2d631000000\",\n \"0x392433d2ce83d3fb4a7602cca3faca4ec140a4b0\": \"0x2c3c465ca58ec0000\",\n \"0x393f783b5cdb86221bf0294fb714959c7b45899c\": \"0x14061b9d77a5e980000\",\n \"0x393ff4255e5c658f2e7f10ecbd292572671bc2d2\": \"0x6c6b935b8bbd400000\",\n \"0x394132600f4155e07f4d45bc3eb8d9fb72dcd784\": \"0x9f6e92edea07d40000\",\n \"0x3951e48e3c869e6b72a143b6a45068cdb9d466d0\": \"0x1158e460913d00000\",\n \"0x3954bdfe0bf587c695a305d9244c3d5bdddac9bb\": \"0x410278327f985608000\",\n \"0x395d6d255520a8db29abc47d83a5db8a1a7df087\": \"0x56bc75e2d63100000\",\n \"0x39636b25811b176abfcfeeca64bc87452f1fdff4\": \"0x15af1d78b58c400000\",\n \"0x3969b4f71bb8751ede43c016363a7a614f76118e\": \"0x6c6b935b8bbd400000\",\n \"0x39782ffe06ac78822a3c3a8afe305e50a56188ce\": \"0x21e19e0c9bab2400000\",\n \"0x397a6ef8763a18f00fac217e055c0d3094101011\": \"0x6c6b935b8bbd400000\",\n \"0x397cdb8c80c67950b18d654229610e93bfa6ee1a\": \"0x3f95c8e08215210000\",\n \"0x39824f8bced176fd3ea22ec6a493d0ccc33fc147\": \"0xd8d726b7177a800000\",\n \"0x39936c2719450b9420cc2522cf91db01f227c1c1\": \"0x1b1ae4d6e2ef500000\",\n \"0x3995e096b08a5a726800fcd17d9c64c64e088d2b\": \"0xad78ebc5ac6200000\",\n \"0x399aa6f5d078cb0970882bc9992006f8fbdf3471\": \"0x3635c9adc5dea00000\",\n \"0x39aa05e56d7d32385421cf9336e90d3d15a9f859\": \"0x168d28e3f00280000\",\n \"0x39aaf0854db6eb39bc7b2e43846a76171c0445de\": \"0x6449e84e47a8a80000\",\n \"0x39b1c471ae94e12164452e811fbbe2b3cd7275ac\": \"0x6c6b935b8bbd400000\",\n \"0x39b299327490d72f9a9edff11b83afd0e9d3c450\": \"0xad78ebc5ac6200000\",\n \"0x39bac68d947859f59e9226089c96d62e9fbe3cde\": \"0x22b1c8c1227a00000\",\n \"0x39bfd978689bec048fc776aa15247f5e1d7c39a2\": \"0x43c33c1937564800000\",\n \"0x39c773367c8825d3596c686f42bf0d14319e3f84\": \"0x73f75d1a085ba0000\",\n \"0x39d4a931402c0c79c457186f24df8729cf957031\": \"0xd8d726b7177a800000\",\n \"0x39d6caca22bccd6a72f87ee7d6b59e0bde21d719\": \"0x6c8754c8f30c080000\",\n \"0x39e0db4d60568c800b8c5500026c2594f5768960\": \"0x3635c9adc5dea00000\",\n \"0x39ee4fe00fbced647068d4f57c01cb22a80bccd1\": \"0x14542ba12a337c00000\",\n \"0x39f198331e4b21c1b760a3155f4ab2fe00a74619\": \"0x6c6b935b8bbd400000\",\n \"0x39f44663d92561091b82a70dcf593d754005973a\": \"0xad78b2edc21598000\",\n \"0x3a035594c747476d42d1ee966c36224cdd224993\": \"0x134af74569f9c50000\",\n \"0x3a04572847d31e81f7765ca5bfc9d557159f3683\": \"0x7362d0dabeafd8000\",\n \"0x3a06e3bb1edcfd0c44c3074de0bb606b049894a2\": \"0x21e19e0c9bab2400000\",\n \"0x3a10888b7e149cae272c01302c327d0af01a0b24\": \"0xebec21ee1da40000\",\n \"0x3a3108c1e680a33b336c21131334409d97e5adec\": \"0x1158e460913d00000\",\n \"0x3a368efe4ad786e26395ec9fc6ad698cae29fe01\": \"0x2245899675f9f40000\",\n \"0x3a3dd104cd7eb04f21932fd433ea7affd39369f5\": \"0x13614f23e242260000\",\n \"0x3a4297da3c555e46c073669d0478fce75f2f790e\": \"0x6ac5c62d9486070000\",\n \"0x3a476bd2c9e664c63ab266aa4c6e4a4825f516c3\": \"0xad78ebc5ac6200000\",\n \"0x3a48e0a7098b06a905802b87545731118e89f439\": \"0x6c6b935b8bbd400000\",\n \"0x3a4da78dce05aeb87de9aead9185726da1926798\": \"0xad78ebc5ac6200000\",\n \"0x3a59a08246a8206f8d58f70bb1f0d35c5bcc71bd\": \"0xa076407d3f7440000\",\n \"0x3a72d635aadeee4382349db98a1813a4cfeb3df1\": \"0x2a5a058fc295ed000000\",\n \"0x3a7db224acae17de7798797d82cdf8253017dfa8\": \"0x10f0cf064dd59200000\",\n \"0x3a805fa0f7387f73055b7858ca8519edd93d634f\": \"0x6449e84e47a8a80000\",\n \"0x3a84e950ed410e51b7e8801049ab2634b285fea1\": \"0x3f52fdaa822d2c80000\",\n \"0x3a86ee94862b743dd34f410969d94e2c5652d4ad\": \"0xaede69ad30e810000\",\n \"0x3a9132b7093d3ec42e1e4fb8cb31ecdd43ae773c\": \"0x6c6b935b8bbd400000\",\n \"0x3a9960266df6492063538a99f487c950a3a5ec9e\": \"0x5150ae84a8cdf000000\",\n \"0x3a9b111029ce1f20c9109c7a74eeeef34f4f2eb2\": \"0xd8d726b7177a800000\",\n \"0x3a9e5441d44b243be55b75027a1ceb9eacf50df2\": \"0x3635c9adc5dea00000\",\n \"0x3aa07a34a1afc8967d3d1383b96b62cf96d5fa90\": \"0x43c33c1937564800000\",\n \"0x3aa42c21b9b31c3e27ccd17e099af679cdf56907\": \"0x1b1ae4d6e2ef5000000\",\n \"0x3aa948ea02397755effb2f9dc9392df1058f7e33\": \"0x2e141ea081ca080000\",\n \"0x3aadf98b61e5c896e7d100a3391d3250225d61df\": \"0xcaf67003701680000\",\n \"0x3aae4872fd9093cbcad1406f1e8078bab50359e2\": \"0x222c8eb3ff6640000\",\n \"0x3abb8adfc604f48d5984811d7f1d52fef6758270\": \"0xf29719b66f110c0000\",\n \"0x3ac2f0ff1612e4a1c346d53382abf6d8a25baa53\": \"0x6c6b935b8bbd400000\",\n \"0x3ac9dc7a436ae98fd01c7a9621aa8e9d0b8b531d\": \"0x61093d7c2c6d380000\",\n \"0x3ad06149b21c55ff867cc3fb9740d2bcc7101231\": \"0x29b76432b94451200000\",\n \"0x3ad70243d88bf0400f57c8c1fd57811848af162a\": \"0x2e9ee5c38653f00000\",\n \"0x3ad915d550b723415620f5a9b5b88a85f382f035\": \"0x3635c9adc5dea00000\",\n \"0x3ae160e3cd60ae31b9d6742d68e14e76bd96c517\": \"0x1a055690d9db80000\",\n \"0x3ae62bd271a760637fad79c31c94ff62b4cd12f7\": \"0x6c6b935b8bbd400000\",\n \"0x3aea4e82d2400248f99871a41ca257060d3a221b\": \"0x3635c9adc5dea00000\",\n \"0x3af65b3e28895a4a001153391d1e69c31fb9db39\": \"0xd5967be4fc3f100000\",\n \"0x3b07db5a357f5af2484cbc9d77d73b1fd0519fc7\": \"0x1b1ae4d6e2ef500000\",\n \"0x3b0accaf4b607cfe61d17334c214b75cdefdbd89\": \"0x6c6b935b8bbd400000\",\n \"0x3b13631a1b89cb566548899a1d60915cdcc4205b\": \"0x6c6b935b8bbd400000\",\n \"0x3b159099075207c6807663b1f0f7eda54ac8cce3\": \"0x6ac4e65b69f92d8000\",\n \"0x3b1937d5e793b89b63fb8eb5f1b1c9ca6ba0fa8e\": \"0x6c6b935b8bbd400000\",\n \"0x3b22da2a0271c8efe102532773636a69b1c17e09\": \"0x1b36a6444a3e180000\",\n \"0x3b22dea3c25f1b59c7bd27bb91d3a3eaecef3984\": \"0x56bc75e2d63100000\",\n \"0x3b2367f8494b5fe18d683c055d89999c9f3d1b34\": \"0x21e19e0c9bab2400000\",\n \"0x3b2c45990e21474451cf4f59f01955b331c7d7c9\": \"0x6c6b935b8bbd400000\",\n \"0x3b4100e30a73b0c734b18ffa8426d19b19312f1a\": \"0xbb5d1aa700afd900000\",\n \"0x3b42a66d979f582834747a8b60428e9b4eeccd23\": \"0x21a1c790fadc580000\",\n \"0x3b4768fd71e2db2cbe7fa050483c27b4eb931df3\": \"0x6c6b935b8bbd400000\",\n \"0x3b566a8afad19682dc2ce8679a3ce444a5b0fd4f\": \"0x6c6b935b8bbd400000\",\n \"0x3b5c251d7fd7893ba209fe541cecd0ce253a990d\": \"0x65a4da25d3016c00000\",\n \"0x3b5e8b3c77f792decb7a8985df916efb490aac23\": \"0x6c6b935b8bbd400000\",\n \"0x3b6e814f770748a7c3997806347605480a3fd509\": \"0x6c6b935b8bbd400000\",\n \"0x3b7b4f53c45655f3dc5f017edc23b16f9bc536fa\": \"0x56bc75e2d63100000\",\n \"0x3b7b8e27de33d3ce7961b98d19a52fe79f6c25be\": \"0x152d02c7e14af6800000\",\n \"0x3b7c77dbe95dc2602ce3269a9545d04965fefdbd\": \"0x6c6b935b8bbd400000\",\n \"0x3b8098533f7d9bdcd307dbb23e1777ca18418936\": \"0x6c6b935b8bbd400000\",\n \"0x3b93b16136f11eaf10996c95990d3b2739ccea5f\": \"0x21e19e0c9bab2400000\",\n \"0x3bab4b01a7c84ba13feea9b0bb191b77a3aadca3\": \"0xad78ebc5ac6200000\",\n \"0x3bb53598cc20e2055dc553b049404ac9b7dd1e83\": \"0x21571df77c00be0000\",\n \"0x3bbc13d04accc0707aebdcaef087d0b87e0b5ee3\": \"0xbed1d0263d9f000000\",\n \"0x3bc6e3ee7a56ce8f14a37532590f63716b9966e8\": \"0x6c6b935b8bbd400000\",\n \"0x3bc85d6c735b9cda4bba5f48b24b13e70630307b\": \"0x6acb3df27e1f880000\",\n \"0x3bd624b548cb659736907ed8aa3c0c705e24b575\": \"0x6c6b935b8bbd400000\",\n \"0x3bd9a06d1bd36c4edd27fc0d1f5b088ddae3c72a\": \"0x1b1a7a420ba00d0000\",\n \"0x3bddbc8134f77d55597fc97c26d26698090604eb\": \"0xbe202d6a0eda0000\",\n \"0x3bf86ed8a3153ec933786a02ac090301855e576b\": \"0x5f4a8c8375d155400000\",\n \"0x3bfbd3847c17a61cf3f17b52f8eba1b960b3f39f\": \"0xa2a15d09519be00000\",\n \"0x3c03bbc023e1e93fa3a3a6e428cf0cd8f95e1ec6\": \"0x52663ccab1e1c00000\",\n \"0x3c0c3defac9cea7acc319a96c30b8e1fedab4574\": \"0x692ae8897081d00000\",\n \"0x3c15b3511df6f0342e7348cc89af39a168b7730f\": \"0x3635c9adc5dea00000\",\n \"0x3c1f91f301f4b565bca24751aa1f761322709ddd\": \"0x61093d7c2c6d380000\",\n \"0x3c286cfb30146e5fd790c2c8541552578de334d8\": \"0x2291b11aa306e8c0000\",\n \"0x3c322e611fdb820d47c6f8fc64b6fad74ca95f5e\": \"0xd258ece1b13150000\",\n \"0x3c5a241459c6abbf630239c98a30d20b8b3ac561\": \"0x88b23acffd9900000\",\n \"0x3c79c863c3d372b3ff0c6f452734a7f97042d706\": \"0x98a7d9b8314c00000\",\n \"0x3c83c1701db0388b68210d00f5717cd9bd322c6a\": \"0x65a4da25d3016c00000\",\n \"0x3c860e2e663f46db53427b29fe3ea5e5bf62bbcc\": \"0x556f64c1fe7fa0000\",\n \"0x3c869c09696523ced824a070414605bb76231ff2\": \"0x3635c9adc5dea00000\",\n \"0x3c925619c9b33144463f0537d896358706c520b0\": \"0x6c6b935b8bbd400000\",\n \"0x3c98594bf68b57351e8814ae9e6dfd2d254aa06f\": \"0x1043561a8829300000\",\n \"0x3cadeb3d3eed3f62311d52553e70df4afce56f23\": \"0xd8d726b7177a800000\",\n \"0x3caedb5319fe806543c56e5021d372f71be9062e\": \"0x878678326eac9000000\",\n \"0x3cafaf5e62505615068af8eb22a13ad8a9e55070\": \"0x6c660645aa47180000\",\n \"0x3cb179cb4801a99b95c3b0c324a2bdc101a65360\": \"0x168d28e3f00280000\",\n \"0x3cb561ce86424b359891e364ec925ffeff277df7\": \"0xad78ebc5ac6200000\",\n \"0x3ccb71aa6880cb0b84012d90e60740ec06acd78f\": \"0x6c6b935b8bbd400000\",\n \"0x3ccef88679573947e94997798a1e327e08603a65\": \"0x2bc916d69f3b020000\",\n \"0x3cd1d9731bd548c1dd6fcea61beb75d91754f7d3\": \"0x1161d01b215cae48000\",\n \"0x3cd3a6e93579c56d494171fc533e7a90e6f59464\": \"0x6c6b935b8bbd400000\",\n \"0x3cd6b7593cbee77830a8b19d0801958fcd4bc57a\": \"0x1b1ae4d6e2ef500000\",\n \"0x3cd7f7c7c2353780cde081eeec45822b25f2860c\": \"0xad78ebc5ac6200000\",\n \"0x3ce1dc97fcd7b7c4d3a18a49d6f2a5c1b1a906d7\": \"0xad78ebc5ac6200000\",\n \"0x3cea302a472a940379dd398a24eafdbadf88ad79\": \"0xa2a15d09519be00000\",\n \"0x3ceca96bb1cdc214029cbc5e181d398ab94d3d41\": \"0x10f0cf064dd592000000\",\n \"0x3cf484524fbdfadae26dc185e32b2b630fd2e726\": \"0x185452cb2a91c30000\",\n \"0x3cf9a1d465e78b7039e3694478e2627b36fcd141\": \"0x4a60532ad51bf00000\",\n \"0x3cfbf066565970639e130df2a7d16b0e14d6091c\": \"0x5c283d410394100000\",\n \"0x3d09688d93ad07f3abe68c722723cd680990435e\": \"0x65a4ce99f769e6e0000\",\n \"0x3d31587b5fd5869845788725a663290a49d3678c\": \"0x1b1ae4d6e2ef500000\",\n \"0x3d3fad49c9e5d2759c8e8e5a7a4d60a0dd135692\": \"0x1158e460913d00000\",\n \"0x3d574fcf00fae1d98cc8bf9ddfa1b3953b9741bc\": \"0x6acb3df27e1f880000\",\n \"0x3d5a8b2b80be8b35d8ecf789b5ed7a0775c5076c\": \"0x1158e460913d00000\",\n \"0x3d66cd4bd64d5c8c1b5eea281e106d1c5aad2373\": \"0x69c4f3a8a110a60000\",\n \"0x3d6ae053fcbc318d6fd0fbc353b8bf542e680d27\": \"0xc673ce3c40160000\",\n \"0x3d6ff82c9377059fb30d9215723f60c775c891fe\": \"0xd8e5ce617f2d50000\",\n \"0x3d79a853d71be0621b44e29759656ca075fdf409\": \"0x6c6b935b8bbd400000\",\n \"0x3d7ea5bf03528100ed8af8aed2653e921b6e6725\": \"0x3635c9adc5dea00000\",\n \"0x3d813ff2b6ed57b937dabf2b381d148a411fa085\": \"0x56bc75e2d63100000\",\n \"0x3d881433f04a7d0d27f84944e08a512da3555287\": \"0x410d586a20a4c00000\",\n \"0x3d89e505cb46e211a53f32f167a877bec87f4b0a\": \"0x15b3557f1937f8000\",\n \"0x3d8d0723721e73a6c0d860aa0557abd14c1ee362\": \"0x10f0cf064dd59200000\",\n \"0x3d8f39881b9edfe91227c33fa4cdd91e678544b0\": \"0x4ab07ba43ada98000\",\n \"0x3d9d6be57ff83e065985664f12564483f2e600b2\": \"0x6eace43f23bd800000\",\n \"0x3da39ce3ef4a7a3966b32ee7ea4ebc2335a8f11f\": \"0x6c6b935b8bbd400000\",\n \"0x3daa01ceb70eaf9591fa521ba4a27ea9fb8ede4a\": \"0x5a63d2c9bc76540000\",\n \"0x3db5fe6a68bd3612ac15a99a61e555928eeceaf3\": \"0x55a6e79ccd1d300000\",\n \"0x3db9ed7f024c7e26372feacf2b050803445e3810\": \"0x45b148b4996a300000\",\n \"0x3dbf0dbfd77890800533f09dea8301b9f025d2a6\": \"0x3635c9adc5dea00000\",\n \"0x3dcef19c868b15d34eda426ec7e04b18b6017002\": \"0x6c68ccd09b022c0000\",\n \"0x3dd12e556a603736feba4a6fa8bd4ac45d662a04\": \"0x23757b9183e078280000\",\n \"0x3dde8b15b3ccbaa5780112c3d674f313bba68026\": \"0x601d515a3e4f940000\",\n \"0x3ddedbe48923fbf9e536bf9ffb0747c9cdd39eef\": \"0x368c8623a8b4d100000\",\n \"0x3deae43327913f62808faa1b6276a2bd6368ead9\": \"0x6c6b935b8bbd400000\",\n \"0x3df762049eda8ac6927d904c7af42f94e5519601\": \"0x6c6b935b8bbd400000\",\n \"0x3e040d40cb80ba0125f3b15fdefcc83f3005da1b\": \"0x384524cc70b7780000\",\n \"0x3e0b8ed86ed669e12723af7572fbacfe829b1e16\": \"0x514de7f9b812dc0000\",\n \"0x3e0cbe6a6dcb61f110c45ba2aa361d7fcad3da73\": \"0x1b2df9d219f57980000\",\n \"0x3e194b4ecef8bb711ea2ff24fec4e87bd032f7d1\": \"0x8b9dc1bc1a036a8000\",\n \"0x3e1b2230afbbd310b4926a4c776d5ae7819c661d\": \"0x65a4da25d3016c00000\",\n \"0x3e1c53300e4c168912163c7e99b95da268ad280a\": \"0x3662325cd18fe00000\",\n \"0x3e1c962063e0d5295941f210dca3ab531eec8809\": \"0xa2a15d09519be00000\",\n \"0x3e2ca0d234baf607ad466a1b85f4a6488ef00ae7\": \"0x4da21a3483d568000\",\n \"0x3e2f26235e137a7324e4dc154b5df5af46ea1a49\": \"0x137aad8032db90000\",\n \"0x3e3161f1ea2fbf126e79da1801da9512b37988c9\": \"0xa6dd90cae5114480000\",\n \"0x3e36c17253c11cf38974ed0db1b759160da63783\": \"0x17b7883c06916600000\",\n \"0x3e3cd3bec06591d6346f254b621eb41c89008d31\": \"0x35dfbeda9f37340000\",\n \"0x3e45bd55db9060eced923bb9cb733cb3573fb531\": \"0x58e7926ee858a00000\",\n \"0x3e4d13c55a84e46ed7e9cb90fd355e8ad991e38f\": \"0x3635c9adc5dea00000\",\n \"0x3e4e9265223c9738324cf20bd06006d0073edb8c\": \"0x73f75d1a085ba0000\",\n \"0x3e4fbd661015f6461ed6735cefef01f31445de3a\": \"0x36e342998b8b0200000\",\n \"0x3e53ff2107a8debe3328493a92a586a7e1f49758\": \"0x4e69c2a71a405ab0000\",\n \"0x3e5a39fdda70df1126ab0dc49a7378311a537a1f\": \"0x821ab0d44149800000\",\n \"0x3e5abd09ce5af7ba8487c359e0f2a93a986b0b18\": \"0x21e19e0c9bab2400000\",\n \"0x3e5cb8928c417825c03a3bfcc52183e5c91e42d7\": \"0xe731d9c52c962f0000\",\n \"0x3e5e93fb4c9c9d1246f8f247358e22c3c5d17b6a\": \"0x821ab0d4414980000\",\n \"0x3e618350fa01657ab0ef3ebac8e37012f8fc2b6f\": \"0x9806de3da6e9780000\",\n \"0x3e63ce3b24ca2865b4c5a687b7aea3597ef6e548\": \"0x6c6b935b8bbd400000\",\n \"0x3e66b84769566ab67945d5fa81373556bcc3a1fa\": \"0x83d6c7aab63600000\",\n \"0x3e76a62db187aa74f63817533b306cead0e8cebe\": \"0x69b5afac750bb800000\",\n \"0x3e7a966b5dc357ffb07e9fe067c45791fd8e3049\": \"0x3342d60dff1960000\",\n \"0x3e81772175237eb4cbe0fe2dcafdadffeb6a1999\": \"0x1dd0c885f9a0d800000\",\n \"0x3e8349b67f5745449f659367d9ad4712db5b895a\": \"0x62a992e53a0af00000\",\n \"0x3e83544f0082552572c782bee5d218f1ef064a9d\": \"0x56cd55fc64dfe0000\",\n \"0x3e84b35c5b2265507061d30b6f12da033fe6f8b9\": \"0x61093d7c2c6d380000\",\n \"0x3e8641d43c42003f0a33c929f711079deb2b9e46\": \"0x1b1ae4d6e2ef500000\",\n \"0x3e8745ba322f5fd6cb50124ec46688c7a69a7fae\": \"0x10afc1ade3b4ed40000\",\n \"0x3e914e3018ac00449341c49da71d04dfeeed6221\": \"0xd8d726b7177a800000\",\n \"0x3e9410d3b9a87ed5e451a6b91bb8923fe90fb2b5\": \"0xad78ebc5ac6200000\",\n \"0x3e94df5313fa520570ef232bc3311d5f622ff183\": \"0x6c6b935b8bbd400000\",\n \"0x3e9b34a57f3375ae59c0a75e19c4b641228d9700\": \"0xf8699329677e0000\",\n \"0x3eada8c92f56067e1bb73ce378da56dc2cdfd365\": \"0x77cde93aeb0d480000\",\n \"0x3eaf0879b5b6db159b589f84578b6a74f6c10357\": \"0x18938b671fa65a28000\",\n \"0x3eaf316b87615d88f7adc77c58e712ed4d77966b\": \"0x56dbc4cee24648000\",\n \"0x3eb8b33b21d23cda86d8288884ab470e164691b5\": \"0x1b1ae4d6e2ef500000\",\n \"0x3eb9ef06d0c259040319947e8c7a6812aa0253d8\": \"0x90d972f32323c0000\",\n \"0x3ecc8e1668dde995dc570fe414f44211c534a615\": \"0x6c6b935b8bbd400000\",\n \"0x3ecdb532e397579662b2a46141e78f8235936a5f\": \"0x39fbae8d042dd0000\",\n \"0x3eee6f1e96360b7689b3069adaf9af8eb60ce481\": \"0x3635c9adc5dea00000\",\n \"0x3f08d9ad894f813e8e2148c160d24b353a8e74b0\": \"0xcb49b44ba602d800000\",\n \"0x3f0c83aac5717962734e5ceaeaecd39b28ad06be\": \"0x6c6b935b8bbd400000\",\n \"0x3f10800282d1b7ddc78fa92d8230074e1bf6aeae\": \"0x10afc1ade3b4ed40000\",\n \"0x3f1233714f204de9de4ee96d073b368d8197989f\": \"0x217c41074e6bb0000\",\n \"0x3f173aa6edf469d185e59bd26ae4236b92b4d8e1\": \"0x1158e460913d000000\",\n \"0x3f1bc420c53c002c9e90037c44fe6a8ef4ddc962\": \"0x960db77681e940000\",\n \"0x3f236108eec72289bac3a65cd283f95e041d144c\": \"0x3634bf39ab98788000\",\n \"0x3f2da093bb16eb064f8bfa9e30b929d15f8e1c4c\": \"0x6c6b935b8bbd400000\",\n \"0x3f2dd55db7eab0ebee65b33ed8202c1e992e958b\": \"0x2c73c937742c500000\",\n \"0x3f2f381491797cc5c0d48296c14fd0cd00cdfa2d\": \"0x2b95bdcc39b6100000\",\n \"0x3f30d3bc9f602232bc724288ca46cd0b0788f715\": \"0xd8d726b7177a800000\",\n \"0x3f3c8e61e5604cef0605d436dd22accd862217fc\": \"0x487a9a304539440000\",\n \"0x3f3f46b75cabe37bfacc8760281f4341ca7f463d\": \"0x20ac448235fae88000\",\n \"0x3f472963197883bbda5a9b7dfcb22db11440ad31\": \"0x1a19643cb1eff08000\",\n \"0x3f4cd1399f8a34eddb9a17a471fc922b5870aafc\": \"0xad78ebc5ac6200000\",\n \"0x3f551ba93cd54693c183fb9ad60d65e1609673c9\": \"0x6c6b935b8bbd400000\",\n \"0x3f627a769e6a950eb87017a7cd9ca20871136831\": \"0x2eb8eb1a172dcb80000\",\n \"0x3f6dd3650ee428dcb7759553b017a96a94286ac9\": \"0x487a9a304539440000\",\n \"0x3f747237806fed3f828a6852eb0867f79027af89\": \"0x5150ae84a8cdf00000\",\n \"0x3f75ae61cc1d8042653b5baec4443e051c5e7abd\": \"0x52d542804f1ce0000\",\n \"0x3fb7d197b3ba4fe045efc23d50a14585f558d9b2\": \"0x1158e460913d00000\",\n \"0x3fbc1e4518d73400c6d046359439fb68ea1a49f4\": \"0x3790bb8551376400000\",\n \"0x3fbed6e7e0ca9c84fbe9ebcf9d4ef9bb49428165\": \"0x6c6b935b8bbd400000\",\n \"0x3fd0bb47798cf44cdfbe4d333de637df4a00e45c\": \"0x56c5579f722140000\",\n \"0x3fe40fbd919aad2818df01ee4df46c46842ac539\": \"0x14542ba12a337c00000\",\n \"0x3fe801e61335c5140dc7eda2ef5204460a501230\": \"0x6c6b935b8bbd400000\",\n \"0x3ff836b6f57b901b440c30e4dbd065cf37d3d48c\": \"0xad78ebc5ac6200000\",\n \"0x3ffcb870d4023d255d5167d8a507cefc366b68ba\": \"0x23343c4354d2ac0000\",\n \"0x401354a297952fa972ad383ca07a0a2811d74a71\": \"0xc249fdd327780000\",\n \"0x4030a925706b2c101c8c5cb9bd05fbb4f6759b18\": \"0xd8d726b7177a800000\",\n \"0x403145cb4ae7489fcc90cd985c6dc782b3cc4e44\": \"0x1453ff387b27cac0000\",\n \"0x403220600a36f73f24e190d1edb2d61be3f41354\": \"0x107ad8f556c6c00000\",\n \"0x4039bd50a2bde15ffe37191f410390962a2b8886\": \"0xad78ebc5ac6200000\",\n \"0x403c64896a75cad816a9105e18d8aa5bf80f238e\": \"0x35659ef93f0fc40000\",\n \"0x403d53cf620f0922b417848dee96c190b5bc8271\": \"0x215f835bc769da80000\",\n \"0x404100db4c5d0eec557823b58343758bcc2c8083\": \"0x1158e460913d00000\",\n \"0x4041374b0feef4792e4b33691fb86897a4ff560c\": \"0x13c9647e25a9940000\",\n \"0x40467d80e74c35407b7db51789234615fea66818\": \"0x150894e849b3900000\",\n \"0x40585200683a403901372912a89834aadcb55fdb\": \"0x6c6b935b8bbd400000\",\n \"0x4058808816fdaa3a5fc98ed47cfae6c18315422e\": \"0xad4c8316a0b0c0000\",\n \"0x405f596b94b947344c033ce2dcbff12e25b79784\": \"0x6c6b935b8bbd400000\",\n \"0x40630024bd2c58d248edd8465617b2bf1647da0e\": \"0x3635c9adc5dea00000\",\n \"0x40652360d6716dc55cf9aab21f3482f816cc2cbd\": \"0x21e19e0c9bab2400000\",\n \"0x407295ebd94b48269c2d569c9b9af9aa05e83e5e\": \"0x21e19e0c9bab2400000\",\n \"0x4073fa49b87117cb908cf1ab512da754a932d477\": \"0x6acb3df27e1f880000\",\n \"0x408a69a40715e1b313e1354e600800a1e6dc02a5\": \"0x1e7b891cc92540000\",\n \"0x409bd75085821c1de70cdc3b11ffc3d923c74010\": \"0xd8d726b7177a800000\",\n \"0x409d5a962edeeebea178018c0f38b9cdb213f289\": \"0x1158e460913d00000\",\n \"0x40a331195b977325c2aa28fa2f42cb25ec3c253c\": \"0x6c6b935b8bbd400000\",\n \"0x40a7f72867a7dc86770b162b7557a434ed50cce9\": \"0x3635c9adc5dea00000\",\n \"0x40ab0a3e83d0c8ac9366910520eab1772bac3b1a\": \"0x34f10c2dc05e7c0000\",\n \"0x40ab66fe213ea56c3afb12c75be33f8e32fd085d\": \"0xd8d726b7177a800000\",\n \"0x40ad74bc0bce2a45e52f36c3debb1b3ada1b7619\": \"0x170162de109c6580000\",\n \"0x40cf890591eae4a18f812a2954cb295f633327e6\": \"0x29bf736fc591a0000\",\n \"0x40cf90ef5b768c5da585002ccbe6617650d8e837\": \"0x36330322d5238c0000\",\n \"0x40d45d9d7625d15156c932b771ca7b0527130958\": \"0x152d02c7e14af6800000\",\n \"0x40db1ba585ce34531edec5494849391381e6ccd3\": \"0x61093d7c2c6d380000\",\n \"0x40df495ecf3f8b4cef2a6c189957248fe884bc2b\": \"0x28a857425466f800000\",\n \"0x40e0dbf3efef9084ea1cd7e503f40b3b4a8443f6\": \"0xd8d726b7177a800000\",\n \"0x40e2440ae142c880366a12c6d4102f4b8434b62a\": \"0x3635c9adc5dea00000\",\n \"0x40e3c283f7e24de0410c121bee60a5607f3e29a6\": \"0x3635c9adc5dea00000\",\n \"0x40ea5044b204b23076b1a5803bf1d30c0f88871a\": \"0x2f6f10780d22cc00000\",\n \"0x40eddb448d690ed72e05c225d34fc8350fa1e4c5\": \"0x17b7883c06916600000\",\n \"0x40f4f4c06c732cd35b119b893b127e7d9d0771e4\": \"0x21e19e0c9bab2400000\",\n \"0x41010fc8baf8437d17a04369809a168a17ca56fb\": \"0x56bc75e2d63100000\",\n \"0x4103299671d46763978fa4aa19ee34b1fc952784\": \"0xad78ebc5ac6200000\",\n \"0x41033c1b6d05e1ca89b0948fc64453fbe87ab25e\": \"0x487a9a304539440000\",\n \"0x41098a81452317c19e3eef0bd123bbe178e9e9ca\": \"0x97c9ce4cf6d5c00000\",\n \"0x411610b178d5617dfab934d293f512a93e5c10e1\": \"0x93739534d28680000\",\n \"0x411c831cc6f44f1965ec5757ab4e5b3ca4cffd1f\": \"0x170a0f5040e5040000\",\n \"0x412a68f6c645559cc977fc4964047a201d1bb0e2\": \"0xa968163f0a57b400000\",\n \"0x413f4b02669ccff6806bc826fcb7deca3b0ea9bc\": \"0x1158e460913d00000\",\n \"0x414599092e879ae25372a84d735af5c4e510cd6d\": \"0x15af1d78b58c400000\",\n \"0x41485612d03446ec4c05e5244e563f1cbae0f197\": \"0x34957444b840e80000\",\n \"0x415d096ab06293183f3c033d25f6cf7178ac3bc7\": \"0x22b1c8c1227a00000\",\n \"0x4166fc08ca85f766fde831460e9dc93c0e21aa6c\": \"0x3635c9adc5dea00000\",\n \"0x416784af609630b070d49a8bcd12235c6428a408\": \"0x43c33c1937564800000\",\n \"0x4167cd48e733418e8f99ffd134121c4a4ab278c4\": \"0xc55325ca7415e00000\",\n \"0x416c86b72083d1f8907d84efd2d2d783dffa3efb\": \"0x6c6acc67d7b1d40000\",\n \"0x4173419d5c9f6329551dc4d3d0ceac1b701b869e\": \"0x4c53ecdc18a600000\",\n \"0x4174fa1bc12a3b7183cbabb77a0b59557ba5f1db\": \"0x6c6b935b8bbd400000\",\n \"0x41786a10d447f484d33244ccb7facd8b427b5b8c\": \"0x3635c9adc5dea00000\",\n \"0x417a3cd19496530a6d4204c3b5a17ce0f207b1a5\": \"0x1b1ae4d6e2ef5000000\",\n \"0x417e4e2688b1fd66d821529e46ed4f42f8b3db3d\": \"0x6c6b935b8bbd400000\",\n \"0x419a71a36c11d105e0f2aef5a3e598078e85c80b\": \"0x10f0cf064dd59200000\",\n \"0x419bde7316cc1ed295c885ace342c79bf7ee33ea\": \"0x14542ba12a337c00000\",\n \"0x41a2f2e6ecb86394ec0e338c0fc97e9c5583ded2\": \"0x6cee06ddbe15ec0000\",\n \"0x41a8c2830081b102df6e0131657c07ab635b54ce\": \"0x6c6acc67d7b1d40000\",\n \"0x41a8e236a30e6d63c1ff644d132aa25c89537e01\": \"0x1158e460913d00000\",\n \"0x41a9a404fc9f5bfee48ec265b12523338e29a8bf\": \"0x150894e849b3900000\",\n \"0x41ad369f758fef38a19aa3149379832c818ef2a0\": \"0x36369ed7747d260000\",\n \"0x41b2d34fde0b1029262b4172c81c1590405b03ae\": \"0x3635c9adc5dea00000\",\n \"0x41b2dbd79dda9b864f6a7030275419c39d3efd3b\": \"0xad78ebc5ac62000000\",\n \"0x41c3c2367534d13ba2b33f185cdbe6ac43c2fa31\": \"0xd8d726b7177a800000\",\n \"0x41cb9896445f70a10a14215296daf614e32cf4d5\": \"0x678a932062e4180000\",\n \"0x41ce79950935cff55bf78e4ccec2fe631785db95\": \"0x6c6b935b8bbd400000\",\n \"0x41d3b731a326e76858baa5f4bd89b57b36932343\": \"0x155bd9307f9fe80000\",\n \"0x41e4a20275e39bdcefeb655c0322744b765140c2\": \"0x21e19e0c9bab2400000\",\n \"0x41ed2d8e7081482c919fc23d8f0091b3c82c4685\": \"0x463a1e765bd78a0000\",\n \"0x41f27e744bd29de2b0598f02a0bb9f98e681eaa4\": \"0x1a4aba225c207400000\",\n \"0x41f489a1ec747bc29c3e5f9d8db97877d4d1b4e9\": \"0x73f75d1a085ba0000\",\n \"0x420fb86e7d2b51401fc5e8c72015decb4ef8fc2e\": \"0x3635c9adc5dea00000\",\n \"0x421684baa9c0b4b5f55338e6f6e7c8e146d41cb7\": \"0x5150ae84a8cdf00000\",\n \"0x42399659aca6a5a863ea2245c933fe9a35b7880e\": \"0x6ece32c26c82700000\",\n \"0x423bca47abc00c7057e3ad34fca63e375fbd8b4a\": \"0x3cfc82e37e9a7400000\",\n \"0x423c3107f4bace414e499c64390a51f74615ca5e\": \"0x6c6b935b8bbd400000\",\n \"0x423cc4594cf4abb6368de59fd2b1230734612143\": \"0x6c6b935b8bbd400000\",\n \"0x4244f1331158b9ce26bbe0b9236b9203ca351434\": \"0x21e19e0c9bab2400000\",\n \"0x425177eb74ad0a9d9a5752228147ee6d6356a6e6\": \"0xb98bc829a6f90000\",\n \"0x425725c0f08f0811f5f006eec91c5c5c126b12ae\": \"0x821ab0d4414980000\",\n \"0x4258fd662fc4ce3295f0d4ed8f7bb1449600a0a9\": \"0x16c452ed6088ad80000\",\n \"0x425c1816868f7777cc2ba6c6d28c9e1e796c52b3\": \"0x21e19e0c9bab2400000\",\n \"0x425c338a1325e3a1578efa299e57d986eb474f81\": \"0x6c6b935b8bbd400000\",\n \"0x426259b0a756701a8b663528522156c0288f0f24\": \"0x218ae196b8d4f300000\",\n \"0x426d15f407a01135b13a6b72f8f2520b3531e302\": \"0x1158e460913d00000\",\n \"0x426f78f70db259ac8534145b2934f4ef1098b5d8\": \"0x138400eca364a00000\",\n \"0x42732d8ef49ffda04b19780fd3c18469fb374106\": \"0x170b00e5e4a9be0000\",\n \"0x427417bd16b1b3d22dbb902d8f9657016f24a61c\": \"0x6c6b935b8bbd400000\",\n \"0x42746aeea14f27beff0c0da64253f1e7971890a0\": \"0x54069233bf7f780000\",\n \"0x427b462ab84e5091f48a46eb0cdc92ddcb26e078\": \"0x6c6b935b8bbd400000\",\n \"0x427e4751c3babe78cff8830886febc10f9908d74\": \"0x6acb3df27e1f880000\",\n \"0x427ec668ac9404e895cc861511d1620a4912be98\": \"0x878678326eac9000000\",\n \"0x4280a58f8bb10b9440de94f42b4f592120820191\": \"0x6c6b935b8bbd400000\",\n \"0x428a1ee0ed331d7952ccbe1c7974b2852bd1938a\": \"0x77b74a4e8de5650000\",\n \"0x429c06b487e8546abdfc958a25a3f0fba53f6f00\": \"0xbb644af542198000\",\n \"0x42a98bf16027ce589c4ed2c95831e2724205064e\": \"0x21e19e0c9bab2400000\",\n \"0x42c6edc515d35557808d13cd44dcc4400b2504e4\": \"0xaba14c59ba7320000\",\n \"0x42cecfd2921079c2d7df3f08b07aa3beee5e219a\": \"0x3635c9adc5dea00000\",\n \"0x42d1a6399b3016a8597f8b640927b8afbce4b215\": \"0xa18bcec34888100000\",\n \"0x42d34940edd2e7005d46e2188e4cfece8311d74d\": \"0x890b0c2e14fb80000\",\n \"0x42d3a5a901f2f6bd9356f112a70180e5a1550b60\": \"0x3224f42723d4540000\",\n \"0x42d6b263d9e9f4116c411424fc9955783c763030\": \"0x6c6b935b8bbd400000\",\n \"0x42db0b902559e04087dd5c441bc7611934184b89\": \"0x6d33b17d253a620000\",\n \"0x42ddd014dc52bfbcc555325a40b516f4866a1dd3\": \"0x6c6b935b8bbd400000\",\n \"0x4319263f75402c0b5325f263be4a5080651087f0\": \"0x354b0f14631bab0000\",\n \"0x431f2c19e316b044a4b3e61a0c6ff8c104a1a12f\": \"0x3635c9adc5dea00000\",\n \"0x43227d65334e691cf231b4a4e1d339b95d598afb\": \"0x21e19e0c9bab2400000\",\n \"0x432809a2390f07c665921ff37d547d12f1c9966a\": \"0x65a4da25d3016c00000\",\n \"0x4329fc0931cbeb033880fe4c9398ca45b0e2d11a\": \"0x6c7120716d33680000\",\n \"0x432d884bd69db1acc0d89c64ade4cb4fc3a88b7a\": \"0x869a8c10808eec0000\",\n \"0x4331ab3747d35720a9d8ca25165cd285acd4bda8\": \"0x6c6b935b8bbd400000\",\n \"0x433a3b68e56b0df1862b90586bbd39c840ff1936\": \"0x6c6b935b8bbd400000\",\n \"0x433e3ba1c51b810fc467d5ba4dea42f7a9885e69\": \"0x878678326eac9000000\",\n \"0x433eb94a339086ed12d9bde9cd1d458603c97dd6\": \"0x152d02c7e14af6800000\",\n \"0x4349225a62f70aea480a029915a01e5379e64fa5\": \"0x8cd67e2334c0d80000\",\n \"0x4354221e62dc09e6406436163a185ef06d114a81\": \"0x6c6b935b8bbd400000\",\n \"0x435443b81dfdb9bd8c6787bc2518e2d47e57c15f\": \"0x1438d9397881ef20000\",\n \"0x4361d4846fafb377b6c0ee49a596a78ddf3516a3\": \"0xc2127af858da700000\",\n \"0x4364309a9fa07095600f79edc65120cdcd23dc64\": \"0x21e19e0c9bab2400000\",\n \"0x4367ae4b0ce964f4a54afd4b5c368496db169e9a\": \"0x6c6b935b8bbd400000\",\n \"0x43748928e8c3ec4436a1d092fbe43ac749be1251\": \"0x15af1d78b58c400000\",\n \"0x43767bf7fd2af95b72e9312da9443cb1688e4343\": \"0x1043561a8829300000\",\n \"0x437983388ab59a4ffc215f8e8269461029c3f1c1\": \"0x43c33c1937564800000\",\n \"0x43898c49a34d509bfed4f76041ee91caf3aa6aa5\": \"0x1043561a8829300000\",\n \"0x438c2f54ff8e629bab36b1442b760b12a88f02ae\": \"0x6c6b935b8bbd400000\",\n \"0x4398628ea6632d393e929cbd928464c568aa4a0c\": \"0x4be4e7267b6ae00000\",\n \"0x439d2f2f5110a4d58b1757935015408740fec7f8\": \"0xcfa5c5150f4c888000\",\n \"0x439dee3f7679ff1030733f9340c096686b49390b\": \"0x6c6b935b8bbd400000\",\n \"0x43b079baf0727999e66bf743d5bcbf776c3b0922\": \"0x6c6b935b8bbd400000\",\n \"0x43bc2d4ddcd6583be2c7bc094b28fb72e62ba83b\": \"0x6c6b935b8bbd400000\",\n \"0x43c7ebc5b3e7af16f47dc5617ab10e0f39b4afbb\": \"0x678a932062e4180000\",\n \"0x43cb9652818c6f4d6796b0e89409306c79db6349\": \"0x6c6b935b8bbd400000\",\n \"0x43cc08d0732aa58adef7619bed46558ad7774173\": \"0xf0e7dcb0122a8f0000\",\n \"0x43d5a71ce8b8f8ae02b2eaf8eaf2ca2840b93fb6\": \"0x14542ba12a337c00000\",\n \"0x43db7ff95a086d28ebbfb82fb8fb5f230a5ebccd\": \"0xdf6eb0b2d3ca0000\",\n \"0x43e7ec846358d7d0f937ad1c350ba069d7bf72bf\": \"0x670ae629214680000\",\n \"0x43f16f1e75c3c06a9478e8c597a40a3cb0bf04cc\": \"0x9df7dfa8f760480000\",\n \"0x43f470ed659e2991c375957e5ddec5bd1d382231\": \"0x56bc75e2d63100000\",\n \"0x43f7e86e381ec51ec4906d1476cba97a3db584e4\": \"0x3635c9adc5dea00000\",\n \"0x43ff38743ed0cd43308c066509cc8e7e72c862aa\": \"0x692ae8897081d00000\",\n \"0x43ff8853e98ed8406b95000ada848362d6a0392a\": \"0x4ae0b1c4d2e84d00000\",\n \"0x44098866a69b68c0b6bc168229b9603587058967\": \"0xa31062beeed700000\",\n \"0x4419ac618d5dea7cdc6077206fb07dbdd71c1702\": \"0xd8d726b7177a800000\",\n \"0x441a52001661fac718b2d7b351b7c6fb521a7afd\": \"0x15af1d78b58c400000\",\n \"0x441aca82631324acbfa2468bda325bbd78477bbf\": \"0x14542ba12a337c00000\",\n \"0x441f37e8a029fd02482f289c49b5d06d00e408a4\": \"0x1211ecb56d13488000\",\n \"0x4420aa35465be617ad2498f370de0a3cc4d230af\": \"0x6c6b935b8bbd400000\",\n \"0x44232ff66ddad1fd841266380036afd7cf7d7f42\": \"0xad78ebc5ac6200000\",\n \"0x44250d476e062484e9080a3967bf3a4a732ad73f\": \"0x1158e460913d00000\",\n \"0x4429a29fee198450672c0c1d073162250bec6474\": \"0x362aaf8202f2500000\",\n \"0x44355253b27748e3f34fe9cae1fb718c8f249529\": \"0xad78ebc5ac6200000\",\n \"0x4438e880cb2766b0c1ceaec9d2418fceb952a044\": \"0x73fa073903f080000\",\n \"0x444caf79b71338ee9aa7c733b02acaa7dc025948\": \"0x22b1c8c1227a00000\",\n \"0x445cb8de5e3df520b499efc980f52bff40f55c76\": \"0x6c6b935b8bbd400000\",\n \"0x446a8039cecf9dce4879cbcaf3493bf545a88610\": \"0x17b7883c06916600000\",\n \"0x4474299d0ee090dc90789a1486489c3d0d645e6d\": \"0x3635c9adc5dea00000\",\n \"0x448bf410ad9bbc2fecc4508d87a7fc2e4b8561ad\": \"0xad6eedd17cf3b8000\",\n \"0x44901e0d0e08ac3d5e95b8ec9d5e0ff5f12e0393\": \"0x16a1f9f5fd7d960000\",\n \"0x4493123c021ece3b33b1a452c9268de14007f9d3\": \"0x16a6502f15a1e540000\",\n \"0x449ac4fbe383e36738855e364a57f471b2bfa131\": \"0x29b76432b94451200000\",\n \"0x44a01fb04ac0db2cce5dbe281e1c46e28b39d878\": \"0x6c6acc67d7b1d40000\",\n \"0x44a63d18424587b9b307bfc3c364ae10cd04c713\": \"0x1158e460913d00000\",\n \"0x44a8989e32308121f72466978db395d1f76c3a4b\": \"0x18850299f42b06a0000\",\n \"0x44c1110b18870ec81178d93d215838c551d48e64\": \"0xad6f98593bd8f0000\",\n \"0x44c14765127cde11fab46c5d2cf4d4b2890023fd\": \"0x6c6b935b8bbd400000\",\n \"0x44c54eaa8ac940f9e80f1e74e82fc14f1676856a\": \"0x1ab2cf7c9f87e200000\",\n \"0x44cd77535a893fa7c4d5eb3a240e79d099a72d2d\": \"0x2c73c937742c500000\",\n \"0x44dfba50b829becc5f4f14d1b04aab3320a295e5\": \"0x3635c9adc5dea00000\",\n \"0x44e2fdc679e6bee01e93ef4a3ab1bcce012abc7c\": \"0x163d194900c5458000\",\n \"0x44f62f2aaabc29ad3a6b04e1ff6f9ce452d1c140\": \"0x39992648a23c8a00000\",\n \"0x44fff37be01a3888d3b8b8e18880a7ddefeeead3\": \"0xe0c5bfc7dae9a8000\",\n \"0x4506fe19fa4b006baa3984529d8516db2b2b50ab\": \"0x6c6b935b8bbd400000\",\n \"0x451b3699475bed5d7905f8905aa3456f1ed788fc\": \"0x8ac7230489e8000000\",\n \"0x451b7070259bdba27100e36e23428a53dfe304e9\": \"0xb98bc829a6f90000\",\n \"0x45272b8f62e9f9fa8ce04420e1aea3eba9686eac\": \"0xd8d726b7177a800000\",\n \"0x452b64db8ef7d6df87c788639c2290be8482d575\": \"0x1b1ae4d6e2ef5000000\",\n \"0x453e359a3397944c5a275ab1a2f70a5e5a3f6989\": \"0xd02ab486cedc00000\",\n \"0x4549b15979255f7e65e99b0d5604db98dfcac8bf\": \"0xd8d726b7177a800000\",\n \"0x454b61b344c0ef965179238155f277c3829d0b38\": \"0x6c6b935b8bbd400000\",\n \"0x454f0141d721d33cbdc41018bd01119aa4784818\": \"0x14542ba12a337c00000\",\n \"0x45533390e340fe0de3b3cf5fb9fc8ea552e29e62\": \"0x4f2591f896a6500000\",\n \"0x455396a4bbd9bae8af9fb7c4d64d471db9c24505\": \"0x8ba52e6fc45e40000\",\n \"0x455b9296921a74d1fc41617f43b8303e6f3ed76c\": \"0xe3aeb5737240a00000\",\n \"0x455cb8ee39ffbc752331e5aefc588ef0ee593454\": \"0x3635463a780def8000\",\n \"0x456ae0aca48ebcfae166060250525f63965e760f\": \"0x1043561a8829300000\",\n \"0x456f8d746682b224679349064d1b368c7c05b176\": \"0xc893d09c8f51500000\",\n \"0x457029c469c4548d168cec3e65872e4428d42b67\": \"0x6c6b935b8bbd400000\",\n \"0x4571de672b9904bad8743692c21c4fdcea4c2e01\": \"0xd8d726b7177a800000\",\n \"0x45781bbe7714a1c8f73b1c747921df4f84278b70\": \"0x6c6b935b8bbd400000\",\n \"0x457bcef37dd3d60b2dd019e3fe61d46b3f1e7252\": \"0x1158e460913d00000\",\n \"0x458e3cc99e947844a18e6a42918fef7e7f5f5eb3\": \"0x7b53f79e888dac00000\",\n \"0x459393d63a063ef3721e16bd9fde45ee9dbd77fb\": \"0x6abad6a3c153050000\",\n \"0x45a570dcc2090c86a6b3ea29a60863dde41f13b5\": \"0xc9a95ee2986520000\",\n \"0x45a820a0672f17dc74a08112bc643fd1167736c3\": \"0xad6c43b2815ed8000\",\n \"0x45b47105fe42c4712dce6e2a21c05bffd5ea47a9\": \"0x6c6b935b8bbd400000\",\n \"0x45bb829652d8bfb58b8527f0ecb621c29e212ec3\": \"0x6c6b935b8bbd400000\",\n \"0x45c0d19f0b8e054f9e893836d5ecae7901af2812\": \"0x10f0cf064dd59200000\",\n \"0x45c4ecb4ee891ea984a7c5cefd8dfb00310b2850\": \"0x6b56051582a9700000\",\n \"0x45ca8d956608f9e00a2f9974028640888465668f\": \"0x6c6b935b8bbd400000\",\n \"0x45ca9862003b4e40a3171fb5cafa9028cac8de19\": \"0x2eb8eb1a172dcb80000\",\n \"0x45d1c9eedf7cab41a779057b79395f5428d80528\": \"0x6c6b935b8bbd400000\",\n \"0x45d4b54d37a8cf599821235f062fa9d170ede8a4\": \"0x1190673b5fda900000\",\n \"0x45db03bccfd6a5f4d0266b82a22a368792c77d83\": \"0x1b1ae4d6e2ef5000000\",\n \"0x45e3a93e72144ada860cbc56ff85145ada38c6da\": \"0x57473d05dabae80000\",\n \"0x45e68db8dbbaba5fc2cb337c62bcd0d61b059189\": \"0x6c6b935b8bbd400000\",\n \"0x45e68db94c7d0ab7ac41857a71d67147870f4e71\": \"0x54b40b1f852bda000000\",\n \"0x45f4fc60f08eaca10598f0336329801e3c92cb46\": \"0xad78ebc5ac6200000\",\n \"0x460d5355b2ceeb6e62107d81e51270b26bf45620\": \"0x6cb7e74867d5e60000\",\n \"0x46224f32f4ece5c8867090d4409d55e50b18432d\": \"0x14542ba12a337c00000\",\n \"0x4627c606842671abde8295ee5dd94c7f549534f4\": \"0xf895fbd8732f40000\",\n \"0x462b678b51b584f3ed7ada070b5cd99c0bf7b87f\": \"0x56bc75e2d63100000\",\n \"0x464d9c89cce484df000277198ed8075fa63572d1\": \"0x1158e460913d00000\",\n \"0x46504e6a215ac83bccf956befc82ab5a679371c8\": \"0x1c212805c2b4a50000\",\n \"0x4651dc420e08c3293b27d2497890eb50223ae2f4\": \"0x43c33c1937564800000\",\n \"0x46531e8b1bde097fdf849d6d119885608a008df7\": \"0xad78ebc5ac6200000\",\n \"0x466292f0e80d43a78774277590a9eb45961214f4\": \"0x34957444b840e80000\",\n \"0x4662a1765ee921842ddc88898d1dc8627597bd7e\": \"0x21e19e0c9bab2400000\",\n \"0x4665e47396c7db97eb2a03d90863d5d4ba319a94\": \"0x2086ac351052600000\",\n \"0x466fda6b9b58c5532750306a10a2a8c768103b07\": \"0xad6eedd17cf3b8000\",\n \"0x467124ae7f452f26b3d574f6088894fa5d1cfb3b\": \"0x925e06eec972b00000\",\n \"0x46722a36a01e841d03f780935e917d85d5a67abd\": \"0xcec76f0e71520000\",\n \"0x46779a5656ff00d73eac3ad0c38b6c853094fb40\": \"0xc8253c96c6af00000\",\n \"0x4677b04e0343a32131fd6abb39b1b6156bba3d5b\": \"0xad78ebc5ac6200000\",\n \"0x467d5988249a68614716659840ed0ae6f6f457bc\": \"0x1501a48cefdfde0000\",\n \"0x467e0ed54f3b76ae0636176e07420815a021736e\": \"0x6c6b935b8bbd400000\",\n \"0x467ea10445827ef1e502daf76b928a209e0d4032\": \"0x6c6b935b8bbd400000\",\n \"0x467fbf41441600757fe15830c8cd5f4ffbbbd560\": \"0x21e19e0c9bab2400000\",\n \"0x469358709332c82b887e20bcddd0220f8edba7d0\": \"0x3a9d5baa4abf1d00000\",\n \"0x4697baaf9ccb603fd30430689d435445e9c98bf5\": \"0xad201a6794ff80000\",\n \"0x46a30b8a808931217445c3f5a93e882c0345b426\": \"0xd8db5ebd7b2638000\",\n \"0x46a430a2d4a894a0d8aa3feac615361415c3f81f\": \"0x6c6b935b8bbd400000\",\n \"0x46aa501870677e7f0a504876b4e8801a0ad01c46\": \"0x2b5e3af16b18800000\",\n \"0x46bfc5b207eb2013e2e60f775fecd71810c5990c\": \"0x54069233bf7f780000\",\n \"0x46c1aa2244b9c8a957ca8fac431b0595a3b86824\": \"0xd8d726b7177a800000\",\n \"0x46d80631284203f6288ecd4e5758bb9d41d05dbe\": \"0x6c6b935b8bbd400000\",\n \"0x470ac5d1f3efe28f3802af925b571e63868b397d\": \"0x6c6b935b8bbd400000\",\n \"0x471010da492f4018833b088d9872901e06129174\": \"0x1b1ae4d6e2ef500000\",\n \"0x4712540265cbeec3847022c59f1b318d43400a9e\": \"0xbdbc41e0348b300000\",\n \"0x4714cfa4f46bd6bd70737d75878197e08f88e631\": \"0x27f3edfb34e6e400000\",\n \"0x472048cc609aeb242165eaaa8705850cf3125de0\": \"0x3635c9adc5dea00000\",\n \"0x47219229e8cd56659a65c2a943e2dd9a8f4bfd89\": \"0x52663ccab1e1c00000\",\n \"0x4737d042dc6ae73ec73ae2517acea2fdd96487c5\": \"0x3635c9adc5dea00000\",\n \"0x474158a1a9dc693c133f65e47b5c3ae2f773a86f\": \"0xada55474b81340000\",\n \"0x4745ab181a36aa8cbf2289d0c45165bc7ebe2381\": \"0x222c8eb3ff6640000\",\n \"0x475066f9ad26655196d5535327bbeb9b7929cb04\": \"0xa4cc799563c3800000\",\n \"0x4752218e54de423f86c0501933917aea08c8fed5\": \"0x43c33c1937564800000\",\n \"0x475a6193572d4a4e59d7be09cb960ddd8c530e2f\": \"0x242cf78cdf07ff8000\",\n \"0x47648bed01f3cd3249084e635d14daa9e7ec3c8a\": \"0xa844a7424d9c80000\",\n \"0x47688410ff25d654d72eb2bc06e4ad24f833b094\": \"0x8b28d61f3d3ac0000\",\n \"0x476b5599089a3fb6f29c6c72e49b2e4740ea808d\": \"0x97c9ce4cf6d5c00000\",\n \"0x47730f5f8ebf89ac72ef80e46c12195038ecdc49\": \"0xab4dcf399a3a600000\",\n \"0x477b24eee8839e4fd19d1250bd0b6645794a61ca\": \"0x1b1ae4d6e2ef5000000\",\n \"0x4781a10a4df5eebc82f4cfe107ba1d8a7640bd66\": \"0x61093d7c2c6d380000\",\n \"0x47885ababedf4d928e1c3c71d7ca40d563ed595f\": \"0x62a992e53a0af00000\",\n \"0x478dc09a1311377c093f9cc8ae74111f65f82f39\": \"0xd8d726b7177a800000\",\n \"0x478e524ef2a381d70c82588a93ca7a5fa9d51cbf\": \"0x35fa97226f8899700000\",\n \"0x479298a9de147e63a1c7d6d2fce089c7e64083bd\": \"0x21e19dd3c3c0d798000\",\n \"0x479abf2da4d58716fd973a0d13a75f530150260a\": \"0x1158e460913d00000\",\n \"0x47a281dff64167197855bf6e705eb9f2cef632ea\": \"0x3636c9796436740000\",\n \"0x47beb20f759100542aa93d41118b3211d664920e\": \"0x6c6b935b8bbd400000\",\n \"0x47c247f53b9fbeb17bba0703a00c009fdb0f6eae\": \"0x43c33c1937564800000\",\n \"0x47c7e5efb48b3aed4b7c6e824b435f357df4c723\": \"0xfc936392801c0000\",\n \"0x47cf9cdaf92fc999cc5efbb7203c61e4f1cdd4c3\": \"0x71f8a93d01e540000\",\n \"0x47d20e6ae4cad3f829eac07e5ac97b66fdd56cf5\": \"0x3635c9adc5dea00000\",\n \"0x47d792a756779aedf1343e8883a6619c6c281184\": \"0x6c6b935b8bbd400000\",\n \"0x47e25df8822538a8596b28c637896b4d143c351d\": \"0x110be9eb24b881500000\",\n \"0x47f4696bd462b20da09fb83ed2039818d77625b3\": \"0x813ca56906d340000\",\n \"0x47fef58584465248a0810d60463ee93e5a6ee8d3\": \"0xf58cd3e1269160000\",\n \"0x47ff6feb43212060bb1503d7a397fc08f4e70352\": \"0x6c6b935b8bbd400000\",\n \"0x47fff42c678551d141eb75a6ee398117df3e4a8d\": \"0x56beae51fd2d10000\",\n \"0x48010ef3b8e95e3f308f30a8cb7f4eb4bf60d965\": \"0x6c6b935b8bbd400000\",\n \"0x480af52076009ca73781b70e43b95916a62203ab\": \"0x321972f4083d878000\",\n \"0x480f31b989311e4124c6a7465f5a44094d36f9d0\": \"0x3790bb855137640000\",\n \"0x481115296ab7db52492ff7b647d63329fb5cbc6b\": \"0x368c8623a8b4d100000\",\n \"0x481e3a91bfdc2f1c8428a0119d03a41601417e1c\": \"0x3635c9adc5dea00000\",\n \"0x4828e4cbe34e1510afb72c2beeac8a4513eaebd9\": \"0xd5967be4fc3f100000\",\n \"0x482982ac1f1c6d1721feecd9b9c96cd949805055\": \"0x21e19e0c9bab2400000\",\n \"0x48302c311ef8e5dc664158dd583c81194d6e0d58\": \"0xb6676ce0bccb5c0000\",\n \"0x483ba99034e900e3aedf61499d3b2bce39beb7aa\": \"0x35659ef93f0fc40000\",\n \"0x48548b4ba62bcb2f0d34a88dc69a680e539cf046\": \"0x56cf1cbbb74320000\",\n \"0x4863849739265a63b0a2bf236a5913e6f959ce15\": \"0x52663ccab1e1c00000\",\n \"0x48659d8f8c9a2fd44f68daa55d23a608fbe500dc\": \"0x6c6b935b8bbd400000\",\n \"0x48669eb5a801d8b75fb6aa58c3451b7058c243bf\": \"0x68d42c138dab9f00000\",\n \"0x486a6c8583a84484e3df43a123837f8c7e2317d0\": \"0x1187c571ab80450000\",\n \"0x487adf7d70a6740f8d51cbdd68bb3f91c4a5ce68\": \"0x39fbae8d042dd0000\",\n \"0x487e108502b0b189ef9c8c6da4d0db6261eec6c0\": \"0x678a932062e4180000\",\n \"0x4888fb25cd50dbb9e048f41ca47d78b78a27c7d9\": \"0x3a9d5baa4abf1d00000\",\n \"0x489334c2b695c8ee0794bd864217fb9fd8f8b135\": \"0xfc936392801c0000\",\n \"0x48a30de1c919d3fd3180e97d5f2b2a9dbd964d2d\": \"0x2629f66e0c5300000\",\n \"0x48bf14d7b1fc84ebf3c96be12f7bce01aa69b03e\": \"0x68155a43676e00000\",\n \"0x48c2ee91a50756d8ce9abeeb7589d22c6fee5dfb\": \"0xae8e7a0bb575d00000\",\n \"0x48c5c6970b9161bb1c7b7adfed9cdede8a1ba864\": \"0xd8d726b7177a800000\",\n \"0x48d2434b7a7dbbff08223b6387b05da2e5093126\": \"0x3cfc82e37e9a7400000\",\n \"0x48d4f2468f963fd79a006198bb67895d2d5aa4d3\": \"0x4be4e7267b6ae00000\",\n \"0x48e0cbd67f18acdb7a6291e1254db32e0972737f\": \"0x56be03ca3e47d8000\",\n \"0x48f60a35484fe7792bcc8a7b6393d0dda1f6b717\": \"0xc328093e61ee400000\",\n \"0x48f883e567b436a27bb5a3124dbc84dec775a800\": \"0x29d76e869dcd800000\",\n \"0x490145afa8b54522bb21f352f06da5a788fa8f1d\": \"0x1f46c62901a03fb0000\",\n \"0x4909b31998ead414b8fb0e846bd5cbde393935be\": \"0xd8d726b7177a800000\",\n \"0x4912d902931676ff39fc34fe3c3cc8fb2182fa7a\": \"0x1158e460913d00000\",\n \"0x49136fe6e28b7453fcb16b6bbbe9aaacba8337fd\": \"0x6c6b935b8bbd400000\",\n \"0x491561db8b6fafb9007e62d050c282e92c4b6bc8\": \"0x65a4da25d3016c00000\",\n \"0x49185dd7c23632f46c759473ebae966008cd3598\": \"0xdc55fdb17647b0000\",\n \"0x492cb5f861b187f9df21cd4485bed90b50ffe22d\": \"0x1b19e50b44977c0000\",\n \"0x492de46aaf8f1d708d59d79af1d03ad2cb60902f\": \"0x6c6b935b8bbd400000\",\n \"0x492e70f04d18408cb41e25603730506b35a2876b\": \"0x222c8eb3ff6640000\",\n \"0x493a67fe23decc63b10dda75f3287695a81bd5ab\": \"0x2fb474098f67c00000\",\n \"0x493d48bda015a9bfcf1603936eab68024ce551e0\": \"0x138a388a43c000000\",\n \"0x494256e99b0f9cd6e5ebca3899863252900165c8\": \"0x2f6f10780d22cc00000\",\n \"0x494dec4d5ee88a2771a815f1ee7264942fb58b28\": \"0x6c6b935b8bbd400000\",\n \"0x495b641b1cdea362c3b4cbbd0f5cc50b1e176b9c\": \"0x3635c9adc5dea00000\",\n \"0x4968a2cedb457555a139295aea28776e54003c87\": \"0x2231aefc9a6628f0000\",\n \"0x496d365534530a5fc1577c0a5241cb88c4da7072\": \"0x61093d7c2c6d380000\",\n \"0x496e319592b341eaccd778dda7c8196d54cac775\": \"0x1f5718987664b480000\",\n \"0x496f5843f6d24cd98d255e4c23d1e1f023227545\": \"0x5f179fd4a6ee098000\",\n \"0x4970d3acf72b5b1f32a7003cf102c64ee0547941\": \"0x1da56a4b0835bf800000\",\n \"0x4977a7939d0939689455ce2639d0ee5a4cd910ed\": \"0x62a992e53a0af00000\",\n \"0x4979194ec9e97db9bee8343b7c77d9d7f3f1dc9f\": \"0x1158e460913d00000\",\n \"0x49793463e1681083d6abd6e725d5bba745dccde8\": \"0x1d98e94c4e471f0000\",\n \"0x4981c5ff66cc4e9680251fc4cd2ff907cb327865\": \"0x28a857425466f80000\",\n \"0x49897fe932bbb3154c95d3bce6d93b6d732904dd\": \"0xd8d726b7177a800000\",\n \"0x4989e1ab5e7cd00746b3938ef0f0d064a2025ba5\": \"0x6c6b935b8bbd400000\",\n \"0x498abdeb14c26b7b7234d70fceaef361a76dff72\": \"0xa2a15d09519be00000\",\n \"0x49a645e0667dfd7b32d075cc2467dd8c680907c4\": \"0x70601958fcb9c0000\",\n \"0x49b74e169265f01a89ec4c9072c5a4cd72e4e835\": \"0x368c8623a8b4d100000\",\n \"0x49bdbc7ba5abebb6389e91a3285220d3451bd253\": \"0x3635c9adc5dea00000\",\n \"0x49c941e0e5018726b7290fc473b471d41dae80d1\": \"0x1b1ae4d6e2ef500000\",\n \"0x49c9771fca19d5b9d245c891f8158fe49f47a062\": \"0x21e19e0c9bab2400000\",\n \"0x49cf1e54be363106b920729d2d0ba46f0867989a\": \"0xe873f44133cb00000\",\n \"0x49d2c28ee9bc545eaaf7fd14c27c4073b4bb5f1a\": \"0x4fe9b806b40daf0000\",\n \"0x49ddee902e1d0c99d1b11af3cc8a96f78e4dcf1a\": \"0xacea5e4c18c530000\",\n \"0x49f028395b5a86c9e07f7778630e4c2e3d373a77\": \"0x6a74a5038db918000\",\n \"0x4a192035e2619b24b0709d56590e9183ccf2c1d9\": \"0x21e19e0c9bab2400000\",\n \"0x4a4053b31d0ee5dbafb1d06bd7ac7ff3222c47d6\": \"0x4be4e7267b6ae00000\",\n \"0x4a430170152de5172633dd8262d107a0afd96a0f\": \"0xab4dcf399a3a600000\",\n \"0x4a47fc3e177f567a1e3893e000e36bba23520ab8\": \"0x6c6b935b8bbd400000\",\n \"0x4a52bad20357228faa1e996bed790c93674ba7d0\": \"0x487a9a304539440000\",\n \"0x4a53dcdb56ce4cdce9f82ec0eb13d67352e7c88b\": \"0xe3aeb5737240a00000\",\n \"0x4a5fae3b0372c230c125d6d470140337ab915656\": \"0x56bc75e2d631000000\",\n \"0x4a719061f5285495b37b9d7ef8a51b07d6e6acac\": \"0xad4c8316a0b0c0000\",\n \"0x4a73389298031b8816cca946421c199e18b343d6\": \"0x223868b879146f0000\",\n \"0x4a735d224792376d331367c093d31c8794341582\": \"0x66ffcbfd5e5a300000\",\n \"0x4a7494cce44855cc80582842be958a0d1c0072ee\": \"0x821ab0d44149800000\",\n \"0x4a75c3d4fa6fccbd5dd5a703c15379a1e783e9b7\": \"0x62a992e53a0af00000\",\n \"0x4a81abe4984c7c6bef63d69820e55743c61f201c\": \"0x36401004e9aa3470000\",\n \"0x4a82694fa29d9e213202a1a209285df6e745c209\": \"0xd8d726b7177a800000\",\n \"0x4a835c25824c47ecbfc79439bf3f5c3481aa75cd\": \"0x4be4e7267b6ae00000\",\n \"0x4a918032439159bb315b6725b6830dc83697739f\": \"0x12a32ef678334c0000\",\n \"0x4a97e8fcf4635ea7fc5e96ee51752ec388716b60\": \"0x1d9945ab2b03480000\",\n \"0x4a9a26fd0a8ba10f977da4f77c31908dab4a8016\": \"0x61093d7c2c6d380000\",\n \"0x4aa148c2c33401e66a2b586e6577c4b292d3f240\": \"0xbb860b285f7740000\",\n \"0x4aa693b122f314482a47b11cc77c68a497876162\": \"0x6acb3df27e1f880000\",\n \"0x4ab2d34f04834fbf7479649cab923d2c4725c553\": \"0xbed1d0263d9f000000\",\n \"0x4ac07673e42f64c1a25ec2fa2d86e5aa2b34e039\": \"0x6c6b935b8bbd400000\",\n \"0x4ac5acad000b8877214cb1ae00eac9a37d59a0fd\": \"0xd8d726b7177a800000\",\n \"0x4ac9905a4cb6ab1cfd62546ee5917300b87c4fde\": \"0x3708baed3d68900000\",\n \"0x4acfa9d94eda6625c9dfa5f9f4f5d107c4031fdf\": \"0x222c8eb3ff6640000\",\n \"0x4ad047fae67ef162fe68fedbc27d3b65caf10c36\": \"0x6acb3df27e1f880000\",\n \"0x4ad95d188d6464709add2555fb4d97fe1ebf311f\": \"0x12c1b6eed03d280000\",\n \"0x4adbf4aae0e3ef44f7dd4d8985cfaf096ec48e98\": \"0x821ab0d4414980000\",\n \"0x4ae2a04d3909ef454e544ccfd614bfefa71089ae\": \"0x1801159df1eef80000\",\n \"0x4ae93082e45187c26160e66792f57fad3551c73a\": \"0x4961520daff82280000\",\n \"0x4af0db077bb9ba5e443e21e148e59f379105c592\": \"0x2086ac351052600000\",\n \"0x4b0619d9d8aa313a9531ac7dbe04ca0d6a5ad1b6\": \"0x6c6b935b8bbd400000\",\n \"0x4b0bd8acfcbc53a6010b40d4d08ddd2d9d69622d\": \"0x243d4d18229ca20000\",\n \"0x4b19eb0c354bc1393960eb06063b83926f0d67b2\": \"0x19274b259f6540000\",\n \"0x4b29437c97b4a844be71cca3b648d4ca0fdd9ba4\": \"0x824719834cfac0000\",\n \"0x4b31bf41abc75c9ae2cd8f7f35163b6e2b745054\": \"0x14b550a013c7380000\",\n \"0x4b3a7cc3a7d7b00ed5282221a60259f25bf6538a\": \"0x3635c9adc5dea00000\",\n \"0x4b3aab335ebbfaa870cc4d605e7d2e74c668369f\": \"0xcb49b44ba602d800000\",\n \"0x4b3c7388cc76da3d62d40067dabccd7ef0433d23\": \"0x56cd55fc64dfe0000\",\n \"0x4b3dfbdb454be5279a3b8addfd0ed1cd37a9420d\": \"0x6c6b935b8bbd400000\",\n \"0x4b470f7ba030bc7cfcf338d4bf0432a91e2ea5ff\": \"0x6c6b935b8bbd400000\",\n \"0x4b53ae59c784b6b5c43616b9a0809558e684e10c\": \"0x410d586a20a4c00000\",\n \"0x4b58101f44f7e389e12d471d1635b71614fdd605\": \"0x8ac7230489e800000\",\n \"0x4b5cdb1e428c91dd7cb54a6aed4571da054bfe52\": \"0x4c53ecdc18a600000\",\n \"0x4b60a3e253bf38c8d5662010bb93a473c965c3e5\": \"0x50c5e761a444080000\",\n \"0x4b74f5e58e2edf76daf70151964a0b8f1de0663c\": \"0x1190ae4944ba120000\",\n \"0x4b762166dd1118e84369f804c75f9cd657bf730c\": \"0x1b1ae4d6e2ef500000\",\n \"0x4b792e29683eb586e394bb33526c6001b397999e\": \"0x2086ac351052600000\",\n \"0x4b904e934bd0cc8b20705f879e905b93ea0ccc30\": \"0x6c6b935b8bbd400000\",\n \"0x4b9206ba6b549a1a7f969e1d5dba867539d1fa67\": \"0x1ab2cf7c9f87e200000\",\n \"0x4b984ef26c576e815a2eaed2f5177f07dbb1c476\": \"0x54915956c409600000\",\n \"0x4b9e068fc4680976e61504912985fd5ce94bab0d\": \"0x243d4d18229ca20000\",\n \"0x4ba0d9e89601772b496847a2bb4340186787d265\": \"0x3635c9adc5dea00000\",\n \"0x4ba53ab549e2016dfa223c9ed5a38fad91288d07\": \"0x4be4e7267b6ae00000\",\n \"0x4ba8e0117fc0b6a3e56b24a3a58fe6cef442ff98\": \"0x131beb925ffd3200000\",\n \"0x4bac846af4169f1d95431b341d8800b22180af1a\": \"0x1158e460913d00000\",\n \"0x4bb6d86b8314c22d8d37ea516d0019f156aae12d\": \"0x3635c9adc5dea00000\",\n \"0x4bb9655cfb2a36ea7c637a7b859b4a3154e26ebe\": \"0x3635c9adc5dea000000\",\n \"0x4bbcbf38b3c90163a84b1cd2a93b58b2a3348d87\": \"0x1b1ae4d6e2ef5000000\",\n \"0x4bd6dd0cff23400e1730ba7b894504577d14e74a\": \"0x2ba0ccddd0df73b00000\",\n \"0x4be8628a8154874e048d80c142181022b180bcc1\": \"0x340aad21b3b700000\",\n \"0x4be90d412129d5a4d0424361d6649d4e47a62316\": \"0x3708baed3d68900000\",\n \"0x4bea288eea42c4955eb9faad2a9faf4783cbddac\": \"0x618be1663c4af490000\",\n \"0x4bf4479799ef82eea20943374f56a1bf54001e5e\": \"0xd5967be4fc3f100000\",\n \"0x4bf8bf1d35a231315764fc8001809a949294fc49\": \"0x39fbae8d042dd0000\",\n \"0x4bf8e26f4c2790da6533a2ac9abac3c69a199433\": \"0xad78ebc5ac6200000\",\n \"0x4c0aca508b3caf5ee028bc707dd1e800b838f453\": \"0xfc936392801c0000\",\n \"0x4c0b1515dfced7a13e13ee12c0f523ae504f032b\": \"0xa968163f0a57b400000\",\n \"0x4c13980c32dcf3920b78a4a7903312907c1b123f\": \"0x3410015faae0c0000\",\n \"0x4c1579af3312e4f88ae93c68e9449c2e9a68d9c4\": \"0x6c6b935b8bbd400000\",\n \"0x4c23b370fc992bb67cec06e26715b62f0b3a4ac3\": \"0x21e19e0c9bab2400000\",\n \"0x4c24b78baf2bafc7fcc69016426be973e20a50b2\": \"0xa2a15d09519be00000\",\n \"0x4c2f1afef7c5868c44832fc77cb03b55f89e6d6e\": \"0x43c33c1937564800000\",\n \"0x4c377bb03ab52c4cb79befa1dd114982924c4ae9\": \"0x631603ccd38dd70000\",\n \"0x4c3e95cc3957d252ce0bf0c87d5b4f2234672e70\": \"0x878678326eac900000\",\n \"0x4c423c76930d07f93c47a5cc4f615745c45a9d72\": \"0x56bc75e2d63100000\",\n \"0x4c45d4c9a725d11112bfcbca00bf31186ccaadb7\": \"0x15af1d78b58c400000\",\n \"0x4c4e6f13fb5e3f70c3760262a03e317982691d10\": \"0x56bc75e2d63100000\",\n \"0x4c5afe40f18ffc48d3a1aec41fc29de179f4d297\": \"0x6c6b935b8bbd400000\",\n \"0x4c5b3dc0e2b9360f91289b1fe13ce12c0fbda3e1\": \"0x6c6b935b8bbd400000\",\n \"0x4c666b86f1c5ee8ca41285f5bde4f79052081406\": \"0x1b1ae4d6e2ef500000\",\n \"0x4c696be99f3a690440c3436a59a7d7e937d6ba0d\": \"0xbb9125542263900000\",\n \"0x4c6a248fc97d705def495ca20759169ef0d36471\": \"0x29331e6558f0e00000\",\n \"0x4c6a9dc2cab10abb2e7c137006f08fecb5b779e1\": \"0x1b0d04202f47ec0000\",\n \"0x4c6b93a3bec16349540cbfcae96c9621d6645010\": \"0x6c6b935b8bbd400000\",\n \"0x4c759813ad1386bed27ffae9e4815e3630cca312\": \"0x6c6b935b8bbd400000\",\n \"0x4c760cd9e195ee4f2d6bce2500ff96da7c43ee91\": \"0xcb49b44ba602d800000\",\n \"0x4c767b65fd91161f4fbdcc6a69e2f6ad711bb918\": \"0x270801d946c9400000\",\n \"0x4c7e2e2b77ad0cd6f44acb2861f0fb8b28750ef9\": \"0x1158e460913d00000\",\n \"0x4c85ed362f24f6b9f04cdfccd022ae535147cbb9\": \"0x5150ae84a8cdf00000\",\n \"0x4c935bb250778b3c4c7f7e07fc251fa630314aab\": \"0x5150ae84a8cdf00000\",\n \"0x4c997992036c5b433ac33d25a8ea1dc3d4e4e6d8\": \"0x1953b3d4ab1680000\",\n \"0x4c99dae96481e807c1f99f8b7fbde29b7547c5bf\": \"0x821ab0d4414980000\",\n \"0x4c9a862ad115d6c8274ed0b944bdd6a5500510a7\": \"0x56bc75e2d63100000\",\n \"0x4ca783b556e5bf53aa13c8116613d65782c9b642\": \"0x5561840b4ad83c00000\",\n \"0x4ca7b717d9bc8793b04e051a8d23e1640f5ba5e3\": \"0x43b514549ecf620000\",\n \"0x4ca8db4a5efefc80f4cd9bbcccb03265931332b6\": \"0xad78ebc5ac6200000\",\n \"0x4cac91fb83a147d2f76c3267984b910a79933348\": \"0x75792a8abdef7c0000\",\n \"0x4cadf573ce4ceec78b8e1b21b0ed78eb113b2c0e\": \"0x6c6b935b8bbd400000\",\n \"0x4cb5c6cd713ca447b848ae2f56b761ca14d7ad57\": \"0xe7eeba3410b740000\",\n \"0x4cc22c9bc9ad05d875a397dbe847ed221c920c67\": \"0x6c6b935b8bbd400000\",\n \"0x4cd0b0a6436362595ceade052ebc9b929fb6c6c0\": \"0x6c6b935b8bbd400000\",\n \"0x4cda41dd533991290794e22ae324143e309b3d3d\": \"0x821ab0d44149800000\",\n \"0x4cee901b4ac8b156c5e2f8a6f1bef572a7dceb7e\": \"0x3635c9adc5dea00000\",\n \"0x4cefbe2398e47d52e78db4334c8b697675f193ae\": \"0xd96fce90cfabcc0000\",\n \"0x4cf5537b85842f89cfee359eae500fc449d2118f\": \"0x3635c9adc5dea00000\",\n \"0x4d08471d68007aff2ae279bc5e3fe4156fbbe3de\": \"0x878678326eac9000000\",\n \"0x4d200110124008d56f76981256420c946a6ff45c\": \"0xad6eedd17cf3b8000\",\n \"0x4d24b7ac47d2f27de90974ba3de5ead203544bcd\": \"0x56bc75e2d63100000\",\n \"0x4d29fc523a2c1629532121da9998e9b5ab9d1b45\": \"0xdb44e049bb2c0000\",\n \"0x4d38d90f83f4515c03cc78326a154d358bd882b7\": \"0xa076407d3f7440000\",\n \"0x4d4cf5807429615e30cdface1e5aae4dad3055e6\": \"0x2086ac351052600000\",\n \"0x4d57e716876c0c95ef5eaebd35c8f41b069b6bfe\": \"0x6c6b935b8bbd400000\",\n \"0x4d67f2ab8599fef5fc413999aa01fd7fce70b43d\": \"0x21e19e0c9bab2400000\",\n \"0x4d6e8fe109ccd2158e4db114132fe75fecc8be5b\": \"0x15b3557f1937f8000\",\n \"0x4d71a6eb3d7f327e1834278e280b039eddd31c2f\": \"0x14542ba12a337c00000\",\n \"0x4d7cfaa84cb33106800a8c802fb8aa463896c599\": \"0x61093d7c2c6d380000\",\n \"0x4d801093c19ca9b8f342e33cc9c77bbd4c8312cf\": \"0x12b3e7fb95cda48000\",\n \"0x4d828894752f6f25175daf2177094487954b6f9f\": \"0x4f212bc2c49c838000\",\n \"0x4d82d7700c123bb919419bbaf046799c6b0e2c66\": \"0x43c33c1937564800000\",\n \"0x4d836d9d3b0e2cbd4de050596faa490cffb60d5d\": \"0x1043561a8829300000\",\n \"0x4d8697af0fbf2ca36e8768f4af22133570685a60\": \"0x1158e460913d00000\",\n \"0x4d9279962029a8bd45639737e98b511eff074c21\": \"0x487a9a304539440000\",\n \"0x4d93696fa24859f5d2939aebfa54b4b51ae1dccc\": \"0x10910d4cdc9f60000\",\n \"0x4d9c77d0750c5e6fbc247f2fd79274686cb353d6\": \"0x1158e460913d00000\",\n \"0x4da5edc688b0cb62e1403d1700d9dcb99ffe3fd3\": \"0x6c6b935b8bbd400000\",\n \"0x4da8030769844bc34186b85cd4c7348849ff49e9\": \"0x21e19e0c9bab2400000\",\n \"0x4db1c43a0f834d7d0478b8960767ec1ac44c9aeb\": \"0x2f5181305627370000\",\n \"0x4db21284bcd4f787a7556500d6d7d8f36623cf35\": \"0x6928374f77a3630000\",\n \"0x4dc3da13b2b4afd44f5d0d3189f444d4ddf91b1b\": \"0x6c6b935b8bbd400000\",\n \"0x4dc4bf5e7589c47b28378d7503cf96488061dbbd\": \"0x5f68e8131ecf800000\",\n \"0x4dc9d5bb4b19cecd94f19ec25d200ea72f25d7ed\": \"0x6c6b935b8bbd400000\",\n \"0x4dcd11815818ae29b85d01367349a8a7fb12d06b\": \"0x1ac4286100191f00000\",\n \"0x4dcf62a3de3f061db91498fd61060f1f6398ff73\": \"0x6c6acc67d7b1d40000\",\n \"0x4dd131c74a068a37c90aded4f309c2409f6478d3\": \"0x15af39e4aab2740000\",\n \"0x4ddda7586b2237b053a7f3289cf460dc57d37a09\": \"0x21e19e0c9bab2400000\",\n \"0x4de3fe34a6fbf634c051997f47cc7f48791f5824\": \"0x6c5db2a4d815dc0000\",\n \"0x4df140ba796585dd5489315bca4bba680adbb818\": \"0x90f534608a72880000\",\n \"0x4e020779b5ddd3df228a00cb48c2fc979da6ae38\": \"0x6c6b935b8bbd400000\",\n \"0x4e0bd32473c4c51bf25654def69f797c6b29a232\": \"0x56c95de8e8ca1d0000\",\n \"0x4e2225a1bb59bc88a2316674d333b9b0afca6655\": \"0x8670e9ec6598c0000\",\n \"0x4e2310191ead8d3bc6489873a5f0c2ec6b87e1be\": \"0x3635c9adc5dea00000\",\n \"0x4e232d53b3e6be8f895361d31c34d4762b12c82e\": \"0x5f68e8131ecf800000\",\n \"0x4e2bfa4a466f82671b800eee426ad00c071ba170\": \"0xd8d726b7177a800000\",\n \"0x4e3edad4864dab64cae4c5417a76774053dc6432\": \"0x2008fb478cbfa98000\",\n \"0x4e4318f5e13e824a54edfe30a7ed4f26cd3da504\": \"0x6c6b935b8bbd400000\",\n \"0x4e5b77f9066159e615933f2dda7477fa4e47d648\": \"0xad78ebc5ac6200000\",\n \"0x4e6600806289454acda330a2a3556010dfacade6\": \"0x14542ba12a337c00000\",\n \"0x4e73cf2379f124860f73d6d91bf59acc5cfc845b\": \"0x22ca3587cf4eb0000\",\n \"0x4e7aa67e12183ef9d7468ea28ad239c2eef71b76\": \"0x10afc1ade3b4ed40000\",\n \"0x4e7b54474d01fefd388dfcd53b9f662624418a05\": \"0x1b1ae4d6e2ef5000000\",\n \"0x4e892e8081bf36e488fddb3b2630f3f1e8da30d2\": \"0x28aba30752451fc0000\",\n \"0x4e8a6d63489ccc10a57f885f96eb04ecbb546024\": \"0x3eae3130ecc96900000\",\n \"0x4e8e47ae3b1ef50c9d54a38e14208c1abd3603c2\": \"0x7928db1276660c0000\",\n \"0x4e90ccb13258acaa9f4febc0a34292f95991e230\": \"0xdb44e049bb2c0000\",\n \"0x4ea56e1112641c038d0565a9c296c463afefc17e\": \"0x9ddc1e3b901180000\",\n \"0x4ea70f04313fae65c3ff224a055c3d2dab28dddf\": \"0x43c30fb0884a96c0000\",\n \"0x4eb1454b573805c8aca37edec7149a41f61202f4\": \"0x1043561a8829300000\",\n \"0x4eb87ba8788eba0df87e5b9bd50a8e45368091c1\": \"0x1158e460913d00000\",\n \"0x4ebc5629f9a6a66b2cf3363ac4895c0348e8bf87\": \"0x3637096c4bcc690000\",\n \"0x4ec768295eeabafc42958415e22be216cde77618\": \"0x33b1dbc39c5480000\",\n \"0x4ecc19948dd9cd87b4c7201ab48e758f28e7cc76\": \"0x1b1dab61d3aa640000\",\n \"0x4ed14d81b60b23fb25054d8925dfa573dcae6168\": \"0x126e72a69a50d00000\",\n \"0x4ee13c0d41200b46d19dee5c4bcec71d82bb8e38\": \"0x1abee13ccbeefaf8000\",\n \"0x4eead40aad8c73ef08fc84bc0a92c9092f6a36bf\": \"0x1731790534df20000\",\n \"0x4eebe80cb6f3ae5904f6f4b28d907f907189fcab\": \"0x6c6acc67d7b1d40000\",\n \"0x4eebf1205d0cc20cee6c7f8ff3115f56d48fba26\": \"0x10d3aa536e2940000\",\n \"0x4ef1c214633ad9c0703b4e2374a2e33e3e429291\": \"0x487a9a304539440000\",\n \"0x4efcd9c79fb4334ca6247b0a33bd9cc33208e272\": \"0x487a9a304539440000\",\n \"0x4f06246b8d4bd29661f43e93762201d286935ab1\": \"0x105394ffc4636110000\",\n \"0x4f152b2fb8659d43776ebb1e81673aa84169be96\": \"0x6c6b935b8bbd400000\",\n \"0x4f177f9d56953ded71a5611f393322c30279895c\": \"0xd55ef90a2da180000\",\n \"0x4f1a2da54a4c6da19d142412e56e815741db2325\": \"0x56bc75e2d63100000\",\n \"0x4f23b6b817ffa5c664acdad79bb7b726d30af0f9\": \"0x5f68e8131ecf800000\",\n \"0x4f26690c992b7a312ab12e1385d94acd58288e7b\": \"0x2f6f10780d22cc00000\",\n \"0x4f2b47e2775a1fa7178dad92985a5bbe493ba6d6\": \"0xad78ebc5ac6200000\",\n \"0x4f3a4854911145ea01c644044bdb2e5a960a982f\": \"0xd8d726b7177a800000\",\n \"0x4f3f2c673069ac97c2023607152981f5cd6063a0\": \"0x2086ac351052600000\",\n \"0x4f4a9be10cd5d3fb5de48c17be296f895690645b\": \"0x878678326eac9000000\",\n \"0x4f52ad6170d25b2a2e850eadbb52413ff2303e7f\": \"0xa4cc799563c3800000\",\n \"0x4f5801b1eb30b712d8a0575a9a71ff965d4f34eb\": \"0x1043561a8829300000\",\n \"0x4f5df5b94357de948604c51b7893cddf6076baad\": \"0xcbd47b6eaa8cc00000\",\n \"0x4f64a85e8e9a40498c0c75fceb0337fb49083e5e\": \"0x3635c9adc5dea00000\",\n \"0x4f67396d2553f998785f704e07a639197dd1948d\": \"0x104472521ba7380000\",\n \"0x4f6d4737d7a940382487264886697cf7637f8015\": \"0x5a87e7d7f5f6580000\",\n \"0x4f7330096f79ed264ee0127f5d30d2f73c52b3d8\": \"0x1b1a7a420ba00d0000\",\n \"0x4f767bc8794aef9a0a38fea5c81f14694ff21a13\": \"0x1bc433f23f83140000\",\n \"0x4f85bc1fc5cbc9c001e8f1372e07505370d8c71f\": \"0x32f51edbaaa3300000\",\n \"0x4f88dfd01091a45a9e2676021e64286cd36b8d34\": \"0x3635c9adc5dea00000\",\n \"0x4f8972838f70c903c9b6c6c46162e99d6216d451\": \"0xf9e89a0f2c56c80000\",\n \"0x4f8ae80238e60008557075ab6afe0a7f2e74d729\": \"0x56bc75e2d63100000\",\n \"0x4f8e8d274fb22a3fd36a47fe72980471544b3434\": \"0xad78ebc5ac6200000\",\n \"0x4f9ce2af9b8c5e42c6808a3870ec576f313545d1\": \"0x21e19e0c9bab2400000\",\n \"0x4fa3f32ef4086448b344d5f0a9890d1ce4d617c3\": \"0x5150ae84a8cdf00000\",\n \"0x4fa554ab955c249217386a4d3263bbf72895434e\": \"0x1154e53217ddb0000\",\n \"0x4fa983bb5e3073a8edb557effeb4f9fb1d60ef86\": \"0x56b9af57e575ec0000\",\n \"0x4faf90b76ecfb9631bf9022176032d8b2c207009\": \"0x36363b5d9a77700000\",\n \"0x4fc46c396e674869ad9481638f0013630c87caac\": \"0x3635c9adc5dea00000\",\n \"0x4fcc19ea9f4c57dcbce893193cfb166aa914edc5\": \"0x17b8baa7f19546a0000\",\n \"0x4fce8429ba49caa0369d1e494db57e89eab2ad39\": \"0x2a5a058fc295ed000000\",\n \"0x4fdac1aa517007e0089430b3316a1badd12c01c7\": \"0x1b1ae4d6e2ef500000\",\n \"0x4fe56ab3bae1b0a44433458333c4b05a248f8241\": \"0x762d93d1dd6f900000\",\n \"0x4feb846be43041fd6b34202897943e3f21cb7f04\": \"0x482fe260cbca90000\",\n \"0x4fee50c5f988206b09a573469fb1d0b42ebb6dce\": \"0x6cee06ddbe15ec0000\",\n \"0x4ff676e27f681a982d8fd9d20e648b3dce05e945\": \"0x97c9ce4cf6d5c00000\",\n \"0x4ff67fb87f6efba9279930cfbd1b7a343c79fade\": \"0x15af1d78b58c400000\",\n \"0x5006fe4c22173980f00c74342b39cd231c653129\": \"0x6c6b935b8bbd400000\",\n \"0x500c16352e901d48ba8d04e2c767121772790b02\": \"0x1a3a6824973098000\",\n \"0x500c902958f6421594d1b6ded712490d52ed6c44\": \"0x6acb3df27e1f880000\",\n \"0x500e34cde5bd9e2b71bb92d7cf55eee188d5fa0c\": \"0x121ea68c114e5100000\",\n \"0x5032e4bcf7932b49fdba377b6f1499636513cfc3\": \"0x56bc75e2d63100000\",\n \"0x50378af7ef54043f892ab7ce97d647793511b108\": \"0x11164759ffb320000\",\n \"0x503bdbd8bc421c32a443032deb2e3e4cd5ba8b4e\": \"0x6c6b935b8bbd400000\",\n \"0x504666ce8931175e11a5ed11c1dcaa06e57f4e66\": \"0x27f3edfb34e6e400000\",\n \"0x50584d9206a46ce15c301117ee28f15c30e60e75\": \"0xb9f65d00f63c0000\",\n \"0x505a33a18634dd4800693c67f48a1d693d4833f8\": \"0x18921b79941dcd00000\",\n \"0x505e4f7c275588c533a20ebd2ac13b409bbdea3c\": \"0xf43fc2c04ee00000\",\n \"0x5062e5134c612f12694dbd0e131d4ce197d1b6a4\": \"0x3635c9adc5dea00000\",\n \"0x506411fd79003480f6f2b6aac26b7ba792f094b2\": \"0x1b1ae4d6e2ef500000\",\n \"0x5067f4549afbfe884c59cbc12b96934923d45db0\": \"0x3635c9adc5dea00000\",\n \"0x50763add868fd7361178342fc055eaa2b95f6846\": \"0x39f9046e0898f0000\",\n \"0x508cf19119db70aa86454253da764a2cb1b2be1a\": \"0x3635c9adc5dea00000\",\n \"0x509982f56237ee458951047e0a2230f804e2e895\": \"0x3b4ad496106b7f00000\",\n \"0x509a20bc48e72be1cdaf9569c711e8648d957334\": \"0x6c6b935b8bbd400000\",\n \"0x509c8668036d143fb8ae70b11995631f3dfcad87\": \"0x3635c9adc5dea00000\",\n \"0x50ad187ab21167c2b6e78be0153f44504a07945e\": \"0x56cd55fc64dfe0000\",\n \"0x50b9fef0a1329b02d16506255f5a2db71ec92d1f\": \"0x47da821564085c0000\",\n \"0x50bb67c8b8d8bd0f63c4760904f2d333f400aace\": \"0x6c6b935b8bbd400000\",\n \"0x50bef2756248f9a7a380f91b051ba3be28a649ed\": \"0x6c69f73e29134e0000\",\n \"0x50ca86b5eb1d01874df8e5f34945d49c6c1ab848\": \"0x3635c9adc5dea00000\",\n \"0x50cd97e9378b5cf18f173963236c9951ef7438a5\": \"0x4be4e7267b6ae00000\",\n \"0x50dcbc27bcad984093a212a9b4178eabe9017561\": \"0x7e362790b5ca40000\",\n \"0x50e13023bd9ca96ad4c53fdfd410cb6b1f420bdf\": \"0xad78ebc5ac6200000\",\n \"0x50e1c8ec98415bef442618708799437b86e6c205\": \"0x14542ba12a337c00000\",\n \"0x50f8fa4bb9e2677c990a4ee8ce70dd1523251e4f\": \"0x1693d23164f6b0000\",\n \"0x50fb36c27107ee2ca9a3236e2746cca19ace6b49\": \"0x6c6b935b8bbd400000\",\n \"0x50fef296955588caae74c62ec32a23a454e09ab8\": \"0x411dffabc507380000\",\n \"0x5102a4a42077e11c58df4773e3ac944623a66d9f\": \"0x6c7015fd52ed408000\",\n \"0x51039377eed0c573f986c5e8a95fb99a59e9330f\": \"0x6acb3df27e1f880000\",\n \"0x5103bc09933e9921fd53dc536f11f05d0d47107d\": \"0xd8d726b7177a800000\",\n \"0x5104ecc0e330dd1f81b58ac9dbb1a9fbf88a3c85\": \"0x152d02c7e14af6800000\",\n \"0x510d8159cc945768c7450790ba073ec0d9f89e30\": \"0x8ac7230489e8000000\",\n \"0x510eda5601499a0d5e1a006bfffd833672f2e267\": \"0x6c6b935b8bbd400000\",\n \"0x51126446ab3d8032557e8eba65597d75fadc815c\": \"0x1174a5cdf88bc80000\",\n \"0x5118557d600d05c2fcbf3806ffbd93d02025d730\": \"0x267d3ab6423f5800000\",\n \"0x511e0efb04ac4e3ff2e6550e498295bfcd56ffd5\": \"0x243d4d18229ca20000\",\n \"0x512116817ba9aaf843d1507c65a5ea640a7b9eec\": \"0x2b5e3af16b1880000\",\n \"0x5126460d692c71c9af6f05574d93998368a23799\": \"0x2d1a51c7e00500000\",\n \"0x51277fe7c81eebd252a03df69a6b9f326e272207\": \"0x3402e79cab44c8000\",\n \"0x51296f5044270d17707646129c86aad1645eadc1\": \"0x487c72b310d4648000\",\n \"0x512b91bbfaa9e581ef683fc90d9db22a8f49f48b\": \"0x41a522386d9b95c00000\",\n \"0x5135fb8757600cf474546252f74dc0746d06262c\": \"0x6c6b935b8bbd400000\",\n \"0x514632efbd642c04de6ca342315d40dd90a2dba6\": \"0x90f534608a72880000\",\n \"0x514b7512c9ae5ea63cbf11715b63f21e18d296c1\": \"0x6c6acc67d7b1d40000\",\n \"0x5153a0c3c8912881bf1c3501bf64b45649e48222\": \"0xd8d726b7177a800000\",\n \"0x515651d6db4faf9ecd103a921bbbbe6ae970fdd4\": \"0x43c33c1937564800000\",\n \"0x515f30bc90cdf4577ee47d65d785fbe2e837c6bc\": \"0x2271b5e018ba0580000\",\n \"0x5160ed612e1b48e73f3fc15bc4321b8f23b8a24b\": \"0x1e826b422865d80000\",\n \"0x5161fd49e847f67455f1c8bb7abb36e985260d03\": \"0x410d586a20a4c00000\",\n \"0x516954025fca2608f47da81c215eedfd844a09ff\": \"0x14b550a013c7380000\",\n \"0x5169c60aee4ceed1849ab36d664cff97061e8ea8\": \"0xa2a15d09519be00000\",\n \"0x517c75430de401c341032686112790f46d4d369e\": \"0x150894e849b3900000\",\n \"0x517cd7608e5d0d83a26b717f3603dac2277dc3a4\": \"0x6c6b935b8bbd400000\",\n \"0x51865db148881951f51251710e82b9be0d7eadb2\": \"0x6c6b935b8bbd400000\",\n \"0x51891b2ccdd2f5a44b2a8bc49a5d9bca6477251c\": \"0x10ce1d3d8cb3180000\",\n \"0x518cef27b10582b6d14f69483ddaa0dd3c87bb5c\": \"0x2086ac351052600000\",\n \"0x51a6d627f66a8923d88d6094c4715380d3057cb6\": \"0x3e73d27a35941e0000\",\n \"0x51a8c2163602a32ee24cf4aa97fd9ea414516941\": \"0x368f7e6b8672c0000\",\n \"0x51b4758e9e1450e7af4268c3c7b1e7bd6f5c7550\": \"0x3635c9adc5dea00000\",\n \"0x51ca8bd4dc644fac47af675563d5804a0da21eeb\": \"0x2ab7b260ff3fd00000\",\n \"0x51d24bc3736f88dd63b7222026886630b6eb878d\": \"0x6c6b935b8bbd400000\",\n \"0x51d78b178d707e396e8710965c4f41b1a1d9179d\": \"0x5fee222041e340000\",\n \"0x51e32f14f4ca5e287cdac057a7795ea9e0439953\": \"0x1b1ae4d6e2ef500000\",\n \"0x51e43fe0d25c782860af81ea89dd793c13f0cbb1\": \"0x340aad21b3b700000\",\n \"0x51e7b55c2f9820eed73884361b5066a59b6f45c6\": \"0x6c6b935b8bbd400000\",\n \"0x51ea1c0934e3d04022ed9c95a087a150ef705e81\": \"0x1547081e7224d200000\",\n \"0x51ee0cca3bcb10cd3e983722ced8493d926c0866\": \"0x36356633ebd8ea0000\",\n \"0x51f4663ab44ff79345f427a0f6f8a6c8a53ff234\": \"0x43c33c1937564800000\",\n \"0x51f55ef47e6456a418ab32b9221ed27dba6608ee\": \"0xe3aeb5737240a00000\",\n \"0x51f9c432a4e59ac86282d6adab4c2eb8919160eb\": \"0x703b5b89c3a6e7400000\",\n \"0x520f66a0e2657ff0ac4195f2f064cf2fa4b24250\": \"0x22b1c8c1227a00000\",\n \"0x52102354a6aca95d8a2e86d5debda6de69346076\": \"0x6c6b935b8bbd400000\",\n \"0x5213f459e078ad3ab95a0920239fcf1633dc04ca\": \"0x8cf2187c2afb188000\",\n \"0x5215183b8f80a9bc03d26ce91207832a0d39e620\": \"0x3635c9adc5dea00000\",\n \"0x52214378b54004056a7cc08c891327798ac6b248\": \"0x337fe5feaf2d1800000\",\n \"0x522323aad71dbc96d85af90f084b99c3f09decb7\": \"0x14542ba12a337c00000\",\n \"0x523e140dc811b186dee5d6c88bf68e90b8e096fd\": \"0x6c6b935b8bbd400000\",\n \"0x523f6d64690fdacd942853591bb0ff20d3656d95\": \"0x62a992e53a0af00000\",\n \"0x524fb210522c5e23bb67dfbf8c26aa616da49955\": \"0x363562a66d34238000\",\n \"0x5255dc69155a45b970c604d30047e2f530690e7f\": \"0x1158e460913d00000\",\n \"0x5260dc51ee07bddaababb9ee744b393c7f4793a6\": \"0x1d8665fa5fa4c0000\",\n \"0x5267f4d41292f370863c90d793296903843625c7\": \"0x4be4e7267b6ae00000\",\n \"0x526bb533b76e20c8ee1ebf123f1e9ff4148e40be\": \"0xaadec983fcff40000\",\n \"0x526cb09ce3ada3672eec1deb46205be89a4b563e\": \"0x85ca615bf9c0100000\",\n \"0x52738c90d860e04cb12f498d96fdb5bf36fc340e\": \"0x1a055690d9db80000\",\n \"0x527a8ca1268633a6c939c5de1b929aee92aeac8d\": \"0x30ca024f987b900000\",\n \"0x528101ce46b720a2214dcdae6618a53177ffa377\": \"0x1b9612b9dc01ae0000\",\n \"0x5281733473e00d87f11e9955e589b59f4ac28e7a\": \"0x8bd62ff4eec559200000\",\n \"0x5298ab182a19359ffcecafd7d1b5fa212dede6dd\": \"0x1158e460913d00000\",\n \"0x529aa002c6962a3a8545027fd8b05f22b5bf9564\": \"0x5a87e7d7f5f6580000\",\n \"0x529e824fa072582b4032683ac7eecc1c04b4cac1\": \"0x6c6b935b8bbd400000\",\n \"0x52a5e4de4393eeccf0581ac11b52c683c76ea15d\": \"0x43c30fb0884a96c0000\",\n \"0x52b4257cf41b6e28878d50d57b99914ffa89873a\": \"0xd50dc9aa2c41770000\",\n \"0x52b8a9592634f7300b7c5c59a3345b835f01b95c\": \"0x6c6b935b8bbd400000\",\n \"0x52bdd9af5978850bc24110718b3723759b437e59\": \"0x5dc892aa1131c80000\",\n \"0x52cd20403ba7eda6bc307a3d63b5911b817c1263\": \"0x1158e460913d00000\",\n \"0x52d380511df19d5ec2807bbcb676581b67fd37a3\": \"0xb9f65d00f63c0000\",\n \"0x52e1731350f983cc2c4189842fde0613fad50ce1\": \"0x277017338a30ae00000\",\n \"0x52e46783329a769301b175009d346768f4c87ee4\": \"0x6c6b935b8bbd400000\",\n \"0x52f058d46147e9006d29bf2c09304ad1cddd6e15\": \"0x5150ae84a8cdf00000\",\n \"0x52f15423323c24f19ae2ab673717229d3f747d9b\": \"0x37a034cbe8e3f38000\",\n \"0x52f8b509fee1a874ab6f9d87367fbeaf15ac137f\": \"0x3635c9adc5dea00000\",\n \"0x52fb46ac5d00c3518b2c3a1c177d442f8165555f\": \"0x5150ae84a8cdf00000\",\n \"0x530077c9f7b907ff9cec0c77a41a70e9029add4a\": \"0x6c6b935b8bbd400000\",\n \"0x530319db0a8f93e5bb7d4dbf4816314fbed8361b\": \"0x6c6b935b8bbd400000\",\n \"0x53047dc8ac9083d90672e8b3473c100ccd278323\": \"0x22b1c8c1227a00000\",\n \"0x530b61e42f39426d2408d40852b9e34ab5ebebc5\": \"0xe7eeba3410b740000\",\n \"0x530ffac3bc3412e2ec0ea47b7981c770f5bb2f35\": \"0x73f75d1a085ba0000\",\n \"0x5317ecb023052ca7f5652be2fa854cfe4563df4d\": \"0x1b1ab319f5ec750000\",\n \"0x53194d8afa3e883502767edbc30586af33b114d3\": \"0x6c6b935b8bbd400000\",\n \"0x532a7da0a5ad7407468d3be8e07e69c7dd64e861\": \"0x1b1ae4d6e2ef500000\",\n \"0x532d32b00f305bcc24dcef56817d622f34fb2c24\": \"0x6194049f30f7200000\",\n \"0x533444584082eba654e1ad30e149735c6f7ba922\": \"0x5dc892aa1131c80000\",\n \"0x5338ef70eac9dd9af5a0503b5efad1039e67e725\": \"0x90f534608a72880000\",\n \"0x53396f4a26c2b4604496306c5442e7fcba272e36\": \"0x43f2f08d40e5afc0000\",\n \"0x533a73a4a2228eee05c4ffd718bbf3f9c1b129a7\": \"0x14542ba12a337c00000\",\n \"0x533c06928f19d0a956cc28866bf6c8d8f4191a94\": \"0xfd8c14338e6300000\",\n \"0x534065361cb854fac42bfb5c9fcde0604ac919da\": \"0x6c6b935b8bbd400000\",\n \"0x53437fecf34ab9d435f4deb8ca181519e2592035\": \"0xa31062beeed700000\",\n \"0x535201a0a1d73422801f55ded4dfaee4fbaa6e3b\": \"0x226211f7915428000\",\n \"0x53608105ce4b9e11f86bf497ffca3b78967b5f96\": \"0x43c33c1937564800000\",\n \"0x536e4d8029b73f5579dca33e70b24eba89e11d7e\": \"0x6acb3df27e1f880000\",\n \"0x53700d53254d430f22781a4a76a463933b5d6b08\": \"0x6acb3df27e1f880000\",\n \"0x537f9d4d31ef70839d84b0d9cdb72b9afedbdf35\": \"0xed2b525841adfc00000\",\n \"0x5381448503c0c702542b1de7cc5fb5f6ab1cf6a5\": \"0x1b1ae4d6e2ef5000000\",\n \"0x53942e7949d6788bb780a7e8a0792781b1614b84\": \"0x35deb46684f10c80000\",\n \"0x5395a4455d95d178b4532aa4725b193ffe512961\": \"0x3635c9adc5dea00000\",\n \"0x53989ed330563fd57dfec9bd343c3760b0799390\": \"0x150894e849b39000000\",\n \"0x53a244672895480f4a2b1cdf7da5e5a242ec4dbc\": \"0x3635c9adc5dea00000\",\n \"0x53a714f99fa00fef758e23a2e746326dad247ca7\": \"0x50c5e761a444080000\",\n \"0x53af32c22fef99803f178cf90b802fb571c61cb9\": \"0xd255d112e103a00000\",\n \"0x53c0bb7fc88ea422d2ef7e540e2d8f28b1bb8183\": \"0x1158e460913d00000\",\n \"0x53c5fe0119e1e848640cee30adea96940f2a5d8b\": \"0x49ada5fa8c10c880000\",\n \"0x53c9eca40973f63bb5927be0bc6a8a8be1951f74\": \"0x6c6b935b8bbd400000\",\n \"0x53ce88e66c5af2f29bbd8f592a56a3d15f206c32\": \"0x7a28c31cc36040000\",\n \"0x53cec6c88092f756efe56f7db11228a2db45b122\": \"0xd8d726b7177a800000\",\n \"0x53e35b12231f19c3fd774c88fec8cbeedf1408b2\": \"0x1bc16d674ec8000000\",\n \"0x53e4d9696dcb3f4d7b3f70dcaa4eecb71782ff5c\": \"0xad78ebc5ac6200000\",\n \"0x53faf165be031ec18330d9fce5bd1281a1af08db\": \"0x796e3ea3f8ab00000\",\n \"0x540a1819bd7c35861e791804e5fbb3bc97c9abb1\": \"0x4ed7dac64230200000\",\n \"0x540c072802014ef0d561345aec481e8e11cb3570\": \"0x1b1ae4d6e2ef5000000\",\n \"0x540cf23dd95c4d558a279d778d2b3735b3164191\": \"0x21e19e0c9bab2400000\",\n \"0x541060fc58c750c40512f83369c0a63340c122b6\": \"0x6acb3df27e1f880000\",\n \"0x5413c97ffa4a6e2a7bba8961dc9fce8530a787d7\": \"0x3635c9adc5dea00000\",\n \"0x541db20a80cf3b17f1621f1b3ff79b882f50def3\": \"0x3635c9adc5dea00000\",\n \"0x542e8096bafb88162606002e8c8a3ed19814aeac\": \"0x6c6b935b8bbd400000\",\n \"0x54310b3aa88703a725dfa57de6e646935164802c\": \"0x678a932062e4180000\",\n \"0x5431b1d18751b98fc9e2888ac7759f1535a2db47\": \"0x6c6b935b8bbd400000\",\n \"0x5431ca427e6165a644bae326bd09750a178c650d\": \"0x6c6b935b8bbd400000\",\n \"0x5435c6c1793317d32ce13bba4c4ffeb973b78adc\": \"0xd8e6b1c1285ef0000\",\n \"0x543629c95cdef428ad37d453ca9538a9f90900ac\": \"0x92896529baddc880000\",\n \"0x54391b4d176d476cea164e5fb535c69700cb2535\": \"0x56cd55fc64dfe0000\",\n \"0x543a8c0efb8bcd15c543e2a6a4f807597631adef\": \"0x13f80e7e14f2d440000\",\n \"0x543f8c674e2462d8d5daa0e80195a8708e11a29e\": \"0x37758833b3a7a0000\",\n \"0x544b5b351d1bc82e9297439948cf4861dac9ae11\": \"0x4a89f54ef0121c00000\",\n \"0x544dda421dc1eb73bb24e3e56a248013b87c0f44\": \"0x6acb3df27e1f880000\",\n \"0x54575c3114751e3c631971da6a2a02fd3ffbfcc8\": \"0x692ae8897081d00000\",\n \"0x545bb070e781172eb1608af7fc2895d6cb87197e\": \"0x79a5c17ec748900000\",\n \"0x5475d7f174bdb1f789017c7c1705989646079d49\": \"0x1fd933494aa5fe00000\",\n \"0x548558d08cfcb101181dac1eb6094b4e1a896fa6\": \"0x6c6acc67d7b1d40000\",\n \"0x54939ff08921b467cf2946751d856378296c63ed\": \"0x3635c9adc5dea00000\",\n \"0x549b47649cfad993e4064d2636a4baa0623305cc\": \"0x209d922f5259c50000\",\n \"0x549d51af29f724c967f59423b85b2681e7b15136\": \"0xcbd47b6eaa8cc00000\",\n \"0x54a1370116fe22099e015d07cd2669dd291cc9d1\": \"0x1158e460913d00000\",\n \"0x54a62bf9233e146ffec3876e45f20ee8414adeba\": \"0x21e19e0c9bab2400000\",\n \"0x54b4429b182f0377be7e626939c5db6440f75d7a\": \"0x6acb3df27e1f880000\",\n \"0x54bcb8e7f73cda3d73f4d38b2d0847e600ba0df8\": \"0x3a70415882df180000\",\n \"0x54c93e03a9b2e8e4c3672835a9ee76f9615bc14e\": \"0x10d3aa536e2940000\",\n \"0x54ce88275956def5f9458e3b95decacd484021a0\": \"0x6c6b935b8bbd400000\",\n \"0x54db5e06b4815d31cb56a8719ba33af2d73e7252\": \"0x24521e2a3017b80000\",\n \"0x54e01283cc8b384538dd646770b357c960d6cacd\": \"0x10f0cf064dd59200000\",\n \"0x54ec7300b81ac84333ed1b033cd5d7a33972e234\": \"0xad78ebc5ac6200000\",\n \"0x54febcce20fe7a9098a755bd90988602a48c089e\": \"0x22b1c8c1227a000000\",\n \"0x550aadae1221b07afea39fba2ed62e05e5b7b5f9\": \"0x1158e460913d00000\",\n \"0x550c306f81ef5d9580c06cb1ab201b95c748a691\": \"0x2417d4c470bf140000\",\n \"0x551999ddd205563327b9b530785acff9bc73a4ba\": \"0x14542ba12a337c00000\",\n \"0x551e7784778ef8e048e495df49f2614f84a4f1dc\": \"0x2086ac351052600000\",\n \"0x5529830a61c1f13c197e550beddfd6bd195c9d02\": \"0x21e19e0c9bab2400000\",\n \"0x552987f0651b915b2e1e5328c121960d4bdd6af4\": \"0x61093d7c2c6d380000\",\n \"0x553b6b1c57050e88cf0c31067b8d4cd1ff80cb09\": \"0x15af1d78b58c400000\",\n \"0x553f37d92466550e9fd775ae74362df030179132\": \"0x6c6b935b8bbd400000\",\n \"0x554336ee4ea155f9f24f87bca9ca72e253e12cd2\": \"0x56bc75e2d63100000\",\n \"0x5543dd6d169eec8a213bbf7a8af9ffd15d4ff759\": \"0xfc936392801c0000\",\n \"0x5547fdb4ae11953e01292b7807fa9223d0e4606a\": \"0x55d117dcb1d260000\",\n \"0x5552f4b3ed3e1da79a2f78bb13e8ae5a68a9df3b\": \"0x3635c9adc5dea00000\",\n \"0x555ca9f05cc134ab54ae9bea1c3ff87aa85198ca\": \"0x56bc75e2d63100000\",\n \"0x555d8d3ce1798aca902754f164b8be2a02329c6c\": \"0x21e19e0c9bab2400000\",\n \"0x555df19390c16d01298772bae8bc3a1152199cbd\": \"0xad78ebc5ac6200000\",\n \"0x555ebe84daa42ba256ea789105cec4b693f12f18\": \"0x56bc75e2d63100000\",\n \"0x557f5e65e0da33998219ad4e99570545b2a9d511\": \"0x2559cbb985842400000\",\n \"0x558360206883dd1b6d4a59639e5629d0f0c675d0\": \"0x6c6b935b8bbd400000\",\n \"0x5584423050e3c2051f0bbd8f44bd6dbc27ecb62c\": \"0xa2a15d09519be00000\",\n \"0x55852943492970f8d629a15366cdda06a94f4513\": \"0x6c6b935b8bbd400000\",\n \"0x55866486ec168f79dbe0e1abb18864d98991ae2c\": \"0xdf6eb0b2d3ca0000\",\n \"0x558c54649a8a6e94722bd6d21d14714f71780534\": \"0x6c6b935b8bbd400000\",\n \"0x559194304f14b1b93afe444f0624e053c23a0009\": \"0x15af1d78b58c400000\",\n \"0x5593c9d4b664730fd93ca60151c25c2eaed93c3b\": \"0xad78ebc5ac6200000\",\n \"0x559706c332d20779c45f8a6d046a699159b74921\": \"0x149b442e85a3cf8000\",\n \"0x5598b3a79a48f32b1f5fc915b87b645d805d1afe\": \"0x1b1ae4d6e2ef500000\",\n \"0x55a3df57b7aaec16a162fd5316f35bec082821cf\": \"0x6acb3df27e1f880000\",\n \"0x55a4cac0cb8b582d9fef38c5c9fff9bd53093d1f\": \"0x6acb3df27e1f880000\",\n \"0x55a61b109480b5b2c4fcfdef92d90584160c0d35\": \"0x26c564d2b53f60000\",\n \"0x55aa5d313ebb084da0e7801091e29e92c5dec3aa\": \"0x6c6b935b8bbd400000\",\n \"0x55ab99b0e0e55d7bb874b7cfe834de631c97ec23\": \"0x37e98ce36899e40000\",\n \"0x55af092f94ba6a79918b0cf939eab3f01b3f51c7\": \"0x820d5e39576120000\",\n \"0x55c564664166a1edf3913e0169f1cd451fdb5d0c\": \"0x8217ea49508e6c0000\",\n \"0x55ca6abe79ea2497f46fdbb830346010fe469cbe\": \"0x1369fb96128ac480000\",\n \"0x55caff4bba04d220c9a5d2018672ec85e31ef83e\": \"0x6c6b935b8bbd400000\",\n \"0x55d057bcc04bd0f4af9642513aa5090bb3ff93fe\": \"0x3bfe452c8edd4c0000\",\n \"0x55d42eb495bf46a634997b5f2ea362814918e2b0\": \"0x5c0d265b5b2a80000\",\n \"0x55da9dcdca61cbfe1f133c7bcefc867b9c8122f9\": \"0x2fb474098f67c00000\",\n \"0x55e220876262c218af4f56784798c7e55da09e91\": \"0x73d99c15645d30000\",\n \"0x55fd08d18064bd202c0ec3d2cce0ce0b9d169c4d\": \"0x6acb3df27e1f880000\",\n \"0x5600730a55f6b20ebd24811faa3de96d1662abab\": \"0x65ea3db75546600000\",\n \"0x5603241eb8f08f721e348c9d9ad92f48e390aa24\": \"0xad78ebc5ac6200000\",\n \"0x560536794a9e2b0049d10233c41adc5f418a264a\": \"0x3635c9adc5dea00000\",\n \"0x5607590059a9fec1881149a44b36949aef85d560\": \"0x6c6b935b8bbd400000\",\n \"0x560becdf52b71f3d8827d927610f1a980f33716f\": \"0x17474d705f56d08000\",\n \"0x560da37e956d862f81a75fd580a7135c1b246352\": \"0x21e19e0c9bab2400000\",\n \"0x560fc08d079f047ed8d7df75551aa53501f57013\": \"0x19bff2ff57968c00000\",\n \"0x561be9299b3e6b3e63b79b09169d1a948ae6db01\": \"0x1b1ae4d6e2ef500000\",\n \"0x562020e3ed792d2f1835fe5f55417d5111460c6a\": \"0x43c33c1937564800000\",\n \"0x5620f46d1451c2353d6243a5d4b427130be2d407\": \"0x340aad21b3b700000\",\n \"0x562105e82b099735de49f62692cc87cd38a8edcd\": \"0x14542ba12a337c00000\",\n \"0x562a8dcbbeeef7b360685d27303bd69e094accf6\": \"0x21e19e0c9bab2400000\",\n \"0x562bced38ab2ab6c080f3b0541b8456e70824b3f\": \"0x22ca3587cf4eb00000\",\n \"0x562be95aba17c5371fe2ba828799b1f55d2177d6\": \"0x816d37e87b9d1e00000\",\n \"0x562f16d79abfcec3943e34b20f05f97bdfcda605\": \"0xd8d726b7177a800000\",\n \"0x56373daab46316fd7e1576c61e6affcb6559ddd7\": \"0xbac715d146c9e0000\",\n \"0x56397638bb3cebf1f62062794b5eb942f916171d\": \"0x6c6b935b8bbd400000\",\n \"0x563a03ab9c56b600f6d25b660c21e16335517a75\": \"0x3635c9adc5dea00000\",\n \"0x563cb8803c1d32a25b27b64114852bd04d9c20cd\": \"0xb149ead0ad9d80000\",\n \"0x56586391040c57eec6f5affd8cd4abde10b50acc\": \"0xd8d726b7177a800000\",\n \"0x566c10d638e8b88b47d6e6a414497afdd00600d4\": \"0x56b394263a40c0000\",\n \"0x566c28e34c3808d9766fe8421ebf4f2b1c4f7d77\": \"0x6acb3df27e1f880000\",\n \"0x568df31856699bb5acfc1fe1d680df9960ca4359\": \"0x4acf5552f3b2498000\",\n \"0x5691dd2f6745f20e22d2e1d1b955aa2903d65656\": \"0x6ac5c62d9486070000\",\n \"0x56a1d60d40f57f308eebf087dee3b37f1e7c2cba\": \"0x3edcaec82d06f80000\",\n \"0x56ac20d63bd803595cec036da7ed1dc66e0a9e07\": \"0x3772a53ccdc658000\",\n \"0x56b6c23dd2ec90b4728f3bb2e764c3c50c85f144\": \"0x3635c9adc5dea00000\",\n \"0x56df05bad46c3f00ae476ecf017bb8c877383ff1\": \"0xab15daaef70400000\",\n \"0x56ee197f4bbf9f1b0662e41c2bbd9aa1f799e846\": \"0x3635c9adc5dea00000\",\n \"0x56f493a3d108aaa2d18d98922f8efe1662cfb73d\": \"0x6d8121a194d1100000\",\n \"0x56fc1a7bad4047237ce116146296238e078f93ad\": \"0x9a63f08ea63880000\",\n \"0x56febf9e1003af15b1bd4907ec089a4a1b91d268\": \"0xad78ebc5ac6200000\",\n \"0x5717cc9301511d4a81b9f583148beed3d3cc8309\": \"0x8cf23f909c0fa00000\",\n \"0x5717f2d8f18ffcc0e5fe247d3a4219037c3a649c\": \"0xd8bb6549b02bb80000\",\n \"0x571950ea2c90c1427d939d61b4f2de4cf1cfbfb0\": \"0x1158e460913d00000\",\n \"0x5719f49b720da68856f4b9e708f25645bdbc4b41\": \"0x22b1c8c1227a000000\",\n \"0x572ac1aba0de23ae41a7cae1dc0842d8abfc103b\": \"0x678a932062e4180000\",\n \"0x572dd8cd3fe399d1d0ec281231b7cefc20b9e4bb\": \"0x233c8fe42703e800000\",\n \"0x574921838cc77d6c98b17d903a3ae0ee0da95bd0\": \"0xb5328178ad0f2a00000\",\n \"0x574ad9355390e4889ef42acd138b2a27e78c00ae\": \"0x5467b732a913340000\",\n \"0x574de1b3f38d915846ae3718564a5ada20c2f3ed\": \"0xd8d726b7177a800000\",\n \"0x575c00c2818210c28555a0ff29010289d3f82309\": \"0x21e19e0c9bab2400000\",\n \"0x5773b6026721a1dd04b7828cd62b591bfb34534c\": \"0x5b7ac4553de7ae00000\",\n \"0x5777441c83e03f0be8dd340bde636850847c620b\": \"0x21e19e0c9bab2400000\",\n \"0x5778ffdc9b94c5a59e224eb965b6de90f222d170\": \"0x122d7ff36603fc0000\",\n \"0x577aeee8d4bc08fc97ab156ed57fb970925366be\": \"0x120df1147258bf0000\",\n \"0x577b2d073c590c50306f5b1195a4b2ba9ecda625\": \"0x1440bdd49515f00000\",\n \"0x577bfe64e3a1e3800e94db1c6c184d8dc8aafc66\": \"0x5134ed17417f280000\",\n \"0x57825aeb09076caa477887fbc9ae37e8b27cc962\": \"0x56bc75e2d63100000\",\n \"0x57883010b4ac857fedac03eab2551723a8447ffb\": \"0x3635c9adc5dea00000\",\n \"0x5789d01db12c816ac268e9af19dc0dd6d99f15df\": \"0xad78ebc5ac6200000\",\n \"0x5792814f59a33a1843faa01baa089eb02ffb5cf1\": \"0x1b1ab319f5ec750000\",\n \"0x5793abe6f1533311fd51536891783b3f9625ef1c\": \"0x2cd8a656f23fda0000\",\n \"0x5797b60fd2894ab3c2f4aede86daf2e788d745ad\": \"0x14542ba12a337c00000\",\n \"0x57a852fdb9b1405bf53ccf9508f83299d3206c52\": \"0x6c6b935b8bbd400000\",\n \"0x57b23d6a1adc06c652a779c6a7fb6b95b9fead66\": \"0xad78ebc5ac6200000\",\n \"0x57bc20e2d62b3d19663cdb4c309d5b4f2fc2db8f\": \"0x56bc75e2d63100000\",\n \"0x57bddf078834009c89d88e6282759dc45335b470\": \"0x74717cfb6883100000\",\n \"0x57beea716cbd81700a73d67f9ff039529c2d9025\": \"0xad78ebc5ac6200000\",\n \"0x57d032a43d164e71aa2ef3ffd8491b0a4ef1ea5b\": \"0x6c6b935b8bbd400000\",\n \"0x57d3df804f2beee6ef53ab94cb3ee9cf524a18d3\": \"0x1556616b9606670000\",\n \"0x57d5fd0e3d3049330ffcdcd020456917657ba2da\": \"0x6bf20195f554d40000\",\n \"0x57dd9471cbfa262709f5f486bcb774c5f527b8f8\": \"0xaadec983fcff40000\",\n \"0x57df23bebdc65eb75feb9cb2fad1c073692b2baf\": \"0xd8d726b7177a800000\",\n \"0x5800cd8130839e94495d2d8415a8ea2c90e0c5cb\": \"0xad78ebc5ac6200000\",\n \"0x5803e68b34da121aef08b602badbafb4d12481ca\": \"0x3cfc82e37e9a7400000\",\n \"0x5816c2687777b6d7d2a2432d59a41fa059e3a406\": \"0x1c4fe43adb0a5e900000\",\n \"0x581a3af297efa4436a29af0072929abf9826f58b\": \"0x6c6b935b8bbd400000\",\n \"0x581b9fd6eae372f3501f42eb9619eec820b78a84\": \"0x42be2c00ca53b8d8000\",\n \"0x581bdf1bb276dbdd86aedcdb397a01efc0e00c5b\": \"0x3635c9adc5dea00000\",\n \"0x581f34b523e5b41c09c87c298e299cbc0e29d066\": \"0x3d5833aafd39758000\",\n \"0x5824a7e22838277134308c5f4b50dab65e43bb31\": \"0x14542ba12a337c00000\",\n \"0x582b70669c97aab7d68148d8d4e90411e2810d56\": \"0x36356633ebd8ea0000\",\n \"0x582e7cc46f1d7b4e6e9d95868bfd370573178f4c\": \"0x6c6b935b8bbd400000\",\n \"0x583e83ba55e67e13e0e76f8392d873cd21fbf798\": \"0x1158e460913d00000\",\n \"0x5869fb867d71f1387f863b698d09fdfb87c49b5c\": \"0xc6bbf858b316080000\",\n \"0x587d6849b168f6c3332b7abae7eb6c42c37f48bf\": \"0x2fb474098f67c00000\",\n \"0x5887dc6a33dfed5ac1edefe35ef91a216231ac96\": \"0xd8d726b7177a80000\",\n \"0x588ed990a2aff44a94105d58c305257735c868ac\": \"0x368c8623a8b4d100000\",\n \"0x58ae2ddc5f4c8ada97e06c0086171767c423f5d7\": \"0x57473d05dabae80000\",\n \"0x58aed6674affd9f64233272a578dd9386b99c263\": \"0xb8507a820728200000\",\n \"0x58b808a65b51e6338969afb95ec70735e451d526\": \"0x8784bc1b9837a380000\",\n \"0x58b8ae8f63ef35ed0762f0b6233d4ac14e64b64d\": \"0x6c6b935b8bbd400000\",\n \"0x58ba1569650e5bbbb21d35d3e175c0d6b0c651a9\": \"0x1b1ae4d6e2ef500000\",\n \"0x58c555bc293cdb16c6362ed97ae9550b92ea180e\": \"0x1158e460913d00000\",\n \"0x58c650ced40bb65641b8e8a924a039def46854df\": \"0x100bd33fb98ba0000\",\n \"0x58c90754d2f20a1cb1dd330625e04b45fa619d5c\": \"0x6c6b935b8bbd400000\",\n \"0x58e2f11223fc8237f69d99c6289c148c0604f742\": \"0x5150ae84a8cdf000000\",\n \"0x58e554af3d87629620da61d538c7f5b4b54c4afe\": \"0x46509d694534728000\",\n \"0x58e5c9e344c806650dacfc904d33edba5107b0de\": \"0x10910d4cdc9f60000\",\n \"0x58e661d0ba73d6cf24099a5562b808f7b3673b68\": \"0x6c6b935b8bbd400000\",\n \"0x58f05b262560503ca761c61890a4035f4c737280\": \"0x1b1ae4d6e2ef5000000\",\n \"0x58fb947364e7695765361ebb1e801ffb8b95e6d0\": \"0xad78ebc5ac6200000\",\n \"0x590181d445007bd0875aaf061c8d51153900836a\": \"0x6c6b935b8bbd400000\",\n \"0x5902e44af769a87246a21e079c08bf36b06efeb3\": \"0x3635c9adc5dea00000\",\n \"0x590acbda37290c0d3ec84fc2000d7697f9a4b15d\": \"0x1b1ae4d6e2ef500000\",\n \"0x590ccb5911cf78f6f622f535c474375f4a12cfcf\": \"0x43c33c1937564800000\",\n \"0x5910106debd291a1cd80b0fbbb8d8d9e93a7cc1e\": \"0x6c6b935b8bbd400000\",\n \"0x59161749fedcf1c721f2202d13ade2abcf460b3d\": \"0x6c6b935b8bbd400000\",\n \"0x591bef3171d1c5957717a4e98d17eb142c214e56\": \"0x43c33c1937564800000\",\n \"0x59203cc37599b648312a7cc9e06dacb589a9ae6a\": \"0x80f7971b6400e8000\",\n \"0x59268171b833e0aa13c54b52ccc0422e4fa03aeb\": \"0xa2a15d09519be00000\",\n \"0x592777261e3bd852c48eca95b3a44c5b7f2d422c\": \"0x43c33c1937564800000\",\n \"0x593044670faeff00a55b5ae051eb7be870b11694\": \"0x73f75d1a085ba0000\",\n \"0x593b45a1864ac5c7e8f0caaeba0d873cd5d113b2\": \"0x14542ba12a337c00000\",\n \"0x593c48935beaff0fde19b04d309cd530a28e52ce\": \"0xd8d726b7177a800000\",\n \"0x59473cd300fffae240f5785626c65dfec792b9af\": \"0x1158e460913d00000\",\n \"0x5948bc3650ed519bf891a572679fd992f8780c57\": \"0xaadec983fcff40000\",\n \"0x594a76f06935388dde5e234696a0668bc20d2ddc\": \"0x97c9ce4cf6d5c00000\",\n \"0x59569a21d28fba4bda37753405a081f2063da150\": \"0xd8d726b7177a800000\",\n \"0x5956b28ec7890b76fc061a1feb52d82ae81fb635\": \"0x6c6b935b8bbd400000\",\n \"0x595e23d788a2d4bb85a15df7136d264a635511b3\": \"0xd5967be4fc3f100000\",\n \"0x597038ff91a0900cbbab488af483c790e6ec00a0\": \"0x21e19e0c9bab2400000\",\n \"0x5970fb1b144dd751e4ce2eca7caa20e363dc4da3\": \"0x21e19e0c9bab2400000\",\n \"0x5975b9528f23af1f0e2ec08ac8ebaa786a2cb8e0\": \"0x12bf50503ae3038000\",\n \"0x5975d78d974ee5bb9e4d4ca2ae77c84b9c3b4b82\": \"0x4a4491bd6dcd280000\",\n \"0x5985c59a449dfc5da787d8244e746c6d70caa55f\": \"0x56bc75e2d63100000\",\n \"0x598aaabae9ed833d7bc222e91fcaa0647b77580b\": \"0x6194049f30f7200000\",\n \"0x5992624c54cdec60a5ae938033af8be0c50cbb0a\": \"0xc454e0f8870f2b0000\",\n \"0x599728a78618d1a17b9e34e0fed8e857d5c40622\": \"0x2f6f10780d22cc00000\",\n \"0x5997ffefb3c1d9d10f1ae2ac8ac3c8e2d2292783\": \"0x3635c9adc5dea00000\",\n \"0x59a087b9351ca42f58f36e021927a22988284f38\": \"0x100bd33fb98ba0000\",\n \"0x59a12df2e3ef857aceff9306b309f6a500f70134\": \"0x3635c9adc5dea00000\",\n \"0x59b96deb8784885d8d3b4a166143cc435d2555a1\": \"0x487a9a304539440000\",\n \"0x59b9e733cba4be00429b4bd9dfa64732053a7d55\": \"0x1158e460913d00000\",\n \"0x59c5d06b170ee4d26eb0a0eb46cb7d90c1c91019\": \"0x21e19e0c9bab2400000\",\n \"0x59c7f785c93160e5807ed34e5e534bc6188647a7\": \"0x22b1c8c1227a000000\",\n \"0x59d139e2e40c7b97239d23dfaca33858f602d22b\": \"0x6c6b935b8bbd400000\",\n \"0x59f6247b0d582aaa25e5114765e4bf3c774f43c2\": \"0x2b5e3af16b1880000\",\n \"0x59fe00696dbd87b7976b29d1156c8842a2e17914\": \"0x6c6b935b8bbd400000\",\n \"0x5a0d609aae2332b137ab3b2f26615a808f37e433\": \"0x21e19e0c9bab24000000\",\n \"0x5a192b964afd80773e5f5eda6a56f14e25e0c6f3\": \"0x1b1ae4d6e2ef500000\",\n \"0x5a1a336962d6e0c63031cc83c6a5c6a6f4478ecb\": \"0x3635c9adc5dea00000\",\n \"0x5a1d2d2d1d520304b6208849570437eb3091bb9f\": \"0x6acb3df27e1f880000\",\n \"0x5a267331facb262daaecd9dd63a9700c5f5259df\": \"0x56bc75e2d63100000\",\n \"0x5a285755391e914e58025faa48cc685f4fd4f5b8\": \"0x581767ba6189c400000\",\n \"0x5a2916b8d2e8cc12e207ab464d433e2370d823d9\": \"0x6c6b935b8bbd400000\",\n \"0x5a2b1c853aeb28c45539af76a00ac2d8a8242896\": \"0x15af1d78b58c40000\",\n \"0x5a2daab25c31a61a92a4c82c9925a1d2ef58585e\": \"0xc380da9c7950c0000\",\n \"0x5a30feac37ac9f72d7b4af0f2bc73952c74fd5c3\": \"0x6c6b935b8bbd400000\",\n \"0x5a5468fa5ca226c7532ecf06e1bc1c45225d7ec9\": \"0x678a932062e4180000\",\n \"0x5a565285374a49eedd504c957d510874d00455bc\": \"0x56bc75e2d63100000\",\n \"0x5a5ee8e9bb0e8ab2fecb4b33d29478be50bbd44b\": \"0x2a1129d09367200000\",\n \"0x5a5f8508da0ebebb90be9033bd4d9e274105ae00\": \"0x16a6502f15a1e540000\",\n \"0x5a6071bcebfcba4ab57f4db96fc7a68bece2ba5b\": \"0x6c6b935b8bbd400000\",\n \"0x5a60c924162873fc7ea4da7f972e350167376031\": \"0x487f277a885798000\",\n \"0x5a6686b0f17e07edfc59b759c77d5bef164d3879\": \"0x50c5e761a444080000\",\n \"0x5a70106f20d63f875265e48e0d35f00e17d02bc9\": \"0x1158e460913d00000\",\n \"0x5a74ba62e7c81a3474e27d894fed33dd24ad95fe\": \"0xfc936392801c0000\",\n \"0x5a7735007d70b06844da9901cdfadb11a2582c2f\": \"0x14542ba12a337c00000\",\n \"0x5a82f96cd4b7e2d93d10f3185dc8f43d4b75aa69\": \"0x6c633fbab98c040000\",\n \"0x5a87f034e6f68f4e74ffe60c64819436036cf7d7\": \"0x1158e460913d00000\",\n \"0x5a891155f50e42074374c739baadf7df2651153a\": \"0x102da6fd0f73a3c0000\",\n \"0x5a9c8b69fc614d69564999b00dcb42db67f97e90\": \"0xb9e615abad3a778000\",\n \"0x5aaf1c31254a6e005fba7f5ab0ec79d7fc2b630e\": \"0x14061b9d77a5e980000\",\n \"0x5ab1a5615348001c7c775dc75748669b8be4de14\": \"0x256a72fb29e69c0000\",\n \"0x5abfec25f74cd88437631a7731906932776356f9\": \"0x9d83cc0dfa11177ff8000\",\n \"0x5ac2908b0f398c0df5bac2cb13ca7314fba8fa3d\": \"0xad4c8316a0b0c0000\",\n \"0x5ac99ad7816ae9020ff8adf79fa9869b7cea6601\": \"0x472698b413b43200000\",\n \"0x5ad12c5ed4fa827e2150cfa0d68c0aa37b1769b8\": \"0x2b5e3af16b18800000\",\n \"0x5ad5e420755613886f35aa56ac403eebdfe4b0d0\": \"0x10f0cf064dd592000000\",\n \"0x5ade77fd81c25c0af713b10702768c1eb2f975e7\": \"0x1158e460913d00000\",\n \"0x5ae64e853ba0a51282cb8db52e41615e7c9f733f\": \"0x6c6b935b8bbd400000\",\n \"0x5aed0e6cfe95f9d680c76472a81a2b680a7f93e2\": \"0xaadec983fcff40000\",\n \"0x5aef16a226dd68071f2483e1da42598319f69b2c\": \"0x6c6b935b8bbd400000\",\n \"0x5af46a25ac09cb73616b53b14fb42ff0a51cddb2\": \"0xd8d726b7177a800000\",\n \"0x5af7c072b2c5acd71c76addcce535cf7f8f93585\": \"0x1158e460913d00000\",\n \"0x5afda9405c8e9736514574da928de67456010918\": \"0x145b8b0239a46920000\",\n \"0x5b06d1e6930c1054692b79e3dbe6ecce53966420\": \"0xb227f63be813c0000\",\n \"0x5b25cae86dcafa2a60e7723631fc5fa49c1ad87d\": \"0x870c58510e85200000\",\n \"0x5b287c7e734299e727626f93fb1187a60d5057fe\": \"0x57cd934a914cb0000\",\n \"0x5b290c01967c812e4dc4c90b174c1b4015bae71e\": \"0x820eb348d52b90000\",\n \"0x5b2b64e9c058e382a8b299224eecaa16e09c8d92\": \"0x8ba52e6fc45e40000\",\n \"0x5b2e2f1618552eab0db98add55637c2951f1fb19\": \"0x28a857425466f800000\",\n \"0x5b30608c678e1ac464a8994c3b33e5cdf3497112\": \"0x15af1d78b58c400000\",\n \"0x5b333696e04cca1692e71986579c920d6b2916f9\": \"0x1b1ae4d6e2ef500000\",\n \"0x5b430d779696a3653fc60e74fbcbacf6b9c2baf1\": \"0x2f6f10780d22cc00000\",\n \"0x5b437365ae3a9a2ff97c68e6f90a7620188c7d19\": \"0x6c8754c8f30c080000\",\n \"0x5b49afcd75447838f6e7ceda8d21777d4fc1c3c0\": \"0xd8d726b7177a800000\",\n \"0x5b4c0c60f10ed2894bdb42d9dd1d210587810a0d\": \"0x1b1ae4d6e2ef500000\",\n \"0x5b4ea16db6809b0352d4b6e81c3913f76a51bb32\": \"0x15af1d78b58c400000\",\n \"0x5b5be0d8c67276baabd8edb30d48ea75640b8b29\": \"0x2cb1f55fb7be100000\",\n \"0x5b5d517029321562111b43086d0b043591109a70\": \"0x8cf23f909c0fa00000\",\n \"0x5b5d8c8eed6c85ac215661de026676823faa0a0c\": \"0x43c33c1937564800000\",\n \"0x5b6d55f6712967405c659129f4b1de09acf2cb7b\": \"0xe7eeba3410b740000\",\n \"0x5b70c49cc98b3df3fbe2b1597f5c1b6347a388b7\": \"0x34957444b840e80000\",\n \"0x5b736eb18353629bde9676dadd165034ce5ecc68\": \"0x6acb3df27e1f880000\",\n \"0x5b759fa110a31c88469f54d44ba303d57dd3e10f\": \"0x5b46dd2f0ea3b80000\",\n \"0x5b7784caea01799ca30227827667ce207c5cbc76\": \"0x6c6b935b8bbd400000\",\n \"0x5b78eca27fbdea6f26befba8972b295e7814364b\": \"0x6c6b935b8bbd400000\",\n \"0x5b800bfd1b3ed4a57d875aed26d42f1a7708d72a\": \"0x15a82d1d5bb88e00000\",\n \"0x5b85e60e2af0544f2f01c64e2032900ebd38a3c7\": \"0x6c6b935b8bbd400000\",\n \"0x5ba2c6c35dfaec296826591904d544464aeabd5e\": \"0x1158e460913d00000\",\n \"0x5baf6d749620803e8348af3710e5c4fbf20fc894\": \"0x10f4002615dfe900000\",\n \"0x5bc1f95507b1018642e45cd9c0e22733b9b1a326\": \"0x56bc75e2d63100000\",\n \"0x5bd23547477f6d09d7b2a005c5ee650c510c56d7\": \"0x21e19e0c9bab2400000\",\n \"0x5bd24aac3612b20c609eb46779bf95698407c57c\": \"0x6acb3df27e1f880000\",\n \"0x5bd6862d517d4de4559d4eec0a06cad05e2f946e\": \"0xad78ebc5ac6200000\",\n \"0x5be045512a026e3f1cebfd5a7ec0cfc36f2dc16b\": \"0x68155a43676e00000\",\n \"0x5bf9f2226e5aeacf1d80ae0a59c6e38038bc8db5\": \"0x14542ba12a337c00000\",\n \"0x5bfafe97b1dd1d712be86d41df79895345875a87\": \"0x1b1ae4d6e2ef500000\",\n \"0x5c0f2e51378f6b0d7bab617331580b6e39ad3ca5\": \"0x2086ac3510526000000\",\n \"0x5c29f9e9a523c1f8669448b55c48cbd47c25e610\": \"0x3446a0dad04cb00000\",\n \"0x5c308bac4857d33baea074f3956d3621d9fa28e1\": \"0x10f08eda8e555098000\",\n \"0x5c312a56c784b122099b764d059c21ece95e84ca\": \"0x52663ccab1e1c0000\",\n \"0x5c31996dcac015f9be985b611f468730ef244d90\": \"0xad78ebc5ac6200000\",\n \"0x5c323457e187761a8276e359b7b7af3f3b6e3df6\": \"0x21e19e0c9bab2400000\",\n \"0x5c3c1c645b917543113b3e6c1c054da1fe742b9a\": \"0x2b5e3af16b18800000\",\n \"0x5c3d19441d196cb443662020fcad7fbb79b29e78\": \"0xc673ce3c40160000\",\n \"0x5c3f567faff7bad1b5120022e8cbcaa82b4917b3\": \"0x6c6b935b8bbd400000\",\n \"0x5c4368918ace6409c79eca80cdaae4391d2b624e\": \"0xd8d726b7177a800000\",\n \"0x5c464197791c8a3da3c925436f277ab13bf2faa2\": \"0x1b1ae4d6e2ef5000000\",\n \"0x5c4881165cb42bb82e97396c8ef44adbf173fb99\": \"0x5fee222041e340000\",\n \"0x5c4892907a0720df6fd3413e63ff767d6b398023\": \"0x2cb009fd3b5790f8000\",\n \"0x5c4f24e994ed8f850ea7818f471c8fac3bcf0452\": \"0x5d80688d9e31c00000\",\n \"0x5c5419565c3aad4e714e0739328e3521c98f05cc\": \"0x1c9f78d2893e400000\",\n \"0x5c6136e218de0a61a137b2b3962d2a6112b809d7\": \"0xff3dbb65ff4868000\",\n \"0x5c61ab79b408dd3229f662593705d72f1e147bb8\": \"0x4d0243d3498cd840000\",\n \"0x5c6d041da7af4487b9dc48e8e1f60766d0a56dbc\": \"0x4f070a003e9c740000\",\n \"0x5c6f36af90ab1a656c6ec8c7d521512762bba3e1\": \"0x6c68ccd09b022c0000\",\n \"0x5c7b9ec7a2438d1e3c7698b545b9c3fd77b7cd55\": \"0x3635c9adc5dea00000\",\n \"0x5c936f3b9d22c403db5e730ff177d74eef42dbbf\": \"0x410d586a20a4c0000\",\n \"0x5cb731160d2e8965670bde925d9de5510935347d\": \"0x22b1c8c1227a00000\",\n \"0x5cb953a0e42f5030812226217fffc3ce230457e4\": \"0x56bc75e2d63100000\",\n \"0x5cbd8daf27ddf704cdd0d909a789ba36ed4f37b2\": \"0xb9f65d00f63c0000\",\n \"0x5cc4cba621f220637742057f6055b80dffd77e13\": \"0x878477b7d253b660000\",\n \"0x5cc7d3066d45d27621f78bb4b339473e442a860f\": \"0x21e1899f0377aea0000\",\n \"0x5cccf1508bfd35c20530aa642500c10dee65eaed\": \"0x2e141ea081ca080000\",\n \"0x5cce72d068c7c3f55b1d2819545e77317cae8240\": \"0x692ae8897081d00000\",\n \"0x5cd0e475b54421bdfc0c12ea8e082bd7a5af0a6a\": \"0x332ca1b67940c0000\",\n \"0x5cd588a14ec648ccf64729f9167aa7bf8be6eb3d\": \"0x3635c9adc5dea00000\",\n \"0x5cd8af60de65f24dc3ce5730ba92653022dc5963\": \"0x61093d7c2c6d380000\",\n \"0x5cdc4708f14f40dcc15a795f7dc8cb0b7faa9e6e\": \"0x1d1c5f3eda20c40000\",\n \"0x5ce0b6862cce9162e87e0849e387cb5df4f9118c\": \"0x5a87e7d7f5f6580000\",\n \"0x5ce2e7ceaaa18af0f8aafa7fbad74cc89e3cd436\": \"0x43c33c1937564800000\",\n \"0x5ce44068b8f4a3fe799e6a8311dbfdeda29dee0e\": \"0x6c6b935b8bbd400000\",\n \"0x5cebe30b2a95f4aefda665651dc0cf7ef5758199\": \"0xfc936392801c0000\",\n \"0x5cf18fa7c8a7c0a2b3d5efd1990f64ddc569242c\": \"0x3635c9adc5dea00000\",\n \"0x5cf44e10540d65716423b1bcb542d21ff83a94cd\": \"0x21e19e0c9bab2400000\",\n \"0x5cf8c03eb3e872e50f7cfd0c2f8d3b3f2cb5183a\": \"0xad78ebc5ac6200000\",\n \"0x5cfa8d568575658ca4c1a593ac4c5d0e44c60745\": \"0xfc66fae3746ac0000\",\n \"0x5cfa9877f719c79d9e494a08d1e41cf103fc87c9\": \"0xad78ebc5ac6200000\",\n \"0x5d1dc3387b47b8451e55106c0cc67d6dc72b7f0b\": \"0x6c6b935b8bbd400000\",\n \"0x5d231a70c1dfeb360abd97f616e2d10d39f3cab5\": \"0x15af1d78b58c400000\",\n \"0x5d24bdbc1c47f0eb83d128cae48ac33c4817e91f\": \"0x3635c9adc5dea00000\",\n \"0x5d2819e8d57821922ee445650ccaec7d40544a8d\": \"0xad78ebc5ac6200000\",\n \"0x5d2f7f0b04ba4be161e19cb6f112ce7a5e7d7fe4\": \"0x1e87f85809dc00000\",\n \"0x5d32f6f86e787ff78e63d78b0ef95fe6071852b8\": \"0x15be6174e1912e0000\",\n \"0x5d39ef9ea6bdfff15d11fe91f561a6f9e31f5da5\": \"0x6c6b935b8bbd400000\",\n \"0x5d3f3b1f7130b0bb21a0fd32396239179a25657f\": \"0xd3ab8ea5e8fd9e80000\",\n \"0x5d5751819b4f3d26ed0c1ac571552735271dbefa\": \"0x3635c9adc5dea00000\",\n \"0x5d5c2c1099bbeefb267e74b58880b444d94449e0\": \"0xdbf0bd181e2e70000\",\n \"0x5d5cdbe25b2a044b7b9be383bcaa5807b06d3c6b\": \"0x6c6b935b8bbd400000\",\n \"0x5d5d6e821c6eef96810c83c491468560ef70bfb5\": \"0x6c6b935b8bbd400000\",\n \"0x5d68324bcb776d3ffd0bf9fea91d9f037fd6ab0f\": \"0x6c6b935b8bbd400000\",\n \"0x5d6ae8cbd6b3393c22d16254100d0238e808147c\": \"0x2707e56d51a30c0000\",\n \"0x5d6c5c720d66a6abca8397142e63d26818eaab54\": \"0x22b1c8c1227a00000\",\n \"0x5d6ccf806738091042ad97a6e095fe8c36aa79c5\": \"0xa31062beeed700000\",\n \"0x5d71799c8df3bccb7ee446df50b8312bc4eb71c5\": \"0xad78ebc5ac6200000\",\n \"0x5d822d9b3ef4b502627407da272f67814a6becd4\": \"0x1158e460913d00000\",\n \"0x5d83b21bd2712360436b67a597ee3378db3e7ae4\": \"0x6c6b935b8bbd400000\",\n \"0x5d872b122e994ef27c71d7deb457bf65429eca6c\": \"0x1b1aded81d394108000\",\n \"0x5d8d31faa864e22159cd6f5175ccecc53fa54d72\": \"0x5b696b70dd567100000\",\n \"0x5d958a9bd189c2985f86c58a8c69a7a78806e8da\": \"0x228f16f861578600000\",\n \"0x5da2a9a4c2c0a4a924cbe0a53ab9d0c627a1cfa0\": \"0x27bf38c6544df50000\",\n \"0x5da4ca88935c27f55c311048840e589e04a8a049\": \"0x4563918244f400000\",\n \"0x5da54785c9bd30575c89deb59d2041d20a39e17b\": \"0x6aa209f0b91d658000\",\n \"0x5db69fe93e6fb6fbd450966b97238b110ad8279a\": \"0x878678326eac9000000\",\n \"0x5db7bba1f9573f24115d8c8c62e9ce8895068e9f\": \"0x2b5aad72c65200000\",\n \"0x5db84400570069a9573cab04b4e6b69535e202b8\": \"0x20dd68aaf3289100000\",\n \"0x5dc36de5359450a1ec09cb0c44cf2bb42b3ae435\": \"0x3c946d893b33060000\",\n \"0x5dc6f45fef26b06e3302313f884daf48e2746fb9\": \"0x1b1ae4d6e2ef500000\",\n \"0x5dcdb6b87a503c6d8a3c65c2cf9a9aa883479a1e\": \"0x1f2bba5d84f99c00000\",\n \"0x5dd112f368c0e6ceff77a9df02a5481651a02fb7\": \"0x93472c85c6d540000\",\n \"0x5dd53ae897526b167d39f1744ef7c3da5b37a293\": \"0x1b1ae4d6e2ef5000000\",\n \"0x5dded049a6e1f329dc4b971e722c9c1f2ade83f0\": \"0x3635c9adc5dea00000\",\n \"0x5de598aba344378cab4431555b4f79992dc290c6\": \"0x487a9a304539440000\",\n \"0x5de9e7d5d1b667d095dd34099c85b0421a0bc681\": \"0x1158e460913d00000\",\n \"0x5df3277ca85936c7a0d2c0795605ad25095e7159\": \"0x6c6b935b8bbd400000\",\n \"0x5dff811dad819ece3ba602c383fb5dc64c0a3a48\": \"0xa1544be879ea80000\",\n \"0x5e031b0a724471d476f3bcd2eb078338bf67fbef\": \"0xfc936392801c0000\",\n \"0x5e0785532c7723e4c0af9357d5274b73bdddddde\": \"0x54b41ea9bdb61dc0000\",\n \"0x5e11ecf69d551d7f4f84df128046b3a13240a328\": \"0x1158e460913d00000\",\n \"0x5e1fbd4e58e2312b3c78d7aaaafa10bf9c3189e3\": \"0x878678326eac9000000\",\n \"0x5e32c72191b8392c55f510d8e3326e3a60501d62\": \"0x9513ea9de0243800000\",\n \"0x5e51b8a3bb09d303ea7c86051582fd600fb3dc1a\": \"0x1158e460913d00000\",\n \"0x5e58e255fc19870a04305ff2a04631f2ff294bb1\": \"0xf43fc2c04ee00000\",\n \"0x5e5a441974a83d74c687ebdc633fb1a49e7b1ad7\": \"0xa2a15d09519be00000\",\n \"0x5e65458be964ae449f71773704979766f8898761\": \"0x1ca7cc735b6f7c0000\",\n \"0x5e67df8969101adabd91accd6bb1991274af8df2\": \"0x1b1ae4d6e2ef500000\",\n \"0x5e6e9747e162f8b45c656e0f6cae7a84bac80e4e\": \"0x6c6b935b8bbd400000\",\n \"0x5e731b55ced452bb3f3fe871ddc3ed7ee6510a8f\": \"0xa2a15d09519be00000\",\n \"0x5e74ed80e9655788e1bb269752319667fe754e5a\": \"0x30927f74c9de00000\",\n \"0x5e772e27f28800c50dda973bb33e10762e6eea20\": \"0x61093d7c2c6d380000\",\n \"0x5e7b8c54dc57b0402062719dee7ef5e37ea35d62\": \"0x9bf9810fd05c840000\",\n \"0x5e7f70378775589fc66a81d3f653e954f55560eb\": \"0x83f289181d84c80000\",\n \"0x5e806e845730f8073e6cc9018ee90f5c05f909a3\": \"0x201e96dacceaf200000\",\n \"0x5e8e4df18cf0af770978a8df8dac90931510a679\": \"0x6c6b935b8bbd400000\",\n \"0x5e90c85877198756b0366c0e17b28e52b446505a\": \"0x144a4a18efeb680000\",\n \"0x5e95fe5ffcf998f9f9ac0e9a81dab83ead77003d\": \"0x1d42c20d32797f0000\",\n \"0x5ead29037a12896478b1296ab714e9cb95428c81\": \"0x3e043072d406e0000\",\n \"0x5eb371c407406c427b3b7de271ad3c1e04269579\": \"0xa2a15d09519be00000\",\n \"0x5ecdbaeab9106ffe5d7b519696609a05baeb85ad\": \"0x1158e460913d00000\",\n \"0x5ed0d6338559ef44dc7a61edeb893fa5d83fa1b5\": \"0xbed1d0263d9f00000\",\n \"0x5ed3bbc05240e0d399eb6ddfe60f62de4d9509af\": \"0x2914c02475f9d6d30000\",\n \"0x5ed3f1ebe2ae6756b5d8dc19cad02c419aa5778b\": \"0x0\",\n \"0x5ed56115bd6505a88273df5c56839470d24a2db7\": \"0x38e6591ee56668000\",\n \"0x5ef8c96186b37984cbfe04c598406e3b0ac3171f\": \"0x1fd933494aa5fe00000\",\n \"0x5efbdfe5389999633c26605a5bfc2c1bb5959393\": \"0x3c057c95cd9080000\",\n \"0x5f13154631466dcb1353c890932a7c97e0878e90\": \"0x14542ba12a337c00000\",\n \"0x5f167aa242bc4c189adecb3ac4a7c452cf192fcf\": \"0x6c6b4c4da6ddbe0000\",\n \"0x5f1c8a04c90d735b8a152909aeae636fb0ce1665\": \"0x17b7827618c5a370000\",\n \"0x5f23ba1f37a96c45bc490259538a54c28ba3b0d5\": \"0x410d586a20a4c00000\",\n \"0x5f26cf34599bc36ea67b9e7a9f9b4330c9d542a3\": \"0x3635c9adc5dea00000\",\n \"0x5f29c9de765dde25852af07d33f2ce468fd20982\": \"0x6c6b935b8bbd400000\",\n \"0x5f2f07d2d697e8c567fcfdfe020f49f360be2139\": \"0x6c6b935b8bbd400000\",\n \"0x5f321b3daaa296cadf29439f9dab062a4bffedd6\": \"0x47025903ea7ae0000\",\n \"0x5f333a3b2310765a0d1832b9be4c0a03704c1c09\": \"0x3635c9adc5dea00000\",\n \"0x5f344b01c7191a32d0762ac188f0ec2dd460911d\": \"0x3635c9adc5dea00000\",\n \"0x5f363e0ab747e02d1b3b66abb69ea53c7baf523a\": \"0x277017338a30ae00000\",\n \"0x5f375b86600c40cca8b2676b7a1a1d1644c5f52c\": \"0x44618d74c623f0000\",\n \"0x5f3e1e6739b0c62200e00a003691d9efb238d89f\": \"0xa2a15d09519be00000\",\n \"0x5f483ffb8f680aedf2a38f7833afdcde59b61e4b\": \"0x6c6b935b8bbd400000\",\n \"0x5f4ace4c1cc13391e01f00b198e1f20b5f91cbf5\": \"0x10f0fa8b9d3811a0000\",\n \"0x5f521282e9b278dc8c034c72af53ee29e5443d78\": \"0x161732d2f8f3ae00000\",\n \"0x5f68a24c7eb4117667737b33393fb3c2148a53b6\": \"0x2cede918d453c0000\",\n \"0x5f708eaf39d823946c51b3a3e9b7b3c003e26341\": \"0x62a992e53a0af00000\",\n \"0x5f742e487e3ab81af2f94afdbe1b9b8f5ccc81bc\": \"0x75c445d41163e60000\",\n \"0x5f74ed0e24ff80d9b2c4a44baa9975428cd6b935\": \"0xa18bcec34888100000\",\n \"0x5f76f0a306269c78306b3d650dc3e9c37084db61\": \"0x821ab0d44149800000\",\n \"0x5f77a107ab1226b3f95f10ee83aefc6c5dff3edc\": \"0x1b1ae4d6e2ef500000\",\n \"0x5f7b3bbac16dab831a4a0fc53b0c549dc36c31ca\": \"0x692ae8897081d00000\",\n \"0x5f93ff832774db5114c55bb4bf44ccf3b58f903f\": \"0x28a9c91a263458290000\",\n \"0x5f9616c47b4a67f406b95a14fe6fc268396f1721\": \"0xad78ebc5ac6200000\",\n \"0x5f981039fcf50225e2adf762752112d1cc26b6e3\": \"0x1b1a416a2153a50000\",\n \"0x5f99dc8e49e61d57daef606acdd91b4d7007326a\": \"0xa2a15d09519be00000\",\n \"0x5fa61f152de6123516c751242979285f796ac791\": \"0xb0f11972963b00000\",\n \"0x5fa7bfe043886127d4011d8356a47e947963aca8\": \"0x62a992e53a0af00000\",\n \"0x5fa8a54e68176c4fe2c01cf671c515bfbdd528a8\": \"0x45e155fa0110fa400000\",\n \"0x5fad960f6b2c84569c9f4d47bf1985fcb2c65da6\": \"0x36356633ebd8ea0000\",\n \"0x5fc6c11426b4a1eae7e51dd512ad1090c6f1a85b\": \"0x93fe5c57d710680000\",\n \"0x5fcd84546896dd081db1a320bd4d8c1dd1528c4c\": \"0x1158e460913d00000\",\n \"0x5fcda847aaf8d7fa8bca08029ca2849166aa15a3\": \"0x21cab81259a3bf0000\",\n \"0x5fd1c3e31778276cb42ea740f5eae9c641dbc701\": \"0xa844a7424d9c80000\",\n \"0x5fd3d6777ec2620ae83a05528ed425072d3ca8fd\": \"0x6c6b935b8bbd400000\",\n \"0x5fd973af366aa5157c54659bcfb27cbfa5ac15d6\": \"0xd8d726b7177a800000\",\n \"0x5fe77703808f823e6c399352108bdb2c527cb87c\": \"0x6a4076cf7995a00000\",\n \"0x5fec49c665e64ee89dd441ee74056e1f01e92870\": \"0x1569b9e733474c00000\",\n \"0x5ff326cd60fd136b245e29e9087a6ad3a6527f0d\": \"0x65ea3db75546600000\",\n \"0x5ff93de6ee054cad459b2d5eb0f6870389dfcb74\": \"0xbed1d0263d9f00000\",\n \"0x6006e36d929bf45d8f16231b126a011ae283d925\": \"0x98a7d9b8314c00000\",\n \"0x6021e85a8814fce1e82a41abd1d3b2dad2faefe0\": \"0x6c6b935b8bbd400000\",\n \"0x6038740ae28d66ba93b0be08482b3205a0f7a07b\": \"0x11216185c29f700000\",\n \"0x603f2fab7afb6e017b94766069a4b43b38964923\": \"0x59d2db2414da990000\",\n \"0x6042276df2983fe2bc4759dc1943e18fdbc34f77\": \"0x6acb3df27e1f880000\",\n \"0x6042c644bae2b96f25f94d31f678c90dc96690db\": \"0x6c6b935b8bbd400000\",\n \"0x604cdf18628dbfa8329194d478dd5201eecc4be7\": \"0x13f306a2409fc0000\",\n \"0x604e9477ebf4727c745bcabbedcb6ccf29994022\": \"0x36369ed7747d260000\",\n \"0x60676d1fa21fca052297e24bf96389c5b12a70d7\": \"0xd177c5a7a68d60000\",\n \"0x60676e92d18b000509c61de540e6c5ddb676d509\": \"0x410d586a20a4c00000\",\n \"0x606f177121f7855c21a5062330c8762264a97b31\": \"0xd8d726b7177a800000\",\n \"0x60864236930d04d8402b5dcbeb807f3caf611ea2\": \"0xd8d726b7177a800000\",\n \"0x60ab71cd26ea6d6e59a7a0f627ee079c885ebbf6\": \"0x1731790534df20000\",\n \"0x60af0ee118443c9b37d2fead77f5e521debe1573\": \"0x678a932062e4180000\",\n \"0x60b358cb3dbefa37f47df2d7365840da8e3bc98c\": \"0x1158e460913d00000\",\n \"0x60b8d6b73b79534fb08bb8cbcefac7f393c57bfe\": \"0x5f68e8131ecf800000\",\n \"0x60be6f953f2a4d25b6256ffd2423ac1438252e4e\": \"0x821ab0d4414980000\",\n \"0x60c3714fdddb634659e4a2b1ea42c4728cc7b8ba\": \"0xb98bc829a6f90000\",\n \"0x60cc3d445ebdf76a7d7ae571c6971dff68cc8585\": \"0x3635c9adc5dea00000\",\n \"0x60d5667140d12614b21c8e5e8a33082e32dfcf23\": \"0x43c33c1937564800000\",\n \"0x60de22a1507432a47b01cc68c52a0bf8a2e0d098\": \"0x10910d4cdc9f60000\",\n \"0x60e0bdd0a259bb9cb09d3f37e5cd8b9daceabf8a\": \"0x4a4491bd6dcd280000\",\n \"0x60e3cc43bcdb026aad759c7066f555bbf2ac66f5\": \"0x6c6b935b8bbd400000\",\n \"0x61042b80fd6095d1b87be2f00f109fabafd157a6\": \"0x56bc75e2d63100000\",\n \"0x6107d71dd6d0eefb11d4c916404cb98c753e117d\": \"0x6c6b935b8bbd400000\",\n \"0x610fd6ee4eebab10a8c55d0b4bd2e7d6ef817156\": \"0x1159561065d5d0000\",\n \"0x6114b0eae5576903f80bfb98842d24ed92237f1e\": \"0x56bc75e2d63100000\",\n \"0x6121af398a5b2da69f65c6381aec88ce9cc6441f\": \"0x22b1c8c1227a000000\",\n \"0x612667f172135b950b2cd1de10afdece6857b873\": \"0x3635c9adc5dea00000\",\n \"0x612ced8dc0dc9e899ee46f7962333315f3f55e44\": \"0x125e35f9cd3d9b0000\",\n \"0x6134d942f037f2cc3d424a230c603d67abd3edf7\": \"0x6c6b935b8bbd400000\",\n \"0x613ac53be565d46536b820715b9b8d3ae68a4b95\": \"0xcbd47b6eaa8cc00000\",\n \"0x613fab44b16bbe554d44afd178ab1d02f37aeaa5\": \"0x6c6b935b8bbd400000\",\n \"0x614e8bef3dd2c59b59a4145674401018351884ea\": \"0x1158e460913d00000\",\n \"0x61518464fdd8b73c1bb6ac6db600654938dbf17a\": \"0xad78ebc5ac6200000\",\n \"0x61547d376e5369bcf978fc162c3c56ae453547e8\": \"0xad78ebc5ac6200000\",\n \"0x6158e107c5eb54cb7604e0cd8dc1e07500d91c3c\": \"0x2b5e3af16b1880000\",\n \"0x615a6f36777f40d6617eb5819896186983fd3731\": \"0x14061b9d77a5e980000\",\n \"0x615f82365c5101f071e7d2cb6af14f7aad2c16c6\": \"0x1158e460913d00000\",\n \"0x6170dd0687bd55ca88b87adef51cfdc55c4dd458\": \"0x6cb32f5c34fe440000\",\n \"0x61733947fab820dbd351efd67855ea0e881373a0\": \"0x1158e460913d00000\",\n \"0x6179979907fe7f037e4c38029d60bcbab832b3d6\": \"0x57473d05dabae80000\",\n \"0x617f20894fa70e94a86a49cd74e03238f64d3cd9\": \"0x10f0dbae61009528000\",\n \"0x617ff2cc803e31c9082233b825d025be3f7b1056\": \"0x6acb3df27e1f880000\",\n \"0x6191ddc9b64a8e0890b4323709d7a07c48b92a64\": \"0x2a034919dfbfbc0000\",\n \"0x6196c3d3c0908d254366b7bca55745222d9d4db1\": \"0xd8d726b7177a800000\",\n \"0x619f171445d42b02e2e07004ad8afe694fa53d6a\": \"0x1158e460913d00000\",\n \"0x61adf5929a5e2981684ea243baa01f7d1f5e148a\": \"0x5fabf6c984f230000\",\n \"0x61b1b8c012cd4c78f698e470f90256e6a30f48dd\": \"0xad78ebc5ac6200000\",\n \"0x61b3df2e9e9fd968131f1e88f0a0eb5bd765464d\": \"0xd8d726b7177a800000\",\n \"0x61b902c5a673885826820d1fe14549e4865fbdc2\": \"0x1224efed2ae1918000\",\n \"0x61b905de663fc17386523b3a28e2f7d037a655cd\": \"0x1b1ae4d6e2ef500000\",\n \"0x61ba87c77e9b596de7ba0e326fddfeec2163ef66\": \"0xad78ebc5ac6200000\",\n \"0x61bf84d5ab026f58c873f86ff0dfca82b55733ae\": \"0x6c6b935b8bbd400000\",\n \"0x61c4ee7c864c4d6b5e37ea1331c203739e826b2f\": \"0x1a1353b382a918000\",\n \"0x61c830f1654718f075ccaba316faacb85b7d120b\": \"0x15af1d78b58c400000\",\n \"0x61c8f1fa43bf846999ecf47b2b324dfb6b63fe3a\": \"0x2b5e3af16b18800000\",\n \"0x61c9dce8b2981cb40e98b0402bc3eb28348f03ac\": \"0xaacacd9b9e22b0000\",\n \"0x61cea71fa464d62a07063f920b0cc917539733d8\": \"0x5a87e7d7f5f6580000\",\n \"0x61d101a033ee0e2ebb3100ede766df1ad0244954\": \"0x1b1ae4d6e2ef500000\",\n \"0x61ed5596c697207f3d55b2a51aa7d50f07fa09e8\": \"0x6c6b935b8bbd400000\",\n \"0x61ff8e67b34d9ee6f78eb36ffea1b9f7c15787af\": \"0x58e7926ee858a00000\",\n \"0x6205c2d5647470848a3840f3887e9b015d34755c\": \"0x6194049f30f7200000\",\n \"0x6228ade95e8bb17d1ae23bfb0518414d497e0eb8\": \"0x15af1d78b58c400000\",\n \"0x6229dcc203b1edccfdf06e87910c452a1f4d7a72\": \"0x6e1d41a8f9ec3500000\",\n \"0x622be4b45495fcd93143efc412d699d6cdc23dc5\": \"0xf015f25736420000\",\n \"0x62331df2a3cbee3520e911dea9f73e905f892505\": \"0x6c6b935b8bbd400000\",\n \"0x625644c95a873ef8c06cdb9e9f6d8d7680043d62\": \"0x6194049f30f7200000\",\n \"0x6265b2e7730f36b776b52d0c9d02ada55d8e3cb6\": \"0x3635c9adc5dea00000\",\n \"0x62680a15f8ccb8bdc02f7360c25ad8cfb57b8ccd\": \"0x3635c9adc5dea00000\",\n \"0x6294eae6e420a3d5600a39c4141f838ff8e7cc48\": \"0xa030dcebbd2f4c0000\",\n \"0x62971bf2634cee0be3c9890f51a56099dbb9519b\": \"0x238fd42c5cf0400000\",\n \"0x629be7ab126a5398edd6da9f18447e78c692a4fd\": \"0x6c6b935b8bbd400000\",\n \"0x62b4a9226e61683c72c183254690daf511b4117a\": \"0xe18398e7601900000\",\n \"0x62b9081e7710345e38e02e16449ace1b85bcfc4e\": \"0x3154c9729d05780000\",\n \"0x62c37c52b97f4b040b1aa391d6dec152893c4707\": \"0x3635c9adc5dea00000\",\n \"0x62c9b271ffd5b770a5eee4edc9787b5cdc709714\": \"0x6c6b935b8bbd400000\",\n \"0x62d5cc7117e18500ac2f9e3c26c86b0a94b0de15\": \"0x5b12aefafa8040000\",\n \"0x62dc72729024375fc37cbb9c7c2393d10233330f\": \"0x6c6b935b8bbd400000\",\n \"0x62e6b2f5eb94fa7a43831fc87e254a3fe3bf8f89\": \"0xd8d726b7177a80000\",\n \"0x62f2e5ccecd52cc4b95e0597df27cc079715608c\": \"0x7c0860e5a80dc0000\",\n \"0x62fb8bd1f0e66b90533e071e6cbe6111fef0bc63\": \"0x3ba1910bf341b000000\",\n \"0x630a913a9031c9492abd4c41dbb15054cfec4416\": \"0x13458db67af35e00000\",\n \"0x630c5273126d517ce67101811cab16b8534cf9a8\": \"0x1feccc62573bbd38000\",\n \"0x631030a5b27b07288a45696f189e1114f12a81c0\": \"0x1b1a7a420ba00d0000\",\n \"0x6310b020fd98044957995092090f17f04e52cdfd\": \"0x55a6e79ccd1d300000\",\n \"0x632b9149d70178a7333634275e82d5953f27967b\": \"0x25f273933db5700000\",\n \"0x632cecb10cfcf38ec986b43b8770adece9200221\": \"0x1158e460913d00000\",\n \"0x6331028cbb5a21485bc51b565142993bdb2582a9\": \"0x1cfdd7468216e80000\",\n \"0x63334fcf1745840e4b094a3bb40bb76f9604c04c\": \"0xd7a5d703a717e80000\",\n \"0x63340a57716bfa63eb6cd133721202575bf796f0\": \"0xb61e0a20c12718000\",\n \"0x634efc24371107b4cbf03f79a93dfd93e431d5fd\": \"0x423582e08edc5c8000\",\n \"0x635c00fdf035bca15fa3610df3384e0fb79068b1\": \"0x1e7e4171bf4d3a00000\",\n \"0x63612e7862c27b587cfb6daf9912cb051f030a9f\": \"0x25b19d4bfe8ed0000\",\n \"0x63666755bd41b5986997783c13043008242b3cb5\": \"0x1b1ae4d6e2ef500000\",\n \"0x637be71b3aa815ff453d5642f73074450b64c82a\": \"0x6c6b935b8bbd400000\",\n \"0x637d67d87f586f0a5a479e20ee13ea310a10b647\": \"0xa3a5926afa1e7300000\",\n \"0x637f5869d6e4695f0eb9e27311c4878aff333380\": \"0x6ac04e68aaec860000\",\n \"0x63977cad7d0dcdc52b9ac9f2ffa136e8642882b8\": \"0x410d586a20a4c0000\",\n \"0x63a61dc30a8e3b30a763c4213c801cbf98738178\": \"0x3635c9adc5dea00000\",\n \"0x63ac545c991243fa18aec41d4f6f598e555015dc\": \"0x2086ac351052600000\",\n \"0x63b9754d75d12d384039ec69063c0be210d5e0e3\": \"0x920b860cc8ecfd8000\",\n \"0x63bb664f9117037628594da7e3c5089fd618b5b5\": \"0x1158e460913d00000\",\n \"0x63c2a3d235e5eeabd0d4a6afdb89d94627396495\": \"0x434ef05b9d84820000\",\n \"0x63c8dfde0b8e01dadc2e748c824cc0369df090b3\": \"0xd255d112e103a00000\",\n \"0x63d55ad99b9137fd1b20cc2b4f03d42cbaddf334\": \"0x15af1d78b58c400000\",\n \"0x63d80048877596e0c28489e650cd4ac180096a49\": \"0xf2dc7d47f15600000\",\n \"0x63e414603e80d4e5a0f5c18774204642258208e4\": \"0x10f0cf064dd59200000\",\n \"0x63e88e2e539ffb450386b4e46789b223f5476c45\": \"0x155170a778e25d00000\",\n \"0x63ef2fbc3daf5edaf4a295629ccf31bcdf4038e5\": \"0x4f2591f896a6500000\",\n \"0x63f0e5a752f79f67124eed633ad3fd2705a397d4\": \"0xd5967be4fc3f100000\",\n \"0x63f5b53d79bf2e411489526530223845fac6f601\": \"0x65a4da25d3016c00000\",\n \"0x63fc93001305adfbc9b85d29d9291a05f8f1410b\": \"0x3635c9adc5dea00000\",\n \"0x63fe6bcc4b8a9850abbe75803730c932251f145b\": \"0xfc936392801c0000\",\n \"0x6403d062549690c8e8b63eae41d6c109476e2588\": \"0x6c6b935b8bbd400000\",\n \"0x64042ba68b12d4c151651ca2813b7352bd56f08e\": \"0x2086ac351052600000\",\n \"0x6405dd13e93abcff377e700e3c1a0086eca27d29\": \"0xfc936392801c0000\",\n \"0x640aba6de984d94517377803705eaea7095f4a11\": \"0x21e19e0c9bab2400000\",\n \"0x640bf87415e0cf407301e5599a68366da09bbac8\": \"0x1abc9f416098158000\",\n \"0x6420f8bcc8164a6152a99d6b99693005ccf7e053\": \"0x36356633ebd8ea0000\",\n \"0x64241a7844290e0ab855f1d4aa75b55345032224\": \"0x56bc75e2d631000000\",\n \"0x64264aedd52dcae918a012fbcd0c030ee6f71821\": \"0x3635c9adc5dea00000\",\n \"0x64370e87202645125a35b207af1231fb6072f9a7\": \"0xad78ebc5ac6200000\",\n \"0x643d9aeed4b180947ed2b9207cce4c3ddc55e1f7\": \"0xad78ebc5ac6200000\",\n \"0x6443b8ae639de91cf73c5ae763eeeed3ddbb9253\": \"0x6c6b935b8bbd400000\",\n \"0x64457fa33b0832506c4f7d1180dce48f46f3e0ff\": \"0x6c6b935b8bbd400000\",\n \"0x64464a6805b462412a901d2db8174b06c22deea6\": \"0x19c846a029c7c80000\",\n \"0x644ba6c61082e989109f5c11d4b40e991660d403\": \"0xd8d726b7177a800000\",\n \"0x64628c6fb8ec743adbd87ce5e018d531d9210437\": \"0x1731790534df20000\",\n \"0x6463f715d594a1a4ace4bb9c3b288a74decf294d\": \"0x6acb3df27e1f880000\",\n \"0x646628a53c2c4193da88359ce718dadd92b7a48d\": \"0xad8006c2f5ef00000\",\n \"0x64672da3ab052821a0243d1ce4b6e0a36517b8eb\": \"0xad78ebc5ac6200000\",\n \"0x646afba71d849e80c0ed59cac519b278e7f7abe4\": \"0x3635c9adc5dea00000\",\n \"0x646e043d0597a664948fbb0dc15475a3a4f3a6ed\": \"0x1158e460913d00000\",\n \"0x6470a4f92ec6b0fccd01234fa59023e9ff1f3aac\": \"0xa2a15d09519be00000\",\n \"0x647b85044df2cf0b4ed4882e88819fe22ae5f793\": \"0x36363b5d9a77700000\",\n \"0x6485470e61db110aebdbafd536769e3c599cc908\": \"0x2086ac351052600000\",\n \"0x648f5bd2a2ae8902db37847d1cb0db9390b06248\": \"0x1a535ecf0760a048000\",\n \"0x649a2b9879cd8fb736e6703b0c7747849796f10f\": \"0x18ee22da01ad34f0000\",\n \"0x649a85b93653075fa6562c409a565d087ba3e1ba\": \"0x6c6b935b8bbd400000\",\n \"0x64adcceec53dd9d9dd15c8cc1a9e736de4241d2c\": \"0x30927f74c9de00000\",\n \"0x64cf0935bf19d2cebbecd8780d27d2e2b2c34166\": \"0x6acb3df27e1f880000\",\n \"0x64d80c3b8ba68282290b75e65d8978a15a87782c\": \"0x6acb3df27e1f880000\",\n \"0x64dba2d6615b8bd7571836dc75bc79d314f5ecee\": \"0x21e19e0c9bab2400000\",\n \"0x64e0217a5b38aa40583625967fa9883690388b6f\": \"0xad78ebc5ac6200000\",\n \"0x64e02abb016cc23a2934f6bcddb681905021d563\": \"0x3635c9adc5dea00000\",\n \"0x64e03ef070a54703b7184e48276c5c0077ef4b34\": \"0x1158e460913d000000\",\n \"0x64e2de21200b1899c3a0c0653b5040136d0dc842\": \"0x43c33c1937564800000\",\n \"0x64ec8a5b743f3479e707dae9ee20ddaa4f40f1d9\": \"0xad78ebc5ac6200000\",\n \"0x6503860b191008c15583bfc88158099301762828\": \"0x3635c9adc5dea00000\",\n \"0x65053191319e067a25e6361d47f37f6318f83419\": \"0x155bd9307f9fe80000\",\n \"0x65093b239bbfba23c7775ca7da5a8648a9f54cf7\": \"0x15af1d78b58c400000\",\n \"0x6509eeb1347e842ffb413e37155e2cbc738273fd\": \"0x6c6b935b8bbd400000\",\n \"0x650b425555e4e4c51718146836a2c1ee77a5b421\": \"0x43c33c1937564800000\",\n \"0x650cf67db060cce17568d5f2a423687c49647609\": \"0x56bc75e2d63100000\",\n \"0x6510df42a599bcb0a519cca961b488759a6f6777\": \"0x6c6b935b8bbd400000\",\n \"0x653675b842d7d8b461f722b4117cb81dac8e639d\": \"0x1ae361fc1451c0000\",\n \"0x654b7e808799a83d7287c67706f2abf49a496404\": \"0x6acb3df27e1f880000\",\n \"0x654f524847b3a6acc0d3d5f1f362b603edf65f96\": \"0x1b1ae4d6e2ef5000000\",\n \"0x655934da8e744eaa3de34dbbc0894c4eda0b61f2\": \"0xad78ebc5ac6200000\",\n \"0x655d5cd7489629e2413c2105b5a172d933c27af8\": \"0xdb03186cd840a60000\",\n \"0x656018584130db83ab0591a8128d9381666a8d0e\": \"0x3779f912019fc0000\",\n \"0x6560941328ff587cbc56c38c78238a7bb5f442f6\": \"0x2861906b59c47a0000\",\n \"0x656579daedd29370d9b737ee3f5cd9d84bc2b342\": \"0x4d853c8f8908980000\",\n \"0x657473774f63ac3d6279fd0743d5790c4f161503\": \"0xad78ebc5ac6200000\",\n \"0x6580b1bc94390f04b397bd73e95d96ef11eaf3a8\": \"0x1158e460913d00000\",\n \"0x65849be1af20100eb8a3ba5a5be4d3ae8db5a70e\": \"0x15af1d78b58c400000\",\n \"0x659c0a72c767a3a65ced0e1ca885a4c51fd9b779\": \"0x6c6b935b8bbd400000\",\n \"0x65a52141f56bef98991724c6e7053381da8b5925\": \"0x3429c335d57fe0000\",\n \"0x65a9dad42e1632ba3e4e49623fab62a17e4d3611\": \"0x50c4cb2a10c600000\",\n \"0x65af8d8b5b1d1eedfa77bcbc96c1b133f83306df\": \"0x55005f0c614480000\",\n \"0x65af9087e05167715497c9a5a749189489004def\": \"0x2d43f3ebfafb2c0000\",\n \"0x65b42faecc1edfb14283ca979af545f63b30e60c\": \"0xfc936392801c0000\",\n \"0x65d33eb39cda6453b19e61c1fe4db93170ef9d34\": \"0xb98bc829a6f90000\",\n \"0x65d8dd4e251cbc021f05b010f2d5dc520c3872e0\": \"0x2d43579a36a90e0000\",\n \"0x65ea26eabbe2f64ccccfe06829c25d4637520225\": \"0x25f273933db5700000\",\n \"0x65ea67ad3fb56ad5fb94387dd38eb383001d7c68\": \"0x56bc75e2d63100000\",\n \"0x65ebaed27edb9dcc1957aee5f452ac2105a65c0e\": \"0x937dfadae25e29b8000\",\n \"0x65ee20b06d9ad589a7e7ce04b9f5f795f402aece\": \"0x6c6b935b8bbd400000\",\n \"0x65f534346d2ffb787fa9cf185d745ba42986bd6e\": \"0x1b1ae4d6e2ef500000\",\n \"0x65f5870f26bce089677dfc23b5001ee492483428\": \"0x112b1f155aa32a30000\",\n \"0x65fd02d704a12a4dace9471b0645f962a89671c8\": \"0x18d1ce6e427cd8000\",\n \"0x65ff874fafce4da318d6c93d57e2c38a0d73e820\": \"0x3638021cecdab00000\",\n \"0x660557bb43f4be3a1b8b85e7df7b3c5bcd548057\": \"0x14542ba12a337c00000\",\n \"0x66082c75a8de31a53913bbd44de3a0374f7faa41\": \"0x4f2591f896a6500000\",\n \"0x6611ce59a98b072ae959dc49ad511daaaaa19d6b\": \"0xad78ebc5ac6200000\",\n \"0x66201bd227ae6dc6bdfed5fbde811fecfe5e9dd9\": \"0x203e9e8492788c0000\",\n \"0x662334814724935b7931ddca6100e00d467727cd\": \"0x2288269d0783d40000\",\n \"0x66274fea82cd30b6c29b23350e4f4f3d310a5899\": \"0x70370550ab82980000\",\n \"0x662cfa038fab37a01745a364e1b98127c503746d\": \"0xd5967be4fc3f100000\",\n \"0x6635b46f711d2da6f0e16370cd8ee43efb2c2d52\": \"0x6c6b935b8bbd400000\",\n \"0x663604b0503046e624cd26a8b6fb4742dce02a6f\": \"0x38b9b797ef68c0000\",\n \"0x6636d7ac637a48f61d38b14cfd4865d36d142805\": \"0x1b1ae4d6e2ef500000\",\n \"0x6640ccf053555c130ae2b656647ea6e31637b9ab\": \"0x6acb3df27e1f880000\",\n \"0x66424bd8785b8cb461102a900283c35dfa07ef6a\": \"0x22e2db26666fc8000\",\n \"0x664cd67dccc9ac8228b45c55db8d76550b659cdc\": \"0x155bd9307f9fe80000\",\n \"0x664e43119870af107a448db1278b044838ffcdaf\": \"0x15af1d78b58c400000\",\n \"0x6651736fb59b91fee9c93aa0bd6ea2f7b2506180\": \"0x1b1ae4d6e2ef500000\",\n \"0x665b000f0b772750cc3c217a5ef429a92bf1ccbb\": \"0xd8d726b7177a800000\",\n \"0x66662006015c1f8e3ccfcaebc8ee6807ee196303\": \"0x1b1b3a1ac261ec0000\",\n \"0x666746fb93d1935c5a3c684e725010c4fad0b1d8\": \"0x1158e460913d00000\",\n \"0x666b4f37d55d63b7d056b615bb74c96b3b01991a\": \"0xd8d726b7177a800000\",\n \"0x66719c0682b2ac7f9e27abebec7edf8decf0ae0d\": \"0x1158e460913d00000\",\n \"0x6671b182c9f741a0cd3c356c73c23126d4f9e6f4\": \"0xad78ebc5ac6200000\",\n \"0x6679aeecd87a57a73f3356811d2cf49d0c4d96dc\": \"0x2086ac351052600000\",\n \"0x667b61c03bb937a9f5d0fc5a09f1ea3363c77035\": \"0xe664992288f2280000\",\n \"0x6685fd2e2544702c360b8bb9ee78f130dad16da5\": \"0x6c6b935b8bbd400000\",\n \"0x668b6ba8ab08eace39c502ef672bd5ccb6a67a20\": \"0x697d95d4201333c0000\",\n \"0x66925de3e43f4b41bf9dadde27d5488ef569ea0d\": \"0x222c8eb3ff6640000\",\n \"0x66b0c100c49149935d14c0dc202cce907cea1a3d\": \"0x6acb3df27e1f880000\",\n \"0x66b1a63da4dcd9f81fe54f5e3fcb4055ef7ec54f\": \"0xaeb272adf9cfa0000\",\n \"0x66b39837cb3cac8a802afe3f12a258bbca62dacd\": \"0x15af1d78b58c400000\",\n \"0x66c8331efe7198e98b2d32b938688e3241d0e24f\": \"0x2098051970e39d00000\",\n \"0x66cc8ab23c00d1b82acd7d73f38c99e0d05a4fa6\": \"0x56bc75e2d63100000\",\n \"0x66dcc5fb4ee7fee046e141819aa968799d644491\": \"0x487a9a304539440000\",\n \"0x66e09427c1e63deed7e12b8c55a6a19320ef4b6a\": \"0x93739534d28680000\",\n \"0x66ec16ee9caab411c55a6629e318de6ee216491d\": \"0x2ee449550898e40000\",\n \"0x66f50406eb1b11a946cab45927cca37470e5a208\": \"0x6c6b935b8bbd400000\",\n \"0x66fdc9fee351fa1538eb0d87d819fcf09e7c106a\": \"0x14627b5d93781b20000\",\n \"0x67048f3a12a4dd1f626c64264cb1d7971de2ca38\": \"0x9c2007651b2500000\",\n \"0x6704f169e0d0b36b57bbc39f3c45437b5ee3d28d\": \"0x155bd9307f9fe80000\",\n \"0x671015b97670b10d5e583f3d62a61c1c79c5143f\": \"0x15af1d78b58c400000\",\n \"0x6710c2c03c65992b2e774be52d3ab4a6ba217ef7\": \"0x274d656ac90e3400000\",\n \"0x671110d96aaff11523cc546bf9940eedffb2faf7\": \"0xd8d726b7177a800000\",\n \"0x6715c14035fb57bb3d667f7b707498c41074b855\": \"0x25f273933db5700000\",\n \"0x671bbca099ff899bab07ea1cf86965c3054c8960\": \"0x2b5e3af16b1880000\",\n \"0x6727daf5b9d68efcab489fedec96d7f7325dd423\": \"0x6c6b935b8bbd400000\",\n \"0x672cbca8440a8577097b19aff593a2ad9d28a756\": \"0x4563918244f400000\",\n \"0x672ec42faa8cd69aaa71b32cc7b404881d52ff91\": \"0x21e19e0c9bab2400000\",\n \"0x672fa0a019088db3166f6119438d07a99f8ba224\": \"0x2d4ca05e2b43ca80000\",\n \"0x673144f0ec142e770f4834fee0ee311832f3087b\": \"0x1b1b6bd7af64c70000\",\n \"0x67350b5331926f5e28f3c1e986f96443809c8b8c\": \"0x1314fb370629800000\",\n \"0x673706b1b0e4dc7a949a7a796258a5b83bb5aa83\": \"0x368c8623a8b4d100000\",\n \"0x6742a2cfce8d79a2c4a51b77747498912245cd6a\": \"0xdfd5b80b7e4680000\",\n \"0x674adb21df4c98c7a347ac4c3c24266757dd7039\": \"0x6c6b935b8bbd400000\",\n \"0x67518e5d02b205180f0463a32004471f753c523e\": \"0x6b918aac494b168000\",\n \"0x675d5caa609bf70a18aca580465d8fb7310d1bbb\": \"0x43c33c1937564800000\",\n \"0x67632046dcb25a54936928a96f423f3320cbed92\": \"0x6c6b935b8bbd400000\",\n \"0x6765df25280e8e4f38d4b1cf446fc5d7eb659e34\": \"0x56bc75e2d63100000\",\n \"0x6776e133d9dc354c12a951087b639650f539a433\": \"0x68155a43676e00000\",\n \"0x6785513cf732e47e87670770b5419be10cd1fc74\": \"0x6c6b935b8bbd400000\",\n \"0x679437eacf437878dc293d48a39c87b7421a216c\": \"0x37f81821db2680000\",\n \"0x679b9a109930517e8999099ccf2a914c4c8dd934\": \"0x340aad21b3b700000\",\n \"0x67a80e0190721f94390d6802729dd12c31a895ad\": \"0x6c6b1375bc91560000\",\n \"0x67b8a6e90fdf0a1cac441793301e8750a9fa7957\": \"0x30849ebe16369c0000\",\n \"0x67bc85e87dc34c4e80aafa066ba8d29dbb8e438e\": \"0x15d1cf4176aeba0000\",\n \"0x67c926093e9b8927933810d98222d62e2b8206bb\": \"0x678a932062e4180000\",\n \"0x67cfda6e70bf7657d39059b59790e5145afdbe61\": \"0x23050d095866580000\",\n \"0x67d682a282ef73fb8d6e9071e2614f47ab1d0f5e\": \"0x3635c9adc5dea00000\",\n \"0x67d6a8aa1bf8d6eaf7384e993dfdf10f0af68a61\": \"0xabcbb5718974b8000\",\n \"0x67da922effa472a6b124e84ea8f86b24e0f515aa\": \"0x1158e460913d00000\",\n \"0x67df242d240dd4b8071d72f8fcf35bb3809d71e8\": \"0xd8d726b7177a800000\",\n \"0x67ee406ea4a7ae6a3a381eb4edd2f09f174b4928\": \"0x3829635f0968b00000\",\n \"0x67f2bb78b8d3e11f7c458a10b5c8e0a1d374467d\": \"0x61093d7c2c6d380000\",\n \"0x67fc527dce1785f0fb8bc7e518b1c669f7ecdfb5\": \"0xd02ab486cedc00000\",\n \"0x68027d19558ed7339a08aee8de3559be063ec2ea\": \"0x6c6b935b8bbd400000\",\n \"0x680640838bd07a447b168d6d923b90cf6c43cdca\": \"0x5dc892aa1131c80000\",\n \"0x6807ddc88db489b033e6b2f9a81553571ab3c805\": \"0x19f8e7559924c0000\",\n \"0x680d5911ed8dd9eec45c060c223f89a7f620bbd5\": \"0x43c33c1937564800000\",\n \"0x6811b54cd19663b11b94da1de2448285cd9f68d9\": \"0x3ba1910bf341b00000\",\n \"0x68190ca885da4231874c1cfb42b1580a21737f38\": \"0xcf152640c5c8300000\",\n \"0x682897bc4f8e89029120fcffb787c01a93e64184\": \"0x21e19e0c9bab2400000\",\n \"0x68295e8ea5afd9093fc0a465d157922b5d2ae234\": \"0x1154e53217ddb0000\",\n \"0x682e96276f518d31d7e56e30dfb009c1218201bd\": \"0x1158e460913d00000\",\n \"0x6835c8e8b74a2ca2ae3f4a8d0f6b954a3e2a8392\": \"0x3429c335d57fe0000\",\n \"0x683633010a88686bea5a98ea53e87997cbf73e69\": \"0x56b394263a40c0000\",\n \"0x683dba36f7e94f40ea6aea0d79b8f521de55076e\": \"0x796e3ea3f8ab00000\",\n \"0x68419c6dd2d3ce6fcbb3c73e2fa079f06051bde6\": \"0x6acb3df27e1f880000\",\n \"0x68473b7a7d965904bedba556dfbc17136cd5d434\": \"0x56bc75e2d63100000\",\n \"0x6847825bdee8240e28042c83cad642f286a3bddc\": \"0x5150ae84a8cdf00000\",\n \"0x684a44c069339d08e19a75668bdba303be855332\": \"0xed2b525841adfc00000\",\n \"0x68531f4dda808f5320767a03113428ca0ce2f389\": \"0x10d3aa536e2940000\",\n \"0x687927e3048bb5162ae7c15cf76bd124f9497b9e\": \"0x6c6b935b8bbd400000\",\n \"0x68809af5d532a11c1a4d6e32aac75c4c52b08ead\": \"0x21e19e0c9bab2400000\",\n \"0x6886ada7bbb0617bda842191c68c922ea3a8ac82\": \"0x3ee23bde0e7d200000\",\n \"0x68883e152e5660fee59626e7e3b4f05110e6222f\": \"0xb94633be975a62a0000\",\n \"0x688a569e965524eb1d0ac3d3733eab909fb3d61e\": \"0x478eae0e571ba00000\",\n \"0x688eb3853bbcc50ecfee0fa87f0ab693cabdef02\": \"0x6b10a18400647c00000\",\n \"0x68a7425fe09eb28cf86eb1793e41b211e57bd68d\": \"0x243d4d18229ca20000\",\n \"0x68a86c402388fddc59028fec7021e98cbf830eac\": \"0x10910d4cdc9f60000\",\n \"0x68acdaa9fb17d3c309911a77b05f5391fa034ee9\": \"0x1e52e336cde22180000\",\n \"0x68addf019d6b9cab70acb13f0b3117999f062e12\": \"0x2b51212e6b7c88000\",\n \"0x68b31836a30a016ada157b638ac15da73f18cfde\": \"0x168d28e3f00280000\",\n \"0x68b6854788a7c6496cdbf5f84b9ec5ef392b78bb\": \"0x42bf06b78ed3b500000\",\n \"0x68c08490c89bf0d6b6f320b1aca95c8312c00608\": \"0xd8d726b7177a800000\",\n \"0x68c7d1711b011a33f16f1f55b5c902cce970bdd7\": \"0x83d6c7aab63600000\",\n \"0x68c8791dc342c373769ea61fb7b510f251d32088\": \"0x3635c9adc5dea00000\",\n \"0x68df947c495bebaeb8e889b3f953d533874bf106\": \"0x1d9945ab2b03480000\",\n \"0x68e8022740f4af29eb48db32bcecddfd148d3de3\": \"0x3635c9adc5dea00000\",\n \"0x68ec79d5be7155716c40941c79d78d17de9ef803\": \"0x1b233877b5208c0000\",\n \"0x68eec1e288ac31b6eaba7e1fbd4f04ad579a6b5d\": \"0x6c6b935b8bbd400000\",\n \"0x68f525921dc11c329b754fbf3e529fc723c834cd\": \"0x57473d05dabae80000\",\n \"0x68f719ae342bd7fef18a05cbb02f705ad38ed5b2\": \"0x38ebad5cdc90280000\",\n \"0x68f7573cd457e14c03fea43e302d30347c10705c\": \"0x10f0cf064dd59200000\",\n \"0x68f8f45155e98c5029a4ebc5b527a92e9fa83120\": \"0xf07b44b40793208000\",\n \"0x68fe1357218d095849cd579842c4aa02ff888d93\": \"0x6c6b935b8bbd400000\",\n \"0x690228e4bb12a8d4b5e0a797b0c5cf2a7509131e\": \"0x65ea3db75546600000\",\n \"0x690594d306613cd3e2fd24bca9994ad98a3d73f8\": \"0x6c6b935b8bbd400000\",\n \"0x69073269729e6414b26ec8dc0fd935c73b579f1e\": \"0x65a4da25d3016c00000\",\n \"0x6919dd5e5dfb1afa404703b9faea8cee35d00d70\": \"0x14061b9d77a5e980000\",\n \"0x693492a5c51396a482881669ccf6d8d779f00951\": \"0x12bf50503ae3038000\",\n \"0x693d83be09459ef8390b2e30d7f7c28de4b4284e\": \"0x6c6b935b8bbd400000\",\n \"0x69517083e303d4fbb6c2114514215d69bc46a299\": \"0x56bc75e2d63100000\",\n \"0x695550656cbf90b75d92ad9122d90d23ca68ca4d\": \"0x3635c9adc5dea00000\",\n \"0x6958f83bb2fdfb27ce0409cd03f9c5edbf4cbedd\": \"0x43c33c1937564800000\",\n \"0x695b0f5242753701b264a67071a2dc880836b8db\": \"0xe398811bec680000\",\n \"0x695b4cce085856d9e1f9ff3e79942023359e5fbc\": \"0x10f0cf064dd59200000\",\n \"0x6966063aa5de1db5c671f3dd699d5abe213ee902\": \"0x1b1ae4d6e2ef5000000\",\n \"0x6974c8a414ceaefd3c2e4dfdbef430568d9a960b\": \"0x121ea68c114e510000\",\n \"0x6978696d5150a9a263513f8f74c696f8b1397cab\": \"0x167f482d3c5b1c00000\",\n \"0x69797bfb12c9bed682b91fbc593591d5e4023728\": \"0x21e19e0c9bab2400000\",\n \"0x697f55536bf85ada51841f0287623a9f0ed09a17\": \"0x21e19e0c9bab2400000\",\n \"0x6982fe8a867e93eb4a0bd051589399f2ec9a5292\": \"0x6c6b935b8bbd400000\",\n \"0x698a8a6f01f9ab682f637c7969be885f6c5302bf\": \"0x10d3aa536e2940000\",\n \"0x698ab9a2f33381e07c0c47433d0d21d6f336b127\": \"0x1158e460913d00000\",\n \"0x6994fb3231d7e41d491a9d68d1fa4cae2cc15960\": \"0xd8d726b7177a800000\",\n \"0x699c9ee47195511f35f862ca4c22fd35ae8ffbf4\": \"0x4563918244f400000\",\n \"0x699fc6d68a4775573c1dcdaec830fefd50397c4e\": \"0x340aad21b3b700000\",\n \"0x69af28b0746cac0da17084b9398c5e36bb3a0df2\": \"0x3677036edf0af60000\",\n \"0x69b80ed90f84834afa3ff82eb964703b560977d6\": \"0x1731790534df20000\",\n \"0x69b81d5981141ec7a7141060dfcf8f3599ffc63e\": \"0x10f0cf064dd59200000\",\n \"0x69bcfc1d43b4ba19de7b274bdffb35139412d3d7\": \"0x35659ef93f0fc40000\",\n \"0x69bd25ade1a3346c59c4e930db2a9d715ef0a27a\": \"0xd8d726b7177a800000\",\n \"0x69c08d744754de709ce96e15ae0d1d395b3a2263\": \"0x3635c9adc5dea00000\",\n \"0x69c2d835f13ee90580408e6a3283c8cca6a434a2\": \"0x238fd42c5cf0400000\",\n \"0x69c94e07c4a9be3384d95dfa3cb9290051873b7b\": \"0x3cb71f51fc5580000\",\n \"0x69cb3e2153998d86e5ee20c1fcd1a6baeeb2863f\": \"0xd8d726b7177a800000\",\n \"0x69d39d510889e552a396135bfcdb06e37e387633\": \"0xd8d726b7177a800000\",\n \"0x69d98f38a3ba3dbc01fa5c2c1427d862832f2f70\": \"0x152d02c7e14af6800000\",\n \"0x69e2e2e704307ccc5b5ca3f164fece2ea7b2e512\": \"0x17b7883c06916600000\",\n \"0x69ff429074cb9b6c63bc914284bce5f0c8fbf7d0\": \"0x1b1ae4d6e2ef500000\",\n \"0x69ff8901b541763f817c5f2998f02dcfc1df2997\": \"0x22b1c8c1227a00000\",\n \"0x6a023af57d584d845e698736f130db9db40dfa9a\": \"0x55b201c8900980000\",\n \"0x6a04f5d53fc0f515be942b8f12a9cb7ab0f39778\": \"0xa9aab3459be1940000\",\n \"0x6a05b21c4f17f9d73f5fb2b0cb89ff5356a6cc7e\": \"0x5150ae84a8cdf00000\",\n \"0x6a0f056066c2d56628850273d7ecb7f8e6e9129e\": \"0x10f0d293cc7a5880000\",\n \"0x6a13d5e32c1fd26d7e91ff6e053160a89b2c8aad\": \"0x2e62f20a69be40000\",\n \"0x6a2e86469a5bf37cee82e88b4c3863895d28fcaf\": \"0x1c229266385bbc0000\",\n \"0x6a3694424c7cc6b8bcd9bccaba540cc1f5df18d7\": \"0x6c6b935b8bbd400000\",\n \"0x6a42ca971c6578d5ade295c3e7f4ad331dd3424e\": \"0x14542ba12a337c00000\",\n \"0x6a44af96b3f032ae641beb67f4b6c83342d37c5d\": \"0x19274b259f6540000\",\n \"0x6a4c8907b600248057b1e46354b19bdc859c991a\": \"0x1158e460913d00000\",\n \"0x6a514e6242f6b68c137e97fea1e78eb555a7e5f7\": \"0x1158e460913d00000\",\n \"0x6a53d41ae4a752b21abed5374649953a513de5e5\": \"0x6c6b935b8bbd400000\",\n \"0x6a6159074ab573e0ee581f0f3df2d6a594629b74\": \"0x10ce1d3d8cb3180000\",\n \"0x6a6337833f8f6a6bf10ca7ec21aa810ed444f4cb\": \"0x37bd24345ce8a40000\",\n \"0x6a6353b971589f18f2955cba28abe8acce6a5761\": \"0xa2a15d09519be00000\",\n \"0x6a63fc89abc7f36e282d80787b7b04afd6553e71\": \"0x8ac7230489e800000\",\n \"0x6a679e378fdce6bfd97fe62f043c6f6405d79e99\": \"0xd8d726b7177a800000\",\n \"0x6a686bf220b593deb9b7324615fb9144ded3f39d\": \"0x4f2591f896a6500000\",\n \"0x6a6b18a45a76467e2e5d5a2ef911c3e12929857b\": \"0x115d3a99a9614f400000\",\n \"0x6a74844d8e9cb5581c45079a2e94462a6cee8821\": \"0x3ab53a552dd4c90000\",\n \"0x6a7b2e0d88867ff15d207c222bebf94fa6ce8397\": \"0xcb49b44ba602d800000\",\n \"0x6a7c252042e7468a3ff773d6450bba85efa26391\": \"0x1b1ae4d6e2ef500000\",\n \"0x6a8a4317c45faa0554ccdb482548183e295a24b9\": \"0x3635c9adc5dea00000\",\n \"0x6a8cea2de84a8df997fd3f84e3083d93de57cda9\": \"0x56be03ca3e47d8000\",\n \"0x6a9758743b603eea3aa0524b42889723c4153948\": \"0x22385a827e815500000\",\n \"0x6aa5732f3b86fb8c81efbe6b5b47b563730b06c8\": \"0x3635c9adc5dea00000\",\n \"0x6ab323ae5056ed0a453072c5abe2e42fcf5d7139\": \"0x2fb474098f67c00000\",\n \"0x6ab5b4c41cddb829690c2fda7f20c85e629dd5d5\": \"0x64d4af714c32900000\",\n \"0x6ac40f532dfee5118117d2ad352da77d4f6da2c8\": \"0x15af1d78b58c400000\",\n \"0x6ac4d4be2db0d99da3faaaf7525af282051d6a90\": \"0x458ca58a962b28000\",\n \"0x6acddca3cd2b4990e25cd65c24149d0912099e79\": \"0xa2a1e07c9f6c908000\",\n \"0x6ad90be252d9cd464d998125fab693060ba8e429\": \"0xd8d726b7177a800000\",\n \"0x6add932193cd38494aa3f03aeccc4b7ab7fabca2\": \"0x4db73254763000000\",\n \"0x6ae57f27917c562a132a4d1bf7ec0ac785832926\": \"0x14542ba12a337c00000\",\n \"0x6aeb9f74742ea491813dbbf0d6fcde1a131d4db3\": \"0x17e554308aa0300000\",\n \"0x6af235d2bbe050e6291615b71ca5829658810142\": \"0xa2a15d09519be00000\",\n \"0x6af6c7ee99df271ba15bf384c0b764adcb4da182\": \"0x36356633ebd8ea0000\",\n \"0x6af8e55969682c715f48ad4fc0fbb67eb59795a3\": \"0x6c6b935b8bbd400000\",\n \"0x6af940f63ec9b8d876272aca96fef65cdacecdea\": \"0xa2a15d09519be00000\",\n \"0x6af9f0dfeeaebb5f64bf91ab771669bf05295553\": \"0x15af1d78b58c400000\",\n \"0x6aff1466c2623675e3cb0e75e423d37a25e442eb\": \"0x5dc892aa1131c80000\",\n \"0x6b0da25af267d7836c226bcae8d872d2ce52c941\": \"0x14542ba12a337c00000\",\n \"0x6b10f8f8b3e3b60de90aa12d155f9ff5ffb22c50\": \"0x6c6b935b8bbd400000\",\n \"0x6b17598a8ef54f797ae515ccb6517d1859bf8011\": \"0x56bc75e2d63100000\",\n \"0x6b20c080606a79c73bd8e75b11717a4e8db3f1c3\": \"0x103f735803f0140000\",\n \"0x6b2284440221ce16a8382de5ff0229472269deec\": \"0x3635c9adc5dea00000\",\n \"0x6b30f1823910b86d3acb5a6afc9defb6f3a30bf8\": \"0xe3aeb5737240a00000\",\n \"0x6b38de841fad7f53fe02da115bd86aaf662466bd\": \"0x5dc892aa1131c80000\",\n \"0x6b4b99cb3fa9f7b74ce3a48317b1cd13090a1a7a\": \"0x31b327e695de20000\",\n \"0x6b5ae7bf78ec75e90cb503c778ccd3b24b4f1aaf\": \"0x2b5e3af16b18800000\",\n \"0x6b63a2dfb2bcd0caec0022b88be30c1451ea56aa\": \"0x2bdb6bf91f7f4c8000\",\n \"0x6b6577f3909a4d6de0f411522d4570386400345c\": \"0x65ea3db75546600000\",\n \"0x6b72a8f061cfe6996ad447d3c72c28c0c08ab3a7\": \"0xe78c6ac79912620000\",\n \"0x6b760d4877e6a627c1c967bee451a8507ddddbab\": \"0x3154c9729d05780000\",\n \"0x6b83bae7b565244558555bcf4ba8da2011891c17\": \"0x6c6b935b8bbd400000\",\n \"0x6b925dd5d8ed6132ab6d0860b82c44e1a51f1fee\": \"0x503b203e9fba200000\",\n \"0x6b94615db750656ac38c7e1cf29a9d13677f4e15\": \"0x28a857425466f800000\",\n \"0x6b951a43274eeafc8a0903b0af2ec92bf1efc839\": \"0x56bc75e2d63100000\",\n \"0x6b992521ec852370848ad697cc2df64e63cc06ff\": \"0x3635c9adc5dea00000\",\n \"0x6ba8f7e25fc2d871618e24e40184199137f9f6aa\": \"0x15af64869a6bc20000\",\n \"0x6ba9b21b35106be159d1c1c2657ac56cd29ffd44\": \"0xf2dc7d47f156000000\",\n \"0x6baf7a2a02ae78801e8904ad7ac05108fc56cff6\": \"0x3635c9adc5dea00000\",\n \"0x6bb2aca23fa1626d18efd6777fb97db02d8e0ae4\": \"0x878678326eac9000000\",\n \"0x6bb4a661a33a71d424d49bb5df28622ed4dffcf4\": \"0x222c8eb3ff66400000\",\n \"0x6bb50813146a9add42ee22038c9f1f7469d47f47\": \"0xada55474b81340000\",\n \"0x6bbc3f358a668dd1a11f0380f3f73108426abd4a\": \"0xd8d726b7177a800000\",\n \"0x6bbd1e719390e6b91043f8b6b9df898ea8001b34\": \"0x6c6c4fa6c3da588000\",\n \"0x6bc85acd5928722ef5095331ee88f484b8cf8357\": \"0x9c2007651b2500000\",\n \"0x6bd3e59f239fafe4776bb9bddd6bee83ba5d9d9f\": \"0x3635c9adc5dea00000\",\n \"0x6bd457ade051795df3f2465c3839aed3c5dee978\": \"0x3634bf39ab98788000\",\n \"0x6be16313643ebc91ff9bb1a2e116b854ea933a45\": \"0x1b1ae4d6e2ef500000\",\n \"0x6be7595ea0f068489a2701ec4649158ddc43e178\": \"0x6c6b935b8bbd400000\",\n \"0x6be9030ee6e2fbc491aca3de4022d301772b7b7d\": \"0x1731790534df20000\",\n \"0x6bec311ad05008b4af353c958c40bd06739a3ff3\": \"0x377f62a0f0a62700000\",\n \"0x6bf7b3c065f2c1e7c6eb092ba0d15066f393d1b8\": \"0x15af1d78b58c400000\",\n \"0x6bf86f1e2f2b8032a95c4d7738a109d3d0ed8104\": \"0x62a992e53a0af00000\",\n \"0x6c05e34e5ef2f42ed09deff1026cd66bcb6960bb\": \"0x6c6b935b8bbd400000\",\n \"0x6c08a6dc0173c7342955d1d3f2c065d62f83aec7\": \"0x1158e460913d00000\",\n \"0x6c0ae9f043c834d44271f13406593dfe094f389f\": \"0x52442ae133b62a8000\",\n \"0x6c0cc917cbee7d7c099763f14e64df7d34e2bf09\": \"0xd8d726b7177a80000\",\n \"0x6c0e712f405c59725fe829e9774bf4df7f4dd965\": \"0xc2868889ca68a440000\",\n \"0x6c101205b323d77544d6dc52af37aca3cec6f7f1\": \"0x21e19e0c9bab2400000\",\n \"0x6c15ec3520bf8ebbc820bd0ff19778375494cf9d\": \"0x6cb7e74867d5e60000\",\n \"0x6c1ddd33c81966dc8621776071a4129482f2c65f\": \"0x878678326eac9000000\",\n \"0x6c25327f8dcbb2f45e561e86e35d8850e53ab059\": \"0x3bcdf9bafef2f00000\",\n \"0x6c2e9be6d4ab450fd12531f33f028c614674f197\": \"0xc2127af858da700000\",\n \"0x6c359e58a13d4578a9338e335c67e7639f5fb4d7\": \"0xbd15b94fc8b280000\",\n \"0x6c3d18704126aa99ee3342ce60f5d4c85f1867cd\": \"0x2b5e3af16b1880000\",\n \"0x6c474bc66a54780066aa4f512eefa773abf919c7\": \"0x5188315f776b80000\",\n \"0x6c4e426e8dc005dfa3516cb8a680b02eea95ae8e\": \"0x487a9a304539440000\",\n \"0x6c52cf0895bb35e656161e4dc46ae0e96dd3e62c\": \"0xd8d8583fa2d52f0000\",\n \"0x6c5422fb4b14e6d98b6091fdec71f1f08640419d\": \"0x15af1d78b58c400000\",\n \"0x6c5c3a54cda7c2f118edba434ed81e6ebb11dd7a\": \"0xad78ebc5ac6200000\",\n \"0x6c63f84556d290bfcd99e434ee9997bfd779577a\": \"0x6c6b935b8bbd400000\",\n \"0x6c63fc85029a2654d79b2bea4de349e4524577c5\": \"0x23c757072b8dd00000\",\n \"0x6c6564e5c9c24eaaa744c9c7c968c9e2c9f1fbae\": \"0x499b42a21139640000\",\n \"0x6c67d6db1d03516c128b8ff234bf3d49b26d2941\": \"0x152d02c7e14af6800000\",\n \"0x6c67e0d7b62e2a08506945a5dfe38263339f1f22\": \"0x6acb3df27e1f880000\",\n \"0x6c6aa0d30b64721990b9504a863fa0bfb5e57da7\": \"0x925e06eec972b00000\",\n \"0x6c714a58fff6e97d14b8a5e305eb244065688bbd\": \"0xd8d726b7177a800000\",\n \"0x6c800d4b49ba07250460f993b8cbe00b266a2553\": \"0x1ab2cf7c9f87e20000\",\n \"0x6c808cabb8ff5fbb6312d9c8e84af8cf12ef0875\": \"0xd8d8583fa2d52f0000\",\n \"0x6c822029218ac8e98a260c1e064029348839875b\": \"0x10f97b787e1e3080000\",\n \"0x6c84cba77c6db4f7f90ef13d5ee21e8cfc7f8314\": \"0x6c6b935b8bbd400000\",\n \"0x6c8687e3417710bb8a93559021a1469e6a86bc77\": \"0x25b2da278d96b7b8000\",\n \"0x6c882c27732cef5c7c13a686f0a2ea77555ac289\": \"0x152d02c7e14af6800000\",\n \"0x6ca5de00817de0cedce5fd000128dede12648b3c\": \"0x1158e460913d00000\",\n \"0x6ca6a132ce1cd288bee30ec7cfeffb85c1f50a54\": \"0x6c6b935b8bbd400000\",\n \"0x6cb11ecb32d3ce829601310636f5a10cf7cf9b5f\": \"0x43fe8949c3801f50000\",\n \"0x6cc1c878fa6cde8a9a0b8311247e741e4642fe6d\": \"0x35659ef93f0fc40000\",\n \"0x6ccb03acf7f53ce87aadcc21a9932de915f89804\": \"0x1b1ae4d6e2ef5000000\",\n \"0x6cd212aee04e013f3d2abad2a023606bfb5c6ac7\": \"0x6c6acc67d7b1d40000\",\n \"0x6cd228dc712169307fe27ceb7477b48cfc8272e5\": \"0x434ea94db8a500000\",\n \"0x6ce1b0f6adc47051e8ab38b39edb4186b03babcc\": \"0x41799794cd24cc0000\",\n \"0x6ceae3733d8fa43d6cd80c1a96e8eb93109c83b7\": \"0x102794ad20da680000\",\n \"0x6d0569e5558fc7df2766f2ba15dc8aeffc5beb75\": \"0xd8e6001e6c302b0000\",\n \"0x6d120f0caae44fd94bcafe55e2e279ef96ba5c7a\": \"0xd8d726b7177a800000\",\n \"0x6d1456fff0104ee844a3314737843338d24cd66c\": \"0x7b06ce87fdd680000\",\n \"0x6d20ef9704670a500bb269b5832e859802049f01\": \"0x70c1cc73b00c80000\",\n \"0x6d2f976734b9d0070d1883cf7acab8b3e4920fc1\": \"0x21e19e0c9bab2400000\",\n \"0x6d39a9e98f81f769d73aad2cead276ac1387babe\": \"0x155bd9307f9fe80000\",\n \"0x6d3b7836a2b9d899721a4d237b522385dce8dfcd\": \"0x3636c25e66ece70000\",\n \"0x6d3f2ba856ccbb0237fa7661156b14b013f21240\": \"0x3635c9adc5dea00000\",\n \"0x6d4008b4a888a826f248ee6a0b0dfde9f93210b9\": \"0x127fcb8afae20d00000\",\n \"0x6d40ca27826d97731b3e86effcd7b92a4161fe89\": \"0x6c6b935b8bbd400000\",\n \"0x6d44974a31d187eda16ddd47b9c7ec5002d61fbe\": \"0x32f51edbaaa3300000\",\n \"0x6d4b5c05d06a20957e1748ab6df206f343f92f01\": \"0x21f360699bf825f8000\",\n \"0x6d4cbf3d8284833ae99344303e08b4d614bfda3b\": \"0x28a857425466f800000\",\n \"0x6d59b21cd0e2748804d9abe064eac2bef0c95f27\": \"0x6c6b935b8bbd400000\",\n \"0x6d63d38ee8b90e0e6ed8f192eda051b2d6a58bfd\": \"0x1a055690d9db80000\",\n \"0x6d6634b5b8a40195d949027af4828802092ceeb6\": \"0xa2a15d09519be00000\",\n \"0x6d7d1c949511f88303808c60c5ea0640fcc02683\": \"0x21e19e0c9bab2400000\",\n \"0x6d846dc12657e91af25008519c3e857f51707dd6\": \"0xf8d30bc92342f80000\",\n \"0x6d9193996b194617211106d1635eb26cc4b66c6c\": \"0x15aa1e7e9dd51c0000\",\n \"0x6d9997509882027ea947231424bedede2965d0ba\": \"0x6c81c7b31195e00000\",\n \"0x6da0ed8f1d69339f059f2a0e02471cb44fb8c3bb\": \"0x32bc38bb63a8160000\",\n \"0x6db72bfd43fef465ca5632b45aab7261404e13bf\": \"0x6c6b935b8bbd400000\",\n \"0x6dbe8abfa1742806263981371bf3d35590806b6e\": \"0x43c33c1937564800000\",\n \"0x6dc3f92baa1d21dab7382b893261a0356fa7c187\": \"0x5dc892aa1131c80000\",\n \"0x6dc7053a718616cfc78bee6382ee51add0c70330\": \"0x6c6b935b8bbd400000\",\n \"0x6dcc7e64fcafcbc2dc6c0e5e662cb347bffcd702\": \"0x43c33c1937564800000\",\n \"0x6dda5f788a6c688ddf921fa3852eb6d6c6c62966\": \"0x22b1c8c1227a00000\",\n \"0x6ddb6092779d5842ead378e21e8120fd4c6bc132\": \"0x6c6b935b8bbd400000\",\n \"0x6ddfef639155daab0a5cb4953aa8c5afaa880453\": \"0x62a992e53a0af00000\",\n \"0x6de02f2dd67efdb7393402fa9eaacbcf589d2e56\": \"0x40138b917edfb80000\",\n \"0x6de4b581385cf7fc9fe8c77d131fe2ee7724c76a\": \"0x7d2997733dcce40000\",\n \"0x6de4d15219182faf3aa2c5d4d2595ff23091a727\": \"0x55a6e79ccd1d300000\",\n \"0x6dedf62e743f4d2c2a4b87a787f5424a7aeb393c\": \"0x9c2007651b2500000\",\n \"0x6df24f6685a62f791ba337bf3ff67e91f3d4bc3a\": \"0x756b49d40a48180000\",\n \"0x6df5c84f7b909aab3e61fe0ecb1b3bf260222ad2\": \"0xd8d726b7177a800000\",\n \"0x6dff90e6dc359d2590882b1483edbcf887c0e423\": \"0x3635c9adc5dea00000\",\n \"0x6e01e4ad569c95d007ada30d5e2db12888492294\": \"0xd8d726b7177a800000\",\n \"0x6e073b66d1b8c66744d88096a8dd99ec7e0228da\": \"0xd8d726b7177a800000\",\n \"0x6e0ee70612c976287d499ddfa6c0dcc12c06deea\": \"0x70bd5b95621460000\",\n \"0x6e12b51e225b4a4372e59ad7a2a1a13ea3d3a137\": \"0x30046c8cc775f040000\",\n \"0x6e1a046caf5b4a57f4fd4bc173622126b4e2fd86\": \"0x61093d7c2c6d380000\",\n \"0x6e1ea4b183e252c9bb7767a006d4b43696cb8ae9\": \"0xff3783c85eed08000\",\n \"0x6e255b700ae7138a4bacf22888a9e2c00a285eec\": \"0xd8d726b7177a800000\",\n \"0x6e270ad529f1f0b8d9cb6d2427ec1b7e2dc64a74\": \"0xad78ebc5ac6200000\",\n \"0x6e2eab85dc89fe29dc0aa1853247dab43a523d56\": \"0x4563918244f400000\",\n \"0x6e3a51db743d334d2fe88224b5fe7c008e80e624\": \"0x5bf0ba6634f680000\",\n \"0x6e4c2ab7db026939dbd3bc68384af660a61816b2\": \"0x90d972f32323c0000\",\n \"0x6e4d2e39c8836629e5b487b1918a669aebdd9536\": \"0x3635c9adc5dea00000\",\n \"0x6e5c2d9b1c546a86eefd5d0a5120c9e4e730190e\": \"0xad201a6794ff80000\",\n \"0x6e60aee1a78f8eda8b424c73e353354ae67c3042\": \"0xbd35a48d9919e60000\",\n \"0x6e64e6129f224e378c0e6e736a7e7a06c211e9ec\": \"0x3635c9adc5dea00000\",\n \"0x6e6d5bbbb9053b89d744a27316c2a7b8c09b547d\": \"0x3152710a023e6d8000\",\n \"0x6e72b2a1186a8e2916543b1cb36a68870ea5d197\": \"0xa1544be879ea80000\",\n \"0x6e761eaa0f345f777b5441b73a0fa5b56b85f22d\": \"0x6c6b935b8bbd400000\",\n \"0x6e79edd4845b076e4cd88d188b6e432dd93f35aa\": \"0x33c5499031720c0000\",\n \"0x6e8212b722afd408a7a73ed3e2395ee6454a0330\": \"0x89e917994f71c0000\",\n \"0x6e84876dbb95c40b6656e42ba9aea08a993b54dc\": \"0x3bbc60e3b6cbbe0000\",\n \"0x6e84c2fd18d8095714a96817189ca21cca62bab1\": \"0x127b6c702621cd8000\",\n \"0x6e866d032d405abdd65cf651411d803796c22311\": \"0x6c6b935b8bbd400000\",\n \"0x6e899e59a9b41ab7ea41df7517860f2acb59f4fd\": \"0x43c33c1937564800000\",\n \"0x6e89c51ea6de13e06cdc748b67c4410fe9bcab03\": \"0xd8d726b7177a800000\",\n \"0x6e8a26689f7a2fdefd009cbaaa5310253450daba\": \"0x6f213717bad8d30000\",\n \"0x6e96faeda3054302c45f58f161324c99a3eebb62\": \"0x1158e460913d00000\",\n \"0x6eb0a5a9ae96d22cf01d8fd6483b9f38f08c2c8b\": \"0xd8d726b7177a800000\",\n \"0x6eb3819617404058268f0c3cff3596bfe9148c1c\": \"0x5a87e7d7f5f6580000\",\n \"0x6eb5578a6bb7c32153195b0d8020a6914852c059\": \"0x8bc2abf40221f4800000\",\n \"0x6ebb5e6957aa821ef659b6018a393a504cae4450\": \"0x6c6b935b8bbd400000\",\n \"0x6ebcf9957f5fc5e985add475223b04b8c14a7aed\": \"0x5dc892aa1131c80000\",\n \"0x6ec3659571b11f889dd439bcd4d67510a25be57e\": \"0x6aaf7c8516d0c0000\",\n \"0x6ec89b39f9f5276a553e8da30e6ec17aa47eefc7\": \"0x18424f5f0b1b4e0000\",\n \"0x6ec96d13bdb24dc7a557293f029e02dd74b97a55\": \"0xd8d726b7177a800000\",\n \"0x6ecaefa6fc3ee534626db02c6f85a0c395571e77\": \"0x2086ac351052600000\",\n \"0x6ed2a12b02f8c688c7b5d3a6ea14d63687dab3b6\": \"0x6c6b935b8bbd400000\",\n \"0x6ed884459f809dfa1016e770edaf3e9fef46fa30\": \"0xb852d6782093f10000\",\n \"0x6edf7f5283725c953ee64317f66188af1184b033\": \"0x1b464311d45a6880000\",\n \"0x6ee8aad7e0a065d8852d7c3b9a6e5fdc4bf50c00\": \"0x1158e460913d00000\",\n \"0x6eefdc850e87b715c72791773c0316c3559b58a4\": \"0xd8d726b7177a800000\",\n \"0x6ef9e8c9b6217d56769af97dbb1c8e1b8be799d2\": \"0x9ddc1e3b901180000\",\n \"0x6efba8fb2ac5b6730729a972ec224426a287c3ad\": \"0xf5985fbcbe1680000\",\n \"0x6efd90b535e00bbd889fda7e9c3184f879a151db\": \"0x22385a827e815500000\",\n \"0x6f051666cb4f7bd2b1907221b829b555d7a3db74\": \"0x5f68e8131ecf800000\",\n \"0x6f0edd23bcd85f6015f9289c28841fe04c83efeb\": \"0x10910d4cdc9f60000\",\n \"0x6f137a71a6f197df2cbbf010dcbd3c444ef5c925\": \"0x6c6b935b8bbd400000\",\n \"0x6f176065e88e3c6fe626267d18a088aaa4db80bc\": \"0xbed1d0263d9f000000\",\n \"0x6f18ec767e320508195f1374500e3f2e125689ff\": \"0x3635c9adc5dea00000\",\n \"0x6f1f4907b8f61f0c51568d692806b382f50324f5\": \"0x6c6b935b8bbd400000\",\n \"0x6f24c9af2b763480515d1b0951bb77a540f1e3f9\": \"0x6acb3df27e1f880000\",\n \"0x6f2576da4de283bbe8e3ee69ddd66e5e711db3f5\": \"0x44591d67fecc800000\",\n \"0x6f29bb375be5ed34ed999bb830ee2957dde76d16\": \"0x6c6b935b8bbd400000\",\n \"0x6f2a31900e240395b19f159c1d00dfe4d898ebdf\": \"0x6c660645aa47180000\",\n \"0x6f2a42e6e033d01061131929f7a6ee1538021e52\": \"0x6c6b935b8bbd400000\",\n \"0x6f39cc37caaa2ddc9b610f6131e0619fae772a3c\": \"0x1b1ae4d6e2ef500000\",\n \"0x6f44ca09f0c6a8294cbd519cdc594ad42c67579f\": \"0x2b5e3af16b1880000\",\n \"0x6f50929777824c291a49c46dc854f379a6bea080\": \"0x138400eca364a00000\",\n \"0x6f6cf20649a9e973177ac67dbadee4ebe5c7bdda\": \"0x11363297d01a8600000\",\n \"0x6f791d359bc3536a315d6382b88311af8ed6da47\": \"0x4fcc1a89027f00000\",\n \"0x6f794dbdf623daa6e0d00774ad6962737c921ea4\": \"0x6c6b935b8bbd400000\",\n \"0x6f7ac681d45e418fce8b3a1db5bc3be6f06c9849\": \"0x6c6b935b8bbd400000\",\n \"0x6f81f3abb1f933b1df396b8e9cc723a89b7c9806\": \"0xf2dc7d47f15600000\",\n \"0x6f8f0d15cc96fb7fe94f1065bc6940f8d12957b2\": \"0x3635c9adc5dea00000\",\n \"0x6f92d6e4548c78996509ee684b2ee29ba3c532b4\": \"0x3635c9adc5dea00000\",\n \"0x6fa60df818a5446418b1bbd62826e0b9825e1318\": \"0x2cb92cc8f6714400000\",\n \"0x6fa6388d402b30afe59934c3b9e13d1186476018\": \"0x24521e2a3017b80000\",\n \"0x6fa72015fa78696efd9a86174f7f1f21019286b1\": \"0x487a9a304539440000\",\n \"0x6fc25e7e00ca4f60a9fe6f28d1fde3542e2d1079\": \"0x2aef353bcddd600000\",\n \"0x6fc53662371dca587b59850de78606e2359df383\": \"0x9c2007651b2500000\",\n \"0x6fcc2c732bdd934af6ccd16846fb26ef89b2aa9b\": \"0x21e2b1d42261d490000\",\n \"0x6fd4e0f3f32bee6d3767fdbc9d353a6d3aab7899\": \"0x25b064a875ea940000\",\n \"0x6fd947d5a73b175008ae6ee8228163da289b167d\": \"0x65a4da25d3016c00000\",\n \"0x6fd98e563d12ce0fd60f4f1f850ae396a9823c02\": \"0x445be3f2ef87940000\",\n \"0x6fddbd9bca66e28765c2162c8433548c1052ed11\": \"0x1184429b82a818800000\",\n \"0x6ff5d361b52ad0b68b1588607ec304ae5665fc98\": \"0x692ae8897081d00000\",\n \"0x6ff6cc90d649de4e96cffee1077a5b302a848dcb\": \"0x18ce79c78802c0000\",\n \"0x6ffe5cf82cc9ea5e36cad7c2974ce7249f3749e6\": \"0x692ae8897081d00000\",\n \"0x7005a772282b1f62afda63f89b5dc6ab64c84cb9\": \"0x3cfc82e37e9a7400000\",\n \"0x700711e311bb947355f755b579250ca7fd765a3e\": \"0x61093d7c2c6d380000\",\n \"0x7010be2df57bd0ab9ae8196cd50ab0c521aba9f9\": \"0x6acb3df27e1f880000\",\n \"0x7023c70956e04a92d70025aad297b539af355869\": \"0x6c6b935b8bbd400000\",\n \"0x7025965d2b88da197d4459be3dc9386344cc1f31\": \"0x6cb7e74867d5e60000\",\n \"0x702802f36d00250fab53adbcd696f0176f638a49\": \"0x6c6b935b8bbd400000\",\n \"0x704819d2e44d6ed1da25bfce84c49fcca25613e5\": \"0x15af1d78b58c400000\",\n \"0x704a6eb41ba34f13addde7d2db7df04915c7a221\": \"0x62a992e53a0af00000\",\n \"0x704ab1150d5e10f5e3499508f0bf70650f028d4b\": \"0xd8d726b7177a800000\",\n \"0x704ae21d762d6e1dde28c235d13104597236db1a\": \"0x6c6b935b8bbd400000\",\n \"0x704d243c2978e46c2c86adbecd246e3b295ff633\": \"0x6d121bebf795f00000\",\n \"0x704d5de4846d39b53cd21d1c49f096db5c19ba29\": \"0x83d6c7aab63600000\",\n \"0x705ddd38355482b8c7d3b515bda1500dd7d7a817\": \"0x15af1d78b58c400000\",\n \"0x70616e2892fa269705b2046b8fe3e72fa55816d3\": \"0x43c33c1937564800000\",\n \"0x70670fbb05d33014444b8d1e8e7700258b8caa6d\": \"0x6c6b935b8bbd400000\",\n \"0x7081fa6baad6cfb7f51b2cca16fb8970991a64ba\": \"0xcaec005f6c0f68000\",\n \"0x7085ae7e7e4d932197b5c7858c00a3674626b7a5\": \"0x14542ba12a337c00000\",\n \"0x7086b4bde3e35d4aeb24b825f1a215f99d85f745\": \"0x6c68ccd09b022c0000\",\n \"0x708a2af425ceb01e87ffc1be54c0f532b20eacd6\": \"0x745d483b1f5a18000\",\n \"0x708ea707bae4357f1ebea959c3a250acd6aa21b3\": \"0x1b1ae4d6e2ef500000\",\n \"0x708fa11fe33d85ad1befcbae3818acb71f6a7d7e\": \"0xfc936392801c0000\",\n \"0x7091303116d5f2389b23238b4d656a8596d984d3\": \"0x3b4e7e80aa58330000\",\n \"0x7099d12f6ec656899b049a7657065d62996892c8\": \"0x15af1d78b58c400000\",\n \"0x709fe9d2c1f1ce42207c9585044a60899f35942f\": \"0x6c6b935b8bbd400000\",\n \"0x70a03549aa6168e97e88a508330a5a0bea74711a\": \"0x487a9a304539440000\",\n \"0x70a4067d448cc25dc8e70e651cea7cf84e92109e\": \"0x98a7d9b8314c00000\",\n \"0x70ab34bc17b66f9c3b63f151274f2a727c539263\": \"0x6c6b935b8bbd400000\",\n \"0x70c213488a020c3cfb39014ef5ba6404724bcaa3\": \"0x692ae8897081d00000\",\n \"0x70d25ed2c8ada59c088cf70dd22bf2db93acc18a\": \"0x39474545e4adbc0000\",\n \"0x70e5e9da735ff077249dcb9aaf3db2a48d9498c0\": \"0x3635c9adc5dea00000\",\n \"0x70fee08b00c6c2c04a3c625c1ff77caf1c32df01\": \"0xad78ebc5ac6200000\",\n \"0x7101bd799e411cde14bdfac25b067ac890eab8e8\": \"0x4e9b8aae48de470000\",\n \"0x7109dd011d15f3122d9d3a27588c10d77744508b\": \"0x6c6b935b8bbd400000\",\n \"0x710b0274d712c77e08a5707d6f3e70c0ce3d92cf\": \"0x15af1d78b58c4000000\",\n \"0x710be8fd5e2918468be2aabea80d828435d79612\": \"0xf43fc2c04ee00000\",\n \"0x71135d8f05963c905a4a07922909235a896a52ea\": \"0xa2a15d09519be00000\",\n \"0x711ecf77d71b3d0ea95ce4758afecdb9c131079d\": \"0x29331e6558f0e00000\",\n \"0x71213fca313404204ecba87197741aa9dfe96338\": \"0x340aad21b3b700000\",\n \"0x712b76510214dc620f6c3a1dd29aa22bf6d214fb\": \"0x14542ba12a337c00000\",\n \"0x712ff7370a13ed360973fedc9ff5d2c93a505e9e\": \"0xd5967be4fc3f100000\",\n \"0x7133843a78d939c69d4486e10ebc7b602a349ff7\": \"0x11d5cacce21f840000\",\n \"0x7148aef33261d8031fac3f7182ff35928daf54d9\": \"0xde42ee1544dd900000\",\n \"0x7163758cbb6c4c525e0414a40a049dcccce919bb\": \"0xad78ebc5ac6200000\",\n \"0x7168b3bb8c167321d9bdb023a6e9fd11afc9afd9\": \"0x61093d7c2c6d380000\",\n \"0x7169724ee72271c534cad6420fb04ee644cb86fe\": \"0x163c2b40dba5520000\",\n \"0x716ad3c33a9b9a0a18967357969b94ee7d2abc10\": \"0x1a2117fe412a480000\",\n \"0x716ba01ead2a91270635f95f25bfaf2dd610ca23\": \"0x979e7012056aa780000\",\n \"0x716d50cca01e938500e6421cc070c3507c67d387\": \"0x6c6b935b8bbd400000\",\n \"0x71762c63678c18d1c6378ce068e666381315147e\": \"0x6c6b935b8bbd400000\",\n \"0x71784c105117c1f68935797fe159abc74e43d16a\": \"0x6c81c7b31195e00000\",\n \"0x7179726f5c71ae1b6d16a68428174e6b34b23646\": \"0x18ea250097cbaf60000\",\n \"0x717cf9beab3638308ded7e195e0c86132d163fed\": \"0x3326ee6f865f4220000\",\n \"0x7180b83ee5574317f21c8072b191d895d46153c3\": \"0x18efc84ad0c7b00000\",\n \"0x71946b7117fc915ed107385f42d99ddac63249c2\": \"0x6c6b935b8bbd400000\",\n \"0x719e891fbcc0a33e19c12dc0f02039ca05b801df\": \"0x14f5538463a1b540000\",\n \"0x71c7230a1d35bdd6819ed4b9a88e94a0eb0786dd\": \"0xeca08b353d24140000\",\n \"0x71d2cc6d02578c65f73c575e76ce8fbcfadcf356\": \"0x3ecc078688a480000\",\n \"0x71d9494e50c5dd59c599dba3810ba1755e6537f0\": \"0xd8d726b7177a800000\",\n \"0x71e38ff545f30fe14ca863d4f5297fd48c73a5ce\": \"0xc2127af858da700000\",\n \"0x71ea5b11ad8d29b1a4cb67bf58ca6c9f9c338c16\": \"0x56bc75e2d631000000\",\n \"0x71ec3aec3f8f9221f9149fede06903a0f9a232f2\": \"0xad78ebc5ac6200000\",\n \"0x71f2cdd1b046e2da2fbb5a26723422b8325e25a3\": \"0x56b394263a40c0000\",\n \"0x71fa22cc6d33206b7d701a163a0dab31ae4d31d6\": \"0x57473d05dabae80000\",\n \"0x7201d1c06920cd397ae8ad869bcda6e47ffb1b5a\": \"0x1158e460913d00000\",\n \"0x72072a0ef1cff3d567cdd260e708ddc11cbc9a31\": \"0x56bc75e2d63100000\",\n \"0x72094f3951ffc9771dced23ada080bcaf9c7cca7\": \"0x14542ba12a337c00000\",\n \"0x720994dbe56a3a95929774e20e1fe525cf3704e4\": \"0x1b1ae4d6e2ef5000000\",\n \"0x720e6b22bf430966fa32b6acb9a506eebf662c61\": \"0x83d6c7aab63600000\",\n \"0x721158be5762b119cc9b2035e88ee4ee78f29b82\": \"0x21e19e0c9bab2400000\",\n \"0x721f9d17e5a0e74205947aeb9bc6a7938961038f\": \"0x2d041d705a2c60000\",\n \"0x7222fec7711781d26eaa4e8485f7aa3fac442483\": \"0x18b84570022a200000\",\n \"0x72393d37b451effb9e1ff3b8552712e2a970d8c2\": \"0x35659ef93f0fc40000\",\n \"0x723d8baa2551d2addc43c21b45e8af4ca2bfb2c2\": \"0x5f68e8131ecf800000\",\n \"0x72402300e81d146c2e644e2bbda1da163ca3fb56\": \"0x17b7883c06916600000\",\n \"0x72480bede81ad96423f2228b5c61be44fb523100\": \"0x15af1d78b58c4000000\",\n \"0x724ce858857ec5481c86bd906e83a04882e5821d\": \"0xa2a15d09519be00000\",\n \"0x726a14c90e3f84144c765cffacba3e0df11b48be\": \"0x21e19e0c9bab2400000\",\n \"0x7283cd4675da58c496556151dafd80c7f995d318\": \"0x29331e6558f0e00000\",\n \"0x7286e89cd9de8f7a8a00c86ffdb53992dd9251d1\": \"0x692ae8897081d00000\",\n \"0x728f9ab080157db3073156dbca1a169ef3179407\": \"0x1b1ae4d6e2ef500000\",\n \"0x7294c918b1aefb4d25927ef9d799e71f93a28e85\": \"0xaadec983fcff40000\",\n \"0x7294ec9da310bc6b4bbdf543b0ef45abfc3e1b4d\": \"0x4a89f54ef0121c00000\",\n \"0x729aad4627744e53f5d66309aa74448b3acdf46f\": \"0x6c6b935b8bbd400000\",\n \"0x72a2fc8675feb972fa41b50dffdbbae7fa2adfb7\": \"0x9ab4fc67b528c80000\",\n \"0x72a8260826294726a75bf39cd9aa9e07a3ea14cd\": \"0x6c6b935b8bbd400000\",\n \"0x72b05962fb2ad589d65ad16a22559eba1458f387\": \"0x73f75d1a085ba0000\",\n \"0x72b5633fe477fe542e742facfd690c137854f216\": \"0x5a87e7d7f5f6580000\",\n \"0x72b7a03dda14ca9c661a1d469fd33736f673c8e8\": \"0x6c6b935b8bbd400000\",\n \"0x72b904440e90e720d6ac1c2ad79c321dcc1c1a86\": \"0x54069233bf7f780000\",\n \"0x72b90a4dc097239492c5b9777dcd1e52ba2be2c2\": \"0x14542ba12a337c00000\",\n \"0x72bb27cb99f3e2c2cf90a98f707d30e4a201a071\": \"0x58e7926ee858a00000\",\n \"0x72c083beadbdc227c5fb43881597e32e83c26056\": \"0x43c33c1937564800000\",\n \"0x72cd048a110574482983492dfb1bd27942a696ba\": \"0x6c6b935b8bbd400000\",\n \"0x72d03d4dfab3500cf89b86866f15d4528e14a195\": \"0xf34b82fd8e91200000\",\n \"0x72dabb5b6eed9e99be915888f6568056381608f8\": \"0xb4c96c52cb4fe8000\",\n \"0x72fb49c29d23a18950c4b2dc0ddf410f532d6f53\": \"0x6c6b935b8bbd400000\",\n \"0x72feaf124579523954645b7fafff0378d1c8242e\": \"0x3635c9adc5dea00000\",\n \"0x7301dc4cf26d7186f2a11bf8b08bf229463f64a3\": \"0x6c6b935b8bbd400000\",\n \"0x730447f97ce9b25f22ba1afb36df27f9586beb9b\": \"0x2c73c937742c500000\",\n \"0x7306de0e288b56cfdf987ef0d3cc29660793f6dd\": \"0x1b8abfb62ec8f60000\",\n \"0x730d8763c6a4fd824ab8b859161ef7e3a96a1200\": \"0x43c33c1937564800000\",\n \"0x73128173489528012e76b41a5e28c68ba4e3a9d4\": \"0x3635c9adc5dea00000\",\n \"0x7313461208455455465445a459b06c3773b0eb30\": \"0x6c6b935b8bbd400000\",\n \"0x732fead60f7bfdd6a9dec48125e3735db1b6654f\": \"0x1158e460913d00000\",\n \"0x734223d27ff23e5906caed22595701bb34830ca1\": \"0x6c6b935b8bbd400000\",\n \"0x73473e72115110d0c3f11708f86e77be2bb0983c\": \"0x1158e460913d00000\",\n \"0x7352586d021ad0cf77e0e928404a59f374ff4582\": \"0xb8507a820728200000\",\n \"0x73550beb732ba9ddafda7ae406e18f7feb0f8bb2\": \"0x97c9ce4cf6d5c00000\",\n \"0x735b97f2fc1bd24b12076efaf3d1288073d20c8c\": \"0x1158e460913d00000\",\n \"0x735e328666ed5637142b3306b77ccc5460e72c3d\": \"0x6ab8f37879c9910000\",\n \"0x7363cd90fbab5bb8c49ac20fc62c398fe6fb744c\": \"0x6c6b935b8bbd400000\",\n \"0x736b44503dd2f6dd5469ff4c5b2db8ea4fec65d0\": \"0x1104ee759f21e30000\",\n \"0x736bf1402c83800f893e583192582a134eb532e9\": \"0x21e19d293c01f260000\",\n \"0x738ca94db7ce8be1c3056cd6988eb376359f3353\": \"0x5665b96cf35acf00000\",\n \"0x73914b22fc2f131584247d82be4fecbf978ad4ba\": \"0x6c6b935b8bbd400000\",\n \"0x73932709a97f02c98e51b091312865122385ae8e\": \"0x4d853c8f8908980000\",\n \"0x7393cbe7f9ba2165e5a7553500b6e75da3c33abf\": \"0x56bc75e2d63100000\",\n \"0x73b4d499de3f38bf35aaf769a6e318bc6d123692\": \"0x6c6b935b8bbd400000\",\n \"0x73bedd6fda7ba3272185087b6351fc133d484e37\": \"0x11226bf9dce59780000\",\n \"0x73bfe7710f31cab949b7a2604fbf5239cee79015\": \"0x6c6b935b8bbd400000\",\n \"0x73cf80ae9688e1580e68e782cd0811f7aa494d2c\": \"0x1a4aba225c207400000\",\n \"0x73d7269ff06c9ffd33754ce588f74a966abbbbba\": \"0x165c96647b38a200000\",\n \"0x73d8fee3cb864dce22bb26ca9c2f086d5e95e63b\": \"0x3635c9adc5dea00000\",\n \"0x73df3c3e7955f4f2d859831be38000b1076b3884\": \"0x6acb3df27e1f880000\",\n \"0x73e4a2b60cf48e8baf2b777e175a5b1e4d0c2d8f\": \"0x56bc75e2d63100000\",\n \"0x740af1eefd3365d78ba7b12cb1a673e06a077246\": \"0x42bf06b78ed3b500000\",\n \"0x740bfd52e01667a3419b029a1b8e45576a86a2db\": \"0x38ebad5cdc902800000\",\n \"0x740f641614779dcfa88ed1d425d60db42a060ca6\": \"0x3622c6760810570000\",\n \"0x7412c9bc30b4df439f023100e63924066afd53af\": \"0x1b1ae4d6e2ef500000\",\n \"0x741693c30376508513082020cc2b63e9fa92131b\": \"0x410d586a20a4c00000\",\n \"0x7421ce5be381738ddc83f02621974ff0686c79b8\": \"0x58788cb94b1d800000\",\n \"0x74316adf25378c10f576d5b41a6f47fa98fce33d\": \"0x1238131e5c7ad50000\",\n \"0x743651b55ef8429df50cf81938c2508de5c8870f\": \"0x6c6b935b8bbd400000\",\n \"0x743de50026ca67c94df54f066260e1d14acc11ac\": \"0x6c6b935b8bbd400000\",\n \"0x7445202f0c74297a004eb3726aa6a82dd7c02fa1\": \"0x6c6b935b8bbd400000\",\n \"0x744b03bba8582ae5498e2dc22d19949467ab53fc\": \"0x1b1ae4d6e2ef500000\",\n \"0x744c0c77ba7f236920d1e434de5da33e48ebf02c\": \"0x6acb3df27e1f880000\",\n \"0x7450ff7f99eaa9116275deac68e428df5bbcd8b9\": \"0x6c6b935b8bbd400000\",\n \"0x7456c5b2c5436e3e571008933f1805ccfe34e9ec\": \"0x3635c9adc5dea00000\",\n \"0x745ad3abc6eeeb2471689b539e789ce2b8268306\": \"0x3d4194bea011928000\",\n \"0x745aecbaf9bb39b74a67ea1ce623de368481baa6\": \"0x21e19e0c9bab2400000\",\n \"0x745ccf2d819edbbddea8117b5c49ed3c2a066e93\": \"0xd8d726b7177a800000\",\n \"0x7462c89caa9d8d7891b2545def216f7464d5bb21\": \"0x5eaed54a28b310000\",\n \"0x74648caac748dd135cd91ea14c28e1bd4d7ff6ae\": \"0xa80d24677efef00000\",\n \"0x7471f72eeb300624eb282eab4d03723c649b1b58\": \"0x1b1ae4d6e2ef5000000\",\n \"0x747abc9649056d3926044d28c3ad09ed17b67d70\": \"0x10f0dbae61009528000\",\n \"0x747ff7943b71dc4dcdb1668078f83dd7cc4520c2\": \"0x340aad21b3b700000\",\n \"0x7480de62254f2ba82b578219c07ba5be430dc3cb\": \"0x17da3a04c7b3e000000\",\n \"0x7484d26becc1eea8c6315ec3ee0a450117dc86a0\": \"0x28a857425466f800000\",\n \"0x74863acec75d03d53e860e64002f2c165e538377\": \"0x3635c9adc5dea00000\",\n \"0x7489cc8abe75cda4ef0d01cef2605e47eda67ab1\": \"0x73f75d1a085ba0000\",\n \"0x748c285ef1233fe4d31c8fb1378333721c12e27a\": \"0x6c6b935b8bbd400000\",\n \"0x749087ac0f5a97c6fad021538bf1d6cda18e0daa\": \"0x3635c9adc5dea00000\",\n \"0x7495ae78c0d90261e2140ef2063104731a60d1ed\": \"0x1db50718925210000\",\n \"0x749a4a768b5f237248938a12c623847bd4e688dc\": \"0x3e733628714200000\",\n \"0x749ad6f2b5706bbe2f689a44c4b640b58e96b992\": \"0x56bc75e2d63100000\",\n \"0x74a17f064b344e84db6365da9591ff1628257643\": \"0x1158e460913d00000\",\n \"0x74aeec915de01cc69b2cb5a6356feea14658c6c5\": \"0xc9a95ee2986520000\",\n \"0x74afe54902d615782576f8baac13ac970c050f6e\": \"0x9a1aaa3a9fba70000\",\n \"0x74b7e0228baed65957aebb4d916d333aae164f0e\": \"0x6c6b935b8bbd400000\",\n \"0x74bc4a5e2045f4ff8db184cf3a9b0c065ad807d2\": \"0x6c6b935b8bbd400000\",\n \"0x74bce9ec38362d6c94ccac26d5c0e13a8b3b1d40\": \"0x363526410442f50000\",\n \"0x74bf7a5ab59293149b5c60cf364263e5ebf1aa0d\": \"0x6470c3e771e3c0000\",\n \"0x74c73c90528a157336f1e7ea20620ae53fd24728\": \"0x1e63a2e538f16e30000\",\n \"0x74d1a4d0c7524e018d4e06ed3b648092b5b6af2c\": \"0x2b5e3af16b1880000\",\n \"0x74d366b07b2f56477d7c7077ac6fe497e0eb6559\": \"0x10f0cf064dd59200000\",\n \"0x74d37a51747bf8b771bfbf43943933d100d21483\": \"0x3635c9adc5dea00000\",\n \"0x74d671d99cbea1ab57906375b63ff42b50451d17\": \"0x3635c9adc5dea00000\",\n \"0x74ebf4425646e6cf81b109ce7bf4a2a63d84815f\": \"0x22b1c8c1227a00000\",\n \"0x74ed33acf43f35b98c9230b9e6642ecb5330839e\": \"0x24f6dffb498d280000\",\n \"0x74ef2869cbe608856045d8c2041118579f2236ea\": \"0x33cd64591956e0000\",\n \"0x74fc5a99c0c5460503a13b0509459da19ce7cd90\": \"0xad78ebc5ac6200000\",\n \"0x750bbb8c06bbbf240843cc75782ee02f08a97453\": \"0x2d43f3ebfafb2c0000\",\n \"0x7514adbdc63f483f304d8e94b67ff3309f180b82\": \"0x21c4a06e2d13598000\",\n \"0x7517f16c28d132bb40e3ba36c6aef131c462da17\": \"0xfc936392801c0000\",\n \"0x751a2ca34e7187c163d28e3618db28b13c196d26\": \"0x1b1ae4d6e2ef500000\",\n \"0x751abcb6cc033059911815c96fd191360ab0442d\": \"0x1b1ae4d6e2ef5000000\",\n \"0x7526e482529f0a14eec98871dddd0e721b0cd9a2\": \"0x1158e460913d00000\",\n \"0x7529f3797bb6a20f7ea6492419c84c867641d81c\": \"0x6c6b935b8bbd400000\",\n \"0x752a5ee232612cd3005fb26e5b597de19f776be6\": \"0x127fcb8afae20d00000\",\n \"0x752c9febf42f66c4787bfa7eb17cf5333bba5070\": \"0x6a99f2b54fdd580000\",\n \"0x7539333046deb1ef3c4daf50619993f444e1de68\": \"0x40138b917edfb80000\",\n \"0x7553aa23b68aa5f57e135fe39fdc235eaca8c98c\": \"0x3635c9adc5dea00000\",\n \"0x755a60bf522fbd8fff9723446b7e343a7068567e\": \"0x43c33c1937564800000\",\n \"0x755f587e5efff773a220726a13d0f2130d9f896b\": \"0x3635c9adc5dea00000\",\n \"0x75621865b6591365606ed378308c2d1def4f222c\": \"0xa80d24677efef00000\",\n \"0x75636cdb109050e43d5d6ec47e359e218e857eca\": \"0x4d8b2276c8962280000\",\n \"0x7566496162ba584377be040a4f87777a707acaeb\": \"0xd8d726b7177a800000\",\n \"0x756b84eb85fcc1f4fcdcc2b08db6a86e135fbc25\": \"0xae8e7a0bb575d00000\",\n \"0x756f45e3fa69347a9a973a725e3c98bc4db0b5a0\": \"0xad78ebc5ac6200000\",\n \"0x757b65876dbf29bf911d4f0692a2c9beb1139808\": \"0xdf93a59337d6dd8000\",\n \"0x757fa55446c460968bb74b5ebca96c4ef2c709c5\": \"0x3708baed3d68900000\",\n \"0x75804aac64b4199083982902994d9c5ed8828f11\": \"0x1e3d07b0a620e40000\",\n \"0x7592c69d067b51b6cc639d1164d5578c60d2d244\": \"0x1158e460913d00000\",\n \"0x75abe5270f3a78ce007cf37f8fbc045d489b7bb1\": \"0x6c6acc67d7b1d40000\",\n \"0x75ac547017134c04ae1e11d60e63ec04d18db4ef\": \"0x14542ba12a337c00000\",\n \"0x75b0e9c942a4f0f6f86d3f95ff998022fa67963b\": \"0x50c5e761a444080000\",\n \"0x75b95696e8ec4510d56868a7c1a735c68b244890\": \"0x15af1d78b58c4000000\",\n \"0x75be8ff65e5788aec6b2a52d5fa7b1e7a03ba675\": \"0x3abcdc5343d740000\",\n \"0x75c11d024d12ae486c1095b7a7b9c4af3e8edeb9\": \"0x1158e460913d00000\",\n \"0x75c1ad23d23f24b384d0c3149177e86697610d21\": \"0x15c5bcd6c288bbd0000\",\n \"0x75c2ffa1bef54919d2097f7a142d2e14f9b04a58\": \"0x90f358504032a10000\",\n \"0x75d67ce14e8d29e8c2ffe381917b930b1aff1a87\": \"0xa2a15d09519be00000\",\n \"0x75de7e9352e90b13a59a5878ffecc7831cac4d82\": \"0x9489237adb9a500000\",\n \"0x75f7539d309e9039989efe2e8b2dbd865a0df088\": \"0x855b5ba65c84f00000\",\n \"0x7608f437b31f18bc0b64d381ae86fd978ed7b31f\": \"0x2b5e3af16b1880000\",\n \"0x760ff3354e0fde938d0fb5b82cef5ba15c3d2916\": \"0x21e19e0c9bab2400000\",\n \"0x761a6e362c97fbbd7c5977acba2da74687365f49\": \"0x9f74ae1f953d00000\",\n \"0x761e6caec189c230a162ec006530193e67cf9d19\": \"0x6c6b935b8bbd400000\",\n \"0x761f8a3a2af0a8bdbe1da009321fb29764eb62a1\": \"0x21e19e0c9bab2400000\",\n \"0x762998e1d75227fced7a70be109a4c0b4ed86414\": \"0x1158e460913d00000\",\n \"0x762d6f30dab99135e4eca51d5243d6c8621102d5\": \"0xf498941e664280000\",\n \"0x76331e30796ce664b2700e0d4153700edc869777\": \"0x6c6b935b8bbd400000\",\n \"0x763886e333c56feff85be3951ab0b889ce262e95\": \"0x6c6b935b8bbd400000\",\n \"0x763a7cbab70d7a64d0a7e52980f681472593490c\": \"0x2086ac351052600000\",\n \"0x763eece0b08ac89e32bfa4bece769514d8cb5b85\": \"0xd8d726b7177a800000\",\n \"0x7640a37f8052981515bce078da93afa4789b5734\": \"0x6c6b935b8bbd400000\",\n \"0x7641f7d26a86cddb2be13081810e01c9c83c4b20\": \"0xb98bc829a6f90000\",\n \"0x764692cccb33405dd0ab0c3379b49caf8e6221ba\": \"0x1158e460913d00000\",\n \"0x764d5212263aff4a2a14f031f04ec749dc883e45\": \"0x6449e84e47a8a80000\",\n \"0x764fc46d428b6dbc228a0f5f55c9508c772eab9f\": \"0x581767ba6189c400000\",\n \"0x76506eb4a780c951c74a06b03d3b8362f0999d71\": \"0x1b1ae4d6e2ef500000\",\n \"0x765be2e12f629e6349b97d21b62a17b7c830edab\": \"0x14542ba12a337c00000\",\n \"0x76628150e2995b5b279fc83e0dd5f102a671dd1c\": \"0x878678326eac9000000\",\n \"0x766b3759e8794e926dac473d913a8fb61ad0c2c9\": \"0x4b06dbbb40f4a0000\",\n \"0x7670b02f2c3cf8fd4f4730f3381a71ea431c33c7\": \"0xe7eeba3410b740000\",\n \"0x767a03655af360841e810d83f5e61fb40f4cd113\": \"0x35659ef93f0fc40000\",\n \"0x767ac690791c2e23451089fe6c7083fe55deb62b\": \"0x2c73c937742c500000\",\n \"0x767fd7797d5169a05f7364321c19843a8c348e1e\": \"0x104e70464b1580000\",\n \"0x76846f0de03b5a76971ead298cdd08843a4bc6c6\": \"0xd71b0fe0a28e0000\",\n \"0x768498934e37e905f1d0e77b44b574bcf3ec4ae8\": \"0x43c33c1937564800000\",\n \"0x768ce0daa029b7ded022e5fc574d11cde3ecb517\": \"0x1174a5cdf88bc80000\",\n \"0x7693bdeb6fc82b5bca721355223175d47a084b4d\": \"0x4a89f54ef0121c00000\",\n \"0x76aaf8c1ac012f8752d4c09bb46607b6651d5ca8\": \"0x1158e460913d00000\",\n \"0x76ab87dd5a05ad839a4e2fc8c85aa6ba05641730\": \"0x6c6b935b8bbd400000\",\n \"0x76afc225f4fa307de484552bbe1d9d3f15074c4a\": \"0xa290b5c7ad39680000\",\n \"0x76becae4a31d36f3cb577f2a43594fb1abc1bb96\": \"0x543a9ce0e1332f00000\",\n \"0x76c27535bcb59ce1fa2d8c919cabeb4a6bba01d1\": \"0x6c6b935b8bbd400000\",\n \"0x76ca22bcb8799e5327c4aa2a7d0949a1fcce5f29\": \"0x52a03f228c5ae20000\",\n \"0x76cac488111a4fd595f568ae3a858770fc915d5f\": \"0xad78ebc5ac6200000\",\n \"0x76cb9c8b69f4387675c48253e234cb7e0d74a426\": \"0x190f4482eb91dae0000\",\n \"0x76f83ac3da30f7092628c7339f208bfc142cb1ee\": \"0x9a18ffe7427d640000\",\n \"0x76f9ad3d9bbd04ae055c1477c0c35e7592cb2a20\": \"0x8833f11e3458f200000\",\n \"0x76ffc157ad6bf8d56d9a1a7fddbc0fea010aabf4\": \"0x3635c9adc5dea00000\",\n \"0x77028e409cc43a3bd33d21a9fc53ec606e94910e\": \"0xd255d112e103a00000\",\n \"0x770c2fb2c4a81753ac0182ea460ec09c90a516f8\": \"0x1158e460913d00000\",\n \"0x770d98d31b4353fceee8560c4ccf803e88c0c4e0\": \"0x2086ac351052600000\",\n \"0x7713ab8037411c09ba687f6f9364f0d3239fac28\": \"0x21e19e0c9bab2400000\",\n \"0x771507aeee6a255dc2cd9df55154062d0897b297\": \"0x121ea68c114e510000\",\n \"0x7719888795ad745924c75760ddb1827dffd8cda8\": \"0x6c6b4c4da6ddbe0000\",\n \"0x7727af101f0aaba4d23a1cafe17c6eb5dab1c6dc\": \"0x6c6b935b8bbd400000\",\n \"0x772c297f0ad194482ee8c3f036bdeb01c201d5cc\": \"0xad78ebc5ac6200000\",\n \"0x77306ffe2e4a8f3ca826c1a249f7212da43aeffd\": \"0x43c33c1937564800000\",\n \"0x773141127d8cf318aebf88365add3d5527d85b6a\": \"0x3636d7af5ec98e0000\",\n \"0x7746b6c6699c8f34ca2768a820f1ffa4c207fe05\": \"0xd8d8583fa2d52f0000\",\n \"0x7751f363a0a7fd0533190809ddaf9340d8d11291\": \"0x1158e460913d00000\",\n \"0x7757a4b9cc3d0247ccaaeb9909a0e56e1dd6dcc2\": \"0x1158e460913d00000\",\n \"0x775c10c93e0db7205b2643458233c64fc33fd75b\": \"0x6c6b935b8bbd400000\",\n \"0x77617ebc4bebc5f5ddeb1b7a70cdeb6ae2ffa024\": \"0x6acb3df27e1f880000\",\n \"0x776943ffb2ef5cdd35b83c28bc046bd4f4677098\": \"0xa2a15d09519be00000\",\n \"0x77701e2c493da47c1b58f421b5495dee45bea39b\": \"0x148f649cf6142a58000\",\n \"0x77798f201257b9c35204957057b54674aefa51df\": \"0x813ca56906d340000\",\n \"0x778c43d11afe3b586ff374192d96a7f23d2b9b7f\": \"0x8bb4fcfa3b7d6b8000\",\n \"0x778c79f4de1953ebce98fe8006d53a81fb514012\": \"0x36330322d5238c0000\",\n \"0x779274bf1803a336e4d3b00ddd93f2d4f5f4a62e\": \"0x3635c9adc5dea00000\",\n \"0x77a17122fa31b98f1711d32a99f03ec326f33d08\": \"0x5c283d410394100000\",\n \"0x77a34907f305a54c85db09c363fde3c47e6ae21f\": \"0x35659ef93f0fc40000\",\n \"0x77a769fafdecf4a638762d5ba3969df63120a41d\": \"0x6c6b935b8bbd400000\",\n \"0x77be6b64d7c733a436adec5e14bf9ad7402b1b46\": \"0x3635c9adc5dea00000\",\n \"0x77bfe93ccda750847e41a1affee6b2da96e7214e\": \"0x1043561a8829300000\",\n \"0x77c4a697e603d42b12056cbba761e7f51d0443f5\": \"0x24dce54d34a1a00000\",\n \"0x77cc02f623a9cf98530997ea67d95c3b491859ae\": \"0x497303c36ea0c20000\",\n \"0x77d43fa7b481dbf3db530cfbf5fdced0e6571831\": \"0x6c6b935b8bbd400000\",\n \"0x77da5e6c72fb36bce1d9798f7bcdf1d18f459c2e\": \"0x13695bb6cf93e0000\",\n \"0x77f4e3bdf056883cc87280dbe640a18a0d02a207\": \"0xa81993a2bfb5b0000\",\n \"0x77f609ca8720a023262c55c46f2d26fb3930ac69\": \"0xf015f25736420000\",\n \"0x77f81b1b26fc84d6de97ef8b9fbd72a33130cc4a\": \"0x3635c9adc5dea00000\",\n \"0x7819b0458e314e2b53bfe00c38495fd4b9fdf8d6\": \"0x1158e460913d00000\",\n \"0x781b1501647a2e06c0ed43ff197fccec35e1700b\": \"0xa2a15d09519be00000\",\n \"0x782f52f0a676c77716d574c81ec4684f9a020a97\": \"0x2e14e206b730ad8000\",\n \"0x78355df0a230f83d032c703154414de3eedab557\": \"0x6c6b935b8bbd400000\",\n \"0x7836f7ef6bc7bd0ff3acaf449c84dd6b1e2c939f\": \"0xe08de7a92cd97c0000\",\n \"0x7837fcb876da00d1eb3b88feb3df3fa4042fac82\": \"0x5f68e8131ecf800000\",\n \"0x783eec8aa5dac77b2e6623ed5198a431abbaee07\": \"0x17da3a04c7b3e00000\",\n \"0x785c8ea774d73044a734fa790a1b1e743e77ed7c\": \"0xcf152640c5c830000\",\n \"0x7860a3de38df382ae4a4dce18c0c07b98bce3dfa\": \"0x3635c9adc5dea00000\",\n \"0x78634371e17304cbf339b1452a4ce438dc764cce\": \"0x21e19e0c9bab2400000\",\n \"0x7864dc999fe4f8e003c0f43decc39aae1522dc0f\": \"0x51e102bd8ece00000\",\n \"0x78746a958dced4c764f876508c414a68342cecb9\": \"0x2be374fe8e2c40000\",\n \"0x787d313fd36b053eeeaedbce74b9fb0678333289\": \"0x5c058b7842719600000\",\n \"0x78859c5b548b700d9284cee4b6633c2f52e529c2\": \"0xa030dcebbd2f4c0000\",\n \"0x788e809741a3b14a22a4b1d937c82cfea489eebe\": \"0x17b7883c06916600000\",\n \"0x78a1e254409fb1b55a7cb4dd8eba3b30c8bad9ef\": \"0x56bc75e2d63100000\",\n \"0x78a5e89900bd3f81dd71ba869d25fec65261df15\": \"0xafd812fee03d5700000\",\n \"0x78b978a9d7e91ee529ea4fc4b76feaf8762f698c\": \"0x6c6b935b8bbd4000000\",\n \"0x78ce3e3d474a8a047b92c41542242d0a08c70f99\": \"0x21e19e0c9bab2400000\",\n \"0x78cf8336b328db3d87813a472b9e89b75e0cf3bc\": \"0x3635c9adc5dea00000\",\n \"0x78d4f8c71c1e68a69a98f52fcb45da8af56ea1a0\": \"0x6c6b935b8bbd400000\",\n \"0x78df2681d6d602e22142d54116dea15d454957aa\": \"0x102794ad20da680000\",\n \"0x78e08bc533413c26e291b3143ffa7cc9afb97b78\": \"0xad78ebc5ac6200000\",\n \"0x78e83f80b3678c7a0a4e3e8c84dccde064426277\": \"0x61093d7c2c6d380000\",\n \"0x78f5c74785c5668a838072048bf8b453594ddaab\": \"0x15af1d78b58c400000\",\n \"0x790f91bd5d1c5cc4739ae91300db89e1c1303c93\": \"0x6c6b935b8bbd400000\",\n \"0x7917e5bd82a9790fd650d043cdd930f7799633db\": \"0xd8d4602c26bf6c0000\",\n \"0x7919e7627f9b7d54ea3b14bb4dd4649f4f39dee0\": \"0x5a87e7d7f5f6580000\",\n \"0x791f6040b4e3e50dcf3553f182cd97a90630b75d\": \"0xd8d726b7177a800000\",\n \"0x7930c2d9cbfa87f510f8f98777ff8a8448ca5629\": \"0xad6eedd17cf3b8000\",\n \"0x794529d09d017271359730027075b87ad83dae6e\": \"0x10ce1d3d8cb3180000\",\n \"0x794b51c39e53d9e762b0613b829a44b472f4fff3\": \"0x2435e0647841cc8000\",\n \"0x79551cede376f747e3716c8d79400d766d2e0195\": \"0x9cb37afa4ff78680000\",\n \"0x795ebc2626fc39b0c86294e0e837dcf523553090\": \"0x3635c9adc5dea00000\",\n \"0x796ebbf49b3e36d67694ad79f8ff36767ac6fab0\": \"0x34bc4fdde27c00000\",\n \"0x796f87ba617a2930b1670be92ed1281fb0b346e1\": \"0x6f5e86fb528280000\",\n \"0x797427e3dbf0feae7a2506f12df1dc40326e8505\": \"0x3635c9adc5dea00000\",\n \"0x797510e386f56393ced8f477378a444c484f7dad\": \"0x3635c9adc5dea00000\",\n \"0x797bb7f157d9feaa17f76da4f704b74dc1038341\": \"0xb50fcfafebecb00000\",\n \"0x7988901331e387f713faceb9005cb9b65136eb14\": \"0x6acb3df27e1f880000\",\n \"0x7989d09f3826c3e5af8c752a8115723a84d80970\": \"0x1686f8614cf0ad0000\",\n \"0x7995bd8ce2e0c67bf1c7a531d477bca1b2b97561\": \"0x14248d617829ece0000\",\n \"0x79aeb34566b974c35a5881dec020927da7df5d25\": \"0x6c6b935b8bbd400000\",\n \"0x79b120eb8806732321288f675a27a9225f1cd2eb\": \"0x85a0bf37dec9e40000\",\n \"0x79b48d2d6137c3854d611c01ea42427a0f597bb7\": \"0xa5aa85009e39c0000\",\n \"0x79b8aad879dd30567e8778d2d231c8f37ab8734e\": \"0x6c6b935b8bbd400000\",\n \"0x79bf2f7b6e328aaf26e0bb093fa22da29ef2f471\": \"0x61093d7c2c6d380000\",\n \"0x79c130c762b8765b19d2abc9a083ab8f3aad7940\": \"0xd5967be4fc3f100000\",\n \"0x79c1be19711f73bee4e6316ae7549459aacea2e0\": \"0x15af1d78b58c400000\",\n \"0x79c6002f8452ca157f1317e80a2faf24475559b7\": \"0x1158e460913d00000\",\n \"0x79cac6494f11ef2798748cb53285bd8e22f97cda\": \"0x6c6b935b8bbd400000\",\n \"0x79cfa9780ae6d87b2c31883f09276986c89a6735\": \"0x3635c9adc5dea00000\",\n \"0x79dba256472db4e058f2e4cdc3ea4e8a42773833\": \"0x4f2591f896a6500000\",\n \"0x79ed10cf1f6db48206b50919b9b697081fbdaaf3\": \"0x6c6b935b8bbd400000\",\n \"0x79f08e01ce0988e63c7f8f2908fade43c7f9f5c9\": \"0xfc936392801c0000\",\n \"0x79fd6d48315066c204f9651869c1096c14fc9781\": \"0x6c6b935b8bbd400000\",\n \"0x79ffb4ac13812a0b78c4a37b8275223e176bfda5\": \"0xf015f25736420000\",\n \"0x7a0589b143a8e5e107c9ac66a9f9f8597ab3e7ab\": \"0x51e932d76e8f7b0000\",\n \"0x7a0a78a9cc393f91c3d9e39a6b8c069f075e6bf5\": \"0x487a9a304539440000\",\n \"0x7a1370a742ec2687e761a19ac5a794329ee67404\": \"0xa2a1326761e2920000\",\n \"0x7a2dfc770e24368131b7847795f203f3d50d5b56\": \"0x269fec7f0361d200000\",\n \"0x7a33834e8583733e2d52aead589bd1affb1dd256\": \"0x3635c9adc5dea00000\",\n \"0x7a36aba5c31ea0ca7e277baa32ec46ce93cf7506\": \"0x43c33c1937564800000\",\n \"0x7a381122bada791a7ab1f6037dac80432753baad\": \"0x21e19e0c9bab2400000\",\n \"0x7a48d877b63a8f8f9383e9d01e53e80c528e955f\": \"0x1b1ae4d6e2ef5000000\",\n \"0x7a4f9b850690c7c94600dbee0ca4b0a411e9c221\": \"0x678a932062e4180000\",\n \"0x7a63869fc767a4c6b1cd0e0649f3634cb121d24b\": \"0x433874f632cc60000\",\n \"0x7a67dd043a504fc2f2fc7194e9becf484cecb1fb\": \"0xd8d726b7177a80000\",\n \"0x7a6b26f438d9a352449155b8876cbd17c9d99b64\": \"0x14542ba12a337c00000\",\n \"0x7a6d781c77c4ba1fcadf687341c1e31799e93d27\": \"0xeda838c4929080000\",\n \"0x7a7068e1c3375c0e599db1fbe6b2ea23b8f407d2\": \"0x6c6b935b8bbd400000\",\n \"0x7a74cee4fa0f6370a7894f116cd00c1147b83e59\": \"0x2b5e3af16b18800000\",\n \"0x7a79e30ff057f70a3d0191f7f53f761537af7dff\": \"0x15af1d78b58c400000\",\n \"0x7a7a4f807357a4bbe68e1aa806393210c411ccb3\": \"0x65a4da25d3016c00000\",\n \"0x7a8563867901206f3f2bf0fa3e1c8109cabccd85\": \"0x76d41c62494840000\",\n \"0x7a8797690ab77b5470bf7c0c1bba612508e1ac7d\": \"0x1e09296c3378de40000\",\n \"0x7a8c89c014509d56d7b68130668ff6a3ecec7370\": \"0x1043561a8829300000\",\n \"0x7a94b19992ceb8ce63bc92ee4b5aded10c4d9725\": \"0x38d1a8064bb64c80000\",\n \"0x7aa79ac04316cc8d08f20065baa6d4142897d54e\": \"0x4be4e7267b6ae00000\",\n \"0x7aad4dbcd3acf997df93586956f72b64d8ad94ee\": \"0xd8d726b7177a800000\",\n \"0x7ab256b204800af20137fabcc916a23258752501\": \"0x43c33c1937564800000\",\n \"0x7aba56f63a48bc0817d6b97039039a7ad62fae2e\": \"0x2086ac351052600000\",\n \"0x7abb10f5bd9bc33b8ec1a82d64b55b6b18777541\": \"0x43c33c1937564800000\",\n \"0x7ac48d40c664cc9a6d89f1c5f5c80a1c70e744e6\": \"0xa31062beeed7000000\",\n \"0x7ac58f6ffc4f8107ae6e30378e4e9f99c57fbb24\": \"0x22b1c8c1227a00000\",\n \"0x7ad3f307616f19dcb143e6444dab9c3c33611f52\": \"0x2b5e3af16b1880000\",\n \"0x7ad82caea1a8b4ed05319b9c9870173c814e06ee\": \"0x2164b7a04ac8a00000\",\n \"0x7ade5d66b944bb860c0efdc86276d58f4653f711\": \"0x6c6b935b8bbd400000\",\n \"0x7adfedb06d91f3cc7390450b85550270883c7bb7\": \"0x1178fa40515db40000\",\n \"0x7ae1c19e53c71cee4c73fae2d7fc73bf9ab5e392\": \"0x3635c9adc5dea00000\",\n \"0x7ae659eb3bc46852fa86fac4e21c768d50388945\": \"0xf810c1cb501b80000\",\n \"0x7aea25d42b2612286e99c53697c6bc4100e2dbbf\": \"0x6c6b935b8bbd400000\",\n \"0x7aef7b551f0b9c46e755c0f38e5b3a73fe1199f5\": \"0x50c5e761a444080000\",\n \"0x7b0b31ff6e24745ead8ed9bb85fc0bf2fe1d55d4\": \"0x2b5e3af16b18800000\",\n \"0x7b0fea1176d52159333a143c294943da36bbddb4\": \"0x1fc7da64ea14c100000\",\n \"0x7b11673cc019626b290cbdce26046f7e6d141e21\": \"0x1b1ae4d6e2ef500000\",\n \"0x7b122162c913e7146cad0b7ed37affc92a0bf27f\": \"0x51af096b2301d18000\",\n \"0x7b1bf53a9cbe83a7dea434579fe72aac8d2a0cd0\": \"0xad4c8316a0b0c0000\",\n \"0x7b1daf14891b8a1e1bd429d8b36b9a4aa1d9afbf\": \"0x1b1ae4d6e2ef500000\",\n \"0x7b1fe1ab4dfd0088cdd7f60163ef59ec2aee06f5\": \"0x6c6b935b8bbd400000\",\n \"0x7b25bb9ca8e702217e9333225250e53c36804d48\": \"0x65ea3db75546600000\",\n \"0x7b27d0d1f3dd3c140294d0488b783ebf4015277d\": \"0x15af1d78b58c400000\",\n \"0x7b4007c45e5a573fdbb6f8bd746bf94ad04a3c26\": \"0x33821f5135d259a0000\",\n \"0x7b43c7eea8d62355b0a8a81da081c6446b33e9e0\": \"0xd8d726b7177a800000\",\n \"0x7b4d2a38269069c18557770d591d24c5121f5e83\": \"0x25f273933db5700000\",\n \"0x7b6175ec9befc738249535ddde34688cd36edf25\": \"0x21e19e0c9bab2400000\",\n \"0x7b66126879844dfa34fe65c9f288117fefb449ad\": \"0x14542ba12a337c00000\",\n \"0x7b6a84718dd86e63338429ac811d7c8a860f21f1\": \"0x61093d7c2c6d380000\",\n \"0x7b712c7af11676006a66d2fc5c1ab4c479ce6037\": \"0x1b1ae4d6e2ef5000000\",\n \"0x7b73242d75ca9ad558d650290df17692d54cd8b8\": \"0x6c6e59e67c78540000\",\n \"0x7b761feb7fcfa7ded1f0eb058f4a600bf3a708cb\": \"0xf95dd2ec27cce00000\",\n \"0x7b827cae7ff4740918f2e030ab26cb98c4f46cf5\": \"0x194684c0b39de100000\",\n \"0x7b893286427e72db219a21fc4dcd5fbf59283c31\": \"0x21e19e0c9bab2400000\",\n \"0x7b9226d46fe751940bc416a798b69ccf0dfab667\": \"0xe3aeb5737240a00000\",\n \"0x7b98e23cb96beee80a168069ebba8f20edd55ccf\": \"0xba0c91587c14a0000\",\n \"0x7bb0fdf5a663b5fba28d9c902af0c811e252f298\": \"0xad78ebc5ac6200000\",\n \"0x7bb9571f394b0b1a8eba5664e9d8b5e840677bea\": \"0x11164759ffb320000\",\n \"0x7bb984c6dbb9e279966afafda59c01d02627c804\": \"0x1b464311d45a6880000\",\n \"0x7bbbec5e70bdead8bb32b42805988e9648c0aa97\": \"0x3636d7af5ec98e0000\",\n \"0x7bca1da6c80a66baa5db5ac98541c4be276b447d\": \"0x24cf049680fa3c0000\",\n \"0x7bddb2ee98de19ee4c91f661ee8e67a91d054b97\": \"0x3635c9adc5dea00000\",\n \"0x7be2f7680c802da6154c92c0194ae732517a7169\": \"0xfc936392801c0000\",\n \"0x7be7f2456971883b9a8dbe4c91dec08ac34e8862\": \"0xa2a15d09519be00000\",\n \"0x7be8ccb4f11b66ca6e1d57c0b5396221a31ba53a\": \"0x1158e460913d00000\",\n \"0x7beb81fb2f5e91526b2ac9795e76c69bcff04bc0\": \"0xeb22e794f0a8d600000\",\n \"0x7c0883054c2d02bc7a852b1f86c42777d0d5c856\": \"0x1b1ae4d6e2ef500000\",\n \"0x7c0f5e072043c9ee740242197e78cc4b98cdf960\": \"0xad78ebc5ac6200000\",\n \"0x7c1df24a4f7fb2c7b472e0bb006cb27dcd164156\": \"0x3635c9adc5dea00000\",\n \"0x7c29d47d57a733f56b9b217063b513dc3b315923\": \"0xd8d726b7177a800000\",\n \"0x7c2b9603884a4f2e464eceb97d17938d828bc02c\": \"0xa2a15d09519be00000\",\n \"0x7c382c0296612e4e97e440e02d3871273b55f53b\": \"0xab640391201300000\",\n \"0x7c3eb713c4c9e0381cd8154c7c9a7db8645cde17\": \"0xad78ebc5ac6200000\",\n \"0x7c4401ae98f12ef6de39ae24cf9fc51f80eba16b\": \"0xad78ebc5ac6200000\",\n \"0x7c45f0f8442a56dbd39dbf159995415c52ed479b\": \"0x6c6b935b8bbd400000\",\n \"0x7c532db9e0c06c26fd40acc56ac55c1ee92d3c3a\": \"0x3f870857a3e0e3800000\",\n \"0x7c60a05f7a4a5f8cf2784391362e755a8341ef59\": \"0x6694f0182a37ae0000\",\n \"0x7c60e51f0be228e4d56fdd2992c814da7740c6bc\": \"0xad78ebc5ac6200000\",\n \"0x7c6924d07c3ef5891966fe0a7856c87bef9d2034\": \"0x6c6b935b8bbd400000\",\n \"0x7c8bb65a6fbb49bd413396a9d7e31053bbb37aa9\": \"0x14542ba12a337c00000\",\n \"0x7c9a110cb11f2598b2b20e2ca400325e41e9db33\": \"0x581767ba6189c400000\",\n \"0x7cbca88fca6a0060b960985c9aa1b02534dc2208\": \"0x19127a1391ea2a0000\",\n \"0x7cbeb99932e97e6e02058cfc62d0b26bc7cca52b\": \"0x6c6b935b8bbd400000\",\n \"0x7cc24a6a958c20c7d1249660f7586226950b0d9a\": \"0x6acb3df27e1f880000\",\n \"0x7cd20eccb518b60cab095b720f571570caaa447e\": \"0x1b1ae4d6e2ef500000\",\n \"0x7cd5d81eab37e11e6276a3a1091251607e0d7e38\": \"0x3684d5ef981f40000\",\n \"0x7cdf74213945953db39ad0e8a9781add792e4d1d\": \"0x6c6b935b8bbd400000\",\n \"0x7ce4686446f1949ebed67215eb0d5a1dd72c11b8\": \"0x7839d321b81ab80000\",\n \"0x7cef4d43aa417f9ef8b787f8b99d53f1fea1ee88\": \"0x678a932062e4180000\",\n \"0x7d0350e40b338dda736661872be33f1f9752d755\": \"0x2b4f5a6f191948000\",\n \"0x7d04d2edc058a1afc761d9c99ae4fc5c85d4c8a6\": \"0x42a9c4675c9467d00000\",\n \"0x7d0b255efb57e10f7008aa22d40e9752dfcf0378\": \"0x19f8e7559924c0000\",\n \"0x7d13d6705884ab2157dd8dcc7046caf58ee94be4\": \"0x1d0da07cbb3ee9c00000\",\n \"0x7d273e637ef1eac481119413b91c989dc5eac122\": \"0x1b1ae4d6e2ef500000\",\n \"0x7d2a52a7cf0c8436a8e007976b6c26b7229d1e15\": \"0x17bf06b32a241c0000\",\n \"0x7d34803569e00bd6b59fff081dfa5c0ab4197a62\": \"0x5cd87cb7b9fb860000\",\n \"0x7d34ff59ae840a7413c6ba4c5bb2ba2c75eab018\": \"0xa2a15d09519be00000\",\n \"0x7d392852f3abd92ff4bb5bb26cb60874f2be6795\": \"0x3636c25e66ece70000\",\n \"0x7d445267c59ab8d2a2d9e709990e09682580c49f\": \"0x3635c9adc5dea00000\",\n \"0x7d551397f79a2988b064afd0efebee802c7721bc\": \"0x857e0d6f1da76a00000\",\n \"0x7d5aa33fc14b51841a06906edb2bb49c2a117269\": \"0x104400a2470e680000\",\n \"0x7d5d2f73949dadda0856b206989df0078d51a1e5\": \"0x23c757072b8dd000000\",\n \"0x7d6e990daa7105de2526339833f77b5c0b85d84f\": \"0x43c33c1937564800000\",\n \"0x7d73863038ccca22f96affda10496e51e1e6cd48\": \"0x1158e460913d00000\",\n \"0x7d7dd5ee614dbb6fbfbcd26305247a058c41faa1\": \"0x6c6b935b8bbd400000\",\n \"0x7d7e7c61779adb7706c94d32409a2bb4e994bf60\": \"0x2ef20d9fc71a140000\",\n \"0x7d82e523cc2dc591da3954e8b6bb2caf6461e69c\": \"0x7d8dc2efffb1a90000\",\n \"0x7d858493f07415e0912d05793c972113eae8ae88\": \"0x628dd177d2bc280000\",\n \"0x7d901b28bf7f88ef73d8f73cca97564913ea8a24\": \"0x33c5499031720c0000\",\n \"0x7d980f4b566bb045517e4c14c87750de9346744b\": \"0x487a9a304539440000\",\n \"0x7d9c59631e2ba2e8e82891f3979922aaa3b567a1\": \"0x1b1ae4d6e2ef5000000\",\n \"0x7d9d221a3df89ddd7b5f61c1468c6787d6b333e6\": \"0x77b227cd83be80000\",\n \"0x7da7613445a21299aa74f0ad71431ec43fbb1be9\": \"0x3afb087b876900000\",\n \"0x7db4c7d5b797e9296e6382f203693db409449d62\": \"0x15af1d78b58c400000\",\n \"0x7db9eacc52e429dc83b461c5f4d86010e5383a28\": \"0x3635c9adc5dea00000\",\n \"0x7dd46da677e161825e12e80dc446f58276e1127c\": \"0x2c73c937742c500000\",\n \"0x7dd8d7a1a34fa1f8e73ccb005fc2a03a15b8229c\": \"0xad78ebc5ac6200000\",\n \"0x7ddd57165c87a2707f025dcfc2508c09834759bc\": \"0x4be4e7267b6ae00000\",\n \"0x7de442c82386154d2e993cbd1280bb7ca6b12ada\": \"0xd8f2e8247ec9480000\",\n \"0x7de7fe419cc61f91f408d234cc80d5ca3d054d99\": \"0x1158e460913d00000\",\n \"0x7dece6998ae1900dd3770cf4b93812bad84f0322\": \"0x56bc75e2d63100000\",\n \"0x7dfc342dffcf45dfee74f84c0995397bd1a63172\": \"0xd8d726b7177a80000\",\n \"0x7dfd2962b575bcbeee97f49142d63c30ab009f66\": \"0xd8d726b7177a800000\",\n \"0x7e1e29721d6cb91057f6c4042d8a0bbc644afe73\": \"0x8a9aba557e36c0000\",\n \"0x7e236666b2d06e63ea4e2ab84357e2dfc977e50e\": \"0x36356633ebd8ea0000\",\n \"0x7e24d9e22ce1da3ce19f219ccee523376873f367\": \"0x13fd9079caa60ff0000\",\n \"0x7e24fbdad290175eb2df6d180a19b9a9f41370be\": \"0x3635c9adc5dea00000\",\n \"0x7e268f131ddf687cc325c412f78ba961205e9112\": \"0x36364ee7d301b3c0000\",\n \"0x7e29290038493559194e946d4e460b96fc38a156\": \"0x10c13c527763880000\",\n \"0x7e2ba86da52e785d8625334f3397ba1c4bf2e8d1\": \"0xaadec983fcff40000\",\n \"0x7e3f63e13129a221ba1ab06326342cd98b5126ae\": \"0x56a02659a523340000\",\n \"0x7e47637e97c14622882be057bea229386f4052e5\": \"0x17da3a04c7b3e00000\",\n \"0x7e4e9409704121d1d77997026ff06ea9b19a8b90\": \"0x8d16549ed58fa40000\",\n \"0x7e59dc60be8b2fc19abd0a5782c52c28400bce97\": \"0x3635c9adc5dea00000\",\n \"0x7e5b19ae1be94ff4dee635492a1b012d14db0213\": \"0x56bc75e2d63100000\",\n \"0x7e5d9993104e4cb545e179a2a3f971f744f98482\": \"0x6c6b935b8bbd400000\",\n \"0x7e71171f2949fa0c3ac254254b1f0440e5e6a038\": \"0x22b1c8c1227a00000\",\n \"0x7e7c1e9a61a08a83984835c70ec31d34d3eaa87f\": \"0xa5aa85009e39c0000\",\n \"0x7e7f18a02eccaa5d61ab8fbf030343c434a25ef7\": \"0x39fbae8d042dd0000\",\n \"0x7e81f6449a03374191f3b7cb05d938b72e090dff\": \"0x56bc75e2d63100000\",\n \"0x7e8649e690fc8c1bfda1b5e186581f649b50fe33\": \"0x556f64c1fe7fa0000\",\n \"0x7e87863ec43a481df04d017762edcb5caa629b5a\": \"0x222c8eb3ff6640000\",\n \"0x7e8f96cc29f57b0975120cb593b7dd833d606b53\": \"0xaadec983fcff40000\",\n \"0x7e972a8a7c2a44c93b21436c38d21b9252c345fe\": \"0x61093d7c2c6d380000\",\n \"0x7e99dfbe989d3ba529d19751b7f4317f8953a3e2\": \"0x15af1d78b58c400000\",\n \"0x7ea0f96ee0a573a330b56897761f3d4c0130a8e3\": \"0x487a9a304539440000\",\n \"0x7ea791ebab0445a00efdfc4e4a8e9a7e7565136d\": \"0xfc936392801c0000\",\n \"0x7eaba035e2af3793fd74674b102540cf190addb9\": \"0x45026c835b60440000\",\n \"0x7eb4b0185c92b6439a08e7322168cb353c8a774a\": \"0x227196ca04983ca0000\",\n \"0x7ebd95e9c470f7283583dc6e9d2c4dce0bea8f84\": \"0x2f6f10780d22cc00000\",\n \"0x7ed0a5a847bef9a9da7cba1d6411f5c316312619\": \"0x228eb37e8751d0000\",\n \"0x7edafba8984baf631a820b6b92bbc2c53655f6bd\": \"0x6c6b935b8bbd400000\",\n \"0x7edb02c61a227287611ad950696369cc4e647a68\": \"0xeda838c4929080000\",\n \"0x7ee5ca805dce23af89c2d444e7e40766c54c7404\": \"0xd0bd412edbd820000\",\n \"0x7ee604c7a9dc2909ce321de6b9b24f5767577555\": \"0x12bf9c7985cf62d8000\",\n \"0x7ef16fd8d15b378a0fba306b8d03dd98fc92619f\": \"0x25f273933db5700000\",\n \"0x7ef98b52bee953bef992f305fda027f8911c5851\": \"0x1be722206996bc8000\",\n \"0x7efc90766a00bc52372cac97fabd8a3c831f8ecd\": \"0x890b0c2e14fb80000\",\n \"0x7efec0c6253caf397f71287c1c07f6c9582b5b86\": \"0x1a2cbcb84f30d58000\",\n \"0x7f01dc7c3747ca608f983dfc8c9b39e755a3b914\": \"0xb386cad5f7a5a0000\",\n \"0x7f0662b410298c99f311d3a1454a1eedba2fea76\": \"0xad78ebc5ac6200000\",\n \"0x7f06c89d59807fa60bc60136fcf814cbaf2543bd\": \"0x21e19e0c9bab2400000\",\n \"0x7f0b90a1fdd48f27b268feb38382e55ddb50ef0f\": \"0x32f51edbaaa3300000\",\n \"0x7f0ec3db804692d4d1ea3245365aab0590075bc4\": \"0xd8d726b7177a800000\",\n \"0x7f0f04fcf37a53a4e24ede6e93104e78be1d3c9e\": \"0x6c6b935b8bbd400000\",\n \"0x7f13d760498d7193ca6859bc95c901386423d76c\": \"0x10f0cf064dd59200000\",\n \"0x7f150afb1a77c2b45928c268c1e9bdb4641d47d8\": \"0x6c6b935b8bbd400000\",\n \"0x7f1619988f3715e94ff1d253262dc5581db3de1c\": \"0x30ca024f987b900000\",\n \"0x7f1c81ee1697fc144b7c0be5493b5615ae7fddca\": \"0x1b1dab61d3aa640000\",\n \"0x7f2382ffd8f83956467937f9ba72374623f11b38\": \"0x2086ac351052600000\",\n \"0x7f3709391f3fbeba3592d175c740e87a09541d02\": \"0x1a055690d9db800000\",\n \"0x7f389c12f3c6164f6446566c77669503c2792527\": \"0x556f64c1fe7fa0000\",\n \"0x7f3a1e45f67e92c880e573b43379d71ee089db54\": \"0x152d02c7e14af6800000\",\n \"0x7f3d7203c8a447f7bf36d88ae9b6062a5eee78ae\": \"0x14542ba12a337c00000\",\n \"0x7f46bb25460dd7dae4211ca7f15ad312fc7dc75c\": \"0x16a6502f15a1e540000\",\n \"0x7f49e7a4269882bd8722d4a6f566347629624079\": \"0x6c6b935b8bbd400000\",\n \"0x7f49f20726471ac1c7a83ef106e9775ceb662566\": \"0x14061b9d77a5e980000\",\n \"0x7f4b5e278578c046cceaf65730a0e068329ed5b6\": \"0x65ea3db75546600000\",\n \"0x7f4f593b618c330ba2c3d5f41eceeb92e27e426c\": \"0x966edc756b7cfc0000\",\n \"0x7f541491d2ac00d2612f94aa7f0bcb014651fbd4\": \"0x14620c57dddae00000\",\n \"0x7f5ae05ae0f8cbe5dfe721f044d7a7bef4c27997\": \"0x340aad21b3b700000\",\n \"0x7f603aec1759ea5f07c7f8d41a1428fbbaf9e762\": \"0x1158e460913d00000\",\n \"0x7f616c6f008adfa082f34da7d0650460368075fb\": \"0x3635c9adc5dea00000\",\n \"0x7f61fa6cf5f898b440dac5abd8600d6d691fdef9\": \"0xf2dc7d47f15600000\",\n \"0x7f655c6789eddf455cb4b88099720639389eebac\": \"0x14542ba12a337c00000\",\n \"0x7f6b28c88421e4857e459281d78461692489d3fb\": \"0x6c6b935b8bbd400000\",\n \"0x7f6efb6f4318876d2ee624e27595f44446f68e93\": \"0x54069233bf7f780000\",\n \"0x7f7192c0df1c7db6d9ed65d71184d8e4155a17ba\": \"0x453728d33942c0000\",\n \"0x7f7a3a21b3f5a65d81e0fcb7d52dd00a1aa36dba\": \"0x56bc75e2d63100000\",\n \"0x7f8dbce180ed9c563635aad2d97b4cbc428906d9\": \"0x90f534608a72880000\",\n \"0x7f993ddb7e02c282b898f6155f680ef5b9aff907\": \"0x43c33c1937564800000\",\n \"0x7f9f9b56e4289dfb58e70fd5f12a97b56d35c6a5\": \"0x6acb3df27e1f880000\",\n \"0x7fa37ed67887751a471f0eb306be44e0dbcd6089\": \"0x3976747fe11a100000\",\n \"0x7faa30c31519b584e97250ed2a3cf3385ed5fd50\": \"0x6c6b935b8bbd400000\",\n \"0x7fcf5ba6666f966c5448c17bf1cb0bbcd8019b06\": \"0x56bc3d0aebe498000\",\n \"0x7fd679e5fb0da2a5d116194dcb508318edc580f3\": \"0x1639e49bba162800000\",\n \"0x7fdba031c78f9c096d62d05a369eeab0bccc55e5\": \"0x97c9ce4cf6d5c00000\",\n \"0x7fdbc3a844e40d96b2f3a635322e6065f4ca0e84\": \"0x6c6b935b8bbd400000\",\n \"0x7fdfc88d78bf1b285ac64f1adb35dc11fcb03951\": \"0x7c06fda02fb0360000\",\n \"0x7fea1962e35d62059768c749bedd96cab930d378\": \"0x6c6b935b8bbd400000\",\n \"0x7fef8c38779fb307ec6f044bebe47f3cfae796f1\": \"0x92340f86cf09e8000\",\n \"0x7ff0c63f70241bece19b737e5341b12b109031d8\": \"0x12c1b6eed03d280000\",\n \"0x7ffabfbc390cbe43ce89188f0868b27dcb0f0cad\": \"0x1595182224b26480000\",\n \"0x7ffd02ed370c7060b2ae53c078c8012190dfbb75\": \"0x21e19e0c9bab2400000\",\n \"0x80022a1207e910911fc92849b069ab0cdad043d3\": \"0xb98bc829a6f90000\",\n \"0x8009a7cbd192b3aed4adb983d5284552c16c7451\": \"0xd8d726b7177a800000\",\n \"0x800e7d631c6e573a90332f17f71f5fd19b528cb9\": \"0x83d6c7aab63600000\",\n \"0x80156d10efa8b230c99410630d37e269d4093cea\": \"0x6c6b935b8bbd400000\",\n \"0x801732a481c380e57ed62d6c29de998af3fa3b13\": \"0x56bc75e2d63100000\",\n \"0x801d65c518b11d0e3f4f470221417013c8e53ec5\": \"0xd8d726b7177a800000\",\n \"0x8026435aac728d497b19b3e7e57c28c563954f2b\": \"0x5dc892aa1131c80000\",\n \"0x802dc3c4ff2d7d925ee2859f4a06d7ba60f1308c\": \"0x550940c8fd34c0000\",\n \"0x8030b111c6983f0485ddaca76224c6180634789f\": \"0x4563918244f400000\",\n \"0x8035bcffaefdeeea35830c497d14289d362023de\": \"0x1043561a8829300000\",\n \"0x8035fe4e6b6af27ae492a578515e9d39fa6fa65b\": \"0xd8d726b7177a800000\",\n \"0x8043ed22f997e5a2a4c16e364486ae64975692c4\": \"0x3d4904ffc9112e8000\",\n \"0x8043fdd0bc4c973d1663d55fc135508ec5d4f4fa\": \"0x1158e460913d00000\",\n \"0x804ca94972634f633a51f3560b1d06c0b293b3b1\": \"0xad78ebc5ac6200000\",\n \"0x80522ddf944ec52e27d724ed4c93e1f7be6083d6\": \"0xad78ebc5ac6200000\",\n \"0x80591a42179f34e64d9df75dcd463b28686f5574\": \"0x43c33c1937564800000\",\n \"0x805ce51297a0793b812067f017b3e7b2df9bb1f9\": \"0x56bc75e2d63100000\",\n \"0x805d846fb0bc02a7337226d685be9ee773b9198a\": \"0x43c30fb0884a96c0000\",\n \"0x8063379a7bf2cb923a84c5093e68dac7f75481c5\": \"0x1176102e6e32df0000\",\n \"0x806854588ecce541495f81c28a290373df0274b2\": \"0x1f8cdf5c6e8d580000\",\n \"0x806f44bdeb688037015e84ff218049e382332a33\": \"0x6c5db2a4d815dc0000\",\n \"0x80744618de396a543197ee4894abd06398dd7c27\": \"0x6c6b935b8bbd400000\",\n \"0x8077c3e4c445586e094ce102937fa05b737b568c\": \"0x56bc75e2d63100000\",\n \"0x80907f593148b57c46c177e23d25abc4aae18361\": \"0x56bc75e2d63100000\",\n \"0x80977316944e5942e79b0e3abad38da746086519\": \"0x21a754a6dc5280000\",\n \"0x80a0f6cc186cf6201400736e065a391f52a9df4a\": \"0x21e19e0c9bab2400000\",\n \"0x80abec5aa36e5c9d098f1b942881bd5acac6963d\": \"0x6c6b935b8bbd400000\",\n \"0x80b23d380b825c46e0393899a85556462da0e18c\": \"0x6c6b935b8bbd400000\",\n \"0x80b42de170dbd723f454e88f7716452d92985092\": \"0x104623c0762dd10000\",\n \"0x80b79f338390d1ba1b3737a29a0257e5d91e0731\": \"0x1158e460913d00000\",\n \"0x80bf995ed8ba92701d10fec49f9e7d014dbee026\": \"0x1f0437ca1a7e128000\",\n \"0x80c04efd310f440483c73f744b5b9e64599ce3ec\": \"0x410d586a20a4c00000\",\n \"0x80c3a9f695b16db1597286d1b3a8b7696c39fa27\": \"0x56bc75e2d63100000\",\n \"0x80c53ee7e3357f94ce0d7868009c208b4a130125\": \"0x6c6b935b8bbd400000\",\n \"0x80cc21bd99f39005c58fe4a448909220218f66cb\": \"0x3636c9796436740000\",\n \"0x80d5c40c59c7f54ea3a55fcfd175471ea35099b3\": \"0x3635c9adc5dea00000\",\n \"0x80da2fdda29a9e27f9e115975e69ae9cfbf3f27e\": \"0xad78ebc5ac6200000\",\n \"0x80e7b3205230a566a1f061d922819bb4d4d2a0e1\": \"0x2f6f10780d22cc00000\",\n \"0x80ea1acc136eca4b68c842a95adf6b7fee7eb8a2\": \"0xd8d726b7177a800000\",\n \"0x80f07ac09e7b2c3c0a3d1e9413a544c73a41becb\": \"0x1158e460913d00000\",\n \"0x810db25675f45ea4c7f3177f37ce29e22d67999c\": \"0xad78ebc5ac6200000\",\n \"0x81139bfdcca656c430203f72958c543b6580d40c\": \"0x6c6b935b8bbd400000\",\n \"0x811461a2b0ca90badac06a9ea16e787b33b196cc\": \"0x8e3f50b173c100000\",\n \"0x81164deb10814ae08391f32c08667b6248c27d7a\": \"0x155bd9307f9fe80000\",\n \"0x81186931184137d1192ac88cd3e1e5d0fdb86a74\": \"0x9d3595ab2438d00000\",\n \"0x812a55c43caedc597218379000ce510d548836fd\": \"0xfc936392801c0000\",\n \"0x812ea7a3b2c86eed32ff4f2c73514cc63bacfbce\": \"0x3635c9adc5dea00000\",\n \"0x8134dd1c9df0d6c8a5812426bb55c761ca831f08\": \"0x6a2160bb57ccc0000\",\n \"0x814135da8f9811075783bf1ab67062af8d3e9f40\": \"0x1158e460913d00000\",\n \"0x81498ca07b0f2f17e8bbc7e61a7f4ae7be66b78b\": \"0x581fbb5b33bb00000\",\n \"0x81556db27349ab8b27004944ed50a46e941a0f5f\": \"0xd8bb6549b02bb80000\",\n \"0x8155fa6c51eb31d808412d748aa086105018122f\": \"0x65ea3db75546600000\",\n \"0x8156360bbd370961ceca6b6691d75006ad204cf2\": \"0x878678326eac9000000\",\n \"0x8161d940c3760100b9080529f8a60325030f6edc\": \"0x1043561a8829300000\",\n \"0x8164e78314ae16b28926cc553d2ccb16f356270d\": \"0x1ca134e95fb32c80000\",\n \"0x8165cab0eafb5a328fc41ac64dae715b2eef2c65\": \"0x3635c9adc5dea00000\",\n \"0x8168edce7f2961cf295b9fcd5a45c06cdeda6ef5\": \"0xad78ebc5ac6200000\",\n \"0x816d9772cf11399116cc1e72c26c6774c9edd739\": \"0xad78ebc5ac6200000\",\n \"0x8173c835646a672e0152be10ffe84162dd256e4c\": \"0x1aabdf2145b4300000\",\n \"0x817493cd9bc623702a24a56f9f82e3fd48f3cd31\": \"0x9e4b23f12d4ca00000\",\n \"0x8179c80970182cc5b7d82a4df06ea94db63a25f3\": \"0x276f259de66bf40000\",\n \"0x817ac33bd8f847567372951f4a10d7a91ce3f430\": \"0xad7c406c66dc18000\",\n \"0x818ffe271fc3973565c303f213f6d2da89897ebd\": \"0x136e05342fee1b98000\",\n \"0x8197948121732e63d9c148194ecad46e30b749c8\": \"0xd8d726b7177a800000\",\n \"0x819af9a1c27332b1c369bbda1b3de1c6e933d640\": \"0x1109e654b98f7a0000\",\n \"0x819cdaa5303678ef7cec59d48c82163acc60b952\": \"0x31351545f79816c0000\",\n \"0x819eb4990b5aba5547093da12b6b3c1093df6d46\": \"0x3635c9adc5dea00000\",\n \"0x81a88196fac5f23c3e12a69dec4b880eb7d97310\": \"0x6c6b935b8bbd400000\",\n \"0x81bccbff8f44347eb7fca95b27ce7c952492aaad\": \"0x840c12165dd780000\",\n \"0x81bd75abd865e0c3f04a0b4fdbcb74d34082fbb7\": \"0xd8d726b7177a800000\",\n \"0x81c18c2a238ddc4cba230a072dd7dc101e620273\": \"0x487a9a304539440000\",\n \"0x81c9e1aee2d3365d53bcfdcd96c7c538b0fd7eec\": \"0x62a992e53a0af00000\",\n \"0x81cfad760913d3c322fcc77b49c2ae3907e74f6e\": \"0xaadec983fcff40000\",\n \"0x81d619ff5726f2405f12904c72eb1e24a0aaee4f\": \"0x43c33c1937564800000\",\n \"0x81efe296ae76c860d1c5fbd33d47e8ce9996d157\": \"0x3635c9adc5dea00000\",\n \"0x81f8de2c283d5fd4afbda85dedf9760eabbbb572\": \"0xa2a15d09519be00000\",\n \"0x820c19291196505b65059d9914b7090be1db87de\": \"0x796e3ea3f8ab00000\",\n \"0x821cb5cd05c7ef909fe1be60733d8963d760dc41\": \"0xd8d726b7177a800000\",\n \"0x821d798af19989c3ae5b84a7a7283cd7fda1fabe\": \"0x43c33c1937564800000\",\n \"0x821eb90994a2fbf94bdc3233910296f76f9bf6e7\": \"0x21e19e0c9bab2400000\",\n \"0x82249fe70f61c6b16f19a324840fdc020231bb02\": \"0x20336b08a93635b0000\",\n \"0x8228ebc087480fd64547ca281f5eace3041453b9\": \"0x6acb3df27e1f880000\",\n \"0x8229ceb9f0d70839498d44e6abed93c5ca059f5d\": \"0x1a1c1b3c989a20100000\",\n \"0x822edff636563a6106e52e9a2598f7e6d0ef2782\": \"0x1f4f9693d42d38000\",\n \"0x823219a25976bb2aa4af8bad41ac3526b493361f\": \"0x6c6b935b8bbd400000\",\n \"0x8232d1f9742edf8dd927da353b2ae7b4cbce7592\": \"0x243d4d18229ca20000\",\n \"0x8234f463d18485501f8f85ace4972c9b632dbccc\": \"0x6c6b935b8bbd400000\",\n \"0x823768746737ce6da312d53e54534e106f967cf3\": \"0x1158e460913d00000\",\n \"0x823ba7647238d113bce9964a43d0a098118bfe4d\": \"0xad78ebc5ac6200000\",\n \"0x824074312806da4748434266ee002140e3819ac2\": \"0x51b1d3839261ac0000\",\n \"0x82438fd2b32a9bdd674b49d8cc5fa2eff9781847\": \"0x1158e460913d00000\",\n \"0x82485728d0e281563758c75ab27ed9e882a0002d\": \"0x7f808e9291e6c0000\",\n \"0x824b3c3c443e19295d7ef6faa7f374a4798486a8\": \"0x1158e460913d00000\",\n \"0x8251358ca4e060ddb559ca58bc0bddbeb4070203\": \"0x6c6b935b8bbd400000\",\n \"0x825135b1a7fc1605614c8aa4d0ac6dbad08f480e\": \"0x4d853c8f8908980000\",\n \"0x825309a7d45d1812f51e6e8df5a7b96f6c908887\": \"0x8034f7d9b166d40000\",\n \"0x825a7f4e10949cb6f8964268f1fa5f57e712b4c4\": \"0x1158e460913d00000\",\n \"0x8261fa230c901d43ff579f4780d399f31e6076bc\": \"0x6c6b935b8bbd400000\",\n \"0x8262169b615870134eb4ac6c5f471c6bf2f789fc\": \"0x19127a1391ea2a0000\",\n \"0x8263ece5d709e0d7ae71cca868ed37cd2fef807b\": \"0x35ab028ac154b80000\",\n \"0x826ce5790532e0548c6102a30d3eac836bd6388f\": \"0x3cfc82e37e9a7400000\",\n \"0x826eb7cd7319b82dd07a1f3b409071d96e39677f\": \"0x3635c9adc5dea00000\",\n \"0x827531a6c5817ae35f82b00b9754fcf74c55e232\": \"0xc328093e61ee400000\",\n \"0x8275cd684c3679d5887d03664e338345dc3cdde1\": \"0xdb44e049bb2c0000\",\n \"0x8284923b62e68bbf7c2b9f3414d13ef6c812a904\": \"0xd255d112e103a00000\",\n \"0x828ba651cb930ed9787156299a3de44cd08b7212\": \"0x487a9a304539440000\",\n \"0x82a15cef1d6c8260eaf159ea3f0180d8677dce1c\": \"0x6c6b935b8bbd400000\",\n \"0x82a8b96b6c9e13ebec1e9f18ac02a60ea88a48ff\": \"0x6c6b8c408e73b30000\",\n \"0x82a8cbbfdff02b2e38ae4bbfca15f1f0e83b1aea\": \"0x49b991c27ef6d8000\",\n \"0x82e4461eb9d849f0041c1404219e4272c4900ab4\": \"0x6c6b935b8bbd400000\",\n \"0x82e577b515cb2b0860aafe1ce09a59e09fe7d040\": \"0x2086ac351052600000\",\n \"0x82ea01e3bf2e83836e71704e22a2719377efd9c3\": \"0xa4cc799563c3800000\",\n \"0x82f2e991fd324c5f5d17768e9f61335db6319d6c\": \"0x1b1ae4d6e2ef500000\",\n \"0x82f39b2758ae42277b86d69f75e628d958ebcab0\": \"0x878678326eac9000000\",\n \"0x82f854c9c2f087dffa985ac8201e626ca5467686\": \"0x152d02c7e14af6800000\",\n \"0x82ff716fdf033ec7e942c909d9831867b8b6e2ef\": \"0x61093d7c2c6d380000\",\n \"0x8308ed0af7f8a3c1751fafc877b5a42af7d35882\": \"0x3635c9adc5dea00000\",\n \"0x831c44b3084047184b2ad218680640903750c45d\": \"0x6acb3df27e1f880000\",\n \"0x83210583c16a4e1e1dac84ebd37e3d0f7c57eba4\": \"0x6c6b935b8bbd400000\",\n \"0x832c54176bdf43d2c9bcd7b808b89556b89cbf31\": \"0xad78ebc5ac6200000\",\n \"0x833316985d47742bfed410604a91953c05fb12b0\": \"0x6c6b935b8bbd400000\",\n \"0x8334764b7b397a4e578f50364d60ce44899bff94\": \"0x503b203e9fba20000\",\n \"0x833b6a8ec8da408186ac8a7d2a6dd61523e7ce84\": \"0x3635c9adc5dea000000\",\n \"0x833d3fae542ad5f8b50ce19bde2bec579180c88c\": \"0x12c1b6eed03d280000\",\n \"0x833db42c14163c7be4cab86ac593e06266d699d5\": \"0x24e40d2b6943ef900000\",\n \"0x83563bc364ed81a0c6da3b56ff49bbf267827a9c\": \"0x3ab91d17b20de500000\",\n \"0x837a645dc95c49549f899c4e8bcf875324b2f57c\": \"0x208c394af1c8880000\",\n \"0x838bd565f99fde48053f7917fe333cf84ad548ab\": \"0xad78ebc5ac6200000\",\n \"0x83908aa7478a6d1c9b9b0281148f8f9f242b9fdc\": \"0x6c6b935b8bbd400000\",\n \"0x8392e53776713578015bff4940cf43849d7dcba1\": \"0x84df0355d56170000\",\n \"0x8397a1bc47acd647418159b99cea57e1e6532d6e\": \"0x1f10fa827b550b40000\",\n \"0x8398e07ebcb4f75ff2116de77c1c2a99f303a4cf\": \"0x1b1ae4d6e2ef500000\",\n \"0x83a3148833d9644984f7c475a7850716efb480ff\": \"0xb8507a820728200000\",\n \"0x83a402438e0519773d5448326bfb61f8b20cf52d\": \"0x52663ccab1e1c00000\",\n \"0x83a93b5ba41bf88720e415790cdc0b67b4af34c4\": \"0xad78ebc5ac6200000\",\n \"0x83c23d8a502124ee150f08d71dc6727410a0f901\": \"0x7331f3bfe661b180000\",\n \"0x83c897a84b695eebe46679f7da19d776621c2694\": \"0x1b1ae4d6e2ef500000\",\n \"0x83d532d38d6dee3f60adc68b936133c7a2a1b0dd\": \"0x1b1ae4d6e2ef500000\",\n \"0x83dbf8a12853b40ac61996f8bf1dc8fdbaddd329\": \"0x34957444b840e80000\",\n \"0x83dbfd8eda01d0de8e158b16d0935fc2380a5dc7\": \"0x2086ac351052600000\",\n \"0x83e48055327c28b5936fd9f4447e73bdb2dd3376\": \"0x90f534608a72880000\",\n \"0x83fe5a1b328bae440711beaf6aad6026eda6d220\": \"0x43c33c1937564800000\",\n \"0x84008a72f8036f3feba542e35078c057f32a8825\": \"0x56bc75e2d63100000\",\n \"0x840ec83ea93621f034e7bb3762bb8e29ded4c479\": \"0x878678326eac900000\",\n \"0x841145b44840c946e21dbc190264b8e0d5029369\": \"0x3f870857a3e0e3800000\",\n \"0x84232107932b12e03186583525ce023a703ef8d9\": \"0x6c6b935b8bbd400000\",\n \"0x84244fc95a6957ed7c1504e49f30b8c35eca4b79\": \"0x6c6b935b8bbd400000\",\n \"0x8431277d7bdd10457dc017408c8dbbbd414a8df3\": \"0x222c8eb3ff6640000\",\n \"0x84375afbf59b3a1d61a1be32d075e0e15a4fbca5\": \"0xad78ebc5ac6200000\",\n \"0x843bd3502f45f8bc4da370b323bdac3fcf5f19a6\": \"0x50039d63d11c900000\",\n \"0x84503334630d77f74147f68b2e086613c8f1ade9\": \"0x56bc75e2d631000000\",\n \"0x845203750f7148a9aa262921e86d43bf641974fd\": \"0x56bc75e2d63100000\",\n \"0x8461ecc4a6a45eb1a5b947fb86b88069b91fcd6f\": \"0x6c6b935b8bbd400000\",\n \"0x84675e9177726d45eaa46b3992a340ba7f710c95\": \"0x3635c9adc5dea00000\",\n \"0x84686c7bad762c54b667d59f90943cd14d117a26\": \"0x1158e460913d00000\",\n \"0x8489f6ad1d9a94a297789156899db64154f1dbb5\": \"0x137407c03c8c268000\",\n \"0x848c994a79003fe7b7c26cc63212e1fc2f9c19eb\": \"0x6c6b935b8bbd400000\",\n \"0x848fbd29d67cf4a013cb02a4b176ef244e9ee68d\": \"0x1172a636bbdc20000\",\n \"0x84949dba559a63bfc845ded06e9f2d9b7f11ef24\": \"0x6c6b935b8bbd400000\",\n \"0x849ab80790b28ff1ffd6ba394efc7463105c36f7\": \"0x1e02be4ae6c840000\",\n \"0x849b116f596301c5d8bb62e0e97a8248126e39f3\": \"0x1043561a8829300000\",\n \"0x84a74ceecff65cb93b2f949d773ef1ad7fb4a245\": \"0x50a9b444685c70000\",\n \"0x84aac7fa197ff85c30e03b7a5382b957f41f3afb\": \"0x88b23acffd9900000\",\n \"0x84af1b157342d54368260d17876230a534b54b0e\": \"0x35659ef93f0fc40000\",\n \"0x84b0ee6bb837d3a4c4c5011c3a228c0edab4634a\": \"0x1158e460913d00000\",\n \"0x84b4b74e6623ba9d1583e0cfbe49643f16384149\": \"0x1158e460913d00000\",\n \"0x84b6b6adbe2f5b3e2d682c66af1bc4905340c3ed\": \"0x2192f8d22215008000\",\n \"0x84b91e2e2902d05e2b591b41083bd7beb2d52c74\": \"0x215e5128b4504648000\",\n \"0x84bcbf22c09607ac84341d2edbc03bfb1739d744\": \"0x1b1ae4d6e2ef500000\",\n \"0x84bfcef0491a0ae0694b37ceac024584f2aa0467\": \"0x6c6acc67d7b1d40000\",\n \"0x84cb7da0502df45cf561817bbd2362f451be02da\": \"0x487a9a304539440000\",\n \"0x84cc7878da605fdb019fab9b4ccfc157709cdda5\": \"0x48798513af04c90000\",\n \"0x84db1459bb00812ea67ecb3dc189b72187d9c501\": \"0x811b8fbda85ab8000\",\n \"0x84e9949680bece6841b9a7e5250d08acd87d16cd\": \"0xad78ebc5ac6200000\",\n \"0x84e9cf8166c36abfa49053b7a1ad4036202681ef\": \"0x6c6b935b8bbd400000\",\n \"0x84ec06f24700fe42414cb9897c154c88de2f6132\": \"0x487a9a304539440000\",\n \"0x84f522f0520eba52dd18ad21fa4b829f2b89cb97\": \"0x10c5106d5134f130000\",\n \"0x850b9db18ff84bf0c7da49ea3781d92090ad7e64\": \"0x8cf23f909c0fa00000\",\n \"0x8510ee934f0cbc900e1007eb38a21e2a5101b8b2\": \"0x5bf0ba6634f680000\",\n \"0x8516fcaf77c893970fcd1a958ba9a00e49044019\": \"0xaa3eb1691bce58000\",\n \"0x851aa91c82f42fad5dd8e8bb5ea69c8f3a5977d1\": \"0x80e561f2578798000\",\n \"0x851c0d62be4635d4777e8035e37e4ba8517c6132\": \"0x1b1ae4d6e2ef500000\",\n \"0x851dc38adb4593729a76f33a8616dab6f5f59a77\": \"0x56bc75e2d63100000\",\n \"0x8532490897bbb4ce8b7f6b837e4cba848fbe9976\": \"0x56bc75e2d63100000\",\n \"0x853e6abaf44469c72f151d4e223819aced4e3728\": \"0x6c6b935b8bbd400000\",\n \"0x854691ce714f325ced55ce5928ce9ba12facd1b8\": \"0xed70b5e9c3f2f00000\",\n \"0x854c0c469c246b83b5d1b3eca443b39af5ee128a\": \"0x56bc75e2d631000000\",\n \"0x855d9aef2c39c6230d09c99ef6494989abe68785\": \"0x8ba52e6fc45e40000\",\n \"0x8563c49361b625e768771c96151dbfbd1c906976\": \"0x6c6b935b8bbd400000\",\n \"0x8566610901aace38b83244f3a9c831306a67b9dc\": \"0xb08213bcf8ffe00000\",\n \"0x856aa23c82d7215bec8d57f60ad75ef14fa35f44\": \"0x43c33c1937564800000\",\n \"0x856e5ab3f64c9ab56b009393b01664fc0324050e\": \"0x61093d7c2c6d380000\",\n \"0x856eb204241a87830fb229031343dc30854f581a\": \"0x3635c9adc5dea00000\",\n \"0x85732c065cbd64119941aed430ac59670b6c51c4\": \"0x27a57362ab0a0e8000\",\n \"0x8578e10212ca14ff0732a8241e37467db85632a9\": \"0x14542ba12a337c00000\",\n \"0x8579dadf1a395a3471e20b6f763d9a0ff19a3f6f\": \"0xd8d726b7177a800000\",\n \"0x857f100b1a5930225efc7e9020d78327b41c02cb\": \"0x6c6b935b8bbd400000\",\n \"0x85946d56a4d371a93368539690b60ec825107454\": \"0x5dc892aa1131c80000\",\n \"0x8599cbd5a6a9dcd4b966be387d69775da5e33c6f\": \"0xc51f1b1d52622900000\",\n \"0x859c600cf13d1d0273d5d1da3cd789e495899f27\": \"0x90f534608a72880000\",\n \"0x85a2f6ea94d05e8c1d9ae2f4910338a358e98ded\": \"0x6c6b935b8bbd400000\",\n \"0x85b16f0b8b34dff3804f69e2168a4f7b24d1042b\": \"0x112f423c7646d40000\",\n \"0x85b2998d0c73302cb2ba13f489313301e053be15\": \"0x21e19e0c9bab2400000\",\n \"0x85bb51bc3bfe9a1b2a2f6b1cda95bca8b38c8d5e\": \"0x11712da04ba1ef0000\",\n \"0x85c8f3cc7a354feac99a5e7bfe7cdfa351cfe355\": \"0x15af1d78b58c400000\",\n \"0x85ca1e727e9d1a87991cc2c41840ebb9edf21d1b\": \"0xb98bc829a6f90000\",\n \"0x85ca8bc6da2803d0725f5e1a456c89f9bc774e2f\": \"0x2086ac351052600000\",\n \"0x85d0d88754ac84b8b21ba93dd2bfec72626faba8\": \"0x3635c9adc5dea00000\",\n \"0x85eb256b51c819d60ea61a82d12c9358d59c1cae\": \"0x18efc84ad0c7b00000\",\n \"0x85f0e7c1e3aff805a627a2aaf2cff6b4c0dbe9cb\": \"0x1158e460913d00000\",\n \"0x86026cad3fe4ea1ce7fca260d3d45eb09ea6a364\": \"0xad78ebc5ac6200000\",\n \"0x860f5ffc10de767ded807f71e861d647dfd219b1\": \"0x21e19e0c9bab2400000\",\n \"0x86153063a1ae7f02f1a88136d4d69c7c5e3e4327\": \"0x3635c9adc5dea00000\",\n \"0x86245f596691093ece3f3d3ca2263eace81941d9\": \"0xa31062beeed700000\",\n \"0x862569211e8c6327b5415e3a67e5738b15baaf6e\": \"0x796e3ea3f8ab00000\",\n \"0x86297d730fe0f7a9ee24e08fb1087b31adb306a7\": \"0x6c6b935b8bbd400000\",\n \"0x8644cc281be332ccced36da483fb2a0746d9ba2e\": \"0x15af1d78b58c400000\",\n \"0x86499a1228ff2d7ee307759364506f8e8c8307a5\": \"0x6acb3df27e1f880000\",\n \"0x864bec5069f855a4fd5892a6c4491db07c88ff7c\": \"0x3635c9adc5dea00000\",\n \"0x86570ab259c9b1c32c9729202f77f590c07dd612\": \"0xad78ebc5ac6200000\",\n \"0x8663a241a0a89e70e182c845e2105c8ad7264bcf\": \"0x323b13d8398f3238000\",\n \"0x8667fa1155fed732cfb8dca5a0d765ce0d0705ed\": \"0x46ec965c393b10000\",\n \"0x8668af868a1e98885f937f2615ded6751804eb2d\": \"0x1158e460913d00000\",\n \"0x86740a46648e845a5d96461b18091ff57be8a16f\": \"0x14c0973485bf39400000\",\n \"0x867eba56748a5904350d2ca2a5ce9ca00b670a9b\": \"0x43c33c1937564800000\",\n \"0x86806474c358047d9406e6a07f40945bc8328e67\": \"0x1752eb0f7013d100000\",\n \"0x86883d54cd3915e549095530f9ab1805e8c5432d\": \"0xd8d726b7177a800000\",\n \"0x868c23be873466d4c74c220a19b245d1787e807f\": \"0x4a13bbbd92c88e8000\",\n \"0x86924fb211aad23cf5ce600e0aae806396444087\": \"0x21e19e0c9bab2400000\",\n \"0x8693e9b8be94425eef7969bc69f9d42f7cad671e\": \"0x3637096c4bcc690000\",\n \"0x869f1aa30e4455beb1822091de5cadec79a8f946\": \"0x1b1ae4d6e2ef5000000\",\n \"0x86a1eadeeb30461345d9ef6bd05216fa247c0d0c\": \"0x6c6b935b8bbd400000\",\n \"0x86a5f8259ed5b09e188ce346ee92d34aa5dd93fa\": \"0xad78ebc5ac6200000\",\n \"0x86b7bd563ceab686f96244f9ddc02ad7b0b14bc2\": \"0x21e19e0c9bab2400000\",\n \"0x86c28b5678af37d727ec05e4447790f15f71f2ea\": \"0xad78ebc5ac6200000\",\n \"0x86c4ce06d9ac185bb148d96f7b7abe73f441006d\": \"0x21e19e0c9bab2400000\",\n \"0x86c8d0d982b539f48f9830f9891f9d607a942659\": \"0x2ced37761824fb00000\",\n \"0x86c934e38e53be3b33f274d0539cfca159a4d0d1\": \"0x34957444b840e80000\",\n \"0x86ca0145957e6b0dfe36875fbe7a0dec55e17a28\": \"0x21e19e0c9bab2400000\",\n \"0x86caafacf32aa0317c032ac36babed974791dc03\": \"0x878678326eac9000000\",\n \"0x86cdb7e51ac44772be3690f61d0e59766e8bfc18\": \"0xd8d726b7177a800000\",\n \"0x86df73bd377f2c09de63c45d67f283eaefa0f4ab\": \"0x3635c9adc5dea00000\",\n \"0x86e3fe86e93da486b14266eadf056cbfa4d91443\": \"0x6c6b935b8bbd400000\",\n \"0x86e8670e27598ea09c3899ab7711d3b9fe901c17\": \"0xad78ebc5ac6200000\",\n \"0x86ef6426211949cc37f4c75e7850369d0cf5f479\": \"0x2d65f32ea045af60000\",\n \"0x86f05d19063e9369c6004eb3f123943a7cff4eab\": \"0x6c6acc67d7b1d40000\",\n \"0x86f23e9c0aafc78b9c404dcd60339a925bffa266\": \"0x15af1d78b58c400000\",\n \"0x86f4f40ad984fbb80933ae626e0e42f9333fdd41\": \"0x3635c9adc5dea00000\",\n \"0x86f95c5b11a293940e35c0b898d8b75f08aab06d\": \"0x644e3e875fccf740000\",\n \"0x86fff220e59305c09f483860d6f94e96fbe32f57\": \"0x2535b6ab4c0420000\",\n \"0x870796abc0db84af82da52a0ed68734de7e636f5\": \"0x1043561a8829300000\",\n \"0x870f15e5df8b0eabd02569537a8ef93b56785c42\": \"0x150894e849b3900000\",\n \"0x87183160d172d2e084d327b86bcb7c1d8e6784ef\": \"0xd8d8583fa2d52f0000\",\n \"0x871b8a8b51dea1989a5921f13ec1a955a515ad47\": \"0x1b1ae4d6e2ef5000000\",\n \"0x8725e8c753b3acbfdca55f3c62dfe1a59454968a\": \"0x3637096c4bcc690000\",\n \"0x8737dae671823a8d5917e0157ace9c43468d946b\": \"0x6c6acc67d7b1d40000\",\n \"0x873b7f786d3c99ff012c4a7cae2677270240b9c5\": \"0x5dc892aa1131c80000\",\n \"0x873c6f70efb6b1d0f2bbc57eebcd70617c6ce662\": \"0x36f0d5275d09570000\",\n \"0x873e49135c3391991060290aa7f6ccb8f85a78db\": \"0x1158e460913d00000\",\n \"0x875061ee12e820041a01942cb0e65bb427b00060\": \"0x97c9ce4cf6d5c00000\",\n \"0x87584a3f613bd4fac74c1e780b86d6caeb890cb2\": \"0x5c283d410394100000\",\n \"0x8764d02722000996ecd475b433298e9f540b05bf\": \"0xad78ebc5ac6200000\",\n \"0x876c3f218b4776df3ca9dbfb270de152d94ed252\": \"0x56bc75e2d63100000\",\n \"0x8775a610c502b9f1e6ad4cdadb8ce29bff75f6e4\": \"0x2086ac351052600000\",\n \"0x87764e3677eef604cbc59aed24abdc566b09fc25\": \"0xa2a15d09519be00000\",\n \"0x8787d12677a5ec291e57e31ffbfad105c3324b87\": \"0x2a24eb53208f3128000\",\n \"0x8794bf47d54540ece5c72237a1ffb511ddb74762\": \"0x6c6b935b8bbd400000\",\n \"0x87a53ea39f59a35bada8352521645594a1a714cb\": \"0x678a932062e4180000\",\n \"0x87a7c508ef71582dd9a54372f89cb01f252fb180\": \"0xad78ebc5ac6200000\",\n \"0x87af25d3f6f8eea15313d5fe4557e810c524c083\": \"0x42bf06b78ed3b500000\",\n \"0x87b10f9c280098179a2b76e9ce90be61fc844d0d\": \"0x487a9a304539440000\",\n \"0x87bf7cd5d8a929e1c785f9e5449106ac232463c9\": \"0x437b11fcc45640000\",\n \"0x87c498170934b8233d1ad1e769317d5c475f2f40\": \"0x3708baed3d68900000\",\n \"0x87cf36ad03c9eae9053abb5242de9117bb0f2a0b\": \"0x1b1ae4d6e2ef500000\",\n \"0x87d7ac0653ccc67aa9c3469eef4352193f7dbb86\": \"0x2a5a058fc295ed000000\",\n \"0x87e3062b2321e9dfb0875ce3849c9b2e3522d50a\": \"0x21e19e0c9bab2400000\",\n \"0x87e6034ecf23f8b5639d5f0ea70a22538a920423\": \"0x11c7ea162e78200000\",\n \"0x87ef6d8b6a7cbf9b5c8c97f67ee2adc2a73b3f77\": \"0xadd1bd23c3c480000\",\n \"0x87fb26c31e48644d693134205cae43b21f18614b\": \"0x4a4491bd6dcd280000\",\n \"0x87fc4635263944ce14a46c75fa4a821f39ce7f72\": \"0x1158e460913d00000\",\n \"0x87fcbe7c4193ffcb08143779c9bec83fe7fda9fc\": \"0x56f985d38644b8000\",\n \"0x88015d7203c5e0224aeda286ed12f1a51b789333\": \"0x10f08eda8e555098000\",\n \"0x88106c27d20b74b4b98ca62b232bd5c97411171f\": \"0xaadec983fcff40000\",\n \"0x881230047c211d2d5b00d8de4c5139de5e3227c7\": \"0x21e19e0c9bab2400000\",\n \"0x882aa798bf41df179f85520130f15ccdf59b5e58\": \"0x6c6b935b8bbd400000\",\n \"0x882bd3a2e9d74110b24961c53777f22f1f46dc5d\": \"0x2d4ca05e2b43ca80000\",\n \"0x882c8f81872c79fed521cb5f950d8b032322ea69\": \"0x878678326eac9000000\",\n \"0x882f75708386653c80171d0663bfe30b017ed0ad\": \"0x6c6b935b8bbd400000\",\n \"0x88344909644c7ad4930fd873ca1c0da2d434c07f\": \"0x727739fcb004d0000\",\n \"0x8834b2453471f324fb26be5b25166b5b5726025d\": \"0x1f0ff8f01daad40000\",\n \"0x883a78aeabaa50d8ddd8570bcd34265f14b19363\": \"0xd25522fda379a18000\",\n \"0x8845e9f90e96336bac3c616be9d88402683e004c\": \"0x6c6b935b8bbd400000\",\n \"0x8846928d683289a2d11df8db7a9474988ef01348\": \"0x21e19e0c9bab2400000\",\n \"0x884980eb4565c1048317a8f47fdbb461965be481\": \"0xd8d6119a8146050000\",\n \"0x884a7a39d0916e05f1c242df55607f37df8c5fda\": \"0x4f4843c157c8ca00000\",\n \"0x885493bda36a0432976546c1ddce71c3f4570021\": \"0xbbf510ddfcb260000\",\n \"0x88609e0a465b6e99fce907166d57e9da0814f5c8\": \"0x43c33c1937564800000\",\n \"0x886d0a9e17c9c095af2ea2358b89ec705212ee94\": \"0x18493fba64ef00000\",\n \"0x88797e58675ed5cc4c19980783dbd0c956085153\": \"0x6c6b935b8bbd400000\",\n \"0x887cac41cd706f3345f2d34ac34e01752a6e5909\": \"0x20465cee9da1370000\",\n \"0x88888a57bd9687cbf950aeeacf9740dcc4d1ef59\": \"0x62a992e53a0af00000\",\n \"0x8889448316ccf14ed86df8e2f478dc63c4338340\": \"0xd2f13f7789f00000\",\n \"0x888c16144933197cac26504dd76e06fd6600c789\": \"0x56bc75e2d63100000\",\n \"0x888e94917083d152202b53163939869d271175b4\": \"0xd8d726b7177a800000\",\n \"0x889087f66ff284f8b5efbd29493b706733ab1447\": \"0x215f835bc769da80000\",\n \"0x8895eb726226edc3f78cc6a515077b3296fdb95e\": \"0xd5967be4fc3f100000\",\n \"0x88975a5f1ef2528c300b83c0c607b8e87dd69315\": \"0x486cb9799191e0000\",\n \"0x889da40fb1b60f9ea9bd7a453e584cf7b1b4d9f7\": \"0x22b1c8c1227a00000\",\n \"0x889da662eb4a0a2a069d2bc24b05b4ee2e92c41b\": \"0x5a2c8c5456c9f28000\",\n \"0x88a122a2382c523931fb51a0ccad3beb5b7259c3\": \"0x6c6b935b8bbd400000\",\n \"0x88a2154430c0e41147d3c1fee3b3b006f851edbd\": \"0x36356633ebd8ea0000\",\n \"0x88b217ccb786a254cf4dc57f5d9ac3c455a30483\": \"0x3224f42723d4540000\",\n \"0x88bc43012edb0ea9f062ac437843250a39b78fbb\": \"0x43c33c1937564800000\",\n \"0x88c2516a7cdb09a6276d7297d30f5a4db1e84b86\": \"0xd8d726b7177a800000\",\n \"0x88c361640d6b69373b081ce0c433bd590287d5ec\": \"0xa968163f0a57b400000\",\n \"0x88d541c840ce43cefbaf6d19af6b9859b573c145\": \"0x93739534d28680000\",\n \"0x88de13b09931877c910d593165c364c8a1641bd3\": \"0xa2a15d09519be00000\",\n \"0x88dec5bd3f4eba2d18b8aacefa7b721548c319ba\": \"0x4a4491bd6dcd280000\",\n \"0x88e6f9b247f988f6c0fc14c56f1de53ec69d43cc\": \"0x56bc75e2d63100000\",\n \"0x88ee7f0efc8f778c6b687ec32be9e7d6f020b674\": \"0x6c6b935b8bbd400000\",\n \"0x88f1045f19f2d3191816b1df18bb6e1435ad1b38\": \"0xd02ab486cedc00000\",\n \"0x89009e3c6488bd5e570d1da34eabe28ed024de1b\": \"0x43c33c1937564800000\",\n \"0x89054430dcdc28ac15fa635ef87c105e602bf70c\": \"0x5dacd13ca9e300000\",\n \"0x8908760cd39b9c1e8184e6a752ee888e3f0b7045\": \"0x14542ba12a337c00000\",\n \"0x890fe11f3c24db8732d6c2e772e2297c7e65f139\": \"0xd5627137da8b5900000\",\n \"0x8914a680a5aec5226d4baaec2e5552b44dd7c874\": \"0x56cd55fc64dfe0000\",\n \"0x891cb8238c88e93a1bcf61db49bd82b47a7f4f84\": \"0x914878a8c05ee00000\",\n \"0x8925da4549e15155e57a628522cea9dddf627d81\": \"0x3636c25e66ece70000\",\n \"0x893017ff1adad499aa065401b4236ce6e92b625a\": \"0x6c6acc67d7b1d40000\",\n \"0x8933491760c8f0b4df8caac78ed835caee21046d\": \"0x43c33c1937564800000\",\n \"0x893608751d68d046e85802926673cdf2f57f7cb8\": \"0x11164759ffb320000\",\n \"0x8938d1b4daee55a54d738cf17e4477f6794e46f7\": \"0xfc936392801c0000\",\n \"0x893a6c2eb8b40ab096b4f67e74a897b840746e86\": \"0x5dc892aa1131c80000\",\n \"0x893cdddf5377f3c751bf2e541120045a47cba101\": \"0x56bc75e2d63100000\",\n \"0x895613236f3584216ad75c5d3e07e3fa6863a778\": \"0x6c6b935b8bbd400000\",\n \"0x8957727e72cf629020f4e05edf799aa7458062d0\": \"0x77432217e683600000\",\n \"0x895d694e880b13ccd0848a86c5ce411f88476bbf\": \"0xad6eedd17cf3b8000\",\n \"0x895ec5545644e0b78330fffab8ddeac9e833156c\": \"0x2086ac351052600000\",\n \"0x896009526a2c7b0c09a6f63a80bdf29d9c87de9c\": \"0xbbb86b8223edeb0000\",\n \"0x8967d7b9bdb7b4aed22e65a15dc803cb7a213f10\": \"0x15af1d78b58c400000\",\n \"0x896e335ca47af57962fa0f4dbf3e45e688cba584\": \"0x4a2fc0ab6052120000\",\n \"0x8973aefd5efaee96095d9e288f6a046c97374b43\": \"0x7a4c4a0f332140000\",\n \"0x898c72dd736558ef9e4be9fdc34fef54d7fc7e08\": \"0x3635c9adc5dea00000\",\n \"0x899b3c249f0c4b81df75d212004d3d6d952fd223\": \"0x6c6b935b8bbd400000\",\n \"0x89ab13ee266d779c35e8bb04cd8a90cc2103a95b\": \"0xcb49b44ba602d800000\",\n \"0x89c433d601fad714da6369308fd26c1dc9942bbf\": \"0x6c6b935b8bbd400000\",\n \"0x89d75b8e0831e46f80bc174188184e006fde0eae\": \"0x3635c9adc5dea00000\",\n \"0x89e3b59a15864737d493c1d23cc53dbf8dcb1362\": \"0xd8d726b7177a800000\",\n \"0x89fc8e4d386b0d0bb4a707edf3bd560df1ad8f4e\": \"0xa030dcebbd2f4c0000\",\n \"0x89fee30d1728d96cecc1dab3da2e771afbcfaa41\": \"0x6c6acc67d7b1d40000\",\n \"0x8a1cc5ac111c49bfcfd848f37dd768aa65c88802\": \"0x21e19e0c9bab2400000\",\n \"0x8a20e5b5cee7cd1f5515bace3bf4f77ffde5cc07\": \"0x4563918244f400000\",\n \"0x8a217db38bc35f215fd92906be42436fe7e6ed19\": \"0x14542ba12a337c00000\",\n \"0x8a243a0a9fea49b839547745ff2d11af3f4b0522\": \"0x35659ef93f0fc40000\",\n \"0x8a247d186510809f71cffc4559471c3910858121\": \"0x61093d7c2c6d380000\",\n \"0x8a3470282d5e2a2aefd7a75094c822c4f5aeef8a\": \"0xd28bc606478a58000\",\n \"0x8a36869ad478997cbf6d8924d20a3c8018e9855b\": \"0x1158e460913d00000\",\n \"0x8a4314fb61cd938fc33e15e816b113f2ac89a7fb\": \"0x17764e7aed65100000\",\n \"0x8a4f4a7f52a355ba105fca2072d3065fc8f7944b\": \"0x1b1ae4d6e2ef500000\",\n \"0x8a5831282ce14a657a730dc18826f7f9b99db968\": \"0xeabe8a5b41c1360000\",\n \"0x8a5fb75793d043f1bcd43885e037bd30a528c927\": \"0x13536e6d2e9ac20000\",\n \"0x8a66abbc2d30ce21a833b0db8e561d5105e0a72c\": \"0x25f1de5c76acdf0000\",\n \"0x8a746c5d67064711bfca685b95a4fe291a27028e\": \"0x22b1c8c1227a00000\",\n \"0x8a780ab87a9145fe10ed60fa476a740af4cab1d2\": \"0x121b2e5e6464780000\",\n \"0x8a7a06be199a3a58019d846ac9cbd4d95dd757de\": \"0xa2a423944256f40000\",\n \"0x8a810114b2025db9fbb50099a6e0cb9e2efa6bdc\": \"0x678a932062e4180000\",\n \"0x8a86e4a51c013b1fb4c76bcf30667c78d52eedef\": \"0x6c6b935b8bbd400000\",\n \"0x8a9eca9c5aba8e139f8003edf1163afb70aa3aa9\": \"0x23c757072b8dd00000\",\n \"0x8ab839aeaf2ad37cb78bacbbb633bcc5c099dc46\": \"0x6c6b935b8bbd400000\",\n \"0x8ac89bd9b8301e6b0677fa25fcf0f58f0cc7b611\": \"0x1158e460913d00000\",\n \"0x8adc53ef8c18ed3051785d88e996f3e4b20ecd51\": \"0x8e4d316827686400000\",\n \"0x8ae6f80b70e1f23c91fbd5a966b0e499d95df832\": \"0xaadec983fcff40000\",\n \"0x8ae9ef8c8a8adfa6ab798ab2cdc405082a1bbb70\": \"0x6c6b935b8bbd400000\",\n \"0x8af626a5f327d7506589eeb7010ff9c9446020d2\": \"0x4be4e7267b6ae00000\",\n \"0x8b01da34d470c1d115acf4d8113c4dd8a8c338e4\": \"0x5572dcefab697900000\",\n \"0x8b07d050754dc9ba230db01c310afdb5395aa1b3\": \"0x666b06e62a6200000\",\n \"0x8b20ad3b94656dbdc0dd21a393d8a7d9e02138cb\": \"0xa2a15d09519be00000\",\n \"0x8b27392206b958cd375d7ef8af2cf8ef0598c0bc\": \"0x3635c9adc5dea00000\",\n \"0x8b30c04098d7a7e6420c357ea7bfa49bac9a8a18\": \"0x1b1b113f91fb0140000\",\n \"0x8b338411f26ccf37658cc75521d77629099e467d\": \"0x6c6b935b8bbd400000\",\n \"0x8b36224c7356e751f0c066c35e3b44860364bfc2\": \"0x3627bac7a3d9278000\",\n \"0x8b3696f3c60de32432a2e4c395ef0303b7e81e75\": \"0x65a4da25d3016c00000\",\n \"0x8b393fb0813ee101db1e14ecc7d322c72b8c0473\": \"0x18b26a313e8ae90000\",\n \"0x8b48e19d39dd35b66e6e1bb6b9c657cb2cf59d04\": \"0x3c755ac9c024a018000\",\n \"0x8b505e2871f7deb7a63895208e8227dcaa1bff05\": \"0xcf68efc308d79bc0000\",\n \"0x8b57b2bc83cc8d4de331204e893f2f3b1db1079a\": \"0x22b1c8c1227a00000\",\n \"0x8b5c914b128bf1695c088923fa467e7911f351fa\": \"0x556f64c1fe7fa0000\",\n \"0x8b5f29cc2faa262cdef30ef554f50eb488146eac\": \"0x13b68705c9720810000\",\n \"0x8b7056f6abf3b118d026e944d5c073433ca451d7\": \"0x3635c6204739d98000\",\n \"0x8b714522fa2839620470edcf0c4401b713663df1\": \"0xad78ebc5ac6200000\",\n \"0x8b74a7cb1bb8c58fce267466a30358adaf527f61\": \"0x2e257784e25b4500000\",\n \"0x8b7e9f6f05f7e36476a16e3e7100c9031cf404af\": \"0x3635c9adc5dea00000\",\n \"0x8b81156e698639943c01a75272ad3d35851ab282\": \"0x12b3165f65d3e50000\",\n \"0x8b9577920053b1a00189304d888010d9ef2cb4bf\": \"0x1b1ae4d6e2ef500000\",\n \"0x8b9841862e77fbbe919470935583a93cf027e450\": \"0x6c6c5334427f1f0000\",\n \"0x8b997dbc078ad02961355da0a159f2927ed43d64\": \"0xaadec983fcff40000\",\n \"0x8b9fda7d981fe9d64287f85c94d83f9074849fcc\": \"0x2f6f10780d22cc00000\",\n \"0x8bb0212f3295e029cab1d961b04133a1809e7b91\": \"0x6c6b935b8bbd400000\",\n \"0x8bbeacfc29cfe93402db3c41d99ab759662e73ec\": \"0x6c6b935b8bbd400000\",\n \"0x8bc1ff8714828bf286ff7e8a7709106548ed1b18\": \"0x21e19e0c9bab2400000\",\n \"0x8bd0b65a50ef5cef84fec420be7b89ed1470ceb9\": \"0x28a77936e92c81c0000\",\n \"0x8bd6b1c6d74d010d1008dba6ef835d4430b35c32\": \"0x2b5e3af16b1880000\",\n \"0x8bd8d4c4e943f6c8073921dc17e3e8d7a0761627\": \"0x9f04219d8d34950000\",\n \"0x8bdfda6c215720eda2136f91052321af4e936c1f\": \"0x3635e619bb04d40000\",\n \"0x8bea40379347a5c891d59a6363315640f5a7e07a\": \"0x6c6b76ef96970c0000\",\n \"0x8bf02bd748690e1fd1c76d270833048b66b25fd3\": \"0x27fade568eba9600000\",\n \"0x8bf297f8f453523ed66a1acb7676856337b93bf0\": \"0xd8d726b7177a800000\",\n \"0x8bf373d076814cbc57e1c6d16a82c5be13c73d37\": \"0xad78ebc5ac6200000\",\n \"0x8c1023fde1574db8bb54f1739670157ca47da652\": \"0x179cf9ac3a1b1770000\",\n \"0x8c1fbe5f0aea359c5aa1fa08c8895412ca8e05a6\": \"0x3635c9adc5dea00000\",\n \"0x8c22426055b76f11f0a2de1a7f819a619685fe60\": \"0x6b56051582a9700000\",\n \"0x8c2b7d8b608d28b77f5caa9cd645242a823e4cd9\": \"0x62a992e53a0af00000\",\n \"0x8c2fbeee8eacc5c5d77c16abd462ee9c8145f34b\": \"0x692ae8897081d00000\",\n \"0x8c3a9ee71f729f236cba3867b4d79d8ceee25dbc\": \"0x56bc75e2d63100000\",\n \"0x8c50aa2a9212bcde56418ae261f0b35e7a9dbb82\": \"0x15af1d78b58c400000\",\n \"0x8c54c7f8b9896e75d7d5f5c760258699957142ad\": \"0x22b1c8c1227a00000\",\n \"0x8c5d16ed65e3ed7e8b96ca972bc86173e3500b03\": \"0x6c6b935b8bbd400000\",\n \"0x8c6aa882ee322ca848578c06cb0fa911d3608305\": \"0x2086ac351052600000\",\n \"0x8c6ae7a05a1de57582ae2768204276c0ff47ed03\": \"0x2c0bb3dd30c4e2000000\",\n \"0x8c6f9f4e5b7ae276bf58497bd7bf2a7d25245f64\": \"0x93fe5c57d710680000\",\n \"0x8c75956e8fed50f5a7dd7cfd27da200f6746aea6\": \"0x3635c9adc5dea00000\",\n \"0x8c7cb4e48b25031aa1c4f92925d631a8c3edc761\": \"0x3635c9adc5dea00000\",\n \"0x8c7fa5cae82fedb69ab189d3ff27ae209293fb93\": \"0x15af880d8cdb830000\",\n \"0x8c81410ea8354cc5c65c41be8bd5de733c0b111d\": \"0x205b4dfa1ee74780000\",\n \"0x8c83d424a3cf24d51f01923dd54a18d6b6fede7b\": \"0xd8d726b7177a800000\",\n \"0x8c900a8236b08c2b65405d39d75f20062a7561fd\": \"0x58e7926ee858a00000\",\n \"0x8c93c3c6db9d37717de165c3a1b4fe51952c08de\": \"0x15af1d78b58c400000\",\n \"0x8c999591fd72ef7111efca7a9e97a2356b3b000a\": \"0xdd64e2aa0a67500000\",\n \"0x8ca6989746b06e32e2487461b1ce996a273acfd7\": \"0x1158e460913d00000\",\n \"0x8cb3aa3fcd212854d7578fcc30fdede6742a312a\": \"0x1043561a8829300000\",\n \"0x8cc0d7c016fa7aa950114aa1db094882eda274ea\": \"0x8a9aba557e36c0000\",\n \"0x8cc652dd13e7fe14dabbb36d5d320db9ffee8a54\": \"0x61093d7c2c6d380000\",\n \"0x8ccabf25077f3aa41545344d53be1b2b9c339000\": \"0x5be866c562c5440000\",\n \"0x8ccf3aa21ab742576ad8c422f71bb188591dea8a\": \"0x3635c9adc5dea00000\",\n \"0x8cd0cd22e620eda79c0461e896c93c44837e2968\": \"0x6c6b935b8bbd400000\",\n \"0x8cde8b732e6023878eb23ed16229124b5f7afbec\": \"0x73f75d1a085ba0000\",\n \"0x8ce22f9fa372449a420610b47ae0c8d565481232\": \"0x6c6b935b8bbd400000\",\n \"0x8ce4949d8a16542d423c17984e6739fa72ceb177\": \"0x54b405926f4a63d8000\",\n \"0x8ce5e3b5f591d5eca38abf228f2e3c35134bdac0\": \"0x7dc35b84897c380000\",\n \"0x8cee38d6595788a56e3fb94634b3ffe1fbdb26d6\": \"0x43c33c1937564800000\",\n \"0x8ceea15eec3bdad8023f98ecf25b2b8fef27db29\": \"0x6c6b935b8bbd400000\",\n \"0x8cf3546fd1cda33d58845fc8fcfecabca7c5642a\": \"0x1f1e39932cb3278000\",\n \"0x8cf6da0204dbc4860b46ad973fc111008d9e0c46\": \"0xad78ebc5ac6200000\",\n \"0x8cfedef198db0a9143f09129b3fd64dcbb9b4956\": \"0x6c6b935b8bbd400000\",\n \"0x8d04a5ebfb5db409db0617c9fa5631c192861f4a\": \"0x34957444b840e80000\",\n \"0x8d06e464245cad614939e0af0845e6d730e20374\": \"0xadc8a28f3d87d8000\",\n \"0x8d07d42d831c2d7c838aa1872b3ad5d277176823\": \"0x12ee1f9ddbee680000\",\n \"0x8d0b9ea53fd263415eac11391f7ce9123c447062\": \"0x6c6b935b8bbd400000\",\n \"0x8d1794da509cb297053661a14aa892333231e3c1\": \"0xad201a6794ff80000\",\n \"0x8d1abd897dacd4312e18080c88fb9647eab44052\": \"0xbb59a27953c600000\",\n \"0x8d2303341e1e1eb5e8189bde03f73a60a2a54861\": \"0x56bc75e2d63100000\",\n \"0x8d238e036596987643d73173c37b0ad06055b96c\": \"0x7148bf0a2af0660000\",\n \"0x8d2e31b08803b2c5f13d398ecad88528209f6057\": \"0x21db8bbcad11e840000\",\n \"0x8d378f0edc0bb0f0686d6a20be6a7692c4fa24b8\": \"0x56bc75e2d63100000\",\n \"0x8d4b603c5dd4570c34669515fdcc665890840c77\": \"0xfc936392801c0000\",\n \"0x8d51a4cc62011322c696fd725b9fb8f53feaaa07\": \"0x3635c9adc5dea00000\",\n \"0x8d544c32c07fd0842c761d53a897d6c950bb7599\": \"0xad78ebc5ac6200000\",\n \"0x8d5ef172bf77315ea64e85d0061986c794c6f519\": \"0xd5967be4fc3f100000\",\n \"0x8d616b1eee77eef6f176e0698db3c0c141b2fc8f\": \"0x1b1ae4d6e2ef500000\",\n \"0x8d6170ff66978e773bb621bf72b1ba7be3a7f87e\": \"0xad78ebc5ac6200000\",\n \"0x8d620bde17228f6cbba74df6be87264d985cc179\": \"0x56bc75e2d63100000\",\n \"0x8d629c20608135491b5013f1002586a0383130e5\": \"0x4a4491bd6dcd280000\",\n \"0x8d6657f59711b1f803c6ebef682f915b62f92dc9\": \"0x6c6b935b8bbd400000\",\n \"0x8d667637e29eca05b6bfbef1f96d460eefbf9984\": \"0xd8d726b7177a800000\",\n \"0x8d6df209484d7b94702b03a53e56b9fb0660f6f0\": \"0x6c6b935b8bbd400000\",\n \"0x8d795c5f4a5689ad62da961671f028065286d554\": \"0x6f05b59d3b20000000\",\n \"0x8d7f3e61299c2db9b9c0487cf627519ed00a9123\": \"0x5e74a8505e80a00000\",\n \"0x8d89170b92b2be2c08d57c48a7b190a2f146720f\": \"0x42bf06b78ed3b500000\",\n \"0x8d93dac785f88f1a84bf927d53652b45a154ccdd\": \"0x890b0c2e14fb80000\",\n \"0x8d9952d0bb4ebfa0efd01a3aa9e8e87f0525742e\": \"0xbb9125542263900000\",\n \"0x8d9a0c70d2262042df1017d6c303132024772712\": \"0x6c6b935b8bbd400000\",\n \"0x8d9ed7f4553058c26f7836a3802d3064eb1b363d\": \"0x4e1003b28d9280000\",\n \"0x8da1178f55d97772bb1d24111a404a4f8715b95d\": \"0x2f9ac3f6de00808000\",\n \"0x8da1d359ba6cb4bcc57d7a437720d55db2f01c72\": \"0x4563918244f400000\",\n \"0x8dab948ae81da301d972e3f617a912e5a753712e\": \"0x15af1d78b58c400000\",\n \"0x8daddf52efbd74da95b969a5476f4fbbb563bfd2\": \"0x2d43f3ebfafb2c0000\",\n \"0x8db185fe1b70a94a6a080e7e23a8bedc4acbf34b\": \"0x4be4e7267b6ae00000\",\n \"0x8db58e406e202df9bc703c480bd8ed248d52a032\": \"0x6c6b935b8bbd400000\",\n \"0x8dbc3e6cb433e194f40f82b40faadb1f8b856116\": \"0x678a932062e4180000\",\n \"0x8dc1d5111d09af25fdfcac455c7cec283e6d6775\": \"0x6c6b935b8bbd400000\",\n \"0x8dd484ff8a307364eb66c525a571aac701c5c318\": \"0xd8d726b7177a800000\",\n \"0x8dd6a9bae57f518549ada677466fea8ab04fd9b4\": \"0xd8d726b7177a800000\",\n \"0x8dde3cb8118568ef4503fe998ccdf536bf19a098\": \"0xd8d726b7177a800000\",\n \"0x8dde60eb08a099d7daa356daaab2470d7b025a6b\": \"0xaadec983fcff40000\",\n \"0x8df339214b6ad1b24663ce716034749d6ef838d9\": \"0x2544faa778090e00000\",\n \"0x8df53d96191471e059de51c718b983e4a51d2afd\": \"0x6c6b935b8bbd4000000\",\n \"0x8dfbafbc0e5b5c86cd1ad697feea04f43188de96\": \"0x15252b7f5fa0de0000\",\n \"0x8e073bad25e42218615f4a0e6b2ea8f8de2230c0\": \"0x823d629d026bfa0000\",\n \"0x8e0fee38685a94aabcd7ce857b6b1409824f75b8\": \"0x1b1ae4d6e2ef500000\",\n \"0x8e23facd12c765c36ab81a6dd34d8aa9e68918ae\": \"0x911e4868dba9b0000\",\n \"0x8e2f9034c9254719c38e50c9aa64305ed696df1e\": \"0x1004e2e45fb7ee00000\",\n \"0x8e3240b0810e1cf407a500804740cf8d616432a4\": \"0x22f6655ef0b388000\",\n \"0x8e486a0442d171c8605be348fee57eb5085eff0d\": \"0xd8d726b7177a800000\",\n \"0x8e6156336be2cdbe32140df08a2ba55fd0a58463\": \"0x4099e1d6357180000\",\n \"0x8e670815fb67aeaea57b86534edc00cdf564fee5\": \"0xb2e4b323d9c5100000\",\n \"0x8e6d7485cbe990acc1ad0ee9e8ccf39c0c93440e\": \"0x33c5499031720c0000\",\n \"0x8e74e0d1b77ebc823aca03f119854cb12027f6d7\": \"0x16b352da5e0ed3000000\",\n \"0x8e78f351457d016f4ad2755ec7424e5c21ba6d51\": \"0x7ea28327577080000\",\n \"0x8e7936d592008fdc7aa04edeeb755ab513dbb89d\": \"0x1158e460913d00000\",\n \"0x8e7fd23848f4db07906a7d10c04b21803bb08227\": \"0x3635c9adc5dea00000\",\n \"0x8e92aba38e72a098170b92959246537a2e5556c0\": \"0xe7eeba3410b740000\",\n \"0x8e98766524b0cf2747c50dd43b9567594d9731de\": \"0x6c44b7c26182280000\",\n \"0x8e9b35ad4a0a86f758446fffde34269d940ceacd\": \"0xd8d726b7177a800000\",\n \"0x8e9c08f738661f9676236eff82ba6261dd3f4822\": \"0x56bc75e2d63100000\",\n \"0x8e9c429266df057efa78dd1d5f77fc40742ad466\": \"0x10442ed1b56c7c8000\",\n \"0x8ea656e71ec651bfa17c5a5759d86031cc359977\": \"0x56bc75e2d63100000\",\n \"0x8eae29435598ba8f1c93428cdb3e2b4d31078e00\": \"0x6c6b935b8bbd400000\",\n \"0x8eb1fbe4e5d3019cd7d30dae9c0d5b4c76fb6331\": \"0x6c6b935b8bbd400000\",\n \"0x8eb51774af206b966b8909c45aa6722748802c0c\": \"0x1b1ae4d6e2ef500000\",\n \"0x8eb8c71982a00fb84275293253f8044544b66b49\": \"0x15af1d78b58c400000\",\n \"0x8ecbcfacbfafe9f00c3922a24e2cf0026756ca20\": \"0x131beb925ffd3200000\",\n \"0x8eceb2e124536c5b5ffc640ed14ff15ed9a8cb71\": \"0x6c6b935b8bbd400000\",\n \"0x8ed0af11ff2870da0681004afe18b013f7bd3882\": \"0xd8d726b7177a800000\",\n \"0x8ed143701f2f72280fd04a7b4164281979ea87c9\": \"0xc249fdd327780000\",\n \"0x8ed1528b447ed4297902f639c514d0944a88f8c8\": \"0xac6e77ab663a80000\",\n \"0x8ed4284c0f47449c15b8d9b3245de8beb6ce80bf\": \"0x2b5e3af16b18800000\",\n \"0x8ede7e3dc50749c6c50e2e28168478c34db81946\": \"0x43c30fb0884a96c0000\",\n \"0x8ee584337ddbc80f9e3498df55f0a21eacb57fb1\": \"0x1158e460913d00000\",\n \"0x8eebec1a62c08b05a7d1d59180af9ff0d18e3f36\": \"0x1b1ae4d6e2ef500000\",\n \"0x8ef4d8a2c23c5279187b64e96f741404085385f3\": \"0x103dc1e9a9697b0000\",\n \"0x8ef711e43a13918f1303e81d0ea78c9eefd67eb2\": \"0xd8d726b7177a800000\",\n \"0x8efec058cc546157766a632775404a334aaada87\": \"0x6c5db2a4d815dc0000\",\n \"0x8f02bda6c36922a6be6a509be51906d393f7b99b\": \"0x37490dc12ebe7f8000\",\n \"0x8f0538ed71da1155e0f3bde5667ceb84318a1a87\": \"0x692ae8897081d00000\",\n \"0x8f067c7c1bbd57780b7b9eeb9ec0032f90d0dcf9\": \"0x43c33c1937564800000\",\n \"0x8f0ab894bd3f4e697dbcfb859d497a9ba195994a\": \"0x85d638b65472aa20000\",\n \"0x8f0af37566d152802f1ae8f928b25af9b139b448\": \"0xad78ebc5ac6200000\",\n \"0x8f1952eed1c548d9ee9b97d0169a07933be69f63\": \"0x3635c9adc5dea00000\",\n \"0x8f1fcc3c51e252b693bc5b0ec3f63529fe69281e\": \"0x14542ba12a337c00000\",\n \"0x8f226096c184ebb40105e08dac4d22e1c2d54d30\": \"0x109e437bd1618c0000\",\n \"0x8f29a14a845ad458f2d108b568d813166bcdf477\": \"0x21e19e0c9bab2400000\",\n \"0x8f31c7005197ec997a87e69bec48649ab94bb2a5\": \"0xd8d726b7177a800000\",\n \"0x8f41b1fbf54298f5d0bc2d122f4eb95da4e5cd3d\": \"0x1333832f5e335c0000\",\n \"0x8f47328ee03201c9d35ed2b5412b25decc859362\": \"0x6c6b935b8bbd400000\",\n \"0x8f473d0ab876ddaa15608621d7013e6ff714b675\": \"0x19801c83b6c7c00000\",\n \"0x8f4d1d41693e462cf982fd81d0aa701d3a5374c9\": \"0xd8d726b7177a800000\",\n \"0x8f4d1e7e4561284a34fef9673c0d34e12af4aa03\": \"0x6c6b935b8bbd400000\",\n \"0x8f4fb1aea7cd0f570ea5e61b40a4f4510b6264e4\": \"0xd8d726b7177a800000\",\n \"0x8f561b41b209f248c8a99f858788376250609cf3\": \"0x5c283d410394100000\",\n \"0x8f58d8348fc1dc4e0dd8343b6543c857045ee940\": \"0x2e3038df47303280000\",\n \"0x8f60895fbebbb5017fcbff3cdda397292bf25ba6\": \"0x174406ff9f6fd28000\",\n \"0x8f64b9c1246d857831643107d355b5c75fef5d4f\": \"0x6c6acc67d7b1d40000\",\n \"0x8f660f8b2e4c7cc2b4ac9c47ed28508d5f8f8650\": \"0x43c33c1937564800000\",\n \"0x8f69eafd0233cadb4059ab779c46edf2a0506e48\": \"0x60f06620a849450000\",\n \"0x8f717ec1552f4c440084fba1154a81dc003ebdc0\": \"0x21e19e0c9bab2400000\",\n \"0x8f8acb107607388479f64baaabea8ff007ada97d\": \"0x5c6f3080ad423f40000\",\n \"0x8f8cd26e82e7c6defd02dfad07979021cbf7150c\": \"0xa2a15d09519be00000\",\n \"0x8f8f37d0ad8f335d2a7101b41156b688a81a9cbe\": \"0x3cb71f51fc5580000\",\n \"0x8f92844f282a92999ee5b4a8d773d06b694dbd9f\": \"0x692ae8897081d00000\",\n \"0x8fac748f784a0fed68dba43319b42a75b4649c6e\": \"0x3154c9729d05780000\",\n \"0x8fd9a5c33a7d9edce0997bdf77ab306424a11ea9\": \"0x6c6b935b8bbd400000\",\n \"0x8feffadb387a1547fb284da9b8147f3e7c6dc6da\": \"0x2d627be45305080000\",\n \"0x8ff46045687723dc33e4d099a06904f1ebb584dc\": \"0x6c6b935b8bbd400000\",\n \"0x8ffa062122ac307418821adb9311075a3703bfa3\": \"0x3635c9adc5dea00000\",\n \"0x8ffe322997b8e404422d19c54aadb18f5bc8e9b7\": \"0xd5967be4fc3f100000\",\n \"0x900194c4b1074305d19de405b0ac78280ecaf967\": \"0x3635c9adc5dea00000\",\n \"0x9003d270891ba2df643da8341583193545e3e000\": \"0xd8d726b7177a800000\",\n \"0x90057af9aa66307ec9f033b29724d3b2f41eb6f9\": \"0x19d1d6aadb2c52e80000\",\n \"0x900f0b8e35b668f81ef252b13855aa5007d012e7\": \"0x170a0f5040e5040000\",\n \"0x9018cc1f48d2308e252ab6089fb99a7c1d569410\": \"0xad78ebc5ac6200000\",\n \"0x901d99b699e5c6911519cb2076b4c76330c54d22\": \"0x6c6b935b8bbd400000\",\n \"0x902d74a157f7d2b9a3378b1f56703730e03a1719\": \"0xd8d726b7177a800000\",\n \"0x903413878aea3bc1086309a3fe768b65559e8cab\": \"0x1b1ae4d6e2ef5000000\",\n \"0x904966cc2213b5b8cb5bd6089ef9cddbef7edfcc\": \"0x6c6b935b8bbd400000\",\n \"0x904caa429c619d940f8e6741826a0db692b19728\": \"0x3635c9adc5dea00000\",\n \"0x9052f2e4a3e3c12dd1c71bf78a4ec3043dc88b7e\": \"0xe7eeba3410b740000\",\n \"0x905526568ac123afc0e84aa715124febe83dc87c\": \"0xf8699329677e0000\",\n \"0x9092918707c621fdbd1d90fb80eb787fd26f7350\": \"0x855b5ba65c84f00000\",\n \"0x909b5e763a39dcc795223d73a1dbb7d94ca75ac8\": \"0x6c6b935b8bbd400000\",\n \"0x90acced7e48c08c6b934646dfa0adf29dc94074f\": \"0x30b4b157bbd490000\",\n \"0x90b1f370f9c1eb0be0fb8e2b8ad96a416371dd8a\": \"0x30ca024f987b900000\",\n \"0x90b62f131a5f29b45571513ee7a74a8f0b232202\": \"0x890b0c2e14fb80000\",\n \"0x90bd62a050845261fa4a9f7cf241ea630b05efb8\": \"0x1b1ae4d6e2ef500000\",\n \"0x90c41eba008e20cbe927f346603fc88698125969\": \"0x246ddf97976680000\",\n \"0x90d2809ae1d1ffd8f63eda01de49dd552df3d1bc\": \"0xd8bb6549b02bb80000\",\n \"0x90dc09f717fc2a5b69fd60ba08ebf40bf4e8246c\": \"0xd8d8583fa2d52f0000\",\n \"0x90e300ac71451e401f887f6e7728851647a80e07\": \"0x15af1d78b58c400000\",\n \"0x90e35aabb2deef408bb9b5acef714457dfde6272\": \"0x56cd55fc64dfe0000\",\n \"0x90e7070f4d033fe6910c9efe5a278e1fc6234def\": \"0x571380819b3040000\",\n \"0x90e93e4dc17121487952333614002be42356498e\": \"0x678a932062e4180000\",\n \"0x90e9a9a82edaa814c284d232b6e9ba90701d4952\": \"0x56be03ca3e47d8000\",\n \"0x90f774c9147dde90853ddc43f08f16d455178b8c\": \"0xd8d726b7177a800000\",\n \"0x90fc537b210658660a83baa9ac4a8402f65746a8\": \"0x65ea3db75546600000\",\n \"0x91050a5cffadedb4bb6eaafbc9e5013428e96c80\": \"0x5c283d410394100000\",\n \"0x91051764af6b808e4212c77e30a5572eaa317070\": \"0x3635c9adc5dea00000\",\n \"0x910b7d577a7e39aa23acf62ad7f1ef342934b968\": \"0x21e19e0c9bab2400000\",\n \"0x910e996543344c6815fb97cda7af4b8698765a5b\": \"0x59af69829cf640000\",\n \"0x911feea61fe0ed50c5b9e5a0d66071399d28bdc6\": \"0x340aad21b3b700000\",\n \"0x911ff233e1a211c0172c92b46cf997030582c83a\": \"0x6acb3df27e1f880000\",\n \"0x9120e71173e1ba19ba8f9f4fdbdcaa34e1d6bb78\": \"0x6c6b935b8bbd400000\",\n \"0x91211712719f2b084d3b3875a85069f466363141\": \"0x3635c9adc5dea00000\",\n \"0x912304118b80473d9e9fe3ee458fbe610ffda2bb\": \"0xad78ebc5ac6200000\",\n \"0x91546b79ecf69f936b5a561508b0d7e50cc5992f\": \"0xe7eeba3410b740000\",\n \"0x9156d18029350e470408f15f1aa3be9f040a67c6\": \"0x3635c9adc5dea00000\",\n \"0x91620f3eb304e813d28b0297556d65dc4e5de5aa\": \"0xcf152640c5c8300000\",\n \"0x916bf7e3c545921d3206d900c24f14127cbd5e70\": \"0x3d0ddbc7df2bb100000\",\n \"0x916cf17d71412805f4afc3444a0b8dd1d9339d16\": \"0xc673ce3c40160000\",\n \"0x917b8f9f3a8d09e9202c52c29e724196b897d35e\": \"0x8ba52e6fc45e40000\",\n \"0x918967918cd897dd0005e36dc6c883ef438fc8c7\": \"0x796e3ea3f8ab00000\",\n \"0x91898eab8c05c0222883cd4db23b7795e1a24ad7\": \"0x6c6b935b8bbd400000\",\n \"0x9191f94698210516cf6321a142070e20597674ed\": \"0xee9d5be6fc110000\",\n \"0x91a4149a2c7b1b3a67ea28aff34725e0bf8d7524\": \"0x692ae8897081d00000\",\n \"0x91a787bc5196f34857fe0c372f4df376aaa76613\": \"0x6c6b935b8bbd400000\",\n \"0x91a8baaed012ea2e63803b593d0d0c2aab4c5b0a\": \"0x5150ae84a8cdf00000\",\n \"0x91ac5cfe67c54aa7ebfba448666c461a3b1fe2e1\": \"0x15c93492bf9dfc0000\",\n \"0x91bb3f79022bf3c453f4ff256e269b15cf2c9cbd\": \"0x52585c13fe3a5c0000\",\n \"0x91c75e3cb4aa89f34619a164e2a47898f5674d9c\": \"0x6c6b935b8bbd400000\",\n \"0x91c80caa081b38351d2a0e0e00f80a34e56474c1\": \"0x3635c9adc5dea00000\",\n \"0x91cc46aa379f856a6640dccd5a648a7902f849d9\": \"0xad78ebc5ac6200000\",\n \"0x91d2a9ee1a6db20f5317cca7fbe2313895db8ef8\": \"0x1ccc3a52f306e280000\",\n \"0x91d66ea6288faa4b3d606c2aa45c7b6b8a252739\": \"0x6c6b935b8bbd400000\",\n \"0x91dbb6aaad149585be47375c5d6de5ff09191518\": \"0x43c33c1937564800000\",\n \"0x91e8810652e8e6161525d63bb7751dc20f676076\": \"0x274d656ac90e340000\",\n \"0x91f516146cda20281719978060c6be4149067c88\": \"0x6c6b935b8bbd400000\",\n \"0x91f624b24a1fa5a056fe571229e7379db14b9a1e\": \"0x28a8517c669b3570000\",\n \"0x91fe8a4c6164df8fa606995d6ba7adcaf1c893ce\": \"0x39992648a23c8a00000\",\n \"0x921f5261f4f612760706892625c75e7bce96b708\": \"0x6c6b935b8bbd400000\",\n \"0x9221c9ce01232665741096ac07235903ad1fe2fc\": \"0x6db63335522628000\",\n \"0x9225983860a1cb4623c72480ac16272b0c95e5f5\": \"0x6c6b935b8bbd400000\",\n \"0x9225d46a5a80943924a39e5b84b96da0ac450581\": \"0x878678326eac9000000\",\n \"0x922a20c79a1d3a26dd3829677bf1d45c8f672bb6\": \"0xd8d726b7177a800000\",\n \"0x92438e5203b6346ff886d7c36288aacccc78ceca\": \"0x3635c9adc5dea00000\",\n \"0x9243d7762d77287b12638688b9854e88a769b271\": \"0x3635c9adc5dea00000\",\n \"0x924bce7a853c970bb5ec7bb759baeb9c7410857b\": \"0xbe202d6a0eda0000\",\n \"0x924efa6db595b79313277e88319625076b580a10\": \"0x6c6b935b8bbd400000\",\n \"0x92558226b384626cad48e09d966bf1395ee7ea5d\": \"0x121ea68c114e510000\",\n \"0x926082cb7eed4b1993ad245a477267e1c33cd568\": \"0x144a74badfa4b60000\",\n \"0x926209b7fda54e8ddb9d9e4d3d19ebdc8e88c29f\": \"0x6c6b935b8bbd400000\",\n \"0x9268d62646563611dc3b832a30aa2394c64613e3\": \"0x6c6b935b8bbd400000\",\n \"0x92698e345378c62d8eda184d94366a144b0c105b\": \"0x4be4e7267b6ae00000\",\n \"0x92793ac5b37268774a7130de2bbd330405661773\": \"0x22ca3587cf4eb0000\",\n \"0x9279b2228cec8f7b4dda3f320e9a0466c2f585ca\": \"0x10f0cf064dd59200000\",\n \"0x927cb7dc187036b5427bc7e200c5ec450c1d27d4\": \"0xbb59a27953c600000\",\n \"0x927cc2bfda0e088d02eff70b38b08aa53cc30941\": \"0x646f60a1f986360000\",\n \"0x9284f96ddb47b5186ee558aa31324df5361c0f73\": \"0x3635c9adc5dea000000\",\n \"0x929d368eb46a2d1fbdc8ffa0607ede4ba88f59ad\": \"0x6c6b935b8bbd400000\",\n \"0x92a7c5a64362e9f842a23deca21035857f889800\": \"0x6c6acc67d7b1d40000\",\n \"0x92a898d46f19719c38126a8a3c27867ae2cee596\": \"0x6c6b935b8bbd400000\",\n \"0x92a971a739799f8cb48ea8475d72b2d2474172e6\": \"0xd5967be4fc3f100000\",\n \"0x92aae59768eddff83cfe60bb512e730a05a161d7\": \"0x5c9778410c76d18000\",\n \"0x92ad1b3d75fba67d54663da9fc848a8ade10fa67\": \"0x6c6b935b8bbd400000\",\n \"0x92ae5b7c7eb492ff1ffa16dd42ad9cad40b7f8dc\": \"0x2ee449550898e40000\",\n \"0x92c0f573eccf62c54810ee6ba8d1f113542b301b\": \"0xb7726f16ccb1e00000\",\n \"0x92c13fe0d6ce87fd50e03def9fa6400509bd7073\": \"0x22b1c8c1227a00000\",\n \"0x92c94c2820dfcf7156e6f13088ece7958b3676fd\": \"0x52d542804f1ce0000\",\n \"0x92cfd60188efdfb2f8c2e7b1698abb9526c1511f\": \"0x6c6b935b8bbd400000\",\n \"0x92d8ad9a4d61683b80d4a6672e84c20d62421e80\": \"0x1158e460913d00000\",\n \"0x92dca5e102b3b81b60f1a504634947c374a88ccb\": \"0x6c6b935b8bbd400000\",\n \"0x92e435340e9d253c00256389f52b067d55974e76\": \"0xe873f44133cb00000\",\n \"0x92e4392816e5f2ef5fb65837cec2c2325cc64922\": \"0x21e19e0c9bab2400000\",\n \"0x92e6581e1da1f9b846e09347333dc818e2d2ac66\": \"0xc55325ca7415e00000\",\n \"0x931df34d1225bcd4224e63680d5c4c09bce735a6\": \"0x3afb087b876900000\",\n \"0x931fe712f64207a2fd5022728843548bfb8cbb05\": \"0x6c6b935b8bbd400000\",\n \"0x93235f340d2863e18d2f4c52996516138d220267\": \"0x4002e44fda7d40000\",\n \"0x93258255b37c7f58f4b10673a932dd3afd90f4f2\": \"0x3635c9adc5dea00000\",\n \"0x9328d55ccb3fce531f199382339f0e576ee840a3\": \"0xd8d726b7177a800000\",\n \"0x9329ffdc268babde8874b366406c81445b9b2d35\": \"0x16e62f8c730ca18000\",\n \"0x932b9c04d40d2ac83083d94298169dae81ab2ed0\": \"0x6c6b935b8bbd400000\",\n \"0x933436c8472655f64c3afaaf7c4c621c83a62b38\": \"0x3635c9adc5dea00000\",\n \"0x933bf33f8299702b3a902642c33e0bfaea5c1ca3\": \"0xd2f13f7789f00000\",\n \"0x9340345ca6a3eabdb77363f2586043f29438ce0b\": \"0x1cc805da0dfff10000\",\n \"0x9340b5f678e45ee05eb708bb7abb6ec8f08f1b6b\": \"0x14542ba12a337c00000\",\n \"0x934af21b7ebfa467e2ced65aa34edd3a0ec71332\": \"0x7801f3e80cc0ff00000\",\n \"0x935069444a6a984de2084e46692ab99f671fc727\": \"0x1e7e4171bf4d3a00000\",\n \"0x93507e9e8119cbceda8ab087e7ecb071383d6981\": \"0x2f6f10780d22cc00000\",\n \"0x93678a3c57151aeb68efdc43ef4d36cb59a009f3\": \"0x1a12a92bc3c3e0000\",\n \"0x936dcf000194e3bff50ac5b4243a3ba014d661d8\": \"0x21e19e0c9bab2400000\",\n \"0x936f3813f5f6a13b8e4ffec83fe7f826186a71cd\": \"0x1c30731cec03200000\",\n \"0x9374869d4a9911ee1eaf558bc4c2b63ec63acfdd\": \"0x3635c9adc5dea00000\",\n \"0x937563d8a80fd5a537b0e66d20a02525d5d88660\": \"0x878678326eac900000\",\n \"0x9376dce2af2ec8dcda741b7e7345664681d93668\": \"0x3635c9adc5dea00000\",\n \"0x93868ddb2a794d02ebda2fa4807c76e3609858dc\": \"0x6dee15fc7c24a78000\",\n \"0x939c4313d2280edf5e071bced846063f0a975d54\": \"0x1969368974c05b000000\",\n \"0x93a6b3ab423010f981a7489d4aad25e2625c5741\": \"0x44680fe6a1ede4e8000\",\n \"0x93aa8f92ebfff991fc055e906e651ac768d32bc8\": \"0x32f51edbaaa3300000\",\n \"0x93b4bf3fdff6de3f4e56ba6d7799dc4b93a6548f\": \"0x10910d4cdc9f60000\",\n \"0x93bc7d9a4abd44c8bbb8fe8ba804c61ad8d6576c\": \"0xd8d6119a8146050000\",\n \"0x93c2e64e5de5589ed25006e843196ee9b1cf0b3e\": \"0x5a87e7d7f5f6580000\",\n \"0x93c88e2d88621e30f58a9586bed4098999eb67dd\": \"0x69b5afac750bb800000\",\n \"0x93e0f37ecdfb0086e3e862a97034447b1e4dec1a\": \"0x1a055690d9db80000\",\n \"0x93e303411afaf6c107a44101c9ac5b36e9d6538b\": \"0xdf9ddfecd0365400000\",\n \"0x93f18cd2526040761488c513174d1e7963768b2c\": \"0x82ffac9ad593720000\",\n \"0x940f715140509ffabf974546fab39022a41952d2\": \"0x4be4e7267b6ae00000\",\n \"0x942c6b8c955bc0d88812678a236725b32739d947\": \"0x54069233bf7f780000\",\n \"0x943d37864a4a537d35c8d99723cd6406ce2562e6\": \"0x6c6b935b8bbd400000\",\n \"0x94439ca9cc169a79d4a09cae5e67764a6f871a21\": \"0xd02ab486cedc00000\",\n \"0x94449c01b32a7fa55af8104f42cdd844aa8cbc40\": \"0x38111a1f4f03c100000\",\n \"0x9445ba5c30e98961b8602461d0385d40fbd80311\": \"0x21e19e0c9bab2400000\",\n \"0x944f07b96f90c5f0d7c0c580533149f3f585a078\": \"0x402f4cfee62e80000\",\n \"0x9454b3a8bff9709fd0e190877e6cb6c89974dbd6\": \"0x90f534608a72880000\",\n \"0x945d96ea573e8df7262bbfa572229b4b16016b0f\": \"0xb589ef914c1420000\",\n \"0x945e18769d7ee727c7013f92de24d117967ff317\": \"0x6c6b935b8bbd400000\",\n \"0x94612781033b57b146ee74e753c672017f5385e4\": \"0xc328093e61ee400000\",\n \"0x94644ad116a41ce2ca7fbec609bdef738a2ac7c7\": \"0x10f0cf064dd59200000\",\n \"0x9470cc36594586821821c5c996b6edc83b6d5a32\": \"0x14d1120d7b1600000\",\n \"0x9475c510ec9a26979247744c3d8c3b0e0b5f44d3\": \"0x21e19e0c9bab2400000\",\n \"0x947e11e5ea290d6fc3b38048979e0cd44ec7c17f\": \"0x6c6b935b8bbd400000\",\n \"0x9483d98f14a33fdc118d403955c29935edfc5f70\": \"0x18ea3b34ef51880000\",\n \"0x949131f28943925cfc97d41e0cea0b262973a730\": \"0x97c9ce4cf6d5c00000\",\n \"0x949f84f0b1d7c4a7cf49ee7f8b2c4a134de32878\": \"0x252248deb6e6940000\",\n \"0x949f8c107bc7f0aceaa0f17052aadbd2f9732b2e\": \"0x6c6b935b8bbd400000\",\n \"0x94a7cda8f481f9d89d42c303ae1632b3b709db1d\": \"0x1043561a8829300000\",\n \"0x94a9a71691317c2064271b51c9353fbded3501a8\": \"0xb50fcfafebecb00000\",\n \"0x94ad4bad824bd0eb9ea49c58cebcc0ff5e08346b\": \"0x692ae8897081d00000\",\n \"0x94bbc67d13f89ebca594be94bc5170920c30d9f3\": \"0x458ffa3150a540000\",\n \"0x94be3ae54f62d663b0d4cc9e1ea8fe9556ea9ebf\": \"0x143132ca843180000\",\n \"0x94c055e858357aaa30cf2041fa9059ce164a1f91\": \"0x43c25e0dcc1bd1c0000\",\n \"0x94c742fd7a8b7906b3bfe4f8904fc0be5c768033\": \"0x43c33c1937564800000\",\n \"0x94ca56de777fd453177f5e0694c478e66aff8a84\": \"0x1b1ae4d6e2ef500000\",\n \"0x94d81074db5ae197d2bb1373ab80a87d121c4bd3\": \"0x1fd933494aa5fe00000\",\n \"0x94db807873860aac3d5aea1e885e52bff2869954\": \"0xae8e7a0bb575d00000\",\n \"0x94e1f5cb9b8abace03a1a6428256553b690c2355\": \"0x1158e460913d00000\",\n \"0x94ef8be45077c7d4c5652740de946a62624f713f\": \"0x56cf5593a18f88000\",\n \"0x94f13f9f0836a3ee2437a84922d2984dc0f7d53b\": \"0xa2a0329bc38abe0000\",\n \"0x94f8f057db7e60e675ad940f155885d1a477348e\": \"0x15be6174e1912e0000\",\n \"0x94fcceadfe5c109c5eaeaf462d43873142c88e22\": \"0x1043561a88293000000\",\n \"0x95034e1621865137cd4739b346dc17da3a27c34e\": \"0x55a6e79ccd1d300000\",\n \"0x950c68a40988154d2393fff8da7ccda99614f72c\": \"0xf94146fd8dcde58000\",\n \"0x950fe9c6cad50c18f11a9ed9c45740a6180612d0\": \"0x1b1ae4d6e2ef5000000\",\n \"0x952183cfd38e352e579d36decec5b18450f7fba0\": \"0x6c6b935b8bbd400000\",\n \"0x95278b08dee7c0f2c8c0f722f9fcbbb9a5241fda\": \"0x829309f64f0db00000\",\n \"0x952c57d2fb195107d4cd5ca300774119dfad2f78\": \"0x6c6b935b8bbd400000\",\n \"0x953572f0ea6df9b197cae40e4b8ecc056c4371c5\": \"0x3635c9adc5dea00000\",\n \"0x953ef652e7b769f53d6e786a58952fa93ee6abe7\": \"0x9b0a791f1211300000\",\n \"0x95447046313b2f3a5e19b948fd3b8bedc82c717c\": \"0x1b1ae4d6e2ef500000\",\n \"0x955db3b74360b9a268677e73cea821668af6face\": \"0x65a4da25d3016c00000\",\n \"0x9560e8ac6718a6a1cdcff189d603c9063e413da6\": \"0xd8d726b7177a800000\",\n \"0x9567a0de811de6ff095b7ee64e7f1b83c2615b80\": \"0xe7eeba3410b740000\",\n \"0x95681cdae69b2049ce101e325c759892cac3f811\": \"0x9ae92a9bc94c400000\",\n \"0x9568b7de755628af359a84543de23504e15e41e6\": \"0x878678326eac9000000\",\n \"0x9569c63a9284a805626db3a32e9d236393476151\": \"0x6acb3df27e1f880000\",\n \"0x95809e8da3fbe4b7f281f0b8b1715f420f7d7d63\": \"0x6c6b935b8bbd400000\",\n \"0x959f57fded6ae37913d900b81e5f48a79322c627\": \"0xddb26104749118000\",\n \"0x959ff17f1d51b473b44010052755a7fa8c75bd54\": \"0x6acb3df27e1f880000\",\n \"0x95a577dc2eb3ae6cb9dfc77af697d7efdfe89a01\": \"0x75f610f70ed200000\",\n \"0x95cb6d8a6379f94aba8b885669562c4d448e56a7\": \"0x6c6b935b8bbd400000\",\n \"0x95d550427b5a514c751d73a0f6d29fb65d22ed10\": \"0x1043561a8829300000\",\n \"0x95d98d0c1069908f067a52acac2b8b534da37afd\": \"0x6f59b630a929708000\",\n \"0x95df4e3445d7662624c48eba74cf9e0a53e9f732\": \"0xbdbc41e0348b3000000\",\n \"0x95e6a54b2d5f67a24a4875af75107ca7ea9fd2fa\": \"0x487a9a304539440000\",\n \"0x95e6f93dac228bc7585a25735ac2d076cc3a4017\": \"0x14542ba12a337c00000\",\n \"0x95e7616424cd0961a71727247437f0069272280e\": \"0x15af1d78b58c400000\",\n \"0x95e80a82c20cbe3d2060242cb92d735810d034a2\": \"0x1c32e463fd4b98000\",\n \"0x95f62d0243ede61dad9a3165f53905270d54e242\": \"0x57473d05dabae80000\",\n \"0x95fb5afb14c1ef9ab7d179c5c300503fd66a5ee2\": \"0x1daf7a02b0dbe8000\",\n \"0x9610592202c282ab9bd8a884518b3e0bd4758137\": \"0xe873f44133cb00000\",\n \"0x961c59adc74505d1864d1ecfcb8afa0412593c93\": \"0x878678326eac9000000\",\n \"0x962c0dec8a3d464bf39b1215eafd26480ae490cd\": \"0x6c82e3eaa513e80000\",\n \"0x962cd22a8edf1e4f4e55b4b15ddbfb5d9d541971\": \"0x6c6b935b8bbd400000\",\n \"0x96334bfe04fffa590213eab36514f338b864b736\": \"0x15af1d78b58c400000\",\n \"0x9637dc12723d9c78588542eab082664f3f038d9d\": \"0x3635c9adc5dea00000\",\n \"0x964eab4b276b4cd8983e15ca72b106900fe41fce\": \"0x1b1ae4d6e2ef500000\",\n \"0x9662ee021926682b31c5f200ce457abea76c6ce9\": \"0x24590e8589eb6a0000\",\n \"0x966c04781cb5e67dde3235d7f8620e1ab663a9a5\": \"0x100d2050da6351600000\",\n \"0x967076a877b18ec15a415bb116f06ef32645dba3\": \"0x6c6b935b8bbd400000\",\n \"0x967bfaf76243cdb9403c67d2ceefdee90a3feb73\": \"0x349d87f2a2dc2f0000\",\n \"0x967d4142af770515dd7062af93498dbfdff29f20\": \"0x11854d0f9cee40000\",\n \"0x968b14648f018333687cd213fa640aec04ce6323\": \"0x3635c9adc5dea00000\",\n \"0x968dea60df3e09ae3c8d3505e9c080454be0e819\": \"0x14542ba12a337c00000\",\n \"0x96924191b7df655b3319dc6d6137f481a73a0ff3\": \"0xd9ecb4fd208e500000\",\n \"0x9696052138338c722f1140815cf7749d0d3b3a74\": \"0x1b1ae4d6e2ef500000\",\n \"0x96a55f00dff405dc4de5e58c57f6f6f0cac55d2f\": \"0x6a6616379c87b58000\",\n \"0x96aa573fed2f233410dbae5180145b23c31a02f0\": \"0x5dc892aa1131c80000\",\n \"0x96ad579bbfa8db8ebec9d286a72e4661eed8e356\": \"0x3a0ba42bec61830000\",\n \"0x96b434fe0657e42acc8212b6865139dede15979c\": \"0xd8d726b7177a800000\",\n \"0x96b906ea729f4655afe3e57d35277c967dfa1577\": \"0x3635c9adc5dea00000\",\n \"0x96d62dfd46087f62409d93dd606188e70e381257\": \"0x6c6b935b8bbd400000\",\n \"0x96d9cca8f55eea0040ec6eb348a1774b95d93ef4\": \"0xd8d726b7177a800000\",\n \"0x96e7c0c9d5bf10821bf140c558a145b7cac21397\": \"0x393ef1a5127c800000\",\n \"0x96ea6ac89a2bac95347b51dba63d8bd5ebdedce1\": \"0x6c6b935b8bbd400000\",\n \"0x96eafbf2fb6f4db9a436a74c45b5654452e23819\": \"0x1158e460913d00000\",\n \"0x96eb523e832f500a017de13ec27f5d366c560eff\": \"0x10acceba43ee280000\",\n \"0x96f0462ae6f8b96088f7e9c68c74b9d8ad34b347\": \"0x61093d7c2c6d380000\",\n \"0x96f820500b70f4a3e3239d619cff8f222075b135\": \"0xad78ebc5ac6200000\",\n \"0x96fe59c3dbb3aa7cc8cb62480c65e56e6204a7e2\": \"0x43c33c1937564800000\",\n \"0x96ff6f509968f36cb42cba48db32f21f5676abf8\": \"0x6acb3df27e1f880000\",\n \"0x970938522afb5e8f994873c9fbdc26e3b37e314c\": \"0x3635c9adc5dea00000\",\n \"0x970abd53a54fca4a6429207c182d4d57bb39d4a0\": \"0x6c6b935b8bbd400000\",\n \"0x970d8b8a0016d143054f149fb3b8e550dc0797c7\": \"0x3635c9adc5dea00000\",\n \"0x972c2f96aa00cf8a2f205abcf8937c0c75f5d8d9\": \"0xad78ebc5ac6200000\",\n \"0x973f4e361fe5decd989d4c8f7d7cc97990385daf\": \"0x150f8543a387420000\",\n \"0x974d0541ab4a47ec7f75369c0069b64a1b817710\": \"0x15af1d78b58c400000\",\n \"0x974d2f17895f2902049deaaecf09c3046507402d\": \"0xcc19c29437ab8000\",\n \"0x9752d14f5e1093f071711c1adbc4e3eb1e5c57f3\": \"0x6c6b935b8bbd400000\",\n \"0x9756e176c9ef693ee1eec6b9f8b151d313beb099\": \"0x410d586a20a4c00000\",\n \"0x975f3764e97bbccf767cbd3b795ba86d8ba9840e\": \"0x12c1b6eed03d280000\",\n \"0x976a18536af41874426308871bcd1512a775c9f8\": \"0x21e19e0c9bab2400000\",\n \"0x976e3ceaf3f1af51f8c29aff5d7fa21f0386d8ee\": \"0xd02ab486cedc00000\",\n \"0x9777cc61cf756be3b3c20cd4491c69d275e7a120\": \"0x21e19e0c9bab2400000\",\n \"0x97810bafc37e84306332aacb35e92ad911d23d24\": \"0x3635c9adc5dea00000\",\n \"0x978c430ce4359b06bc2cdf5c2985fc950e50d5c8\": \"0x1a055690d9db800000\",\n \"0x9795f64319fc17dd0f8261f9d206fb66b64cd0c9\": \"0xad78ebc5ac6200000\",\n \"0x9799ca21dbcf69bfa1b3f72bac51b9e3ca587cf9\": \"0x5c283d410394100000\",\n \"0x979cbf21dfec8ace3f1c196d82df962534df394f\": \"0x9991d478dd4d160000\",\n \"0x979d681c617da16f21bcaca101ed16ed015ab696\": \"0x65ea3db75546600000\",\n \"0x979f30158b574b999aab348107b9eed85b1ff8c1\": \"0x34957444b840e80000\",\n \"0x97a86f01ce3f7cfd4441330e1c9b19e1b10606ef\": \"0x6c6b935b8bbd400000\",\n \"0x97b91efe7350c2d57e7e406bab18f3617bcde14a\": \"0x21e1999bbd5d2be0000\",\n \"0x97d0d9725e3b70e675843173938ed371b62c7fac\": \"0x93739534d28680000\",\n \"0x97d9e46a7604d7b5a4ea4ee61a42b3d2350fc3ed\": \"0x6c6b935b8bbd400000\",\n \"0x97dc26ec670a31e0221d2a75bc5dc9f90c1f6fd4\": \"0x2b5e3af16b1880000\",\n \"0x97de21e421c37fe4b8025f9a51b7b390b5df7804\": \"0x10f0cf064dd592000000\",\n \"0x97e28973b860c567402800fbb63ce39a048a3d79\": \"0x542253a126ce40000\",\n \"0x97e5cc6127c4f885be02f44b42d1c8b0ac91e493\": \"0xad78ebc5ac6200000\",\n \"0x97f1fe4c8083e596212a187728dd5cf80a31bec5\": \"0x1158e460913d00000\",\n \"0x97f7760657c1e202759086963eb4211c5f8139b9\": \"0xa8a097fcb3d17680000\",\n \"0x97f99b6ba31346cd98a9fe4c308f87c5a58c5151\": \"0x14542ba12a337c00000\",\n \"0x980a84b686fc31bdc83c221058546a71b11f838a\": \"0x2a415548af86818000\",\n \"0x9810e34a94db6ed156d0389a0e2b80f4fd6b0a8a\": \"0x6c6b935b8bbd400000\",\n \"0x981ddf0404e4d22dda556a0726f00b2d98ab9569\": \"0x36356633ebd8ea0000\",\n \"0x981f712775c0dad97518ffedcb47b9ad1d6c2762\": \"0x16a6502f15a1e540000\",\n \"0x9834682180b982d166badb9d9d1d9bbf016d87ee\": \"0x6c6b935b8bbd400000\",\n \"0x9836b4d30473641ab56aeee19242761d72725178\": \"0x6c6b935b8bbd400000\",\n \"0x98397342ec5f3d4cb877e54ef5d6f1d366731bd4\": \"0x14061b9d77a5e980000\",\n \"0x9846648836a307a057184fd51f628a5f8c12427c\": \"0x40b69bf43dce8f00000\",\n \"0x984a7985e3cc7eb5c93691f6f8cc7b8f245d01b2\": \"0x14542ba12a337c00000\",\n \"0x985d70d207892bed398590024e2421b1cc119359\": \"0x43c33c1937564800000\",\n \"0x986df47e76e4d7a789cdee913cc9831650936c9d\": \"0x10f0cf064dd59200000\",\n \"0x9874803fe1f3a0365e7922b14270eaeb032cc1b5\": \"0x3cf5928824c6c20000\",\n \"0x9875623495a46cdbf259530ff838a1799ec38991\": \"0x6c6b935b8bbd400000\",\n \"0x987618c85656207c7bac1507c0ffefa2fb64b092\": \"0x37dfe433189e38000\",\n \"0x987c9bcd6e3f3990a52be3eda4710c27518f4f72\": \"0x15af1d78b58c400000\",\n \"0x9882967cee68d2a839fad8ab4a7c3dddf6c0adc8\": \"0x4878be1ffaf95d0000\",\n \"0x98855c7dfbee335344904a12c40c731795b13a54\": \"0x39fbae8d042dd00000\",\n \"0x989c0ccff654da03aeb11af701054561d6297e1d\": \"0xd8d726b7177a800000\",\n \"0x98a0e54c6d9dc8be96276cebf4fec460f6235d85\": \"0x6ac882100952c78000\",\n \"0x98b769cc305cecfb629a00c907069d7ef9bc3a12\": \"0x168d28e3f00280000\",\n \"0x98ba4e9ca72fddc20c69b4396f76f8183f7a2a4e\": \"0x2b5e3af16b188000000\",\n \"0x98be696d51e390ff1c501b8a0f6331b628ddc5ad\": \"0x6c6b935b8bbd400000\",\n \"0x98bed3a72eccfbafb923489293e429e703c7e25b\": \"0x6c6b935b8bbd400000\",\n \"0x98bf4af3810b842387db70c14d46099626003d10\": \"0xd8d726b7177a800000\",\n \"0x98c10ebf2c4f97cba5a1ab3f2aafe1cac423f8cb\": \"0x1043561a8829300000\",\n \"0x98c19dba810ba611e68f2f83ee16f6e7744f0c1f\": \"0xad78ebc5ac6200000\",\n \"0x98c5494a03ac91a768dffc0ea1dde0acbf889019\": \"0x2a5a058fc295ed000000\",\n \"0x98d204f9085f8c8e7de23e589b64c6eff692cc63\": \"0x6c6b935b8bbd400000\",\n \"0x98d3731992d1d40e1211c7f735f2189afa0702e0\": \"0x1b1ae4d6e2ef5000000\",\n \"0x98e2b6d606fd2d6991c9d6d4077fdf3fdd4585da\": \"0x30df1a6f8ad6280000\",\n \"0x98e3e90b28fccaee828779b8d40a5568c4116e21\": \"0x22b1c8c1227a00000\",\n \"0x98e6f547db88e75f1f9c8ac2c5cf1627ba580b3e\": \"0x3635c9adc5dea00000\",\n \"0x98f4af3af0aede5fafdc42a081ecc1f89e3ccf20\": \"0x1fd933494aa5fe00000\",\n \"0x98f6b8e6213dbc9a5581f4cce6655f95252bdb07\": \"0x115872b0bca4300000\",\n \"0x9909650dd5b1397b8b8b0eb69499b291b0ad1213\": \"0xad78ebc5ac6200000\",\n \"0x991173601947c2084a62d639527e961512579af9\": \"0x2086ac351052600000\",\n \"0x99129d5b3c0cde47ea0def4dfc070d1f4a599527\": \"0x6c6b935b8bbd400000\",\n \"0x9917d68d4af341d651e7f0075c6de6d7144e7409\": \"0x132d4476c08e6f00000\",\n \"0x991ac7ca7097115f26205eee0ef7d41eb4e311ae\": \"0x1158e460913d00000\",\n \"0x992365d764c5ce354039ddfc912e023a75b8e168\": \"0xfc936392801c0000\",\n \"0x992646ac1acaabf5ddaba8f9429aa6a94e7496a7\": \"0x3637507a30abeb0000\",\n \"0x99268327c373332e06c3f6164287d455b9d5fa4b\": \"0x6c6b935b8bbd400000\",\n \"0x9928ff715afc3a2b60f8eb4cc4ba4ee8dab6e59d\": \"0x17da3a04c7b3e00000\",\n \"0x9932ef1c85b75a9b2a80057d508734c51085becc\": \"0x2b83fa5301d590000\",\n \"0x993f146178605e66d517be782ef0b3c61a4e1925\": \"0x17c1f0535d7a5830000\",\n \"0x99413704b1a32e70f3bc0d69dd881c38566b54cb\": \"0x5cc6b694631f7120000\",\n \"0x994152fc95d5c1ca8b88113abbad4d710e40def6\": \"0x1b1ae4d6e2ef500000\",\n \"0x9944fee9d34a4a880023c78932c00b59d5c82a82\": \"0x28a8a56b3690070000\",\n \"0x994cc2b5227ec3cf048512467c41b7b7b748909f\": \"0x6c6b935b8bbd400000\",\n \"0x9971df60f0ae66dce9e8c84e17149f09f9c52f64\": \"0xad78ebc5ac6200000\",\n \"0x9976947eff5f6ae5da08dd541192f378b428ff94\": \"0x1b1ae4d6e2ef5000000\",\n \"0x997d6592a31589acc31b9901fbeb3cc3d65b3215\": \"0x6c6b935b8bbd400000\",\n \"0x9982a5890ffb5406d3aca8d2bfc1dd70aaa80ae0\": \"0x6c6b935b8bbd400000\",\n \"0x99878f9d6e0a7ed9aec78297b73879a80195afe0\": \"0xd7c198710e66b00000\",\n \"0x998c1f93bcdb6ff23c10d0dc924728b73be2ff9f\": \"0x365bf3a433eaf30000\",\n \"0x9991614c5baa47dd6c96874645f97add2c3d8380\": \"0x6acb3df27e1f880000\",\n \"0x99924a9816bb7ddf3fec1844828e9ad7d06bf4e6\": \"0x5f68e8131ecf800000\",\n \"0x99997668f7c1a4ff9e31f9977ae3224bcb887a85\": \"0xfc936392801c00000\",\n \"0x999c49c174ca13bc836c1e0a92bff48b271543ca\": \"0xb1cf24ddd0b1400000\",\n \"0x99a4de19ded79008cfdcd45d014d2e584b8914a8\": \"0x5150ae84a8cdf00000\",\n \"0x99a96bf2242ea1b39ece6fcc0d18aed00c0179f3\": \"0x1043561a8829300000\",\n \"0x99b018932bcad355b6792b255db6702dec8ce5dd\": \"0xd8d8583fa2d52f0000\",\n \"0x99b743d1d9eff90d9a1934b4db21d519d89b4a38\": \"0x56bc75e2d63100000\",\n \"0x99b8c824869de9ed24f3bff6854cb6dd45cc3f9f\": \"0x65ea3db75546600000\",\n \"0x99c0174cf84e0783c220b4eb6ae18fe703854ad3\": \"0x7079a2573d0c780000\",\n \"0x99c1d9f40c6ab7f8a92fce2fdce47a54a586c53f\": \"0x35659ef93f0fc40000\",\n \"0x99c236141daec837ece04fdaee1d90cf8bbdc104\": \"0x766516acac0d200000\",\n \"0x99c31fe748583787cdd3e525b281b218961739e3\": \"0x3708baed3d68900000\",\n \"0x99c475bf02e8b9214ada5fad02fdfd15ba365c0c\": \"0x2009c5c8bf6fdc0000\",\n \"0x99c883258546cc7e4e971f522e389918da5ea63a\": \"0xd8d726b7177a800000\",\n \"0x99c9f93e45fe3c1418c353e4c5ac3894eef8121e\": \"0x585baf145050b0000\",\n \"0x99d1579cd42682b7644e1d4f7128441eeffe339d\": \"0x43c33c1937564800000\",\n \"0x99d1b585965f406a42a49a1ca70f769e765a3f98\": \"0x3894f0e6f9b9f700000\",\n \"0x99dfd0504c06c743e46534fd7b55f1f9c7ec3329\": \"0x6c6b935b8bbd400000\",\n \"0x99f4147ccc6bcb80cc842e69f6d00e30fa4133d9\": \"0x15af1d78b58c400000\",\n \"0x99f77f998b20e0bcdcd9fc838641526cf25918ef\": \"0x61093d7c2c6d380000\",\n \"0x99fad50038d0d9d4c3fbb4bce05606ecadcd5121\": \"0x6c6b935b8bbd400000\",\n \"0x99fe0d201228a753145655d428eb9fd94985d36d\": \"0x6920bff3515a3a0000\",\n \"0x9a079c92a629ca15c8cafa2eb28d5bc17af82811\": \"0x1b1ae4d6e2ef500000\",\n \"0x9a0d3cee3d9892ea3b3700a27ff84140d9025493\": \"0x340aad21b3b700000\",\n \"0x9a24ce8d485cc4c86e49deb39022f92c7430e67e\": \"0x46791fc84e07d00000\",\n \"0x9a2ce43b5d89d6936b8e8c354791b8afff962425\": \"0x6c6b935b8bbd400000\",\n \"0x9a390162535e398877e416787d6239e0754e937c\": \"0x3635c9adc5dea00000\",\n \"0x9a3da65023a13020d22145cfc18bab10bd19ce4e\": \"0x18bf6ea3464a3a0000\",\n \"0x9a3e2b1bf346dd070b027357feac44a4b2c97db8\": \"0x21e19e0c9bab2400000\",\n \"0x9a4ca8b82117894e43db72b9fa78f0b9b93ace09\": \"0x2b5e3af16b1880000\",\n \"0x9a522e52c195bfb7cf5ffaaedb91a3ba7468161d\": \"0x3635c9adc5dea00000\",\n \"0x9a5af31c7e06339ac8b4628d7c4db0ce0f45c8a4\": \"0x1b1ae4d6e2ef500000\",\n \"0x9a633fcd112cceeb765fe0418170732a9705e79c\": \"0xfc936392801c0000\",\n \"0x9a63d185a79129fdab19b58bb631ea36a420544e\": \"0x246ddf97976680000\",\n \"0x9a6708ddb8903c289f83fe889c1edcd61f854423\": \"0x3635c9adc5dea00000\",\n \"0x9a6ff5f6a7af7b7ae0ed9c20ecec5023d281b786\": \"0x8a12b9bd6a67ec0000\",\n \"0x9a82826d3c29481dcc2bd2950047e8b60486c338\": \"0x43c33c1937564800000\",\n \"0x9a8eca4189ff4aa8ff7ed4b6b7039f0902219b15\": \"0x1158e460913d00000\",\n \"0x9a953b5bcc709379fcb559d7b916afdaa50cadcc\": \"0x56bc75e2d63100000\",\n \"0x9a990b8aeb588d7ee7ec2ed8c2e64f7382a9fee2\": \"0x1d127db69fd8b0000\",\n \"0x9a9d1dc0baa77d6e20c3d849c78862dd1c054c87\": \"0x2fb474098f67c00000\",\n \"0x9aa48c66e4fb4ad099934e32022e827427f277ba\": \"0x21e19e0c9bab2400000\",\n \"0x9aa8308f42910e5ade09c1a5e282d6d91710bdbf\": \"0xad78ebc5ac6200000\",\n \"0x9aaafa0067647ed999066b7a4ca5b4b3f3feaa6f\": \"0x3635c9adc5dea00000\",\n \"0x9ab988b505cfee1dbe9cd18e9b5473b9a2d4f536\": \"0x1158e460913d000000\",\n \"0x9ab98d6dbb1eaae16d45a04568541ad3d8fe06cc\": \"0xec50464fe23f38000\",\n \"0x9aba2b5e27ff78baaab5cdc988b7be855cebbdce\": \"0x21e0c0013070adc0000\",\n \"0x9ac4da51d27822d1e208c96ea64a1e5b55299723\": \"0x56c5579f722140000\",\n \"0x9ac85397792a69d78f286b86432a07aeceb60e64\": \"0xc673ce3c40160000\",\n \"0x9ac907ee85e6f3e223459992e256a43fa08fa8b2\": \"0x21e19e0c9bab2400000\",\n \"0x9ad47fdcf9cd942d28effd5b84115b31a658a13e\": \"0xb259ec00d53b280000\",\n \"0x9adbd3bc7b0afc05d1d2eda49ff863939c48db46\": \"0xad6eedd17cf3b8000\",\n \"0x9adf458bff3599eee1a26398853c575bc38c6313\": \"0xf2dc7d47f15600000\",\n \"0x9ae13bd882f2576575921a94974cbea861ba0d35\": \"0xab4dcf399a3a600000\",\n \"0x9ae9476bfecd3591964dd325cf8c2a24faed82c1\": \"0xd8d726b7177a800000\",\n \"0x9af100cc3dae83a33402051ce4496b16615483f6\": \"0x6c6b935b8bbd400000\",\n \"0x9af11399511c213181bfda3a8b264c05fc81b3ce\": \"0x2f6f10780d22cc00000\",\n \"0x9af5c9894c33e42c2c518e3ac670ea9505d1b53e\": \"0xfc936392801c0000\",\n \"0x9af9dbe47422d177f945bdead7e6d82930356230\": \"0xd5967be4fc3f100000\",\n \"0x9afa536b4c66bc38d875c4b30099d9261fdb38eb\": \"0xb2a8f842a77bc8000\",\n \"0x9b06ad841dffbe4ccf46f1039fc386f3c321446e\": \"0x6c6b935b8bbd400000\",\n \"0x9b1168de8ab64b47552f3389800a9cc08b4666cf\": \"0x5dc892aa1131c80000\",\n \"0x9b1811c3051f46e664ae4bc9c824d18592c4574a\": \"0xad6eedd17cf3b8000\",\n \"0x9b18478655a4851cc906e660feac61f7f4c8bffc\": \"0xe2478d38907d840000\",\n \"0x9b22a80d5c7b3374a05b446081f97d0a34079e7f\": \"0xa2a15d09519be00000\",\n \"0x9b2be7f56754f505e3441a10f7f0e20fd3ddf849\": \"0x126e72a69a50d00000\",\n \"0x9b32cf4f5115f4b34a00a64c617de06387354323\": \"0x5b81ed888207c8000\",\n \"0x9b43dcb95fde318075a567f1e6b57617055ef9e8\": \"0xd5967be4fc3f100000\",\n \"0x9b444fd337e5d75293adcfff70e1ea01db023222\": \"0x56bc75e2d63100000\",\n \"0x9b4824ff9fb2abda554dee4fb8cf549165570631\": \"0x1158e460913d00000\",\n \"0x9b4c2715780ca4e99e60ebf219f1590c8cad500a\": \"0x56bc75e2d631000000\",\n \"0x9b59eb213b1e7565e45047e04ea0374f10762d16\": \"0x6c6b935b8bbd400000\",\n \"0x9b5c39f7e0ac168c8ed0ed340477117d1b682ee9\": \"0x55005f0c614480000\",\n \"0x9b5ec18e8313887df461d2902e81e67a8f113bb1\": \"0x56bc75e2d63100000\",\n \"0x9b64d3cd8d2b73f66841b5c46bb695b88a9ab75d\": \"0x1203a4f760c168000\",\n \"0x9b658fb361e046d4fcaa8aef6d02a99111223625\": \"0x6c6b935b8bbd400000\",\n \"0x9b6641b13e172fc072ca4b8327a3bc28a15b66a9\": \"0x68155a43676e00000\",\n \"0x9b68f67416a63bf4451a31164c92f672a68759e9\": \"0xcb49b44ba602d800000\",\n \"0x9b773669e87d76018c090f8255e54409b9dca8b2\": \"0x1158e460913d00000\",\n \"0x9b77ebced7e215f0920e8c2b870024f6ecb2ff31\": \"0x3635c9adc5dea00000\",\n \"0x9b7c8810cc7cc89e804e6d3e38121850472877fe\": \"0x6c6b935b8bbd400000\",\n \"0x9ba53dc8c95e9a472feba2c4e32c1dc4dd7bab46\": \"0x487a9a304539440000\",\n \"0x9bacd3d40f3b82ac91a264d9d88d908eac8664b9\": \"0x43c33c1937564800000\",\n \"0x9bb760d5c289a3e1db18db095345ca413b9a43c2\": \"0xaadec983fcff40000\",\n \"0x9bb76204186af2f63be79168601687fc9bad661f\": \"0x1043561a8829300000\",\n \"0x9bb9b02a26bfe1ccc3f0c6219e261c397fc5ca78\": \"0x487a9a304539440000\",\n \"0x9bc573bcda23b8b26f9073d90c230e8e71e0270b\": \"0x362f75a4305d0c0000\",\n \"0x9bd7c38a4210304a4d653edeff1b3ce45fce7843\": \"0xf498941e664280000\",\n \"0x9bd88068e13075f3a8cac464a5f949d6d818c0f6\": \"0x14542ba12a337c00000\",\n \"0x9bd905f1719fc7acd0159d4dc1f8db2f21472338\": \"0x3635c9adc5dea00000\",\n \"0x9bdbdc9b973431d13c89a3f9757e9b3b6275bfc7\": \"0x1b1a7dcf8a44d38000\",\n \"0x9be3c329b62a28b8b0886cbd8b99f8bc930ce3e6\": \"0x409e52b48369a0000\",\n \"0x9bf58efbea0784eb068adecfa0bb215084c73a35\": \"0x13a6b2b564871a00000\",\n \"0x9bf672d979b36652fc5282547a6a6bc212ae4368\": \"0x238fd42c5cf0400000\",\n \"0x9bf703b41c3624e15f4054962390bcba3052f0fd\": \"0x1483e01533c2e3c0000\",\n \"0x9bf71f7fb537ac54f4e514947fa7ff6728f16d2f\": \"0x1cf84a30a0a0c0000\",\n \"0x9bf9b3b2f23cf461eb591f28340bc719931c8364\": \"0x3635c9adc5dea00000\",\n \"0x9bfc659c9c601ea42a6b21b8f17084ec87d70212\": \"0x21e19e0c9bab2400000\",\n \"0x9bfff50db36a785555f07652a153b0c42b1b8b76\": \"0x6c6b935b8bbd400000\",\n \"0x9c05e9d0f0758e795303717e31da213ca157e686\": \"0x3635c9adc5dea00000\",\n \"0x9c1b771f09af882af0643083de2aa79dc097c40e\": \"0x8670e9ec6598c00000\",\n \"0x9c28a2c4086091cb5da226a657ce3248e8ea7b6f\": \"0xf2dc7d47f15600000\",\n \"0x9c2fd54089af665df5971d73b804616039647375\": \"0x3635c9adc5dea00000\",\n \"0x9c344098ba615a398f11d009905b177c44a7b602\": \"0x3635c9adc5dea00000\",\n \"0x9c3d0692ceeef80aa4965ceed262ffc7f069f2dc\": \"0xad78ebc5ac6200000\",\n \"0x9c405cf697956138065e11c5f7559e67245bd1a5\": \"0xad78ebc5ac6200000\",\n \"0x9c45202a25f6ad0011f115a5a72204f2f2198866\": \"0x10fcf3a62b080980000\",\n \"0x9c49deff47085fc09704caa2dca8c287a9a137da\": \"0x1b1ae4d6e2ef5000000\",\n \"0x9c4bbcd5f1644a6f075824ddfe85c571d6abf69c\": \"0x6194049f30f7200000\",\n \"0x9c526a140683edf1431cfaa128a935e2b614d88b\": \"0x6046f37e5945c0000\",\n \"0x9c54e4ed479a856829c6bb42da9f0b692a75f728\": \"0x197a8f6dd5519800000\",\n \"0x9c581a60b61028d934167929b22d70b313c34fd0\": \"0xa968163f0a57b400000\",\n \"0x9c5cc111092c122116f1a85f4ee31408741a7d2f\": \"0x1ab2cf7c9f87e20000\",\n \"0x9c6bc9a46b03ae5404f043dfcf21883e4110cc33\": \"0xad78ebc5ac6200000\",\n \"0x9c78963fbc263c09bd72e4f8def74a9475f7055c\": \"0x2eb8eb1a172dcb80000\",\n \"0x9c78fbb4df769ce2c156920cfedfda033a0e254a\": \"0x6acb3df27e1f880000\",\n \"0x9c7b6dc5190fe2912963fcd579683ec7395116b0\": \"0x2a1129d09367200000\",\n \"0x9c80bc18e9f8d4968b185da8c79fa6e11ffc3e23\": \"0xd02ab486cedc00000\",\n \"0x9c98fdf1fdcd8ba8f4c5b04c3ae8587efdf0f6e6\": \"0x14542ba12a337c00000\",\n \"0x9c99a1da91d5920bc14e0cb914fdf62b94cb8358\": \"0x43c33c1937564800000\",\n \"0x9c99b62606281b5cefabf36156c8fe62839ef5f3\": \"0xd8d726b7177a800000\",\n \"0x9c9a07a8e57c3172a919ef64789474490f0d9f51\": \"0x21e19e0c9bab2400000\",\n \"0x9c9de44724a4054da0eaa605abcc802668778bea\": \"0xad7d5ca3fa5a20000\",\n \"0x9c9f3b8a811b21f3ff3fe20fe970051ce66a824f\": \"0x3ec2debc07d4be0000\",\n \"0x9c9f89a3910f6a2ae8a91047a17ab788bddec170\": \"0x21e19e0c9bab2400000\",\n \"0x9ca0429f874f8dcee2e9c062a9020a842a587ab9\": \"0x6c6b935b8bbd400000\",\n \"0x9ca42ee7a0b898f6a5cc60b5a5d7b1bfa3c33231\": \"0x6c6b935b8bbd400000\",\n \"0x9cb28ac1a20a106f7f373692c5ce4c73f13732a1\": \"0x3635c9adc5dea00000\",\n \"0x9ccddcb2cfc2b25b08729a0a98d9e6f0202ea2c1\": \"0x56bc75e2d63100000\",\n \"0x9ce27f245e02d1c312c1d500788c9def7690453b\": \"0xad78ebc5ac6200000\",\n \"0x9ce5363b13e8238aa4dd15acd0b2e8afe0873247\": \"0xad78ebc5ac6200000\",\n \"0x9cf2928beef09a40f9bfc953be06a251116182fb\": \"0x14542ba12a337c00000\",\n \"0x9d069197d1de50045a186f5ec744ac40e8af91c6\": \"0x6c6b935b8bbd400000\",\n \"0x9d0e7d92fb305853d798263bf15e97c72bf9d7e0\": \"0x3635c9adc5dea00000\",\n \"0x9d0f347e826b7dceaad279060a35c0061ecf334b\": \"0xd8d726b7177a800000\",\n \"0x9d207517422cc0d60de7c237097a4d4fce20940c\": \"0x1b1ae4d6e2ef500000\",\n \"0x9d250ae4f110d71cafc7b0adb52e8d9acb6679b8\": \"0x2156d6e997213c00000\",\n \"0x9d2bfc36106f038250c01801685785b16c86c60d\": \"0x5077d75df1b675800000\",\n \"0x9d30cb237bc096f17036fc80dd21ca68992ca2d9\": \"0x66ee7318fdc8f300000\",\n \"0x9d32962ea99700d93228e9dbdad2cc37bb99f07e\": \"0xb4632bedd4ded40000\",\n \"0x9d34dac25bd15828faefaaf28f710753b39e89dc\": \"0x3b1c56fed02df00000\",\n \"0x9d369165fb70b81a3a765f188fd60cbe5e7b0968\": \"0x6c6b935b8bbd400000\",\n \"0x9d40e012f60425a340d82d03a1c757bfabc706fb\": \"0x9346f3addc88d8000\",\n \"0x9d4174aa6af28476e229dadb46180808c67505c1\": \"0x421afda42ed6970000\",\n \"0x9d4213339a01551861764c87a93ce8f85f87959a\": \"0xad78ebc5ac6200000\",\n \"0x9d460c1b379ddb19a8c85b4c6747050ddf17a875\": \"0xb50fcfafebecb00000\",\n \"0x9d47ba5b4c8505ad8da42934280b61a0e1e8b971\": \"0x56bc75e2d63100000\",\n \"0x9d4d321177256ebd9afbda304135d517c3dc5693\": \"0x2164b7a04ac8a00000\",\n \"0x9d4ff989b7bed9ab109d10c8c7e55f02d76734ad\": \"0x3635c9adc5dea00000\",\n \"0x9d511543b3d9dc60d47f09d49d01b6c498d82078\": \"0x26197b9516fc3940000\",\n \"0x9d6ecfa03af2c6e144b7c4692a86951e902e9e1f\": \"0xa2a5aa60ad243f0000\",\n \"0x9d7655e9f3e5ba5d6e87e412aebe9ee0d49247ee\": \"0x8e09311c1d80fa0000\",\n \"0x9d7831e834c20b1baa697af1d8e0c621c5afff9a\": \"0x4b06dbbb40f4a0000\",\n \"0x9d78a975b7db5e4d8e28845cfbe7e31401be0dd9\": \"0x48a43c54602f700000\",\n \"0x9d799e943e306ba2e5b99c8a6858cbb52c0cf735\": \"0x1043561a8829300000\",\n \"0x9d7fda7070bf3ee9bbd9a41f55cad4854ae6c22c\": \"0x255cba3c46fcf120000\",\n \"0x9d81aea69aed6ad07089d61445348c17f34bfc5b\": \"0x1043561a8829300000\",\n \"0x9d911f3682f32fe0792e9fb6ff3cfc47f589fca5\": \"0xd8d726b7177a800000\",\n \"0x9d913b5d339c95d87745562563fea98b23c60cc4\": \"0x941302c7f4d230000\",\n \"0x9d93fab6e22845f8f45a07496f11de71530debc7\": \"0x6c4fd1ee246e780000\",\n \"0x9d99b189bbd9a48fc2e16e8fcda33bb99a317bbb\": \"0x3d16e10b6d8bb20000\",\n \"0x9d9c4efe9f433989e23be94049215329fa55b4cb\": \"0xde3b28903c6b58000\",\n \"0x9d9e57fde30e5068c03e49848edce343b7028358\": \"0x5dc892aa1131c80000\",\n \"0x9da3302240af0511c6fd1857e6ddb7394f77ab6b\": \"0xa80d24677efef00000\",\n \"0x9da4ec407077f4b9707b2d9d2ede5ea5282bf1df\": \"0xd8d726b7177a800000\",\n \"0x9da609fa3a7e6cf2cc0e70cdabe78dc4e382e11e\": \"0x410d586a20a4c00000\",\n \"0x9da61ccd62bf860656e0325d7157e2f160d93bb5\": \"0x10f0ca956f8799e0000\",\n \"0x9da6e075989c7419094cc9f6d2e49393bb199688\": \"0x259bb71d5adf3f00000\",\n \"0x9da8e22ca10e67fea44e525e4751eeac36a31194\": \"0xe18398e7601900000\",\n \"0x9db2e15ca681f4c66048f6f9b7941ed08b1ff506\": \"0xd8d726b7177a800000\",\n \"0x9dc10fa38f9fb06810e11f60173ec3d2fd6a751e\": \"0x6acb3df27e1f880000\",\n \"0x9dd2196624a1ddf14a9d375e5f07152baf22afa2\": \"0x41b05e2463a5438000\",\n \"0x9dd46b1c6d3f05e29e9c6f037eed9a595af4a9aa\": \"0x1b1ae4d6e2ef500000\",\n \"0x9ddd355e634ee9927e4b7f6c97e7bf3a2f1e687a\": \"0x2b5e3af16b1880000\",\n \"0x9de20ae76aa08263b205d5142461961e2408d266\": \"0xda933d8d8c6700000\",\n \"0x9de20bc37e7f48a80ffd7ad84ffbf1a1abe1738c\": \"0xad78ebc5ac6200000\",\n \"0x9de7386dde401ce4c67b71b6553f8aa34ea5a17d\": \"0x340aad21b3b700000\",\n \"0x9deb39027af877992b89f2ec4a1f822ecdf12693\": \"0x6c6b935b8bbd400000\",\n \"0x9defe56a0ff1a1947dba0923f7dd258d8f12fa45\": \"0x5b12aefafa804000000\",\n \"0x9df057cd03a4e27e8e032f857985fd7f01adc8d7\": \"0x6c6b935b8bbd400000\",\n \"0x9df32a501c0b781c0281022f42a1293ffd7b892a\": \"0x1e7e4171bf4d3a00000\",\n \"0x9e01765aff08bc220550aca5ea2e1ce8e5b09923\": \"0x3635c9adc5dea00000\",\n \"0x9e20e5fd361eabcf63891f5b87b09268b8eb3793\": \"0x56bc75e2d63100000\",\n \"0x9e232c08c14dc1a6ed0b8a3b2868977ba5c17d10\": \"0x1158e460913d00000\",\n \"0x9e23c5e4b782b00a5fadf1aead87dacf5b0367a1\": \"0x1158e460913d00000\",\n \"0x9e35399071a4a101e9194daa3f09f04a0b5f9870\": \"0xd8d726b7177a800000\",\n \"0x9e3eb509278fe0dcd8e0bbe78a194e06b6803943\": \"0x32f51edbaaa3300000\",\n \"0x9e427272516b3e67d4fcbf82f59390d04c8e28e5\": \"0xd8d726b7177a800000\",\n \"0x9e4cec353ac3e381835e3c0991f8faa5b7d0a8e6\": \"0x21e18b9e9ab45e48000\",\n \"0x9e5811b40be1e2a1e1d28c3b0774acde0a09603d\": \"0xa2a15d09519be00000\",\n \"0x9e5a311d9f69898a7c6a9d6360680438e67a7b2f\": \"0x50c5e761a444080000\",\n \"0x9e7c2050a227bbfd60937e268cea3e68fea8d1fe\": \"0x56bc75e2d63100000\",\n \"0x9e7f65a90e8508867bccc914256a1ea574cf07e3\": \"0x433874f632cc600000\",\n \"0x9e8144e08e89647811fe6b72d445d6a5f80ad244\": \"0x21e19e0c9bab2400000\",\n \"0x9e8f64ddcde9b8b451bafaa235a9bf511a25ac91\": \"0x90f534608a72880000\",\n \"0x9e951f6dc5e352afb8d04299d2478a451259bf56\": \"0x3e7419881a73a0000\",\n \"0x9e960dcd03d5ba99cb115d17ff4c09248ad4d0be\": \"0xad78ebc5ac6200000\",\n \"0x9eaf6a328a4076024efa6b67b48b21eedcc0f0b8\": \"0x890b0c2e14fb80000\",\n \"0x9eb1ff71798f28d6e989fa1ea0588e27ba86cb7d\": \"0x7a1fe160277000000\",\n \"0x9eb281c32719c40fdb3e216db0f37fbc73a026b7\": \"0x1158e460913d00000\",\n \"0x9eb3a7cb5e6726427a3a361cfa8d6164dbd0ba16\": \"0x2b95bdcc39b6100000\",\n \"0x9eb7834e171d41e069a77947fca87622f0ba4e48\": \"0x56bc75e2d63100000\",\n \"0x9ec03e02e587b7769def538413e97f7e55be71d8\": \"0x42bf06b78ed3b500000\",\n \"0x9ecbabb0b22782b3754429e1757aaba04b81189f\": \"0x2ca7bb061f5e998000\",\n \"0x9ece1400800936c7c6485fcdd3626017d09afbf6\": \"0x10ce1d3d8cb3180000\",\n \"0x9ed4e63f526542d44fddd34d59cd25388ffd6bda\": \"0xd29b34a46348940000\",\n \"0x9ed80eda7f55054db9fb5282451688f26bb374c1\": \"0x1043561a8829300000\",\n \"0x9edc90f4be210865214ab5b35e5a8dd77415279d\": \"0xd8d726b7177a800000\",\n \"0x9edeac4c026b93054dc5b1d6610c6f3960f2ad73\": \"0x410d586a20a4c00000\",\n \"0x9ee93f339e6726ec65eea44f8a4bfe10da3d3282\": \"0x6c6b935b8bbd400000\",\n \"0x9ee9760cc273d4706aa08375c3e46fa230aff3d5\": \"0x1e52e336cde22180000\",\n \"0x9eeb07bd2b7890195e7d46bdf2071b6617514ddb\": \"0x6c6b935b8bbd400000\",\n \"0x9eef442d291a447d74c5d253c49ef324eac1d8f0\": \"0xb96608c8103bf00000\",\n \"0x9ef1896b007c32a15114fb89d73dbd47f9122b69\": \"0xd8d726b7177a800000\",\n \"0x9f017706b830fb9c30efb0a09f506b9157457534\": \"0x6c6b935b8bbd400000\",\n \"0x9f10f2a0463b65ae30b070b3df18cf46f51e89bd\": \"0x678a932062e4180000\",\n \"0x9f19fac8a32437d80ac6837a0bb7841729f4972e\": \"0x233df3299f61720000\",\n \"0x9f1aa8fcfc89a1a5328cbd6344b71f278a2ca4a0\": \"0x1b1ae4d6e2ef500000\",\n \"0x9f21302ca5096bea7402b91b0fd506254f999a3d\": \"0x4397451a003dd80000\",\n \"0x9f271d285500d73846b18f733e25dd8b4f5d4a8b\": \"0x2723c346ae18080000\",\n \"0x9f3497f5ef5fe63095836c004eb9ce02e9013b4b\": \"0x2256861bf9cf080000\",\n \"0x9f3a74fd5e7edcc1162993171381cbb632b7cff0\": \"0x21e19e0c9bab2400000\",\n \"0x9f46e7c1e9078cae86305ac7060b01467d6685ee\": \"0x243d4d18229ca20000\",\n \"0x9f496cb2069563144d0811677ba0e4713a0a4143\": \"0x3cd2e0bf63a4480000\",\n \"0x9f4a7195ac7c151ca258cafda0cab083e049c602\": \"0x53538c32185cee0000\",\n \"0x9f4ac9c9e7e24cb2444a0454fa5b9ad9d92d3853\": \"0x2d43f3ebfafb2c0000\",\n \"0x9f5f44026b576a4adb41e95961561d41039ca391\": \"0xd8d726b7177a80000\",\n \"0x9f607b3f12469f446121cebf3475356b71b4328c\": \"0xd8d726b7177a800000\",\n \"0x9f61beb46f5e853d0a8521c7446e68e34c7d0973\": \"0x1e5b8fa8fe2ac00000\",\n \"0x9f64a8e8dacf4ade30d10f4d59b0a3d5abfdbf74\": \"0x36369ed7747d260000\",\n \"0x9f662e95274121f177566e636d23964cf1fd686f\": \"0x6c6b935b8bbd400000\",\n \"0x9f6a322a6d469981426ae844865d7ee0bb15c7b3\": \"0x2b5ee57929fdb8000\",\n \"0x9f7986924aeb02687cd64189189fb167ded2dd5c\": \"0x35659ef93f0fc40000\",\n \"0x9f7a0392f857732e3004a375e6b1068d49d83031\": \"0x6c6b935b8bbd400000\",\n \"0x9f8245c3ab7d173164861cd3991b94f1ba40a93a\": \"0x9b0a791f1211300000\",\n \"0x9f83a293c324d4106c18faa8888f64d299054ca0\": \"0xad78ebc5ac6200000\",\n \"0x9f86a066edb61fcb5856de93b75c8c791864b97b\": \"0x6c6b935b8bbd400000\",\n \"0x9f98eb34d46979b0a6de8b05aa533a89b825dcf1\": \"0x4b06dbbb40f4a0000\",\n \"0x9f9fe0c95f10fee87af1af207236c8f3614ef02f\": \"0x14542ba12a337c00000\",\n \"0x9faea13c733412dc4b490402bfef27a0397a9bc3\": \"0x10ce1d3d8cb3180000\",\n \"0x9fbe066de57236dc830725d32a02aef9246c6c5e\": \"0x6c6b935b8bbd400000\",\n \"0x9fd1052a60506bd1a9ef003afd9d033c267d8e99\": \"0x3635c9adc5dea00000\",\n \"0x9fd64373f2fbcd9c0faca60547cad62e26d9851f\": \"0x3635c9adc5dea00000\",\n \"0x9fe501aa57ead79278937cd6308c5cfa7a5629fe\": \"0x2b5ee57929fdb8000\",\n \"0x9ffc5fe06f33f5a480b75aa94eb8556d997a16c0\": \"0x1158e460913d00000\",\n \"0x9ffcf5ef46d933a519d1d16c6ba3189b27496224\": \"0x3635c9adc5dea00000\",\n \"0x9ffedcc36b7cc312ad2a9ede431a514fccb49ba3\": \"0x244f579f3f5ca40000\",\n \"0xa006268446643ec5e81e7acb3f17f1c351ee2ed9\": \"0xd8d726b7177a800000\",\n \"0xa008019863c1a77c1499eb39bbd7bf2dd7a31cb9\": \"0x76d41c62494840000\",\n \"0xa009bf076f1ba3fa57d2a7217218bed5565a7a7a\": \"0x3635c9adc5dea00000\",\n \"0xa01e9476df84431825c836e8803a97e22fa5a0cd\": \"0x14542ba12a337c00000\",\n \"0xa01f12d70f44aa7b113b285c22dcdb45873454a7\": \"0xfc936392801c0000\",\n \"0xa01fd1906a908506dedae1e208128872b56ee792\": \"0xa2a15d09519be00000\",\n \"0xa0228240f99e1de9cb32d82c0f2fa9a3d44b0bf3\": \"0x56bc75e2d631000000\",\n \"0xa02bde6461686e19ac650c970d0672e76dcb4fc2\": \"0x1e09296c3378de40000\",\n \"0xa02c1e34064f0475f7fa831ccb25014c3aa31ca2\": \"0x340aad21b3b700000\",\n \"0xa02dc6aa328b880de99eac546823fccf774047fb\": \"0x6acb3df27e1f880000\",\n \"0xa02e3f8f5959a7aab7418612129b701ca1b80010\": \"0x1158e460913d00000\",\n \"0xa0347f0a98776390165c166d32963bf74dcd0a2f\": \"0x3635c9adc5dea00000\",\n \"0xa035a3652478f82dbd6d115faa8ca946ec9e681d\": \"0x5f4e42dd4afec0000\",\n \"0xa03a3dc7c533d1744295be955d61af3f52b51af5\": \"0x22b1c8c1227a00000\",\n \"0xa0459ef3693aacd1647cd5d8929839204cef53be\": \"0x3635c9adc5dea00000\",\n \"0xa04f2ae02add14c12faf65cb259022d0830a8e26\": \"0x152d02c7e14af6800000\",\n \"0xa06cd1f396396c0a64464651d7c205efaf387ca3\": \"0x6c6acc67d7b1d40000\",\n \"0xa072691c8dd7cd4237ff72a75c1a9506d0ce5b9e\": \"0x140ec80fa7ee880000\",\n \"0xa072cebe62a9e9f61cc3fbf88a9efbfe3e9a8d70\": \"0x15af1d78b58c400000\",\n \"0xa07682000b1bcf3002f85c80c0fa2949bd1e82fd\": \"0xd8d726b7177a800000\",\n \"0xa07aa16d74aee8a9a3288d52db1551d593883297\": \"0x2086ac351052600000\",\n \"0xa08d215b5b6aac4861a281ac7e400b78fef04cbf\": \"0x1158e460913d00000\",\n \"0xa0951970dfd0832fb83bda12c23545e79041756c\": \"0x2086ac351052600000\",\n \"0xa09f4d5eaa65a2f4cb750a49923401dae59090af\": \"0x796e3ea3f8ab00000\",\n \"0xa0a0e65204541fca9b2fb282cd95138fae16f809\": \"0x21e19e0c9bab2400000\",\n \"0xa0aa5f0201f04d3bbeb898132f7c11679466d901\": \"0x1fbed5215bb4c0000\",\n \"0xa0aadbd9509722705f6d2358a5c79f37970f00f6\": \"0xad78ebc5ac6200000\",\n \"0xa0b771951ce1deee363ae2b771b73e07c4b5e800\": \"0x4be4e7267b6ae00000\",\n \"0xa0de5c601e696635c698b7ae9ca4539fc7b941ec\": \"0x12c3cbd704c9770000\",\n \"0xa0e8ba661b48154cf843d4c2a5c0f792d528ee29\": \"0x15af1d78b58c400000\",\n \"0xa0fc7e53c5ebd27a2abdac45261f84ab3b51aefb\": \"0xa313daec9bc0d90000\",\n \"0xa0ff5b4cf016027e8323497d4428d3e5a83b8795\": \"0x16598d3c83ec0420000\",\n \"0xa106465bbd19e1b6bce50d1b1157dc59095a3630\": \"0x6c6b935b8bbd400000\",\n \"0xa106e6923edd53ca8ed650968a9108d6ccfd9670\": \"0x202fe1505afec898000\",\n \"0xa109e18bb0a39c9ef82fa19597fc5ed8e9eb6d58\": \"0x58e7926ee858a00000\",\n \"0xa11a03c4bb26d21eff677d5d555c80b25453ee7a\": \"0x3cb2759bc410f8000\",\n \"0xa11effab6cf0f5972cffe4d56596e98968144a8f\": \"0x5a87e7d7f5f6580000\",\n \"0xa1204dad5f560728a35c0d8fc79481057bf77386\": \"0x3635c9adc5dea00000\",\n \"0xa12623e629df93096704b16084be2cd89d562da4\": \"0x1ccc9324511e4500000\",\n \"0xa12a6c2d985daf0e4f5f207ae851aaf729b332cd\": \"0x152d02c7e14af6800000\",\n \"0xa1336dfb96b6bcbe4b3edf3205be5723c90fad52\": \"0x10f0cf064dd59200000\",\n \"0xa13b9d82a99b3c9bba5ae72ef2199edc7d3bb36c\": \"0x6c6acc67d7b1d40000\",\n \"0xa13cfe826d6d1841dcae443be8c387518136b5e8\": \"0x1da56a4b0835bf800000\",\n \"0xa1432ed2c6b7777a88e8d46d388e70477f208ca5\": \"0x1b1a7e413a196c50000\",\n \"0xa144f6b60f72d64a21e330dadb62d8990ade2b09\": \"0x3635c9adc5dea00000\",\n \"0xa15025f595acdbf3110f77c5bf24477e6548f9e8\": \"0x6c6b935b8bbd400000\",\n \"0xa158148a2e0f3e92dc2ce38febc20107e3253c96\": \"0x6c6b935b8bbd400000\",\n \"0xa16160851d2b9c349b92e46f829abfb210943595\": \"0x61093d7c2c6d380000\",\n \"0xa166f911c644ac3213d29e0e1ae010f794d5ad26\": \"0x6c6b935b8bbd400000\",\n \"0xa16d9e3d63986159a800b46837f45e8bb980ee0b\": \"0x6e1175da7ad1200000\",\n \"0xa17070c2e9c5a940a4ec0e4954c4d7d643be8f49\": \"0x6c6b17033b361c8000\",\n \"0xa17c9e4323069518189d5207a0728dcb92306a3f\": \"0x3635c9adc5dea00000\",\n \"0xa18360e985f2062e8f8efe02ad2cbc91ad9a5aad\": \"0xa2a15d09519be00000\",\n \"0xa1911405cf6e999ed011f0ddcd2a4ff7c28f2526\": \"0x22b1c8c1227a00000\",\n \"0xa192698007cc11aa603d221d5feea076bcf7c30d\": \"0x6c6b935b8bbd400000\",\n \"0xa192f06ab052d5fd7f94eea8318e827815fe677a\": \"0x71f8a93d01e540000\",\n \"0xa1998144968a5c70a6415554cefec2824690c4a5\": \"0x1158e460913d00000\",\n \"0xa1a1f0fa6d20b50a794f02ef52085c9d036aa6ca\": \"0x3635c9adc5dea00000\",\n \"0xa1ae8d4540d4db6fdde7146f415b431eb55c7983\": \"0xaadec983fcff40000\",\n \"0xa1b47c4d0ed6018842e6cfc8630ac3a3142e5e6b\": \"0x1158e460913d00000\",\n \"0xa1c4f45a82e1c478d845082eb18875c4ea6539ab\": \"0x2a5a058fc295ed000000\",\n \"0xa1dcd0e5b05a977c9623e5ae2f59b9ada2f33e31\": \"0x56bc75e2d63100000\",\n \"0xa1e4380a3b1f749673e270229993ee55f35663b4\": \"0x6c6b935b8bbd400000\",\n \"0xa1f193a0592f1feb9fdfc90aa813784eb80471c9\": \"0x4be4e7267b6ae00000\",\n \"0xa1f2854050f872658ed82e52b0ad7bbc1cb921f6\": \"0x6d0317e2b326f70000\",\n \"0xa1f5b840140d5a9acef402ac3cc3886a68cad248\": \"0x6c6b935b8bbd400000\",\n \"0xa1f765c44fe45f790677944844be4f2d42165fbd\": \"0xc7e9cfde768ec70000\",\n \"0xa1f7dde1d738d8cd679ea1ee965bee224be7d04d\": \"0x3d184450e5e93c0000\",\n \"0xa1f8d8bcf90e777f19b3a649759ad95027abdfc3\": \"0xad78ebc5ac6200000\",\n \"0xa202547242806f6e70e74058d6e5292defc8c8d4\": \"0x6c8754c8f30c080000\",\n \"0xa20d071b1b003063497d7990e1249dabf36c35f7\": \"0x3635c9adc5dea00000\",\n \"0xa20d8ff60caae31d02e0b665fa435d76f77c9442\": \"0x1a8a909dfcef400000\",\n \"0xa211da03cc0e31ecce5309998718515528a090df\": \"0xad78ebc5ac6200000\",\n \"0xa21442ab05340ade68c915f3c3399b9955f3f7eb\": \"0x2a034919dfbfbc0000\",\n \"0xa2222259dd9c3e3ded127084f808e92a1887302c\": \"0x8c8339dafed480000\",\n \"0xa22ade0ddb5c6ef8d0cd8de94d82b11082cb2e91\": \"0x374b57f3cef2700000\",\n \"0xa24c3ab62181e9a15b78c4621e4c7c588127be26\": \"0x8cde43a83d3310000\",\n \"0xa257ad594bd88328a7d90fc0a907df95eecae316\": \"0x1c3786ff3846930000\",\n \"0xa25b086437fd2192d0a0f64f6ed044f38ef3da32\": \"0x12290f15180bdc0000\",\n \"0xa276b058cb98d88beedb67e543506c9a0d9470d8\": \"0x90aafc76e02fbe0000\",\n \"0xa282e969cac9f7a0e1c0cd90f5d0c438ac570da3\": \"0x2207eb89fc27380000\",\n \"0xa291e9c7990d552dd1ae16cebc3fca342cbaf1d1\": \"0x43c33c1937564800000\",\n \"0xa29319e81069e5d60df00f3de5adee3505ecd5fb\": \"0x6c6b935b8bbd400000\",\n \"0xa2968fc1c64bac0b7ae0d68ba949874d6db253f4\": \"0x43c33c1937564800000\",\n \"0xa29d5bda74e003474872bd5894b88533ff64c2b5\": \"0x21e19e0c9bab2400000\",\n \"0xa29d661a6376f66d0b74e2fe9d8f26c0247ec84c\": \"0xdf3304079c13d20000\",\n \"0xa2a435de44a01bd0ecb29e44e47644e46a0cdffb\": \"0x1b1d445a7affe78000\",\n \"0xa2ace4c993bb1e5383f8ac74e179066e814f0591\": \"0x56bc75e2d63100000\",\n \"0xa2b701f9f5cdd09e4ba62baebae3a88257105885\": \"0x3635c9adc5dea00000\",\n \"0xa2c5854ff1599f98892c5725d262be1da98aadac\": \"0x1109ff333010e78000\",\n \"0xa2c7eaffdc2c9d937345206c909a52dfb14c478f\": \"0x7c0860e5a80dc0000\",\n \"0xa2d2aa626b09d6d4e4b13f7ffc5a88bd7ad36742\": \"0xfb8078507553830000\",\n \"0xa2d38de1c73906f6a7ca6efeb97cf6f69cc421be\": \"0x3635c9adc5dea00000\",\n \"0xa2dc65ee256b59a5bd7929774f904b358df3ada1\": \"0x483bce28beb09f80000\",\n \"0xa2e0683a805de6a05edb2ffbb5e96f0570b637c3\": \"0x1158e460913d00000\",\n \"0xa2e1b8aa900e9c139b3fa122354f6156d92a18b1\": \"0x1b1ae4d6e2ef500000\",\n \"0xa2e2b5941e0c01944bfe1d5fb4e8a34b922ccfb1\": \"0xad78ebc5ac6200000\",\n \"0xa2e460a989cb15565f9ecca7d121a18e4eb405b6\": \"0x6c6b935b8bbd400000\",\n \"0xa2ecce2c49f72a0995a0bda57aacf1e9f001e22a\": \"0xd8d726b7177a800000\",\n \"0xa2f472fe4f22b77db489219ea4023d11582a9329\": \"0x878678326eac9000000\",\n \"0xa2f798e077b07d86124e1407df32890dbb4b6379\": \"0xad78ebc5ac6200000\",\n \"0xa2f86bc061884e9eef05640edd51a2f7c0596c69\": \"0x6c6c44fe47ec050000\",\n \"0xa2fa17c0fb506ce494008b9557841c3f641b8cae\": \"0x1158e460913d00000\",\n \"0xa304588f0d850cd8d38f76e9e83c1bf63e333ede\": \"0x2285601216c8c0000\",\n \"0xa3058c51737a4e96c55f2ef6bd7bb358167ec2a7\": \"0x20db3ae4481ad48000\",\n \"0xa309df54cabce70c95ec3033149cd6678a6fd4cf\": \"0xc1f12c75101580000\",\n \"0xa30a45520e5206d9004070e6af3e7bb2e8dd5313\": \"0x15af1d78b58c400000\",\n \"0xa30e0acb534c9b3084e8501da090b4eb16a2c0cd\": \"0x6c6b935b8bbd400000\",\n \"0xa3203095edb7028e6871ce0a84f548459f83300a\": \"0xd8d726b7177a800000\",\n \"0xa321091d3018064279db399d2b2a88a6f440ae24\": \"0xad78ebc5ac62000000\",\n \"0xa3232d068d50064903c9ebc563b515acc8b7b097\": \"0x6c8754c8f30c080000\",\n \"0xa3241d890a92baf52908dc4aa049726be426ebd3\": \"0x43c2da661ca2f540000\",\n \"0xa3294626ec2984c43b43da4d5d8e4669b11d4b59\": \"0x36a4cf636319c00000\",\n \"0xa32cf7dde20c3dd5679ff5e325845c70c5962662\": \"0x1158e460913d00000\",\n \"0xa339a3d8ca280e27d2415b26d1fc793228b66043\": \"0x36f28695b78ff00000\",\n \"0xa33cb450f95bb46e25afb50fe05feee6fb8cc8ea\": \"0x2a1129d09367200000\",\n \"0xa33f70da7275ef057104dfa7db64f472e9f5d553\": \"0x45946b0f9e9d60000\",\n \"0xa34076f84bd917f20f8342c98ba79e6fb08ecd31\": \"0xe3aeb5737240a00000\",\n \"0xa3430e1f647f321ed34739562323c7d623410b56\": \"0x3634fb9f1489a70000\",\n \"0xa34f9d568bf7afd94c2a5b8a5ff55c66c4087999\": \"0x847d503b220eb00000\",\n \"0xa35606d51220ee7f2146d411582ee4ee4a45596e\": \"0xd8aabe080bc9400000\",\n \"0xa356551bb77d4f45a6d7e09f0a089e79cca249cb\": \"0x126e72a69a50d00000\",\n \"0xa35c19132cac1935576abfed6c0495fb07881ba0\": \"0x6c6b935b8bbd400000\",\n \"0xa365918bfe3f2627b9f3a86775d8756e0fd8a94b\": \"0x15af1d78b58c400000\",\n \"0xa36e0d94b95364a82671b608cb2d373245612909\": \"0x821d221b5291f8000\",\n \"0xa375b4bc24a24e1f797593cc302b2f331063fa5c\": \"0xad78ebc5ac6200000\",\n \"0xa37622ac9bbdc4d82b75015d745b9f8de65a28ec\": \"0x9dc05cce28c2b80000\",\n \"0xa379a5070c503d2fac89b8b3afa080fd45ed4bec\": \"0x42bf06b78ed3b500000\",\n \"0xa3802d8a659e89a2c47e905430b2a827978950a7\": \"0x3635c9adc5dea00000\",\n \"0xa38306cb70baa8e49186bd68aa70a83d242f2907\": \"0x6c6b935b8bbd400000\",\n \"0xa38476691d34942eea6b2f76889223047db4617a\": \"0x6c6b935b8bbd400000\",\n \"0xa387ce4e961a7847f560075c64e1596b5641d21c\": \"0x243d4d18229ca20000\",\n \"0xa387ecde0ee4c8079499fd8e03473bd88ad7522a\": \"0x6acb3df27e1f880000\",\n \"0xa3883a24f7f166205f1a6a9949076c26a76e7178\": \"0x62a992e53a0af00000\",\n \"0xa38b5bd81a9db9d2b21d5ec7c60552cd02ed561b\": \"0x14542ba12a337c00000\",\n \"0xa390ca122b8501ee3e5e07a8ca4b419f7e4dae15\": \"0x56bc75e2d63100000\",\n \"0xa3932a31d6ff75fb3b1271ace7caa7d5e1ff1051\": \"0x43c33c1937564800000\",\n \"0xa394ad4fd9e6530e6f5c53faecbede81cb172da1\": \"0x12f939c99edab800000\",\n \"0xa3979a92760a135adf69d72f75e167755f1cb8c3\": \"0x56bc75e2d63100000\",\n \"0xa39bfee4aec9bd75bd22c6b672898ca9a1e95d32\": \"0x21e19e0c9bab2400000\",\n \"0xa3a262afd2936819230892fde84f2d5a594ab283\": \"0x65ea3db75546600000\",\n \"0xa3a2e319e7d3a1448b5aa2468953160c2dbcba71\": \"0x6c6b935b8bbd400000\",\n \"0xa3a57b0716132804d60aac281197ff2b3d237b01\": \"0x4be4e7267b6ae00000\",\n \"0xa3a93ef9dbea2636263d06d8492f6a41de907c22\": \"0x340aad21b3b700000\",\n \"0xa3ae1879007d801cb5f352716a4dd8ba2721de3d\": \"0x2a5a058fc295ed000000\",\n \"0xa3ba0d3a3617b1e31b4e422ce269e873828d5d69\": \"0x2e141ea081ca080000\",\n \"0xa3bc979b7080092fa1f92f6e0fb347e28d995045\": \"0x97c9ce4cf6d5c00000\",\n \"0xa3bff1dfa9971668360c0d82828432e27bf54e67\": \"0xad78ebc5ac6200000\",\n \"0xa3c14ace28b192cbb062145fcbbd5869c67271f6\": \"0x1b1ae4d6e2ef5000000\",\n \"0xa3c33afc8cb4704e23153de2049d35ae71332472\": \"0x2b58addb89a2580000\",\n \"0xa3d0b03cffbb269f796ac29d80bfb07dc7c6ad06\": \"0x6c6b935b8bbd400000\",\n \"0xa3d583a7b65b23f60b7905f3e4aa62aac87f4227\": \"0x38befa126d5a9f8000\",\n \"0xa3db364a332d884ba93b2617ae4d85a1489bea47\": \"0x5c283d410394100000\",\n \"0xa3e051fb744aa3410c3b88f899f5d57f168df12d\": \"0xa030dcebbd2f4c0000\",\n \"0xa3e3a6ea509573e21bd0239ece0523a7b7d89b2f\": \"0x6acb3df27e1f880000\",\n \"0xa3f4ad14e0bb44e2ce2c14359c75b8e732d37054\": \"0xad78ebc5ac6200000\",\n \"0xa3facc50195c0b4933c85897fecc5bbd995c34b8\": \"0x1158e460913d00000\",\n \"0xa4035ab1e5180821f0f380f1131b7387c8d981cd\": \"0x1158e460913d00000\",\n \"0xa40aa2bbce0c72b4d0dfffcc42715b2b54b01bfa\": \"0x3635c9adc5dea00000\",\n \"0xa419a984142363267575566089340eea0ea20819\": \"0x6c6acc67d7b1d40000\",\n \"0xa421dbb89b3a07419084ad10c3c15dfe9b32d0c2\": \"0x43c33c1937564800000\",\n \"0xa422e4bf0bf74147cc895bed8f16d3cef3426154\": \"0x12ef3f62ee11368000\",\n \"0xa4259f8345f7e3a8b72b0fec2cf75e321fda4dc2\": \"0x678a932062e4180000\",\n \"0xa42908e7fe53980a9abf4044e957a54b70e99cbe\": \"0x6c6b935b8bbd400000\",\n \"0xa429fa88731fdd350e8ecd6ea54296b6484fe695\": \"0x6ac5c62d9486070000\",\n \"0xa430995ddb185b9865dbe62539ad90d22e4b73c2\": \"0x21e19e0c9bab2400000\",\n \"0xa436c75453ccca4a1f1b62e5c4a30d86dde4be68\": \"0x6c6b935b8bbd400000\",\n \"0xa437fe6ec103ca8d158f63b334224eccac5b3ea3\": \"0x1b1ae4d6e2ef5000000\",\n \"0xa43b6da6cb7aac571dff27f09d39f846f53769b1\": \"0x14998f32ac78700000\",\n \"0xa43b81f99356c0af141a03010d77bd042c71c1ee\": \"0x6c6b935b8bbd400000\",\n \"0xa43e1947a9242b355561c30a829dfeeca2815af8\": \"0xd23d99969fd6918000\",\n \"0xa4489a50ead5d5445a7bee4d2d5536c2a76c41f8\": \"0xad78ebc5ac6200000\",\n \"0xa44fe800d96fcad73b7170d0f610cb8c0682d6ce\": \"0xd8d726b7177a800000\",\n \"0xa45432a6f2ac9d56577b938a37fabac8cc7c461c\": \"0x3635c9adc5dea00000\",\n \"0xa466d770d898d8c9d405e4a0e551efafcde53cf9\": \"0x1ab2cf7c9f87e20000\",\n \"0xa4670731175893bbcff4fa85ce97d94fc51c4ba8\": \"0x1b1ae4d6e2ef5000000\",\n \"0xa46b4387fb4dcce011e76e4d73547d4481e09be5\": \"0x487a9a304539440000\",\n \"0xa46cd237b63eea438c8e3b6585f679e4860832ac\": \"0x3635c9adc5dea00000\",\n \"0xa47779d8bc1c7bce0f011ccb39ef68b854f8de8f\": \"0x6c6b935b8bbd400000\",\n \"0xa4826b6c3882fad0ed5c8fbb25cc40cc4f33759f\": \"0x701b43e34433d00000\",\n \"0xa4875928458ec2005dbb578c5cd33580f0cf1452\": \"0x3635c9adc5dea00000\",\n \"0xa49f523aa51364cbc7d995163d34eb590ded2f08\": \"0x9027421b2a9fbc0000\",\n \"0xa4a49f0bc8688cc9e6dc04e1e08d521026e65574\": \"0xad78ebc5ac6200000\",\n \"0xa4a7d306f510cd58359428c0d2f7c3609d5674d7\": \"0xb58cb61c3ccf340000\",\n \"0xa4a83a0738799b971bf2de708c2ebf911ca79eb2\": \"0x2086ac351052600000\",\n \"0xa4b09de6e713dc69546e76ef0acf40b94f0241e6\": \"0x117dc0627ec8700000\",\n \"0xa4d2b429f1ad5349e31704969edc5f25ee8aca10\": \"0x21e19e0c9bab2400000\",\n \"0xa4d6c82eddae5947fbe9cdfbd548ae33d91a7191\": \"0x1b1ae4d6e2ef5000000\",\n \"0xa4da34450d22ec0ffcede0004b02f7872ee0b73a\": \"0x50f616673f0830000\",\n \"0xa4dd59ab5e517d398e49fa537f899fed4c15e95d\": \"0x43c33c1937564800000\",\n \"0xa4e623451e7e94e7e89ba5ed95c8a83a62ffc4ea\": \"0x1158e460913d00000\",\n \"0xa4ed11b072d89fb136759fc69b428c48aa5d4ced\": \"0xe3f1527a03ca80000\",\n \"0xa4fb14409a67b45688a8593e5cc2cf596ced6f11\": \"0x61093d7c2c6d380000\",\n \"0xa514d00edd7108a6be839a638db2415418174196\": \"0x65a4da25d3016c00000\",\n \"0xa522de7eb6ae1250522a513133a93bd42849475c\": \"0x43c33c1937564800000\",\n \"0xa524a8cccc49518d170a328270a2f88133fbaf5d\": \"0xff7022dac108a0000\",\n \"0xa539b4a401b584dfe0f344b1b422c65543167e2e\": \"0xad78ebc5ac6200000\",\n \"0xa53ead54f7850af21438cbe07af686279a315b86\": \"0x21e19e0c9bab2400000\",\n \"0xa543a066fb32a8668aa0736a0c9cd40d78098727\": \"0x3635c9adc5dea00000\",\n \"0xa567770b6ae320bdde50f904d663e746a61dace6\": \"0x6c6b935b8bbd400000\",\n \"0xa568db4d57e4d67462d733c69a9e0fe26e218327\": \"0x3b6bff9266c0ae0000\",\n \"0xa5698035391e67a49013c0002079593114feb353\": \"0xd02ab486cedc00000\",\n \"0xa570223ae3caa851418a9843a1ac55db4824f4fd\": \"0xad78ebc5ac6200000\",\n \"0xa57360f002e0d64d2d74457d8ca4857ee00bcddf\": \"0x1233e232f618aa0000\",\n \"0xa575f2891dcfcda83c5cf01474af11ee01b72dc2\": \"0x56cd55fc64dfe0000\",\n \"0xa5783bf33432ff82ac498985d7d460ae67ec3673\": \"0x62a992e53a0af00000\",\n \"0xa5874d754635a762b381a5c4c792483af8f23d1d\": \"0x2b5e3af16b1880000\",\n \"0xa5a4227f6cf98825c0d5baff5315752ccc1a1391\": \"0x21e19e0c9bab2400000\",\n \"0xa5ab4bd3588f46cb272e56e93deed386ba8b753d\": \"0x4842f04105872c8000\",\n \"0xa5bad86509fbe0e0e3c0e93f6d381f1af6e9d481\": \"0x14542ba12a337c00000\",\n \"0xa5c336083b04f9471b8c6ed73679b74d66c363ec\": \"0xa3650a4c9d20e20000\",\n \"0xa5cd123992194b34c4781314303b03c54948f4b9\": \"0x6cfcc3d91da5630000\",\n \"0xa5d5b8b62d002def92413710d13b6ff8d4fc7dd3\": \"0x15af1d78b58c400000\",\n \"0xa5d96e697d46358d119af7819dc7087f6ae47fef\": \"0x317bee8af3315a78000\",\n \"0xa5de5e434fdcdd688f1c31b6fb512cb196724701\": \"0x2b5e3af16b18800000\",\n \"0xa5e0fc3c3affed3db6710947d1d6fb017f3e276d\": \"0x6c6b935b8bbd400000\",\n \"0xa5e93b49ea7c509de7c44d6cfeddef5910deaaf2\": \"0x6c6b935b8bbd400000\",\n \"0xa5e9cd4b74255d22b7d9b27ae8dd43ed6ed0252b\": \"0x298db2f54411d98000\",\n \"0xa5f0077b351f6c505cd515dfa6d2fa7f5c4cd287\": \"0x878678326eac9000000\",\n \"0xa5f075fd401335577b6683c281e6d101432dc6e0\": \"0x914878a8c05ee00000\",\n \"0xa5fe2ce97f0e8c3856be0de5f4dcb2ce5d389a16\": \"0x13db0b8b6863e0000\",\n \"0xa5ff62222d80c013cec1a0e8850ed4d354dac16d\": \"0xb41075c168b180000\",\n \"0xa609c26dd350c235e44b2b9c1dddccd0a9d9f837\": \"0x3635c9adc5dea00000\",\n \"0xa60c1209754f5d87b181da4f0817a81859ef9fd8\": \"0x2b5e3af16b1880000\",\n \"0xa6101c961e8e1c15798ffcd0e3201d7786ec373a\": \"0x14542ba12a337c00000\",\n \"0xa613456996408af1c2e93e177788ab55895e2b32\": \"0x15919ff477c88b80000\",\n \"0xa61887818f914a20e31077290b83715a6b2d6ef9\": \"0x65ea3db75546600000\",\n \"0xa61a54df784a44d71b771b87317509211381f200\": \"0x3635c9adc5dea00000\",\n \"0xa61cdbadf04b1e54c883de6005fcdf16beb8eb2f\": \"0x6c6b935b8bbd400000\",\n \"0xa639acd96b31ba53b0d08763229e1f06fd105e9d\": \"0x1b1ae4d6e2ef5000000\",\n \"0xa642501004c90ea9c9ed1998ba140a4cd62c6f5f\": \"0xd94fb8b10f8b18000\",\n \"0xa644ed922cc237a3e5c4979a995477f36e50bc62\": \"0x1fa73d845d7e960000\",\n \"0xa646a95c6d6f59f104c6541d7760757ab392b08c\": \"0xe3aeb5737240a00000\",\n \"0xa6484cc684c4c91db53eb68a4da45a6a6bda3067\": \"0x14542ba12a337c00000\",\n \"0xa64e5ffb704c2c9139d77ef61d8cdfa31d7a88e9\": \"0x7c0860e5a80dc0000\",\n \"0xa65426cff378ed23253513b19f496de45fa7e18f\": \"0x18650127cc3dc800000\",\n \"0xa66a4963b27f1ee1932b172be5964e0d3ae54b51\": \"0x960db77681e940000\",\n \"0xa67f38819565423aa85f3e3ab61bc763cbab89dd\": \"0x7377b022c6be080000\",\n \"0xa68c313445c22d919ee46cc2d0cdff043a755825\": \"0x41374fd21b0d88000\",\n \"0xa68e0c30cba3bc5a883e540320f999c7cd558e5c\": \"0x6192333762a58c8000\",\n \"0xa690f1a4b20ab7ba34628620de9ca040c43c1963\": \"0xd8d726b7177a800000\",\n \"0xa69d7cd17d4842fe03f62a90b2fbf8f6af7bb380\": \"0x56bc75e2d63100000\",\n \"0xa6a08252c8595177cc2e60fc27593e2379c81fb1\": \"0x11651ac3e7a758000\",\n \"0xa6a0de421ae54f6d17281308f5646d2f39f7775d\": \"0x6c6b935b8bbd400000\",\n \"0xa6b2d573297360102c07a18fc21df2e7499ff4eb\": \"0xd96fce90cfabcc0000\",\n \"0xa6c910ce4d494a919ccdaaa1fc3b82aa74ba06cf\": \"0x1b1ae4d6e2ef5000000\",\n \"0xa6e3baa38e104a1e27a4d82869afb1c0ae6eff8d\": \"0x11140eead8b710000\",\n \"0xa6eebbe464d39187bf80ca9c13d72027ec5ba8be\": \"0xa2a15d09519be00000\",\n \"0xa6f62b8a3d7f11220701ab9ffffcb327959a2785\": \"0x1b6e291f18dba80000\",\n \"0xa6f93307f8bce03195fece872043e8a03f7bd11a\": \"0x9c734bad5111580000\",\n \"0xa701df79f594901afe1444485e6b20c3bda2b9b3\": \"0x3635c9adc5dea00000\",\n \"0xa7024cfd742c1ec13c01fea18d3042e65f1d5dee\": \"0x263119a28abd0b08000\",\n \"0xa718aaad59bf395cba2b23e09b02fe0c89816247\": \"0x36303c97e468780000\",\n \"0xa7247c53d059eb7c9310f628d7fc6c6a0a773f08\": \"0x1b1ae4d6e2ef500000\",\n \"0xa7253763cf4a75df92ca1e766dc4ee8a2745147b\": \"0x2463770e90a8f500000\",\n \"0xa72ee666c4b35e82a506808b443cebd5c632c7dd\": \"0x2b5e3af16b18800000\",\n \"0xa74444f90fbb54e56f3ac9b6cfccaa4819e4614a\": \"0x1158e460913d00000\",\n \"0xa747439ad0d393b5a03861d77296326de8bb9db9\": \"0x3635c9adc5dea00000\",\n \"0xa7607b42573bb6f6b4d4f23c7e2a26b3a0f6b6f0\": \"0x57473d05dabae80000\",\n \"0xa76929890a7b47fb859196016c6fdd8289ceb755\": \"0x10f0cf064dd59200000\",\n \"0xa76b743f981b693072a131b22ba510965c2fefd7\": \"0xfc936392801c0000\",\n \"0xa76d3f156251b72c0ccf4b47a3393cbd6f49a9c5\": \"0x487a9a304539440000\",\n \"0xa77428bcb2a0db76fc8ef1e20e461a0a32c5ac15\": \"0x15be6174e1912e0000\",\n \"0xa7758cecb60e8f614cce96137ef72b4fbd07774a\": \"0x1b1ae4d6e2ef500000\",\n \"0xa7775e4af6a23afa201fb78b915e51a515b7a728\": \"0x68155a43676e00000\",\n \"0xa77f3ee19e9388bbbb2215c62397b96560132360\": \"0xad78ebc5ac6200000\",\n \"0xa7859fc07f756ea7dcebbccd42f05817582d973f\": \"0x21e19e0c9bab2400000\",\n \"0xa7966c489f4c748a7ae980aa27a574251767caf9\": \"0xa2a15d09519be00000\",\n \"0xa7a3bb6139b0ada00c1f7f1f9f56d994ba4d1fa8\": \"0x6c6b935b8bbd400000\",\n \"0xa7a3f153cdc38821c20c5d8c8241b294a3f82b24\": \"0x1b1ae4d6e2ef500000\",\n \"0xa7a517d7ad35820b09d497fa7e5540cde9495853\": \"0x6c6b935b8bbd400000\",\n \"0xa7c9d388ebd873e66b1713448397d0f37f8bd3a8\": \"0x10f0cf064dd59200000\",\n \"0xa7dcbba9b9bf6762c145416c506a71e3b497209c\": \"0x6c6acc67d7b1d40000\",\n \"0xa7e74f0bdb278ff0a805a648618ec52b166ff1be\": \"0x56bc75e2d63100000\",\n \"0xa7e83772bc200f9006aa2a260dbaa8483dc52b30\": \"0xb42d5366637e50000\",\n \"0xa7ef35ce87eda6c28df248785815053ec97a5045\": \"0x10f0ce949e00f930000\",\n \"0xa7f9220c8047826bd5d5183f4e676a6d77bfed36\": \"0x85068976be81c0000\",\n \"0xa807104f2703d679f8deafc442befe849e42950b\": \"0x6c6b935b8bbd400000\",\n \"0xa80cb1738bac08d4f9c08b4deff515545fa8584f\": \"0x1b1ae4d6e2ef500000\",\n \"0xa819d2ece122e028c8e8a04a064d02b9029b08b9\": \"0x3635c9adc5dea00000\",\n \"0xa825fd5abb7926a67cf36ba246a24bd27be6f6ed\": \"0xf43fc2c04ee00000\",\n \"0xa8285539869d88f8a961533755717d7eb65576ae\": \"0xad78ebc5ac6200000\",\n \"0xa83382b6e15267974a8550b98f7176c1a353f9be\": \"0xbffdaf2fc1b1a40000\",\n \"0xa8446c4781a737ac4328b1e15b8a0b3fbb0fd668\": \"0x48794d1f246192a0000\",\n \"0xa8455b411765d6901e311e726403091e42c56683\": \"0xb73aec3bfe14500000\",\n \"0xa86613e6c4a4c9c55f5c10bcda32175dcbb4af60\": \"0x243d6c2e36be6ae0000\",\n \"0xa86db07d9f812f4796622d40e03d135874a88a74\": \"0x1158e460913d00000\",\n \"0xa87f7abd6fa31194289678efb63cf584ee5e2a61\": \"0xd8d726b7177a800000\",\n \"0xa880e2a8bf88a1a82648b4013c49c4594c433cc8\": \"0x1004e2e45fb7ee00000\",\n \"0xa88577a073fbaf33c4cd202e00ea70ef711b4006\": \"0x6c6b935b8bbd400000\",\n \"0xa8914c95b560ec13f140577338c32bcbb77d3a7a\": \"0x9c2007651b2500000\",\n \"0xa89ac93b23370472daac337e9afdf642543f3e57\": \"0x21e19e0c9bab2400000\",\n \"0xa89df34859edd7c820db887740d8ff9e15157c7b\": \"0x6c6b935b8bbd400000\",\n \"0xa8a43c009100616cb4ae4e033f1fc5d7e0b6f152\": \"0xd588d078b43f4d8000\",\n \"0xa8a708e84f82db86a35502193b4c6ee9a76ebe8f\": \"0x3708baed3d68900000\",\n \"0xa8a7b68adab4e3eadff19ffa58e34a3fcec0d96a\": \"0x14542ba12a337c00000\",\n \"0xa8a8dbdd1a85d1beee2569e91ccc4d09ae7f6ea1\": \"0x13a6b2b564871a00000\",\n \"0xa8aca748f9d312ec747f8b6578142694c7e9f399\": \"0x6c6b935b8bbd400000\",\n \"0xa8b65ba3171a3f77a6350b9daf1f8d55b4d201eb\": \"0x2862f3b0d222040000\",\n \"0xa8beb91c2b99c8964aa95b6b4a184b1269fc3483\": \"0x15af1d78b58c400000\",\n \"0xa8c0b02faf02cb5519dda884de7bbc8c88a2da81\": \"0xe7c2518505060000\",\n \"0xa8c1d6aa41fe3d65f67bd01de2a866ed1ed9ae52\": \"0x1a055690d9db80000\",\n \"0xa8cafac32280d021020bf6f2a9782883d7aabe12\": \"0x56bc75e2d63100000\",\n \"0xa8db0b9b201453333c757f6ad9bcb555c02da93b\": \"0x7742b7830f341d0000\",\n \"0xa8e42a4e33d7526cca19d9a36dcd6e8040d0ea73\": \"0x3a8c02c5ea2de00000\",\n \"0xa8e7201ff619faffc332e6ad37ed41e301bf014a\": \"0x2086ac351052600000\",\n \"0xa8ee1df5d44b128469e913569ef6ac81eeda4fc8\": \"0x1b1ae4d6e2ef500000\",\n \"0xa8ef9ad274436042903e413c3b0c62f5f52ed584\": \"0x21e19e0c9bab2400000\",\n \"0xa8f37f0ab3a1d448a9e3ce40965f97a646083a34\": \"0x11e0e4f8a50bd40000\",\n \"0xa8f89dd5cc6e64d7b1eeace00702022cd7d2f03d\": \"0x25f273933db5700000\",\n \"0xa90476e2efdfee4f387b0f32a50678b0efb573b5\": \"0x21e19e0c9bab2400000\",\n \"0xa9145046fa3628cf5fd4c613927be531e6db1fdd\": \"0x6124fee993bc00000\",\n \"0xa914cdb571bfd93d64da66a4e108ea134e50d000\": \"0x4d8738994713798000\",\n \"0xa91a5a7b341f99c535144e20be9c6b3bb4c28e4d\": \"0x126753aa224a70b0000\",\n \"0xa9252551a624ae513719dabe5207fbefb2fd7749\": \"0x22b1c8c1227a00000\",\n \"0xa927d48bb6cb814bc609cbcaa9151f5d459a27e1\": \"0xeb935090064180000\",\n \"0xa929c8bd71db0c308dac06080a1747f21b1465aa\": \"0x1b1ae4d6e2ef500000\",\n \"0xa94bbb8214cf8da0c2f668a2ac73e86248528d4b\": \"0x340aad21b3b7000000\",\n \"0xa951b244ff50cfae591d5e1a148df6a938ef2a1a\": \"0x5e001584dfcf580000\",\n \"0xa960b1cadd3b5c1a8e6cb3abcaf52ee7c3d9fa88\": \"0x528bc3545e52680000\",\n \"0xa961171f5342b173dd70e7bfe5b5ca238b13bcdd\": \"0xb82794a9244f0c8000\",\n \"0xa975b077fcb4cc8efcbf838459b6fa243a4159d6\": \"0x22b1c8c1227a00000\",\n \"0xa97beb3a48c45f1528284cb6a95f7de453358ec6\": \"0x690836c0af5f5600000\",\n \"0xa97e072144499fe5ebbd354acc7e7efb58985d08\": \"0x90f534608a72880000\",\n \"0xa986762f7a4f294f2e0b173279ad2c81a2223458\": \"0x1158e460913d00000\",\n \"0xa98f109835f5eacd0543647c34a6b269e3802fac\": \"0x15af1d78b58c400000\",\n \"0xa997dfc7986a27050848fa1c64d7a7d6e07acca2\": \"0x7c0860e5a80dc0000\",\n \"0xa99991cebd98d9c838c25f7a7416d9e244ca250d\": \"0x3635c9adc5dea00000\",\n \"0xa9a1cdc33bfd376f1c0d76fb6c84b6b4ac274d68\": \"0x10f0cf064dd59200000\",\n \"0xa9a8eca11a23d64689a2aa3e417dbb3d336bb59a\": \"0xe3453cd3b67ba8000\",\n \"0xa9acf600081bb55bb6bfbab1815ffc4e17e85a95\": \"0xad78ebc5ac6200000\",\n \"0xa9ad1926bc66bdb331588ea8193788534d982c98\": \"0x65a4da25d3016c00000\",\n \"0xa9af21acbe482f8131896a228036ba51b19453c3\": \"0x2b5e021980cc18000\",\n \"0xa9b2d2e0494eab18e07d37bbb856d80e80f84cd3\": \"0x21e19e0c9bab2400000\",\n \"0xa9ba6f413b82fcddf3affbbdd09287dcf50415ca\": \"0xd8d726b7177a800000\",\n \"0xa9be88ad1e518b0bbb024ab1d8f0e73f790e0c76\": \"0x97c9ce4cf6d5c00000\",\n \"0xa9bfc410dddb20711e45c07387eab30a054e19ac\": \"0x3e99601edf4e530000\",\n \"0xa9d4a2bcbe5b9e0869d70f0fe2e1d6aacd45edc5\": \"0xac6e77ab663a80000\",\n \"0xa9d64b4f3bb7850722b58b478ba691375e224e42\": \"0x14542ba12a337c00000\",\n \"0xa9d6f871ca781a759a20ac3adb972cf12829a208\": \"0x3224f42723d4540000\",\n \"0xa9dc0424c6969d798358b393b1933a1f51bee00a\": \"0x43c33c1937564800000\",\n \"0xa9e194661aac704ee9dea043974e9692ded84a5d\": \"0x1a26a51422a0700000\",\n \"0xa9e28337e6357193d9e2cb236b01be44b81427df\": \"0x77432217e683600000\",\n \"0xa9e6e25e656b762558619f147a21985b8874edfe\": \"0x6c6b935b8bbd400000\",\n \"0xa9e9dbce7a2cb03694799897bed7c54d155fdaa8\": \"0xab5ae8fc99d658000\",\n \"0xa9ed377b7d6ec25971c1a597a3b0f3bead57c98f\": \"0x15af1d78b58c400000\",\n \"0xaa0200f1d17e9c54da0647bb96395d57a78538d8\": \"0x393ef1a5127c800000\",\n \"0xaa0ca3737337178a0caac3099c584b056c56301c\": \"0x2fb474098f67c00000\",\n \"0xaa136b47962bb8b4fb540db4ccf5fdd042ffb8cf\": \"0x1b1b6bd7af64c70000\",\n \"0xaa14422d6f0ae5a758194ed15780c838d67f1ee1\": \"0x60932056c449de80000\",\n \"0xaa16269aac9c0d803068d82fc79151dadd334b66\": \"0xd8d726b7177a800000\",\n \"0xaa167026d39ab7a85635944ed9edb2bfeba11850\": \"0x1c1d5e21b4fcf680000\",\n \"0xaa1b3768c16d821f580e76c8e4c8e86d7dc78853\": \"0x15af1d78b58c400000\",\n \"0xaa1df92e51dff70b1973e0e924c66287b494a178\": \"0x1cf84a30a0a0c00000\",\n \"0xaa2c670096d3f939305325427eb955a8a60db3c5\": \"0x6c95590699232d0000\",\n \"0xaa3135cb54f102cbefe09e96103a1a796718ff54\": \"0x32222d9c331940000\",\n \"0xaa321fdbd449180db8ddd34f0fe906ec18ee0914\": \"0x252248deb6e6940000\",\n \"0xaa3925dc220bb4ae2177b2883078b6dc346ca1b2\": \"0x1b1ae4d6e2ef5000000\",\n \"0xaa3f29601a1331745e05c42830a15e71938a6237\": \"0x5c283d410394100000\",\n \"0xaa47a4ffc979363232c99b99fada0f2734b0aeee\": \"0x1b8489df4dbff940000\",\n \"0xaa493d3f4fb866491cf8f800efb7e2324ed7cfe5\": \"0x5c283d410394100000\",\n \"0xaa56a65dc4abb72f11bae32b6fbb07444791d5c9\": \"0x2894e975bf496c0000\",\n \"0xaa5afcfd8309c2df9d15be5e6a504e7d706624c5\": \"0x13cf422e305a1378000\",\n \"0xaa8eb0823b07b0e6d20aadda0e95cf3835be192e\": \"0x1bc16d674ec800000\",\n \"0xaa91237e740d25a92f7fa146faa18ce56dc6e1f3\": \"0x3224f42723d4540000\",\n \"0xaa960e10c52391c54e15387cc67af827b5316dcc\": \"0x6c6b935b8bbd400000\",\n \"0xaa9bd4589535db27fa2bc903ca17d679dd654806\": \"0x6c6b935b8bbd400000\",\n \"0xaaa8defe11e3613f11067fb983625a08995a8dfc\": \"0xad78ebc5ac6200000\",\n \"0xaaaae68b321402c8ebc13468f341c63c0cf03fce\": \"0x52663ccab1e1c00000\",\n \"0xaaad1baade5af04e2b17439e935987bf8c2bb4b9\": \"0x6c6b935b8bbd400000\",\n \"0xaab00abf5828d7ebf26b47ceaccdb8ba03325166\": \"0x21e19e0c9bab2400000\",\n \"0xaabdb35c1514984a039213793f3345a168e81ff1\": \"0x10cac896d239000000\",\n \"0xaaca60d9d700e78596bbbbb1f1e2f70f4627f9d8\": \"0x3635bb77cb4b860000\",\n \"0xaaced8a9563b1bc311dbdffc1ae7f57519c4440c\": \"0x6c6b935b8bbd400000\",\n \"0xaad2b7f8106695078e6c138ec81a7486aaca1eb2\": \"0xad78ebc5ac6200000\",\n \"0xaae61e43cb0d0c96b30699f77e00d711d0a3979b\": \"0x3635c9adc5dea00000\",\n \"0xaae732eda65988c3a00c7f472f351c463b1c968e\": \"0x6c6b935b8bbd400000\",\n \"0xaaf023fef290a49bb78bb7abc95d669c50d528b0\": \"0xad78ebc5ac6200000\",\n \"0xaaf5b207b88b0de4ac40d747cee06e172df6e745\": \"0x6a7b71d7f51d0900000\",\n \"0xaaf9ee4b886c6d1e95496fd274235bf4ecfcb07d\": \"0x4be4e7267b6ae00000\",\n \"0xaafb7b013aa1f8541c7e327bf650adbd194c208f\": \"0x499e092d01f4780000\",\n \"0xab098633eeee0ccefdf632f9575456f6dd80fc86\": \"0x2a5a058fc295ed000000\",\n \"0xab0ced762e1661fae1a92afb1408889413794825\": \"0x678a932062e4180000\",\n \"0xab14d221e33d544629198cd096ed63dfa28d9f47\": \"0x14542ba12a337c00000\",\n \"0xab209fdca979d0a647010af9a8b52fc7d20d8cd1\": \"0x1eee2532c7c2d040000\",\n \"0xab27ba78c8e5e3daef31ad05aef0ff0325721e08\": \"0x195ece006e02d00000\",\n \"0xab2871e507c7be3965498e8fb462025a1a1c4264\": \"0x2a034919dfbfbc0000\",\n \"0xab3861226ffec1289187fb84a08ec3ed043264e8\": \"0x3635c9adc5dea00000\",\n \"0xab3d86bc82927e0cd421d146e07f919327cdf6f9\": \"0x678a932062e4180000\",\n \"0xab3e62e77a8b225e411592b1af300752fe412463\": \"0x215f835bc769da80000\",\n \"0xab3e78294ba886a0cfd5d3487fb3a3078d338d6e\": \"0x6acb3df27e1f880000\",\n \"0xab4004c0403f7eabb0ea586f212156c4203d67f1\": \"0x6c6acc67d7b1d40000\",\n \"0xab416fe30d58afe5d9454c7fce7f830bcc750356\": \"0x6353701c605db8000\",\n \"0xab4572fbb1d72b575d69ec6ad17333873e8552fc\": \"0x6c6ac54cda68470000\",\n \"0xab5a79016176320973e8cd38f6375530022531c0\": \"0x3635c9adc5dea00000\",\n \"0xab5dfc1ea21adc42cf8c3f6e361e243fd0da61e5\": \"0x1043561a8829300000\",\n \"0xab6b65eab8dfc917ec0251b9db0ecfa0fa032849\": \"0x1b1ae4d6e2ef500000\",\n \"0xab7091932e4bc39dbb552380ca934fd7166d1e6e\": \"0xb50fcfafebecb00000\",\n \"0xab7416ff32254951cbbc624ec7fb45fc7ecaa872\": \"0x126e72a69a50d00000\",\n \"0xab7c42c5e52d641a07ad75099c62928b7f86622f\": \"0x12361aa21d14ba0000\",\n \"0xab7d54c7c6570efca5b4b8ce70f52a5773e5d53b\": \"0xf283abe9d9f380000\",\n \"0xab7e0b83ed9a424c6d1e6a6f87a4dbf06409c7d6\": \"0x821ab0d44149800000\",\n \"0xab84a0f147ad265400002b85029a41fc9ce57f85\": \"0x3635c9adc5dea00000\",\n \"0xab93b26ece0a0aa21365afed1fa9aea31cd54468\": \"0x572b7b98736c200000\",\n \"0xab948a4ae3795cbca13126e19253bdc21d3a8514\": \"0xad78ebc5ac6200000\",\n \"0xab9ad36e5c74ce2e96399f57839431d0e79f96ab\": \"0x8e3f50b173c100000\",\n \"0xabb2e6a72a40ba6ed908cdbcec3c5612583132fe\": \"0x4f2591f896a6500000\",\n \"0xabc068b4979b0ea64a62d3b7aa897d73810dc533\": \"0x6acb3df27e1f880000\",\n \"0xabc45f84db7382dde54c5f7d8938c42f4f3a3bc4\": \"0xad78ebc5ac6200000\",\n \"0xabc4caeb474d4627cb6eb456ecba0ecd08ed8ae1\": \"0xd5967be4fc3f100000\",\n \"0xabc74706964960dfe0dca3dca79e9216056f1cf4\": \"0x878678326eac9000000\",\n \"0xabc9a99e8a2148a55a6d82bd51b98eb5391fdbaf\": \"0x14542ba12a337c00000\",\n \"0xabcdbc8f1dd13af578d4a4774a62182bedf9f9be\": \"0x1fcc27bc459d20000\",\n \"0xabd154903513b8da4f019f68284b0656a1d0169b\": \"0x3635c9adc5dea00000\",\n \"0xabd21eff954fc6a7de26912a7cbb303a6607804e\": \"0x523c9aa696eb940000\",\n \"0xabd4d6c1666358c0406fdf3af248f78ece830104\": \"0x727de34a24f9000000\",\n \"0xabd9605b3e91acfd777830d16463478ae0fc7720\": \"0x73f75d1a085ba0000\",\n \"0xabdc9f1bcf4d19ee96591030e772c334302f7d83\": \"0x87e5e11a81cb5f80000\",\n \"0xabde147b2af789eaa586547e66c4fa2664d328a4\": \"0xd6b6081f34c128000\",\n \"0xabe07ced6ac5ddf991eff6c3da226a741bd243fe\": \"0x21e19e0c9bab2400000\",\n \"0xabf12fa19e82f76c718f01bdca0003674523ef30\": \"0x6c6b935b8bbd400000\",\n \"0xabf728cf9312f22128024e7046c251f5dc5901ed\": \"0x641e8a13563d8f80000\",\n \"0xabf8ffe0708a99b528cc1ed4e9ce4b0d0630be8c\": \"0x7ab5c2aeeee6380000\",\n \"0xabfcf5f25091ce57875fc674dcf104e2a73dd2f2\": \"0x11164759ffb320000\",\n \"0xabfe936425dcc7b74b955082bbaaf2a11d78bc05\": \"0x4be4e7267b6ae00000\",\n \"0xac024f594f9558f04943618eb0e6b2ee501dc272\": \"0x6c6b935b8bbd400000\",\n \"0xac122a03cd058c122e5fe17b872f4877f9df9572\": \"0x6ac5c62d9486070000\",\n \"0xac142eda1157b9a9a64390df7e6ae694fac98905\": \"0xad78ebc5ac6200000\",\n \"0xac1dfc984b71a19929a81d81f04a7cbb14073703\": \"0x2086ac351052600000\",\n \"0xac21c1e5a3d7e0b50681679dd6c792dbca87decb\": \"0x152d02c7e14af6800000\",\n \"0xac2889b5966f0c7f9edb42895cb69d1c04f923a2\": \"0x10f0cf064dd59200000\",\n \"0xac28b5edea05b76f8c5f97084541277c96696a4c\": \"0x3635c9adc5dea00000\",\n \"0xac2c8e09d06493a63858437bd20be01962450365\": \"0x678a932062e4180000\",\n \"0xac2e766dac3f648f637ac6713fddb068e4a4f04d\": \"0xaadec983fcff40000\",\n \"0xac3900298dd14d7cc96d4abb428da1bae213ffed\": \"0x53ca12974851c010000\",\n \"0xac3da526cfce88297302f34c49ca520dc271f9b2\": \"0x2b5e3af16b18800000\",\n \"0xac4460a76e6db2b9fcd152d9c7718d9ac6ed8c6f\": \"0xad78ebc5ac6200000\",\n \"0xac4acfc36ed6094a27e118ecc911cd473e8fb91f\": \"0x61913e14403c0c0000\",\n \"0xac4cc256ae74d624ace80db078b2207f57198f6b\": \"0x6c7974123f64a40000\",\n \"0xac4ee9d502e7d2d2e99e59d8ca7d5f00c94b4dd6\": \"0x3635c9adc5dea00000\",\n \"0xac52b77e15664814f39e4f271be641308d91d6cc\": \"0xbed1d0263d9f00000\",\n \"0xac5999a89d2dd286d5a80c6dee7e86aad40f9e12\": \"0xd255d112e103a00000\",\n \"0xac5f627231480d0d95302e6d89fc32cb1d4fe7e3\": \"0xad78ebc5ac6200000\",\n \"0xac608e2bac9dd20728d2947effbbbf900a9ce94b\": \"0x1454b0db37568fc0000\",\n \"0xac6d02e9a46b379fac4ac9b1d7b5d47bc850ce16\": \"0x5f68e8131ecf800000\",\n \"0xac6f68e837cf1961cb14ab47446da168a16dde89\": \"0x487a9a304539440000\",\n \"0xac77bdf00fd5985b5db12bbef800380abc2a0677\": \"0x3635c9adc5dea00000\",\n \"0xac7e03702723cb16ee27e22dd0b815dc2d5cae9f\": \"0x3635c9adc5dea000000\",\n \"0xac8b509aefea1dbfaf2bb33500d6570b6fd96d51\": \"0x62a992e53a0af00000\",\n \"0xac8e87ddda5e78fcbcb9fa7fc3ce038f9f7d2e34\": \"0x6c6b935b8bbd400000\",\n \"0xac9fff68c61b011efbecf038ed72db97bb9e7281\": \"0x205b4dfa1ee74780000\",\n \"0xaca1e6bc64cc3180f620e94dc5b1bcfd8158e45d\": \"0x6c6b935b8bbd400000\",\n \"0xaca2a838330b17302da731d30db48a04f0f207c1\": \"0x487a9a304539440000\",\n \"0xacaaddcbf286cb0e215dda55598f7ff0f4ada5c6\": \"0x3635c9adc5dea00000\",\n \"0xacb94338554bc488cc88ae2d9d94080d6bdf8410\": \"0x3635c9adc5dea00000\",\n \"0xacbc2d19e06c3babbb5b6f052b6bf7fc37e07229\": \"0xad78ebc5ac6200000\",\n \"0xacbd185589f7a68a67aa4b1bd65077f8c64e4e21\": \"0xad78ebc5ac6200000\",\n \"0xacc062702c59615d3444ef6214b8862b009a02ed\": \"0x514fcb24ff9c500000\",\n \"0xacc0909fda2ea6b7b7a88db7a0aac868091ddbf6\": \"0x133765f1e26c78000\",\n \"0xacc1c78786ab4d2b3b277135b5ba123e0400486b\": \"0x44591d67fecc80000\",\n \"0xacc46a2a555c74ded4a2bd094e821b97843b40c0\": \"0x692ae8897081d00000\",\n \"0xacc59f3b30ceffc56461cc5b8df48902240e0e7b\": \"0x6c6b935b8bbd400000\",\n \"0xacce01e0a70610dc70bb91e9926fa9957f372fba\": \"0x1d1c5f3eda20c40000\",\n \"0xacd8dd91f714764c45677c63d852e56eb9eece2e\": \"0x6c6b935b8bbd400000\",\n \"0xace2abb63b0604409fbde3e716d2876d44e8e5dd\": \"0x83d6c7aab63600000\",\n \"0xacec91ef6941cf630ba9a3e787a012f4a2d91dd4\": \"0x10f0cf064dd592000000\",\n \"0xad0a4ae478e9636e88c604f242cf5439c6d45639\": \"0xbed1d0263d9f000000\",\n \"0xad1799aad7602b4540cd832f9db5f11150f1687a\": \"0x6c6b935b8bbd400000\",\n \"0xad1d68a038fd2586067ef6d135d9628e79c2c924\": \"0xfe09a5279e2abc0000\",\n \"0xad2a5c00f923aaf21ab9f3fb066efa0a03de2fb2\": \"0x3635bb77cb4b860000\",\n \"0xad3565d52b688added08168b2d3872d17d0a26ae\": \"0x56bc75e2d63100000\",\n \"0xad377cd25eb53e83ae091a0a1d2b4516f484afde\": \"0x692ae8897081d00000\",\n \"0xad414d29cb7ee973fec54e22a388491786cf5402\": \"0x2f6f10780d22cc00000\",\n \"0xad44357e017e244f476931c7b8189efee80a5d0a\": \"0x1043561a8829300000\",\n \"0xad57aa9d00d10c439b35efcc0becac2e3955c313\": \"0xad78ebc5ac6200000\",\n \"0xad59a78eb9a74a7fbdaefafa82eada8475f07f95\": \"0x1b1ae4d6e2ef500000\",\n \"0xad5a8d3c6478b69f657db3837a2575ef8e1df931\": \"0x20156e104c1b30000\",\n \"0xad660dec825522a9f62fcec3c5b731980dc286ea\": \"0xa2a15d09519be00000\",\n \"0xad6628352ed3390bafa86d923e56014cfcb360f4\": \"0x6c6b935b8bbd400000\",\n \"0xad728121873f0456d0518b80ab6580a203706595\": \"0x1b1ae4d6e2ef500000\",\n \"0xad732c976593eec4783b4e2ecd793979780bfedb\": \"0x6c6b935b8bbd400000\",\n \"0xad7dd053859edff1cb6f9d2acbed6dd5e332426f\": \"0x6acb3df27e1f880000\",\n \"0xad80d865b85c34d2e6494b2e7aefea6b9af184db\": \"0xd8d726b7177a800000\",\n \"0xad8bfef8c68a4816b3916f35cb7bfcd7d3040976\": \"0x878678326eac9000000\",\n \"0xad8e48a377695de014363a523a28b1a40c78f208\": \"0x3635c9adc5dea00000\",\n \"0xad910a23d6850613654af786337ad2a70868ac6d\": \"0x6c68ccd09b022c0000\",\n \"0xad927e03d1599a78ca2bf0cad2a183dceb71eac0\": \"0x6acb3df27e1f880000\",\n \"0xad92ca066edb7c711dfc5b166192d1edf8e77185\": \"0x79f905c6fd34e800000\",\n \"0xad94235fc3b3f47a2413af31e884914908ef0c45\": \"0x1b1b0142d815840000\",\n \"0xad9e97a0482f353a05c0f792b977b6c7e811fa5f\": \"0xad78ebc5ac6200000\",\n \"0xad9f4c890a3b511cee51dfe6cfd7f1093b76412c\": \"0x1b767cbfeb0ce40000\",\n \"0xadaa0e548c035affed64ca678a963fabe9a26bfd\": \"0x3cb71f51fc5580000\",\n \"0xadb948b1b6fefe207de65e9bbc2de98e605d0b57\": \"0x6c6b935b8bbd400000\",\n \"0xadc19ec835afe3e58d87dc93a8a9213c90451326\": \"0x6adbe5342282000000\",\n \"0xadc8228ef928e18b2a807d00fb3c6c79cd1d9e96\": \"0x13c69df334ee80000\",\n \"0xaddb26317227f45c87a2cb90dc4cfd02fb23caf8\": \"0x3635c9adc5dea00000\",\n \"0xade6f8163bf7c7bb4abe8e9893bd0cc112fe8872\": \"0x11c25d004d01f80000\",\n \"0xadeb204aa0c38e179e81a94ed8b3e7d53047c26b\": \"0x20f5b1eaad8d800000\",\n \"0xadeb52b604e5f77faaac88275b8d6b49e9f9f97f\": \"0x71426b00956ed20000\",\n \"0xadf1acfe99bc8c14b304c8d905ba27657b8a7bc4\": \"0x43c33c1937564800000\",\n \"0xadf85203c8376a5fde9815384a350c3879c4cb93\": \"0x3e31fc675815aa0000\",\n \"0xadff0d1d0b97471e76d789d2e49c8a74f9bd54ff\": \"0x65ea3db75546600000\",\n \"0xae062c448618643075de7a0030342dced63dbad7\": \"0x2cc6cd8cc282b30000\",\n \"0xae10e27a014f0d306baf266d4897c89aeee2e974\": \"0x43c33c1937564800000\",\n \"0xae126b382cf257fad7f0bc7d16297e54cc7267da\": \"0x1043561a8829300000\",\n \"0xae13a08511110f32e53be4127845c843a1a57c7b\": \"0x1b1ae4d6e2ef500000\",\n \"0xae179a460db66326743d24e67523a57b246daf7f\": \"0x10007ae7ce5bbe40000\",\n \"0xae222865799079aaf4f0674a0cdaab02a6d570ff\": \"0x6c6b935b8bbd400000\",\n \"0xae239acffd4ebe2e1ba5b4170572dc79cc6533ec\": \"0x28a857425466f800000\",\n \"0xae2f9c19ac76136594432393b0471d08902164d3\": \"0x25df05c6a897e40000\",\n \"0xae34861d342253194ffc6652dfde51ab44cad3fe\": \"0x194608686316bd8000\",\n \"0xae36f7452121913e800e0fcd1a65a5471c23846f\": \"0x8e3f50b173c100000\",\n \"0xae3f98a443efe00f3e711d525d9894dc9a61157b\": \"0x1004e2e45fb7ee0000\",\n \"0xae47e2609cfafe369d66d415d939de05081a9872\": \"0x5baecf025f9b6500000\",\n \"0xae4f122e35c0b1d1e4069291457c83c07f965fa3\": \"0x3635c9adc5dea00000\",\n \"0xae5055814cb8be0c117bb8b1c8d2b63b4698b728\": \"0x1bc932ec573a38000\",\n \"0xae538c73c5b38d8d584d7ebdadefb15cabe48357\": \"0x3627e8f712373c0000\",\n \"0xae57cc129a96a89981dac60d2ffb877d5dc5e432\": \"0x3c3a2394b396550000\",\n \"0xae5aa1e6c2b60f6fd3efe721bb4a719cbe3d6f5d\": \"0x2b24c6b55a5e620000\",\n \"0xae5c9bdad3c5c8a1220444aea5c229c1839f1d64\": \"0x19e2a4c818b9060000\",\n \"0xae5ce3355a7ba9b332760c0950c2bc45a85fa9a0\": \"0x15af1d78b58c400000\",\n \"0xae5d221afcd3d29355f508eadfca408ce33ca903\": \"0x152d02c7e14af6800000\",\n \"0xae635bf73831119d2d29c0d04ff8f8d8d0a57a46\": \"0x487a9a304539440000\",\n \"0xae648155a658370f929be384f7e001047e49dd46\": \"0x2df24ae32be20440000\",\n \"0xae6f0c73fdd77c489727512174d9b50296611c4c\": \"0x14542ba12a337c00000\",\n \"0xae70e69d2c4a0af818807b1a2705f79fd0b5dbc4\": \"0x35659ef93f0fc40000\",\n \"0xae7739124ed153052503fc101410d1ffd8cd13b7\": \"0x3634fb9f1489a70000\",\n \"0xae78bb849139a6ba38ae92a09a69601cc4cb62d1\": \"0x1b1ae4d6e2ef500000\",\n \"0xae842210f44d14c4a4db91fc9d3b3b50014f7bf7\": \"0xd8d726b7177a800000\",\n \"0xae842e81858ecfedf6506c686dc204ac15bf8b24\": \"0x22b1c8c1227a00000\",\n \"0xae8954f8d6166de507cf61297d0fc7ca6b9e7128\": \"0x1043561a8829300000\",\n \"0xae9ecd6bdd952ef497c0050ae0ab8a82a91898ce\": \"0x1a055690d9db80000\",\n \"0xae9f5c3fbbe0c9bcbf1af8ff74ea280b3a5d8b08\": \"0x5dc892aa1131c80000\",\n \"0xaead88d689416b1c91f2364421375b7d3c70fb2e\": \"0x6c6b935b8bbd400000\",\n \"0xaeadfcd0978edad74a32bd01a0a51d37f246e661\": \"0xe18398e7601900000\",\n \"0xaeb916ebf49d0f86c13f7331cef19e129937512d\": \"0x2085655b8d1b0a0000\",\n \"0xaebd4f205de799b64b3564b256d42a711d37ef99\": \"0x3fcf8b4574f84e0000\",\n \"0xaec27ce2133e82d052520afb5c576d9f7eb93ed2\": \"0xdd04120ba09cfe60000\",\n \"0xaec27ff5d7f9ddda91183f46f9d52543b6cd2b2f\": \"0x18650127cc3dc80000\",\n \"0xaee49d68adedb081fd43705a5f78c778fb90de48\": \"0x1158e460913d00000\",\n \"0xaef5b12258a18dec07d5ec2e316574919d79d6d6\": \"0x6c6b935b8bbd400000\",\n \"0xaefcfe88c826ccf131d54eb4ea9eb80e61e1ee25\": \"0x126e72a69a50d00000\",\n \"0xaf06f5fa6d1214ec43967d1bd4dde74ab814a938\": \"0x4c53ecdc18a600000\",\n \"0xaf1148ef6c8e103d7530efc91679c9ac27000993\": \"0xad78ebc5ac6200000\",\n \"0xaf203e229d7e6d419df4378ea98715515f631485\": \"0x6acb3df27e1f880000\",\n \"0xaf2058c7282cf67c8c3cf930133c89617ce75d29\": \"0x177224aa844c7200000\",\n \"0xaf26f7c6bf453e2078f08953e4b28004a2c1e209\": \"0x56bc75e2d63100000\",\n \"0xaf3087e62e04bf900d5a54dc3e946274da92423b\": \"0x1158e460913d00000\",\n \"0xaf3614dcb68a36e45a4e911e62796247222d595b\": \"0x7a81065f1103bc0000\",\n \"0xaf3615c789d0b1152ad4db25fe5dcf222804cf62\": \"0x3635c9adc5dea00000\",\n \"0xaf3cb5965933e7dad883693b9c3e15beb68a4873\": \"0x6c6b935b8bbd400000\",\n \"0xaf4493e8521ca89d95f5267c1ab63f9f45411e1b\": \"0xad78ebc5ac6200000\",\n \"0xaf4cf41785161f571d0ca69c94f8021f41294eca\": \"0x215f835bc769da80000\",\n \"0xaf529bdb459cc185bee5a1c58bf7e8cce25c150d\": \"0xaadec983fcff40000\",\n \"0xaf67fd3e127fd9dc36eb3fcd6a80c7be4f7532b2\": \"0x5a87e7d7f5f6580000\",\n \"0xaf771039345a343001bc0f8a5923b126b60d509c\": \"0x35659ef93f0fc40000\",\n \"0xaf7f79cb415a1fb8dbbd094607ee8d41fb7c5a3b\": \"0x21e19e0c9bab2400000\",\n \"0xaf87d2371ef378957fbd05ba2f1d66931b01e2b8\": \"0x25f273933db5700000\",\n \"0xaf880fc7567d5595cacce15c3fc14c8742c26c9e\": \"0x73f75d1a085ba0000\",\n \"0xaf8e1dcb314c950d3687434d309858e1a8739cd4\": \"0xe7eeba3410b740000\",\n \"0xaf992dd669c0883e5515d3f3112a13f617a4c367\": \"0x6c6b935b8bbd400000\",\n \"0xafa1d5ad38fed44759c05b8993c1aa0dace19f40\": \"0x4563918244f400000\",\n \"0xafa539586e4719174a3b46b9b3e663a7d1b5b987\": \"0x10f0cf064dd59200000\",\n \"0xafa6946effd5ff53154f82010253df47ae280ccc\": \"0x6acb3df27e1f880000\",\n \"0xafc8ebe8988bd4105acc4c018e546a1e8f9c7888\": \"0x1b1ae4d6e2ef500000\",\n \"0xafcc7dbb8356d842d43ae7e23c8422b022a30803\": \"0x66ffcbfd5e5a3000000\",\n \"0xafd019ff36a09155346b69974815a1c912c90aa4\": \"0x6c6b935b8bbd400000\",\n \"0xafdac5c1cb56e245bf70330066a817eaafac4cd1\": \"0x1158e460913d00000\",\n \"0xafdd1b786162b8317e20f0e979f4b2ce486d765d\": \"0x1158e460913d00000\",\n \"0xaff1045adf27a1aa329461b24de1bae9948a698b\": \"0x1cf84a30a0a0c0000\",\n \"0xaff107960b7ec34ed690b665024d60838c190f70\": \"0x1b1ae4d6e2ef500000\",\n \"0xaff11ccf699304d5f5862af86083451c26e79ae5\": \"0x6c5db2a4d815dc0000\",\n \"0xaff161740a6d909fe99c59a9b77945c91cc91448\": \"0x340aad21b3b700000\",\n \"0xaffc99d5ebb4a84fe7788d97dce274b038240438\": \"0x10f0cf064dd59200000\",\n \"0xaffea0473722cb7f0e0e86b9e11883bf428d8d54\": \"0x692ae8897081d00000\",\n \"0xb00996b0566ecb3e7243b8227988dcb352c21899\": \"0x28a857425466f800000\",\n \"0xb01e389b28a31d8e4995bdd7d7c81beeab1e4119\": \"0x3635c9adc5dea00000\",\n \"0xb02d062873334545cea29218e4057760590f7423\": \"0xacb6a1c7d93a880000\",\n \"0xb02fa29387ec12e37f6922ac4ce98c5b09e0b00f\": \"0x6c6b935b8bbd400000\",\n \"0xb036916bdacf94b69e5a8a65602975eb026104dd\": \"0x1158e460913d00000\",\n \"0xb041310fe9eed6864cedd4bee58df88eb4ed3cac\": \"0x21e19e0c9bab2400000\",\n \"0xb055af4cadfcfdb425cf65ba6431078f07ecd5ab\": \"0x56bc75e2d63100000\",\n \"0xb0571153db1c4ed7acaefe13ecdfdb72e7e4f06a\": \"0x110cff796ac195200000\",\n \"0xb06eab09a610c6a53d56a946b2c43487ac1d5b2d\": \"0x3635c9adc5dea00000\",\n \"0xb07249e055044a9155359a402937bbd954fe48b6\": \"0x56bc75e2d63100000\",\n \"0xb07618328a901307a1b7a0d058fcd5786e9e72fe\": \"0x667495d4a4330ce0000\",\n \"0xb079bb4d9866143a6da72ae7ac0022062981315c\": \"0x29331e6558f0e00000\",\n \"0xb07bcc085ab3f729f24400416837b69936ba8873\": \"0x6c6d84bccdd9ce0000\",\n \"0xb07bcf1cc5d4462e5124c965ecf0d70dc27aca75\": \"0x56bc75e2d631000000\",\n \"0xb07cb9c12405b711807543c4934465f87f98bd2d\": \"0x6c6b935b8bbd400000\",\n \"0xb07fdeaff91d4460fe6cd0e8a1b0bd8d22a62e87\": \"0x11d2529f3535ab00000\",\n \"0xb09fe6d4349b99bc37938054022d54fca366f7af\": \"0x2a5a058fc295ed000000\",\n \"0xb0aa00950c0e81fa3210173e729aaf163a27cd71\": \"0x878678326eac9000000\",\n \"0xb0ac4eff6680ee14169cdadbffdb30804f6d25f5\": \"0x6c6b935b8bbd400000\",\n \"0xb0b36af9aeeedf97b6b02280f114f13984ea3260\": \"0x35659ef93f0fc40000\",\n \"0xb0b779b94bfa3c2e1f587bcc9c7e21789222378f\": \"0x54069233bf7f780000\",\n \"0xb0baeb30e313776c4c6d247402ba4167afcda1cc\": \"0x6acb3df27e1f880000\",\n \"0xb0bb29a861ea1d424d45acd4bfc492fb8ed809b7\": \"0x4563918244f400000\",\n \"0xb0c1b177a220e41f7c74d07cde8569c21c75c2f9\": \"0x12f939c99edab800000\",\n \"0xb0c7ce4c0dc3c2bbb99cc1857b8a455f611711ce\": \"0xd8d726b7177a800000\",\n \"0xb0cef8e8fb8984a6019f01c679f272bbe68f5c77\": \"0x83d6c7aab63600000\",\n \"0xb0d32bd7e4e695b7b01aa3d0416f80557dba9903\": \"0x3739ff0f6e613300000\",\n \"0xb0d3c9872b85056ea0c0e6d1ecf7a77e3ce6ab85\": \"0x10f08eda8e555098000\",\n \"0xb0e469c886593815b3495638595daef0665fae62\": \"0x692ae8897081d00000\",\n \"0xb0e760bb07c081777345e0578e8bc898226d4e3b\": \"0x6c6b935b8bbd400000\",\n \"0xb1043004ec1941a8cf4f2b00b15700ddac6ff17e\": \"0x3635c9adc5dea00000\",\n \"0xb105dd3d987cffd813e9c8500a80a1ad257d56c6\": \"0x6c6acc67d7b1d40000\",\n \"0xb10fd2a647102f881f74c9fbc37da632949f2375\": \"0x22b1c8c1227a00000\",\n \"0xb115ee3ab7641e1aa6d000e41bfc1ec7210c2f32\": \"0x2c0bb3dd30c4e200000\",\n \"0xb1178ad47383c31c8134a1941cbcd474d06244e2\": \"0x3635c9adc5dea00000\",\n \"0xb1179589e19db9d41557bbec1cb24ccc2dec1c7f\": \"0x152d02c7e14af6800000\",\n \"0xb119e79aa9b916526581cbf521ef474ae84dcff4\": \"0x4fba1001e5befe0000\",\n \"0xb11fa7fb270abcdf5a2eab95aa30c4b53636efbf\": \"0x2b5e3af16b18800000\",\n \"0xb124bcb6ffa430fcae2e86b45f27e3f21e81ee08\": \"0x6c6b935b8bbd400000\",\n \"0xb129a5cb7105fe810bd895dc7206a991a4545488\": \"0x1a055690d9db80000\",\n \"0xb12ed07b8a38ad5506363fc07a0b6d799936bdaf\": \"0x21e19e0c9bab2400000\",\n \"0xb134c004391ab4992878337a51ec242f42285742\": \"0x6c6b935b8bbd400000\",\n \"0xb13f93af30e8d7667381b2b95bc1a699d5e3e129\": \"0x16c4abbebea0100000\",\n \"0xb1459285863ea2db3759e546ceb3fb3761f5909c\": \"0x3cd72a894087e08000\",\n \"0xb146a0b925553cf06fcaf54a1b4dfea621290757\": \"0x6c6e59e67c78540000\",\n \"0xb14a7aaa8f49f2fb9a8102d6bbe4c48ae7c06fb2\": \"0x1b1ae4d6e2ef5000000\",\n \"0xb14bbeff70720975dc6191b2a44ff49f2672873c\": \"0x7c0860e5a80dc0000\",\n \"0xb14cc8de33d6338236539a489020ce4655a32bc6\": \"0x1b1ae4d6e2ef5000000\",\n \"0xb14ddb0386fb606398b8cc47565afae00ff1d66a\": \"0xa12aff083e66f00000\",\n \"0xb153f828dd076d4a7c1c2574bb2dee1a44a318a8\": \"0x15af1d78b58c400000\",\n \"0xb1540e94cff3465cc3d187e7c8e3bdaf984659e2\": \"0xa215e44390e3330000\",\n \"0xb158db43fa62d30e65f3d09bf781c7b67372ebaa\": \"0x6c5db2a4d815dc0000\",\n \"0xb161725fdcedd17952d57b23ef285b7e4b1169e8\": \"0x2b6dfed3664958000\",\n \"0xb16479ba8e7df8f63e1b95d149cd8529d735c2da\": \"0x2de33a6aac32548000\",\n \"0xb166e37d2e501ae73c84142b5ffb5aa655dd5a99\": \"0x6c5db2a4d815dc0000\",\n \"0xb183ebee4fcb42c220e47774f59d6c54d5e32ab1\": \"0x56f7a9c33c04d10000\",\n \"0xb188078444027e386798a8ae68698919d5cc230d\": \"0xe7eeba3410b740000\",\n \"0xb1896a37e5d8825a2d01765ae5de629977de8352\": \"0xad78ebc5ac6200000\",\n \"0xb18e67a5050a1dc9fb190919a33da838ef445014\": \"0x1158e460913d00000\",\n \"0xb1a2b43a7433dd150bb82227ed519cd6b142d382\": \"0x946d620d744b880000\",\n \"0xb1c0d08b36e184f9952a4037e3e53a667d070a4e\": \"0x3635c9adc5dea00000\",\n \"0xb1c328fb98f2f19ab6646f0a7c8c566fda5a8540\": \"0x878678326eac900000\",\n \"0xb1c751786939bba0d671a677a158c6abe7265e46\": \"0x21e19e0c9bab2400000\",\n \"0xb1cd4bdfd104489a026ec99d597307a04279f173\": \"0x43c33c1937564800000\",\n \"0xb1cf94f8091505055f010ab4bac696e0ca0f67a1\": \"0x55a6e79ccd1d300000\",\n \"0xb1d6b01b94d854fe8b374aa65e895cf22aa2560e\": \"0x32f51edbaaa3300000\",\n \"0xb1dba5250ba9625755246e067967f2ad2f0791de\": \"0x10f0cf064dd592000000\",\n \"0xb1e2dd95e39ae9775c55aeb13f12c2fa233053ba\": \"0x6c6b935b8bbd400000\",\n \"0xb1e6e810c24ab0488de9e01e574837829f7c77d0\": \"0x15af1d78b58c400000\",\n \"0xb1e9c5f1d21e61757a6b2ee75913fc5a1a4101c3\": \"0x6c6b935b8bbd400000\",\n \"0xb203d29e6c56b92699c4b92d1f6f84648dc4cfbc\": \"0x15af1d78b58c400000\",\n \"0xb216dc59e27c3d7279f5cd5bb2becfb2606e14d9\": \"0x15af1d78b58c400000\",\n \"0xb21b7979bf7c5ca01fa82dd640b41c39e6c6bc75\": \"0x6c6acc67d7b1d40000\",\n \"0xb223bf1fbf80485ca2b5567d98db7bc3534dd669\": \"0xd8d726b7177a800000\",\n \"0xb22d5055d9623135961e6abd273c90deea16a3e7\": \"0x4be4e7267b6ae00000\",\n \"0xb22dadd7e1e05232a93237baed98e0df92b1869e\": \"0x6c6b935b8bbd400000\",\n \"0xb234035f7544463ce1e22bc553064684c513cd51\": \"0xd89fa3dc48dcf0000\",\n \"0xb247cf9c72ec482af3eaa759658f793d670a570c\": \"0x31708ae00454400000\",\n \"0xb2676841ee9f2d31c172e82303b0fe9bbf9f1e09\": \"0xad78ebc5ac6200000\",\n \"0xb279c7d355c2880392aad1aa21ee867c3b3507df\": \"0x445be3f2ef87940000\",\n \"0xb27c1a24204c1e118d75149dd109311e07c073ab\": \"0xa80d24677efef00000\",\n \"0xb28181a458a440f1c6bb1de8400281a3148f4c35\": \"0x14620c57dddae00000\",\n \"0xb28245037cb192f75785cb86cbfe7c930da258b0\": \"0x3635c9adc5dea000000\",\n \"0xb287f7f8d8c3872c1b586bcd7d0aedbf7e732732\": \"0x1158e460913d00000\",\n \"0xb28bb39f3466517cd46f979cf59653ee7d8f152e\": \"0x18650127cc3dc80000\",\n \"0xb28dbfc6499894f73a71faa00abe0f4bc9d19f2a\": \"0x56bc75e2d63100000\",\n \"0xb2968f7d35f208871631c6687b3f3daeabc6616c\": \"0x875c47f289f760000\",\n \"0xb29f5b7c1930d9f97a115e067066f0b54db44b3b\": \"0x3635c9adc5dea00000\",\n \"0xb2a144b1ea67b9510f2267f9da39d3f93de26642\": \"0x6c6b935b8bbd400000\",\n \"0xb2a2c2111612fb8bbb8e7dd9378d67f1a384f050\": \"0x1158e460913d00000\",\n \"0xb2a498f03bd7178bd8a789a00f5237af79a3e3f8\": \"0x41bad155e6512200000\",\n \"0xb2aa2f1f8e93e79713d92cea9ffce9a40af9c82d\": \"0x6c6b935b8bbd400000\",\n \"0xb2b516fdd19e7f3864b6d2cf1b252a4156f1b03b\": \"0x2e983c76115fc0000\",\n \"0xb2b7cdb4ff4b61d5b7ce0b2270bbb5269743ec04\": \"0x6c6b935b8bbd400000\",\n \"0xb2bdbedf95908476d7148a370cc693743628057f\": \"0xd8d726b7177a800000\",\n \"0xb2bfaa58b5196c5cb7f89de15f479d1838de713d\": \"0x1236efcbcbb340000\",\n \"0xb2c53efa33fe4a3a1a80205c73ec3b1dbcad0602\": \"0x6801dab35918938000\",\n \"0xb2d0360515f17daba90fcbac8205d569b915d6ac\": \"0x14542ba12a337c00000\",\n \"0xb2d1e99af91231858e7065dd1918330dc4c747d5\": \"0x3894f0e6f9b9f700000\",\n \"0xb2d9ab9664bcf6df203c346fc692fd9cbab9205e\": \"0x17be78976065180000\",\n \"0xb2ddb786d3794e270187d0451ad6c8b79e0e8745\": \"0x15af1d78b58c400000\",\n \"0xb2e085fddd1468ba07415b274e734e11237fb2a9\": \"0x56bc75e2d63100000\",\n \"0xb2e9d76bf50fc36bf7d3944b63e9ca889b699968\": \"0x9032ea62b74b100000\",\n \"0xb2f9c972c1e9737755b3ff1b3088738396395b26\": \"0x43c33c1937564800000\",\n \"0xb2fc84a3e50a50af02f94da0383ed59f71ff01d7\": \"0x65a4da25d3016c00000\",\n \"0xb3050beff9de33c80e1fa15225e28f2c413ae313\": \"0x25f273933db5700000\",\n \"0xb31196714a48dff726ea9433cd2912f1a414b3b3\": \"0x914878a8c05ee00000\",\n \"0xb3145b74506d1a8d047cdcdc55392a7b5350799a\": \"0x1b6229741c0d3d5d8000\",\n \"0xb320834836d1dbfda9e7a3184d1ad1fd4320ccc0\": \"0x3635c9adc5dea00000\",\n \"0xb323dcbf2eddc5382ee4bbbb201ca3931be8b438\": \"0x6c6b935b8bbd400000\",\n \"0xb32400fd13c5500917cb037b29fe22e7d5228f2d\": \"0x878678326eac9000000\",\n \"0xb325674c01e3f7290d5226339fbeac67d221279f\": \"0x97c9ce4cf6d5c00000\",\n \"0xb32825d5f3db249ef4e85cc4f33153958976e8bc\": \"0x1b2df9d219f5798000\",\n \"0xb32af3d3e8d075344926546f2e32887bf93b16bd\": \"0xad78ebc5ac6200000\",\n \"0xb32f1c2689a5ce79f1bc970b31584f1bcf2283e7\": \"0x1158e460913d00000\",\n \"0xb33c0323fbf9c26c1d8ac44ef74391d0804696da\": \"0x1158e460913d00000\",\n \"0xb34f04b8db65bba9c26efc4ce6efc50481f3d65d\": \"0x43c33c1937564800000\",\n \"0xb3557d39b5411b84445f5f54f38f62d2714d0087\": \"0x2086ac351052600000\",\n \"0xb358e97c70b605b1d7d729dfb640b43c5eafd1e7\": \"0x43c33c1937564800000\",\n \"0xb35e8a1c0dac7e0e66dbac736a592abd44012561\": \"0xcfce55aa12b30000\",\n \"0xb3667894b7863c068ad344873fcff4b5671e0689\": \"0x43c33c1937564800000\",\n \"0xb3717731dad65132da792d876030e46ac227bb8a\": \"0x3635c9adc5dea00000\",\n \"0xb3731b046c8ac695a127fd79d0a5d5fa6ae6d12e\": \"0x6c4fd1ee246e780000\",\n \"0xb37c2b9f50637bece0ca959208aefee6463ba720\": \"0x15af1d78b58c400000\",\n \"0xb388b5dfecd2c5e4b596577c642556dbfe277855\": \"0x1158e460913d00000\",\n \"0xb38c4e537b5df930d65a74d043831d6b485bbde4\": \"0x15af1d78b58c400000\",\n \"0xb39139576194a0866195151f33f2140ad1cc86cf\": \"0x152d02c7e14af6800000\",\n \"0xb39f4c00b2630cab7db7295ef43d47d501e17fd7\": \"0xd8d726b7177a800000\",\n \"0xb3a64b1176724f5409e1414a3523661baee74b4a\": \"0x16368ff4ff9c10000\",\n \"0xb3a6bd41f9d9c3201e050b87198fbda399342210\": \"0xc461e1dd1029b58000\",\n \"0xb3a8c2cb7d358e5739941d945ba9045a023a8bbb\": \"0x3635c9adc5dea00000\",\n \"0xb3ae54fba09d3ee1d6bdd1e957923919024c35fa\": \"0x38d2cee65b22a8000\",\n \"0xb3b7f493b44a2c8d80ec78b1cdc75a652b73b06c\": \"0x6c6b935b8bbd400000\",\n \"0xb3c228731d186d2ded5b5fbe004c666c8e469b86\": \"0x19274b259f6540000\",\n \"0xb3c260609b9df4095e6c5dff398eeb5e2df49985\": \"0xdc55fdb17647b0000\",\n \"0xb3c65b845aba6cd816fbaae983e0e46c82aa8622\": \"0x3635c9adc5dea00000\",\n \"0xb3c94811e7175b148b281c1a845bfc9bb6fbc115\": \"0xad78ebc5ac6200000\",\n \"0xb3e20eb4de18bd060221689894bee5aeb25351ee\": \"0x3fc80cce516598000\",\n \"0xb3e3c439069880156600c2892e448d4136c92d9b\": \"0x2e141ea081ca080000\",\n \"0xb3f82a87e59a39d0d2808f0751eb72c2329cdcc5\": \"0x10f0cf064dd59200000\",\n \"0xb3fc1d6881abfcb8becc0bb021b8b73b7233dd91\": \"0x2b5e3af16b1880000\",\n \"0xb40594c4f3664ef849cca6227b8a25aa690925ee\": \"0xd8d726b7177a800000\",\n \"0xb41eaf5d51a5ba1ba39bb418dbb54fab750efb1f\": \"0x3635c9adc5dea00000\",\n \"0xb424d68d9d0d00cec1938c854e15ffb880ba0170\": \"0xad78ebc5ac6200000\",\n \"0xb4256273962bf631d014555cc1da0dcc31616b49\": \"0x6c6b935b8bbd400000\",\n \"0xb43067fe70d9b55973ba58dc64dd7f311e554259\": \"0xad78ebc5ac6200000\",\n \"0xb43657a50eecbc3077e005d8f8d94f377876bad4\": \"0x1ec1b3a1ff75a0000\",\n \"0xb43c27f7a0a122084b98f483922541c8836cee2c\": \"0x26c29e47c4844c0000\",\n \"0xb4413576869c08f9512ad311fe925988a52d3414\": \"0x21e19e0c9bab2400000\",\n \"0xb44605552471a6eee4daab71ff3bb41326d473e0\": \"0x2d7e3d51ba53d00000\",\n \"0xb447571dacbb3ecbb6d1cf0b0c8f3838e52324e2\": \"0x1a318667fb4058000\",\n \"0xb44783c8e57b480793cbd69a45d90c7b4f0c48ac\": \"0x1158e460913d00000\",\n \"0xb44815a0f28e569d0e921a4ade8fb2642526497a\": \"0x302379bf2ca2e0000\",\n \"0xb4496ddb27799a222457d73979116728e8a1845b\": \"0x8d819ea65fa62f8000\",\n \"0xb4524c95a7860e21840296a616244019421c4aba\": \"0x1b1ae4d6e2ef5000000\",\n \"0xb45cca0d36826662683cf7d0b2fdac687f02d0c4\": \"0x3635c9adc5dea00000\",\n \"0xb46440c797a556e04c7d9104660491f96bb076bf\": \"0xcec76f0e71520000\",\n \"0xb46ace865e2c50ea4698d216ab455dff5a11cd72\": \"0x3635c9adc5dea00000\",\n \"0xb46d1182e5aacaff0d26b2fcf72f3c9ffbcdd97d\": \"0xaa2a603cdd7f2c0000\",\n \"0xb48921c9687d5510744584936e8886bdbf2df69b\": \"0x3635c9adc5dea00000\",\n \"0xb498bb0f520005b6216a4425b75aa9adc52d622b\": \"0xd8d726b7177a800000\",\n \"0xb4b11d109f608fa8edd3fea9f8c315649aeb3d11\": \"0x10f0cf064dd59200000\",\n \"0xb4b14bf45455d0ab0803358b7524a72be1a2045b\": \"0x1b1ae4d6e2ef500000\",\n \"0xb4b185d943ee2b58631e33dff5af6854c17993ac\": \"0x3635c9adc5dea00000\",\n \"0xb4bf24cb83686bc469869fefb044b909716993e2\": \"0x6c6b935b8bbd400000\",\n \"0xb4c20040ccd9a1a3283da4d4a2f365820843d7e2\": \"0x3635c9adc5dea00000\",\n \"0xb4c8170f7b2ab536d1d9a25bdd203ae1288dc3d5\": \"0xad78ebc5ac6200000\",\n \"0xb4d82f2e69943f7de0f5f7743879406fac2e9cec\": \"0x22b1c8c1227a00000\",\n \"0xb4dd460cd016725a64b22ea4f8e06e06674e033e\": \"0x1231bb8748547a80000\",\n \"0xb4dd5499daeb2507fb2de12297731d4c72b16bb0\": \"0x1158e460913d00000\",\n \"0xb5046cb3dc1dedbd364514a2848e44c1de4ed147\": \"0x37b7d9bb820405e0000\",\n \"0xb508f987b2de34ae4cf193de85bff61389621f88\": \"0x14542ba12a337c00000\",\n \"0xb50955aa6e341571986608bdc891c2139f540cdf\": \"0x6acb3df27e1f880000\",\n \"0xb50c149a1906fad2786ffb135aab501737e9e56f\": \"0x150894e849b3900000\",\n \"0xb50c9f5789ae44e2dce017c714caf00c830084c2\": \"0x155bd9307f9fe80000\",\n \"0xb514882c979bb642a80dd38754d5b8c8296d9a07\": \"0x33c5499031720c0000\",\n \"0xb51ddcb4dd4e8ae6be336dd9654971d9fec86b41\": \"0x16d464f83de2948000\",\n \"0xb51e558eb5512fbcfa81f8d0bd938c79ebb5242b\": \"0x26c29e47c4844c0000\",\n \"0xb523fff9749871b35388438837f7e6e0dea9cb6b\": \"0x6c6b935b8bbd400000\",\n \"0xb52dfb45de5d74e3df208332bc571c809b8dcf32\": \"0x14542ba12a337c00000\",\n \"0xb535f8db879fc67fec58824a5cbe6e5498aba692\": \"0x678a932062e4180000\",\n \"0xb537d36a70eeb8d3e5c80de815225c1158cb92c4\": \"0x5150ae84a8cdf00000\",\n \"0xb53bcb174c2518348b818aece020364596466ba3\": \"0x6c6b935b8bbd400000\",\n \"0xb5493ef173724445cf345c035d279ba759f28d51\": \"0x1158e460913d00000\",\n \"0xb553d25d6b5421e81c2ad05e0b8ba751f8f010e3\": \"0x6c6b935b8bbd400000\",\n \"0xb55474ba58f0f2f40e6cbabed4ea176e011fcad6\": \"0x6acb3df27e1f880000\",\n \"0xb555d00f9190cc3677aef314acd73fdc39399259\": \"0x6c6b935b8bbd400000\",\n \"0xb557ab9439ef50d237b553f02508364a466a5c03\": \"0xad78ebc5ac6200000\",\n \"0xb56a780028039c81caf37b6775c620e786954764\": \"0x6c6b935b8bbd400000\",\n \"0xb56ad2aec6c8c3f19e1515bbb7dd91285256b639\": \"0x3635c9adc5dea00000\",\n \"0xb57413060af3f14eb479065f1e9d19b3757ae8cc\": \"0x22b1c8c1227a00000\",\n \"0xb57549bfbc9bdd18f736b22650e48a73601fa65c\": \"0x182d7e4cfda0380000\",\n \"0xb577b6befa054e9c040461855094b002d7f57bd7\": \"0x1823f3cf621d23400000\",\n \"0xb57b04fa23d1203fae061eac4542cb60f3a57637\": \"0xa5aa85009e39c0000\",\n \"0xb5870ce342d43343333673038b4764a46e925f3e\": \"0x3635c9adc5dea00000\",\n \"0xb587b44a2ca79e4bc1dd8bfdd43a207150f2e7e0\": \"0x222c8eb3ff66400000\",\n \"0xb589676d15a04448344230d4ff27c95edf122c49\": \"0x3635c9adc5dea00000\",\n \"0xb58b52865ea55d8036f2fab26098b352ca837e18\": \"0xfc936392801c0000\",\n \"0xb5906b0ae9a28158e8ac550e39da086ee3157623\": \"0xad78ebc5ac6200000\",\n \"0xb5a4679685fa14196c2e9230c8c4e33bffbc10e2\": \"0x4be4e7267b6ae00000\",\n \"0xb5a589dd9f4071dbb6fba89b3f5d5dae7d96c163\": \"0x6c6b935b8bbd400000\",\n \"0xb5a606f4ddcbb9471ec67f658caf2b00ee73025e\": \"0xea756ea92afc740000\",\n \"0xb5ad5157dda921e6bafacd9086ae73ae1f611d3f\": \"0x6c6b935b8bbd400000\",\n \"0xb5add1e7809f7d03069bfe883b0a932210be8712\": \"0x3635c9adc5dea00000\",\n \"0xb5ba29917c78a1d9e5c5c713666c1e411d7f693a\": \"0xa80d24677efef00000\",\n \"0xb5c816a8283ca4df68a1a73d63bd80260488df08\": \"0xad78ebc5ac6200000\",\n \"0xb5cac5ed03477d390bb267d4ebd46101fbc2c3da\": \"0xaadec983fcff40000\",\n \"0xb5cdbc4115406f52e5aa85d0fea170d2979cc7ba\": \"0x487a9a304539440000\",\n \"0xb5d9934d7b292bcf603b2880741eb760288383a0\": \"0xe7c2518505060000\",\n \"0xb5dd50a15da34968890a53b4f13fe1af081baaaa\": \"0xd8d726b7177a800000\",\n \"0xb5fa8184e43ed3e0b8ab91216461b3528d84fd09\": \"0x914878a8c05ee00000\",\n \"0xb5fb7ea2ddc1598b667a9d57dd39e85a38f35d56\": \"0x1b1ae4d6e2ef500000\",\n \"0xb600429752f399c80d0734744bae0a022eca67c6\": \"0x1158e460913d00000\",\n \"0xb600feab4aa96c537504d96057223141692c193a\": \"0x15af1d78b58c400000\",\n \"0xb6047cdf932db3e4045f4976122341537ed5961e\": \"0x1158e460913d00000\",\n \"0xb615e940143eb57f875893bc98a61b3d618c1e8c\": \"0x1158e460913d00000\",\n \"0xb61c34fcacda701a5aa8702459deb0e4ae838df8\": \"0x7695a92c20d6fe00000\",\n \"0xb63064bd3355e6e07e2d377024125a33776c4afa\": \"0x8375a2abcca24400000\",\n \"0xb635a4bc71fb28fdd5d2c322983a56c284426e69\": \"0x93739534d28680000\",\n \"0xb646df98b49442746b61525c81a3b04ba3106250\": \"0x6acb3df27e1f880000\",\n \"0xb65941d44c50d24666670d364766e991c02e11c2\": \"0x2086ac351052600000\",\n \"0xb65bd780c7434115162027565223f44e5498ff8c\": \"0x43c30fb0884a96c0000\",\n \"0xb66411e3a02dedb726fa79107dc90bc1cae64d48\": \"0x6c6b935b8bbd400000\",\n \"0xb66675142e3111a1c2ea1eb2419cfa42aaf7a234\": \"0x3635c9adc5dea00000\",\n \"0xb66f92124b5e63035859e390628869dbdea9485e\": \"0x215f835bc769da80000\",\n \"0xb672734afcc224e2e609fc51d4f059732744c948\": \"0x1004e2e45fb7ee0000\",\n \"0xb6771b0bf3427f9ae7a93e7c2e61ee63941fdb08\": \"0x3fb26692954bfc00000\",\n \"0xb67a80f170197d96cdcc4ab6cba627b4afa6e12c\": \"0x821ab0d44149800000\",\n \"0xb68899e7610d4c93a23535bcc448945ba1666f1c\": \"0xad78ebc5ac6200000\",\n \"0xb6a82933c9eadabd981e5d6d60a6818ff806e36b\": \"0x15af1d78b58c400000\",\n \"0xb6aacb8cb30bab2ae4a2424626e6e12b02d04605\": \"0x1b1ae4d6e2ef5000000\",\n \"0xb6b34a263f10c3d2eceb0acc559a7b2ab85ce565\": \"0xd8d726b7177a800000\",\n \"0xb6bfe1c3ef94e1846fb9e3acfe9b50c3e9069233\": \"0x6c6acc67d7b1d40000\",\n \"0xb6cd7432d5161be79768ad45de3e447a07982063\": \"0xd8d726b7177a800000\",\n \"0xb6ce4dc560fc73dc69fb7a62e388db7e72ea764f\": \"0x345df169e9a3580000\",\n \"0xb6decf82969819ba02de29b9b593f21b64eeda0f\": \"0x281d901f4fdd100000\",\n \"0xb6e6c3222b6b6f9be2875d2a89f127fb64100fe2\": \"0x1b21d5323cc30200000\",\n \"0xb6e8afd93dfa9af27f39b4df06076710bee3dfab\": \"0x15af1d78b58c40000\",\n \"0xb6f78da4f4d041b3bc14bc5ba519a5ba0c32f128\": \"0x247dd32c3fe195048000\",\n \"0xb6fb39786250081426a342c70d47ee521e5bc563\": \"0x32d26d12e980b600000\",\n \"0xb70dba9391682b4a364e77fe99256301a6c0bf1f\": \"0xad78ebc5ac6200000\",\n \"0xb71623f35107cf7431a83fb3d204b29ee0b1a7f4\": \"0x11164759ffb320000\",\n \"0xb71a13ba8e95167b80331b52d69e37054fe7a826\": \"0xad78ebc5ac6200000\",\n \"0xb71b62f4b448c02b1201cb5e394ae627b0a560ee\": \"0x1b1ae4d6e2ef500000\",\n \"0xb72220ade364d0369f2d2da783ca474d7b9b34ce\": \"0x1b1ab319f5ec750000\",\n \"0xb7230d1d1ff2aca366963914a79df9f7c5ea2c98\": \"0x1b1ae4d6e2ef5000000\",\n \"0xb7240af2af90b33c08ae9764103e35dce3638428\": \"0x1cadd2fe9686e638000\",\n \"0xb727a9fc82e1cffc5c175fa1485a9befa2cdbdd1\": \"0x3627e8f712373c0000\",\n \"0xb72c2a011c0df50fbb6e28b20ae1aad217886790\": \"0xd8d726b7177a800000\",\n \"0xb7382d37db0398ac72410cf9813de9f8e1ec8dad\": \"0x3636c25e66ece70000\",\n \"0xb73b4ff99eb88fd89b0b6d57a9bc338e886fa06a\": \"0x1bc16d674ec800000\",\n \"0xb73d6a77559c86cf6574242903394bacf96e3570\": \"0x4f1a77ccd3ba00000\",\n \"0xb74372dbfa181dc9242f39bf1d3731dffe2bdacf\": \"0x6c6b935b8bbd400000\",\n \"0xb7479dab5022c4d5dbaaf8de171b4e951dd1a457\": \"0x4563918244f400000\",\n \"0xb749b54e04d5b19bdcedfb84da7701ab478c27ae\": \"0x914878a8c05ee00000\",\n \"0xb74ed2666001c16333cf7af59e4a3d4860363b9c\": \"0xa7ebd5e4363a00000\",\n \"0xb75149e185f6e3927057739073a1822ae1cf0df2\": \"0xd8d8583fa2d52f0000\",\n \"0xb753a75f9ed10b21643a0a3dc0517ac96b1a4068\": \"0x15c8185b2c1ff40000\",\n \"0xb756ad52f3bf74a7d24c67471e0887436936504c\": \"0x43c33c1937564800000\",\n \"0xb7576e9d314df41ec5506494293afb1bd5d3f65d\": \"0x1158e460913d00000\",\n \"0xb758896f1baa864f17ebed16d953886fee68aae6\": \"0x3635c9adc5dea00000\",\n \"0xb768b5234eba3a9968b34d6ddb481c8419b3655d\": \"0xcfce55aa12b30000\",\n \"0xb782bfd1e2de70f467646f9bc09ea5b1fcf450af\": \"0xe7eeba3410b740000\",\n \"0xb7a2c103728b7305b5ae6e961c94ee99c9fe8e2b\": \"0xa968163f0a57b400000\",\n \"0xb7a31a7c38f3db09322eae11d2272141ea229902\": \"0x6c6b935b8bbd400000\",\n \"0xb7a6791c16eb4e2162f14b6537a02b3d63bfc602\": \"0x2a526391ac93760000\",\n \"0xb7a7f77c348f92a9f1100c6bd829a8ac6d7fcf91\": \"0x62a992e53a0af00000\",\n \"0xb7c077946674ba9341fb4c747a5d50f5d2da6415\": \"0x3635c9adc5dea00000\",\n \"0xb7c0d0cc0b4d342d4062bac624ccc3c70cc6da3f\": \"0xd8d726b7177a800000\",\n \"0xb7c9f12b038e73436d17e1c12ffe1aeccdb3f58c\": \"0x1d460162f516f00000\",\n \"0xb7cc6b1acc32d8b295df68ed9d5e60b8f64cb67b\": \"0x1043561a8829300000\",\n \"0xb7ce684b09abda53389a875369f71958aeac3bdd\": \"0x6c6b935b8bbd400000\",\n \"0xb7d12e84a2e4c4a6345af1dd1da9f2504a2a996e\": \"0xad78ebc5ac6200000\",\n \"0xb7d252ee9402b0eef144295f0e69f0db586c0871\": \"0x23c757072b8dd00000\",\n \"0xb7d581fe0af1ec383f3b3c416783f385146a7612\": \"0x43c33c1937564800000\",\n \"0xb7f67314cb832e32e63b15a40ce0d7ffbdb26985\": \"0x398279264a818d0000\",\n \"0xb8040536958d5998ce4bec0cfc9c2204989848e9\": \"0x52ea70d498fd50a0000\",\n \"0xb8310a16cc6abc465007694b930f978ece1930bd\": \"0x281d901f4fdd100000\",\n \"0xb834acf3015322c58382eeb2b79638906e88b6de\": \"0x5150ae84a8cdf000000\",\n \"0xb84b53d0bb125656cddc52eb852ab71d7259f3d5\": \"0x3635c9adc5dea000000\",\n \"0xb84c8b9fd33ece00af9199f3cf5fe0cce28cd14a\": \"0xcf152640c5c8300000\",\n \"0xb85218f342f8012eda9f274e63ce2152b2dcfdab\": \"0xa80d24677efef00000\",\n \"0xb8555010776e3c5cb311a5adeefe9e92bb9a64b9\": \"0xd8d726b7177a800000\",\n \"0xb85f26dd0e72d9c29ebaf697a8af77472c2b58b5\": \"0x28519acc7190c700000\",\n \"0xb85ff03e7b5fc422981fae5e9941dacbdaba7584\": \"0x487a9a304539440000\",\n \"0xb86607021b62d340cf2652f3f95fd2dc67698bdf\": \"0x10f0cf064dd59200000\",\n \"0xb87de1bcd29269d521b8761cc39cfb4319d2ead5\": \"0x3635c9adc5dea00000\",\n \"0xb87f5376c2de0b6cc3c179c06087aa473d6b4674\": \"0x487a9a304539440000\",\n \"0xb884add88d83dc564ab8e0e02cbdb63919aea844\": \"0x6c6b935b8bbd400000\",\n \"0xb88a37c27f78a617d5c091b7d5b73a3761e65f2a\": \"0x6c6b935b8bbd400000\",\n \"0xb8947822d5ace7a6ad8326e95496221e0be6b73d\": \"0x1158e460913d00000\",\n \"0xb89c036ed7c492879921be41e10ca1698198a74c\": \"0x62a992e53a0af00000\",\n \"0xb89f4632df5909e58b2a9964f74feb9a3b01e0c5\": \"0x48875bcc6e7cbeb8000\",\n \"0xb8a79c84945e47a9c3438683d6b5842cff7684b1\": \"0x6c6b935b8bbd400000\",\n \"0xb8a979352759ba09e35aa5935df175bff678a108\": \"0x1158e460913d00000\",\n \"0xb8ab39805bd821184f6cbd3d2473347b12bf175c\": \"0x6685ac1bfe32c0000\",\n \"0xb8ac117d9f0dba80901445823c4c9d4fa3fedc6e\": \"0x3564c4427a8fc7d8000\",\n \"0xb8bc9bca7f71b4ed12e620438d620f53c114342f\": \"0x1b1ae4d6e2ef500000\",\n \"0xb8bedd576a4b4c2027da735a5bc3f533252a1808\": \"0x6c6b935b8bbd400000\",\n \"0xb8c2703d8c3f2f44c584bc10e7c0a6b64c1c097e\": \"0x12cddb8ead6f9f80000\",\n \"0xb8cc0f060aad92d4eb8b36b3b95ce9e90eb383d7\": \"0x1fc3842bd1f071c00000\",\n \"0xb8d2ddc66f308c0158ae3ccb7b869f7d199d7b32\": \"0x2dcbf4840eca000000\",\n \"0xb8d389e624a3a7aebce4d3e5dbdf6cdc29932aed\": \"0xad78ebc5ac6200000\",\n \"0xb8d531a964bcea13829620c0ced72422dadb4cca\": \"0x93715cc5ab8a70000\",\n \"0xb8d5c324a8209d7c8049d0d4aede02ba80ab578b\": \"0x393928629fff75e8000\",\n \"0xb8f20005b61352ffa7699a1b52f01f5ab39167f1\": \"0x21e19e0c9bab2400000\",\n \"0xb8f30758faa808dbc919aa7b425ec922b93b8129\": \"0x3636d7af5ec98e0000\",\n \"0xb9013c51bd078a098fae05bf2ace0849c6be17a5\": \"0x4563918244f400000\",\n \"0xb9144b677c2dc614ceefdf50985f1183208ea64c\": \"0x6c6b935b8bbd400000\",\n \"0xb916b1a01cdc4e56e7657715ea37e2a0f087d106\": \"0x826e3181e027068000\",\n \"0xb91d9e916cd40d193db60e79202778a0087716fc\": \"0x15f1ba7f4716200000\",\n \"0xb9231eb26e5f9e4b4d288f03906704fab96c87d6\": \"0x42bf06b78ed3b500000\",\n \"0xb92427ad7578b4bfe20a9f63a7c5506d5ca12dc8\": \"0x6c6b935b8bbd400000\",\n \"0xb927abd2d28aaaa24db31778d27419df8e1b04bb\": \"0x17e11c2a26f478000\",\n \"0xb94d47b3c052a5e50e4261ae06a20f45d8eee297\": \"0x6c6b935b8bbd400000\",\n \"0xb95396daaa490df2569324fcc6623be052f132ca\": \"0x6c6b935b8bbd400000\",\n \"0xb959dce02e91d9db02b1bd8b7d17a9c41a97af09\": \"0x1b1ae4d6e2ef5000000\",\n \"0xb95c9b10aa981cf4a67a71cc52c504dee8cf58bd\": \"0xd8d726b7177a800000\",\n \"0xb95cfda8465ba9c2661b249fc3ab661bdfa35ff0\": \"0x114a4e79a2c2108000\",\n \"0xb96841cabbc7dbd69ef0cf8f81dff3c8a5e21570\": \"0x28a857425466f800000\",\n \"0xb97a6733cd5fe99864b3b33460d1672434d5cafd\": \"0x6c65bbaa46c2cf8000\",\n \"0xb981ad5e6b7793a23fc6c1e8692eb2965d18d0da\": \"0x21e18d2c821c7520000\",\n \"0xb98ca31785ef06be49a1e47e864f60d076ca472e\": \"0xd8d726b7177a800000\",\n \"0xb9920fd0e2c735c256463caa240fb7ac86a93dfa\": \"0x5f68e8131ecf800000\",\n \"0xb992a967308c02b98af91ee760fd3b6b4824ab0e\": \"0x6c6b935b8bbd400000\",\n \"0xb9a985501ee950829b17fae1c9cf348c3156542c\": \"0xff17517ca9a620000\",\n \"0xb9b0a3219a3288d9b35b091b14650b8fe23dce2b\": \"0x2f6f10780d22cc00000\",\n \"0xb9cf71b226583e3a921103a5316f855a65779d1b\": \"0x5150ae84a8cdf000000\",\n \"0xb9e90c1192b3d5d3e3ab0700f1bf655f5dd4347a\": \"0x1b19e50b44977c0000\",\n \"0xb9fd3833e88e7cf1fa9879bdf55af4b99cd5ce3f\": \"0x3635c9adc5dea00000\",\n \"0xba0249e01d945bef93ee5ec61925e03c5ca509fd\": \"0xd8d726b7177a800000\",\n \"0xba0f39023bdb29eb1862a9f9059cab5d306e662f\": \"0x6c6b935b8bbd400000\",\n \"0xba10f2764290f875434372f79dbf713801caac01\": \"0x33c5499031720c0000\",\n \"0xba1531fb9e791896bcf3a80558a359f6e7c144bd\": \"0xd5967be4fc3f100000\",\n \"0xba176dbe3249e345cd4fa967c0ed13b24c47e586\": \"0x15aef9f1c31c7f0000\",\n \"0xba1f0e03cb9aa021f4dcebfa94e5c889c9c7bc9e\": \"0x6d190c475169a200000\",\n \"0xba1fcaf223937ef89e85675503bdb7ca6a928b78\": \"0x22b1c8c1227a000000\",\n \"0xba24fc436753a739db2c8d40e6d4d04c528e86fa\": \"0x2c0bb3dd30c4e200000\",\n \"0xba42f9aace4c184504abf5425762aca26f71fbdc\": \"0x207077dd8a79c0000\",\n \"0xba469aa5c386b19295d4a1b5473b540353390c85\": \"0x6c6b935b8bbd400000\",\n \"0xba6440aeb3737b8ef0f1af9b0c15f4c214ffc7cf\": \"0x3635c9adc5dea00000\",\n \"0xba6d31b9a261d640b5dea51ef2162c3109f1eba8\": \"0x10f0cf064dd59200000\",\n \"0xba70e8b4759c0c3c82cc00ac4e9a94dd5bafb2b8\": \"0x3043fa33c412d70000\",\n \"0xba8a63f3f40de4a88388bc50212fea8e064fbb86\": \"0x6c6b935b8bbd400000\",\n \"0xba8e46d69d2e2343d86c60d82cf42c2041a0c1c2\": \"0x56bc75e2d63100000\",\n \"0xbaa4b64c2b15b79f5f204246fd70bcbd86e4a92a\": \"0x1b1ae4d6e2ef500000\",\n \"0xbac8922c4acc7d2cb6fd59a14eb45cf3e702214b\": \"0x2b5e3af16b18800000\",\n \"0xbad235d5085dc7b068a67c412677b03e1836884c\": \"0x6c6b935b8bbd400000\",\n \"0xbad4425e171c3e72975eb46ac0a015db315a5d8f\": \"0x6c6b935b8bbd400000\",\n \"0xbadc2aef9f5951a8d78a6b35c3d0b3a4e6e2e739\": \"0x14542ba12a337c00000\",\n \"0xbade43599e02f84f4c3014571c976b13a36c65ab\": \"0xd8d726b7177a800000\",\n \"0xbae9b82f7299631408659dd74e891cb8f3860fe5\": \"0x6acb3df27e1f880000\",\n \"0xbb0366a7cfbd3445a70db7fe5ae34885754fd468\": \"0x14def2c42ebd6400000\",\n \"0xbb076aac92208069ea318a31ff8eeb14b7e996e3\": \"0x813ca56906d340000\",\n \"0xbb0857f1c911b24b86c8a70681473fe6aaa1cce2\": \"0x56bc75e2d63100000\",\n \"0xbb19bf91cbad74cceb5f811db27e411bc2ea0656\": \"0xf43fc2c04ee00000\",\n \"0xbb27c6a7f91075475ab229619040f804c8ec7a6a\": \"0x21e19e0c9bab2400000\",\n \"0xbb371c72c9f0316cea2bd9c6fbb4079e775429ef\": \"0x5f68e8131ecf800000\",\n \"0xbb3b010b18e6e2be1135871026b7ba15ea0fde24\": \"0x2207c80309b77700000\",\n \"0xbb3b9005f46fd2ca3b30162599928c77d9f6b601\": \"0x1b1ae7f2b1bf7db0000\",\n \"0xbb3fc0a29c034d710812dcc775c8cab9d28d6975\": \"0x39d4e844d1cf5f0000\",\n \"0xbb48eaf516ce2dec3e41feb4c679e4957641164f\": \"0xcf152640c5c8300000\",\n \"0xbb4b4a4b548070ff41432c9e08a0ca6fa7bc9f76\": \"0x2e141ea081ca080000\",\n \"0xbb56a404723cff20d0685488b05a02cdc35aacaa\": \"0x1158e460913d00000\",\n \"0xbb618e25221ad9a740b299ed1406bc3934b0b16d\": \"0x3635c9adc5dea00000\",\n \"0xbb61a04bffd57c10470d45c39103f64650347616\": \"0x3635c9adc5dea00000\",\n \"0xbb6823a1bd819f13515538264a2de052b4442208\": \"0x16368ff4ff9c10000\",\n \"0xbb6c284aac8a69b75cddb00f28e145583b56bece\": \"0x6c6b935b8bbd400000\",\n \"0xbb75cb5051a0b0944b4673ca752a97037f7c8c15\": \"0xad78ebc5ac6200000\",\n \"0xbb993b96ee925ada7d99d786573d3f89180ce3aa\": \"0x6c6b935b8bbd400000\",\n \"0xbba3c68004248e489573abb2743677066b24c8a7\": \"0x6c6b935b8bbd400000\",\n \"0xbba4fac3c42039d828e742cde0efffe774941b39\": \"0x6c6ad382d4fb610000\",\n \"0xbba8ab22d2fedbcfc63f684c08afdf1c175090b5\": \"0x55f29f37e4e3b8000\",\n \"0xbba976f1a1215f7512871892d45f7048acd356c8\": \"0x6c6b935b8bbd400000\",\n \"0xbbab000b0408ed015a37c04747bc461ab14e151b\": \"0x14542ba12a337c00000\",\n \"0xbbabf6643beb4bd01c120bd0598a0987d82967d1\": \"0xb5328178ad0f2a0000\",\n \"0xbbb4ee1d82f2e156442cc93338a2fc286fa28864\": \"0x4a4491bd6dcd280000\",\n \"0xbbb5a0f4802c8648009e8a6998af352cde87544f\": \"0x52d542804f1ce0000\",\n \"0xbbb643d2187b364afc10a6fd368d7d55f50d1a3c\": \"0x3635c9adc5dea00000\",\n \"0xbbb8ffe43f98de8eae184623ae5264e424d0b8d7\": \"0x5d53ffde928080000\",\n \"0xbbbd6ecbb5752891b4ceb3cce73a8f477059376f\": \"0x1f399b1438a100000\",\n \"0xbbbf39b1b67995a42241504f9703d2a14a515696\": \"0x55a6e79ccd1d300000\",\n \"0xbbc8eaff637e94fcc58d913c7770c88f9b479277\": \"0xad78ebc5ac6200000\",\n \"0xbbc9d8112e5beb02dd29a2257b1fe69b3536a945\": \"0x6c6b935b8bbd400000\",\n \"0xbbca65b3266ea2fb73a03f921635f912c7bede00\": \"0x6acb3df27e1f880000\",\n \"0xbbf84292d954acd9e4072fb860b1504106e077ae\": \"0x5150ae84a8cdf00000\",\n \"0xbbf85aaaa683738f073baef44ac9dc34c4c779ea\": \"0x6c6b935b8bbd400000\",\n \"0xbbf8616d97724af3def165d0e28cda89b800009a\": \"0x62ef12e2b17618000\",\n \"0xbbfe0a830cace87b7293993a7e9496ce64f8e394\": \"0x14542ba12a337c00000\",\n \"0xbc0ca4f217e052753614d6b019948824d0d8688b\": \"0x15af1d78b58c400000\",\n \"0xbc0e8745c3a549445c2be900f52300804ab56289\": \"0x7029bf5dd4c53b28000\",\n \"0xbc0f98598f88056a26339620923b8f1eb074a9fd\": \"0xad78ebc5ac6200000\",\n \"0xbc1609d685b76b48ec909aa099219022f89b2ccd\": \"0x40138b917edfb80000\",\n \"0xbc171e53d17ac9b61241ae436deec7af452e7496\": \"0x121ea68c114e5100000\",\n \"0xbc1b021a78fde42d9b5226d6ec26e06aa3670090\": \"0x4563918244f400000\",\n \"0xbc1e80c181616342ebb3fb3992072f1b28b802c6\": \"0xd8d726b7177a800000\",\n \"0xbc237148d30c13836ffa2cad520ee4d2e5c4eeff\": \"0x6acb3df27e1f880000\",\n \"0xbc46d537cf2edd403565bde733b2e34b215001bd\": \"0x43c33c1937564800000\",\n \"0xbc4e471560c99c8a2a4b1b1ad0c36aa6502b7c4b\": \"0x28a857425466f800000\",\n \"0xbc62b3096a91e7dc11a1592a293dd2542150d751\": \"0x3635c9adc5dea00000\",\n \"0xbc69a0d2a31c3dbf7a9122116901b2bdfe9802a0\": \"0xa2a15d09519be00000\",\n \"0xbc6b58364bf7f1951c309e0cba0595201cd73f9a\": \"0x62401a457e45f80000\",\n \"0xbc73f7b1ca3b773b34249ada2e2c8a9274cc17c2\": \"0x6c6b935b8bbd400000\",\n \"0xbc7afc8477412274fc265df13c054473427d43c6\": \"0x70c95920ce3250000\",\n \"0xbc967fe4418c18b99858966d870678dca2b88879\": \"0x1d9cbdd8d7ed2100000\",\n \"0xbc999e385c5aebcac8d6f3f0d60d5aa725336d0d\": \"0x6c6b935b8bbd400000\",\n \"0xbc9c95dfab97a574cea2aa803b5caa197cef0cff\": \"0x16c4abbebea0100000\",\n \"0xbc9e0ec6788f7df4c7fc210aacd220c27e45c910\": \"0x1b1ae4d6e2ef500000\",\n \"0xbca3ffd4683fba0ad3bbc90734b611da9cfb457e\": \"0xad78ebc5ac6200000\",\n \"0xbcaed0acb6a76f113f7c613555a2c3b0f5bf34a5\": \"0xa7ebd5e4363a00000\",\n \"0xbcaf347918efb2d63dde03e39275bbe97d26df50\": \"0x56bc75e2d63100000\",\n \"0xbcb422dc4dd2aae94abae95ea45dd1731bb6b0ba\": \"0x18424f5f0b1b4e0000\",\n \"0xbcbd31252ec288f91e298cd812c92160e738331a\": \"0x6b1bc2cac09a590000\",\n \"0xbcbf6ba166e2340db052ea23d28029b0de6aa380\": \"0xd255d112e103a00000\",\n \"0xbcc84597b91e73d5c5b4d69c80ecf146860f779a\": \"0xed70b5e9c3f2f00000\",\n \"0xbcc9593b2da6df6a34d71b1aa38dacf876f95b88\": \"0x1158e460913d00000\",\n \"0xbcd95ef962462b6edfa10fda87d72242fe3edb5c\": \"0x121d06e12fff988000\",\n \"0xbcd99edc2160f210a05e3a1fa0b0434ced00439b\": \"0x6c6b935b8bbd400000\",\n \"0xbcdfacb9d9023c3417182e9100e8ea1d373393a3\": \"0x3342d60dff1960000\",\n \"0xbce13e22322acfb355cd21fd0df60cf93add26c6\": \"0xad78ebc5ac6200000\",\n \"0xbce40475d345b0712dee703d87cd7657fc7f3b62\": \"0x1a420db02bd7d580000\",\n \"0xbcedc4267ccb89b31bb764d7211171008d94d44d\": \"0xad78ebc5ac6200000\",\n \"0xbcfc98e5c82b6adb180a3fcb120b9a7690c86a3f\": \"0x6acb3df27e1f880000\",\n \"0xbd043b67c63e60f841ccca15b129cdfe6590c8e3\": \"0xad78ebc5ac6200000\",\n \"0xbd047ff1e69cc6b29ad26497a9a6f27a903fc4dd\": \"0x2ee449550898e40000\",\n \"0xbd08e0cddec097db7901ea819a3d1fd9de8951a2\": \"0x1158e460913d00000\",\n \"0xbd09126c891c4a83068059fe0e15796c4661a9f4\": \"0x2b5e3af16b18800000\",\n \"0xbd0c5cd799ebc48642ef97d74e8e429064fee492\": \"0x11ac28a8c729580000\",\n \"0xbd17eed82b9a2592019a1b1b3c0fbad45c408d22\": \"0xd8d726b7177a80000\",\n \"0xbd1803370bddb129d239fd16ea8526a6188ae58e\": \"0x1b1ae4d6e2ef500000\",\n \"0xbd2b70fecc37640f69514fc7f3404946aad86b11\": \"0x410d586a20a4c00000\",\n \"0xbd3097a79b3c0d2ebff0e6e86ab0edadbed47096\": \"0x5a87e7d7f5f6580000\",\n \"0xbd325d4029e0d8729f6d399c478224ae9e7ae41e\": \"0xd255d112e103a00000\",\n \"0xbd432a3916249b4724293af9146e49b8280a7f2a\": \"0xd8d726b7177a800000\",\n \"0xbd47f5f76e3b930fd9485209efa0d4763da07568\": \"0x3635c9adc5dea00000\",\n \"0xbd4b60faec740a21e3071391f96aa534f7c1f44e\": \"0x9ddc1e3b901180000\",\n \"0xbd4bd5b122d8ef7b7c8f0667450320db2116142e\": \"0x2086ac351052600000\",\n \"0xbd51ee2ea143d7b1d6b77e7e44bdd7da12f485ac\": \"0x477e06ccb2b9280000\",\n \"0xbd59094e074f8d79142ab1489f148e32151f2089\": \"0x1158e460913d00000\",\n \"0xbd5a8c94bd8be6470644f70c8f8a33a8a55c6341\": \"0xad78ebc5ac6200000\",\n \"0xbd5e473abce8f97a6932f77c2facaf9cc0a00514\": \"0x3c9258a106a6b70000\",\n \"0xbd5f46caab2c3d4b289396bbb07f203c4da82530\": \"0x4563918244f400000\",\n \"0xbd66ffedb530ea0b2e856dd12ac2296c31fe29e0\": \"0xad78ebc5ac6200000\",\n \"0xbd67d2e2f82da8861341bc96a2c0791fddf39e40\": \"0xad7c07947c8fb0000\",\n \"0xbd6a474d66345bcdd707594adb63b30c7822af54\": \"0xd8d726b7177a800000\",\n \"0xbd723b289a7367b6ece2455ed61edb49670ab9c4\": \"0x10f0cdea164213f8000\",\n \"0xbd73c3cbc26a175062ea0320dd84b253bce64358\": \"0x155bd9307f9fe80000\",\n \"0xbd7419dc2a090a46e2873d7de6eaaad59e19c479\": \"0x170bcb671759f080000\",\n \"0xbd8765f41299c7f479923c4fd18f126d7229047d\": \"0xd8d726b7177a800000\",\n \"0xbd93e550403e2a06113ed4c3fba1a8913b19407e\": \"0x6c6b935b8bbd400000\",\n \"0xbd9e56e902f4be1fc8768d8038bac63e2acbbf8e\": \"0x36356633ebd8ea0000\",\n \"0xbda4be317e7e4bed84c0495eee32d607ec38ca52\": \"0x7d32277978ef4e8000\",\n \"0xbdb60b823a1173d45a0792245fb496f1fd3301cf\": \"0x6c6b935b8bbd400000\",\n \"0xbdbaf6434d40d6355b1e80e40cc4ab9c68d96116\": \"0x56bc75e2d63100000\",\n \"0xbdc02cd4330c93d6fbda4f6db2a85df22f43c233\": \"0x6c6b935b8bbd400000\",\n \"0xbdc461462b6322b462bdb33f22799e8108e2417d\": \"0x243d4d18229ca20000\",\n \"0xbdc739a699700b2e8e2c4a4c7b058a0e513ddebe\": \"0x6c6b935b8bbd400000\",\n \"0xbdc74873af922b9df474853b0fa7ff0bf8c82695\": \"0xd8c9460063d31c0000\",\n \"0xbdca2a0ff34588af625fa8e28fc3015ab5a3aa00\": \"0x7ed73f773552fc0000\",\n \"0xbdd3254e1b3a6dc6cc2c697d45711aca21d516b2\": \"0x6c6b935b8bbd400000\",\n \"0xbddfa34d0ebf1b04af53b99b82494a9e3d8aa100\": \"0x28a857425466f800000\",\n \"0xbde4c73f969b89e9ceae66a2b51844480e038e9a\": \"0x3635c9adc5dea00000\",\n \"0xbde9786a84e75b48f18e726dd78d70e4af3ed802\": \"0x1369fb96128ac480000\",\n \"0xbded11612fb5c6da99d1e30e320bc0995466141e\": \"0x15af1d78b58c400000\",\n \"0xbded7e07d0711e684de65ac8b2ab57c55c1a8645\": \"0x2009c5c8bf6fdc0000\",\n \"0xbdf693f833c3fe471753184788eb4bfe4adc3f96\": \"0x6acb3df27e1f880000\",\n \"0xbdf6e68c0cd7584080e847d72cbb23aad46aeb1d\": \"0x6acb3df27e1f880000\",\n \"0xbe0a2f385f09dbfce96732e12bb40ac349871ba8\": \"0x574c115e02b8be0000\",\n \"0xbe0c2a80b9de084b172894a76cf4737a4f529e1a\": \"0x6c6acc67d7b1d40000\",\n \"0xbe1cd7f4c472070968f3bde268366b21eeea8321\": \"0xe91a7cd19fa3b00000\",\n \"0xbe2346a27ff9b702044f500deff2e7ffe6824541\": \"0x1158e460913d00000\",\n \"0xbe2471a67f6047918772d0e36839255ed9d691ae\": \"0xd8d726b7177a800000\",\n \"0xbe2b2280523768ea8ac35cd9e888d60a719300d4\": \"0x6c6b935b8bbd400000\",\n \"0xbe2b326e78ed10e550fee8efa8f8070396522f5a\": \"0x857e0d6f1da76a00000\",\n \"0xbe305a796e33bbf7f9aeae6512959066efda1010\": \"0x24dce54d34a1a000000\",\n \"0xbe478e8e3dde6bd403bb2d1c657c4310ee192723\": \"0x1ab2cf7c9f87e20000\",\n \"0xbe4e7d983f2e2a636b1102ec7039efebc842e98d\": \"0x393ef1a5127c80000\",\n \"0xbe4fd073617022b67f5c13499b827f763639e4e3\": \"0x6c6b935b8bbd400000\",\n \"0xbe525a33ea916177f17283fca29e8b350b7f530b\": \"0x8f019aaf46e8780000\",\n \"0xbe53322f43fbb58494d7cce19dda272b2450e827\": \"0xad7ceaf425c150000\",\n \"0xbe538246dd4e6f0c20bf5ad1373c3b463a131e86\": \"0xad78ebc5ac6200000\",\n \"0xbe5a60689998639ad75bc105a371743eef0f7940\": \"0x1b327c73e1257a0000\",\n \"0xbe5cba8d37427986e8ca2600e858bb03c359520f\": \"0xa030dcebbd2f4c0000\",\n \"0xbe60037e90714a4b917e61f193d834906703b13a\": \"0x5c283d410394100000\",\n \"0xbe633a3737f68439bac7c90a52142058ee8e8a6f\": \"0x340aad21b3b7000000\",\n \"0xbe659d85e7c34f8833ea7f488de1fbb5d4149bef\": \"0x1ebd23ad9d5bb720000\",\n \"0xbe73274d8c5aa44a3cbefc8263c37ba121b20ad3\": \"0x1b1ae4d6e2ef500000\",\n \"0xbe86d0b0438419ceb1a038319237ba5206d72e46\": \"0x3634fb9f1489a70000\",\n \"0xbe8d7f18adfe5d6cc775394989e1930c979d007d\": \"0x3635c9adc5dea00000\",\n \"0xbe9186c34a52514abb9107860f674f97b821bd5b\": \"0x1ba01ee40603100000\",\n \"0xbe935793f45b70d8045d2654d8dd3ad24b5b6137\": \"0x2fb474098f67c00000\",\n \"0xbe98a77fd41097b34f59d7589baad021659ff712\": \"0x30ca024f987b900000\",\n \"0xbe9b8c34b78ee947ff81472eda7af9d204bc8466\": \"0x821ab0d4414980000\",\n \"0xbea00df17067a43a82bc1daecafb6c14300e89e6\": \"0x62a992e53a0af00000\",\n \"0xbea0afc93aae2108a3fac059623bf86fa582a75e\": \"0x5c283d410394100000\",\n \"0xbeb3358c50cf9f75ffc76d443c2c7f55075a0589\": \"0x90f534608a72880000\",\n \"0xbeb4fd315559436045dcb99d49dcec03f40c42dc\": \"0x6c6b935b8bbd400000\",\n \"0xbec2e6de39c07c2bae556acfbee2c4728b9982e3\": \"0x1f0ff8f01daad40000\",\n \"0xbec6640f4909b58cbf1e806342961d607595096c\": \"0x6c6acc67d7b1d40000\",\n \"0xbec8caf7ee49468fee552eff3ac5234eb9b17d42\": \"0x6c6b935b8bbd400000\",\n \"0xbecef61c1c442bef7ce04b73adb249a8ba047e00\": \"0x363b56c3a754c80000\",\n \"0xbed4649df646e2819229032d8868556fe1e053d3\": \"0xfc936392801c0000\",\n \"0xbed4c8f006a27c1e5f7ce205de75f516bfb9f764\": \"0x3635c9adc5dea000000\",\n \"0xbee8d0b008421954f92d000d390fb8f8e658eaee\": \"0x3635c9adc5dea00000\",\n \"0xbeecd6af900c8b064afcc6073f2d85d59af11956\": \"0x6c6b935b8bbd400000\",\n \"0xbeef94213879e02622142bea61290978939a60d7\": \"0x136857b32ad86048000\",\n \"0xbef07d97c3481f9d6aee1c98f9d91a180a32442b\": \"0x152d02c7e14af6800000\",\n \"0xbefb448c0c5f683fb67ee570baf0db5686599751\": \"0x6acb3df27e1f880000\",\n \"0xbf05070c2c34219311c4548b2614a438810ded6d\": \"0x6c6b935b8bbd400000\",\n \"0xbf05ff5ecf0df2df887759fb8274d93238ac267d\": \"0x2b5e3af16b18800000\",\n \"0xbf09d77048e270b662330e9486b38b43cd781495\": \"0x5c539b7bf4ff28800000\",\n \"0xbf17f397f8f46f1bae45d187148c06eeb959fa4d\": \"0x3649c59624bb300000\",\n \"0xbf183641edb886ce60b8190261e14f42d93cce01\": \"0x15b3557f1937f8000\",\n \"0xbf2aea5a1dcf6ed3b5e8323944e983fedfd1acfb\": \"0x55a6e79ccd1d300000\",\n \"0xbf4096bc547dbfc4e74809a31c039e7b389d5e17\": \"0xd5967be4fc3f100000\",\n \"0xbf49c14898316567d8b709c2e50594b366c6d38c\": \"0x27bf38c6544df50000\",\n \"0xbf4c73a7ede7b164fe072114843654e4d8781dde\": \"0x6c6b935b8bbd400000\",\n \"0xbf50ce2e264b9fe2b06830617aedf502b2351b45\": \"0x3635c9adc5dea00000\",\n \"0xbf59aee281fa43fe97194351a9857e01a3b897b2\": \"0x2086ac351052600000\",\n \"0xbf68d28aaf1eeefef646b65e8cc8d190f6c6da9c\": \"0x6c6b935b8bbd400000\",\n \"0xbf6925c00751008440a6739a02bf2b6cdaab5e3a\": \"0x3635c9adc5dea00000\",\n \"0xbf7701fc6225d5a17815438a8941d21ebc5d059d\": \"0x65ea3db75546600000\",\n \"0xbf8b8005d636a49664f74275ef42438acd65ac91\": \"0xad78ebc5ac6200000\",\n \"0xbf92418a0c6c31244d220260cb3e867dd7b4ef49\": \"0x56900d33ca7fc0000\",\n \"0xbf9acd4445d9c9554689cabbbab18800ff1741c2\": \"0x3635c9adc5dea00000\",\n \"0xbf9f271f7a7e12e36dd2fe9facebf385fe6142bd\": \"0x366f84f7bb7840000\",\n \"0xbfa8c858df102cb12421008b0a31c4c7190ad560\": \"0xad78ebc5ac6200000\",\n \"0xbfaeb91067617dcf8b44172b02af615674835dba\": \"0x8b59e884813088000\",\n \"0xbfb0ea02feb61dec9e22a5070959330299c43072\": \"0x43c33c1937564800000\",\n \"0xbfbca418d3529cb393081062032a6e1183c6b2dc\": \"0x1b1ae4d6e2ef5000000\",\n \"0xbfbe05e88c9cbbcc0e92a405fac1d85de248ee24\": \"0x56bc75e2d63100000\",\n \"0xbfbfbcb656c2992be8fcde8219fbc54aadd59f29\": \"0x21e18d2c821c7520000\",\n \"0xbfc57aa666fae28e9f107a49cb5089a4e22151dd\": \"0x3635c9adc5dea00000\",\n \"0xbfcb9730246304700da90b4153e71141622e1c41\": \"0x3635c9adc5dea00000\",\n \"0xbfd93c90c29c07bc5fb5fc49aeea55a40e134f35\": \"0x5ede20f01a459800000\",\n \"0xbfe3a1fc6e24c8f7b3250560991f93cba2cf8047\": \"0x10f0cf064dd592000000\",\n \"0xbfe6bcb0f0c07852643324aa5df5fd6225abc3ca\": \"0x409e52b48369a0000\",\n \"0xbff5df769934b8943ca9137d0efef2fe6ebbb34e\": \"0x56bc75e2d63100000\",\n \"0xbffb6929241f788693273e7022e60e3eab1fe84f\": \"0x6c6b935b8bbd400000\",\n \"0xc0064f1d9474ab915d56906c9fb320a2c7098c9b\": \"0x13683f7f3c15d80000\",\n \"0xc007f0bdb6e7009202b7af3ea90902697c721413\": \"0xa2a0e43e7fb9830000\",\n \"0xc00ab080b643e1c2bae363e0d195de2efffc1c44\": \"0x1b1ae4d6e2ef500000\",\n \"0xc02077449a134a7ad1ef7e4d927affeceeadb5ae\": \"0xfc936392801c0000\",\n \"0xc02471e3fc2ea0532615a7571d493289c13c36ef\": \"0x1158e460913d00000\",\n \"0xc02d6eadeacf1b78b3ca85035c637bb1ce01f490\": \"0xd8d726b7177a800000\",\n \"0xc033b1325a0af45472c25527853b1f1c21fa35de\": \"0x6c6b935b8bbd400000\",\n \"0xc033be10cb48613bd5ebcb33ed4902f38b583003\": \"0xa2a15d09519be00000\",\n \"0xc0345b33f49ce27fe82cf7c84d141c68f590ce76\": \"0x3635c9adc5dea00000\",\n \"0xc03de42a109b657a64e92224c08dc1275e80d9b2\": \"0x1158e460913d00000\",\n \"0xc04069dfb18b096c7867f8bee77a6dc7477ad062\": \"0x90f534608a72880000\",\n \"0xc0413f5a7c2d9a4b8108289ef6ecd271781524f4\": \"0xa968163f0a57b400000\",\n \"0xc043f2452dcb9602ef62bd360e033dd23971fe84\": \"0x6c6b935b8bbd400000\",\n \"0xc04f4bd4049f044685b883b62959ae631d667e35\": \"0x13b80b99c5185700000\",\n \"0xc056d4bd6bf3cbacac65f8f5a0e3980b852740ae\": \"0x56bc75e2d63100000\",\n \"0xc05b740620f173f16e52471dc38b9c514a0b1526\": \"0x796e3ea3f8ab00000\",\n \"0xc069ef0eb34299abd2e32dabc47944b272334824\": \"0x68155a43676e00000\",\n \"0xc06cebbbf7f5149a66f7eb976b3e47d56516da2f\": \"0x6c6b935b8bbd400000\",\n \"0xc0725ec2bdc33a1d826071dea29d62d4385a8c25\": \"0x8a08513463aa6100000\",\n \"0xc07e3867ada096807a051a6c9c34cc3b3f4ad34a\": \"0x60f06620a849450000\",\n \"0xc0895efd056d9a3a81c3da578ada311bfb9356cf\": \"0xad78ebc5ac6200000\",\n \"0xc090fe23dcd86b358c32e48d2af91024259f6566\": \"0xad78ebc5ac6200000\",\n \"0xc09a66172aea370d9a63da04ff71ffbbfcff7f94\": \"0x6c6b935b8bbd400000\",\n \"0xc09e3cfc19f605ff3ec9c9c70e2540d7ee974366\": \"0x1b1ae4d6e2ef500000\",\n \"0xc0a02ab94ebe56d045b41b629b98462e3a024a93\": \"0x56bc75e2d63100000\",\n \"0xc0a39308a80e9e84aaaf16ac01e3b01d74bd6b2d\": \"0x7664ddd4c1c0b8000\",\n \"0xc0a6cbad77692a3d88d141ef769a99bb9e3c9951\": \"0x56bc75e2d63100000\",\n \"0xc0a7e8435dff14c25577739db55c24d5bf57a3d9\": \"0xa6dd90cae5114480000\",\n \"0xc0ae14d724832e2fce2778de7f7b8daf7b12a93e\": \"0x1158e460913d00000\",\n \"0xc0afb7d8b79370cfd663c68cc6b9702a37cd9eff\": \"0x3635c9adc5dea00000\",\n \"0xc0b0b7a8a6e1acdd05e47f94c09688aa16c7ad8d\": \"0x37b6d02ac76710000\",\n \"0xc0b3f244bca7b7de5b48a53edb9cbeab0b6d88c0\": \"0x13b80b99c5185700000\",\n \"0xc0c04d0106810e3ec0e54a19f2ab8597e69a573d\": \"0x2b5e3af16b1880000\",\n \"0xc0ca3277942e7445874be31ceb902972714f1823\": \"0xd8d726b7177a80000\",\n \"0xc0cbad3ccdf654da22cbcf5c786597ca1955c115\": \"0x6c6b935b8bbd400000\",\n \"0xc0cbf6032fa39e7c46ff778a94f7d445fe22cf30\": \"0x10ce1d3d8cb3180000\",\n \"0xc0e0b903088e0c63f53dd069575452aff52410c3\": \"0xa2a15d09519be00000\",\n \"0xc0e457bd56ec36a1246bfa3230fff38e5926ef22\": \"0x692ae8897081d00000\",\n \"0xc0ed0d4ad10de03435b153a0fc25de3b93f45204\": \"0xab4dcf399a3a600000\",\n \"0xc0f29ed0076611b5e55e130547e68a48e26df5e4\": \"0xa2a15d09519be00000\",\n \"0xc1132878235c5ddba5d9f3228b5236e47020dc6f\": \"0x3635c9adc5dea00000\",\n \"0xc1170dbaadb3dee6198ea544baec93251860fda5\": \"0x410d586a20a4c00000\",\n \"0xc126573d87b0175a5295f1dd07c575cf8cfa15f2\": \"0x21e19e0c9bab2400000\",\n \"0xc127aab59065a28644a56ba3f15e2eac13da2995\": \"0x2086ac351052600000\",\n \"0xc12b7f40df9a2f7bf983661422ab84c9c1f50858\": \"0x1b1ae4d6e2ef5000000\",\n \"0xc12cfb7b3df70fceca0ede263500e27873f8ed16\": \"0x3635c9adc5dea00000\",\n \"0xc12f881fa112b8199ecbc73ec4185790e614a20f\": \"0x6c6b935b8bbd400000\",\n \"0xc1384c6e717ebe4b23014e51f31c9df7e4e25b31\": \"0x1b1ae4d6e2ef500000\",\n \"0xc1438c99dd51ef1ca8386af0a317e9b041457888\": \"0xc1daf81d8a3ce0000\",\n \"0xc1631228efbf2a2e3a4092ee8900c639ed34fbc8\": \"0x33c5499031720c0000\",\n \"0xc175be3194e669422d15fee81eb9f2c56c67d9c9\": \"0xad78ebc5ac6200000\",\n \"0xc1827686c0169485ec15b3a7c8c01517a2874de1\": \"0x22b1c8c1227a00000\",\n \"0xc18ab467feb5a0aadfff91230ff056464d78d800\": \"0x6c6b935b8bbd400000\",\n \"0xc1950543554d8a713003f662bb612c10ad4cdf21\": \"0xfc936392801c0000\",\n \"0xc1a41a5a27199226e4c7eb198b031b59196f9842\": \"0xa5aa85009e39c0000\",\n \"0xc1b2a0fb9cad45cd699192cd27540b88d3384279\": \"0x1b1ae4d6e2ef500000\",\n \"0xc1b2aa8cb2bf62cdc13a47ecc4657facaa995f98\": \"0x363793fa96e6a68000\",\n \"0xc1b500011cfba95d7cd636e95e6cbf6167464b25\": \"0xad78ebc5ac6200000\",\n \"0xc1b9a5704d351cfe983f79abeec3dbbbae3bb629\": \"0x1158e460913d00000\",\n \"0xc1cbd2e2332a524cf219b10d871ccc20af1fb0fa\": \"0x3635c9adc5dea00000\",\n \"0xc1cdc601f89c0428b31302d187e0dc08ad7d1c57\": \"0x14542ba12a337c00000\",\n \"0xc1d4af38e9ba799040894849b8a8219375f1ac78\": \"0x43c33c1937564800000\",\n \"0xc1e1409ca52c25435134d006c2a6a8542dfb7273\": \"0x1dd1e4bd8d1ee0000\",\n \"0xc1eba5684aa1b24cba63150263b7a9131aeec28d\": \"0x1158e460913d00000\",\n \"0xc1ec81dd123d4b7c2dd9b4d438a7072c11dc874c\": \"0x6c6b935b8bbd400000\",\n \"0xc1f39bd35dd9cec337b96f47c677818160df37b7\": \"0x1158e460913d00000\",\n \"0xc1ffad07db96138c4b2a530ec1c7de29b8a0592c\": \"0xf43fc2c04ee00000\",\n \"0xc21fa6643a1f14c02996ad7144b75926e87ecb4b\": \"0x43c33c1937564800000\",\n \"0xc2340a4ca94c9678b7494c3c852528ede5ee529f\": \"0x2a36b05a3fd7c8000\",\n \"0xc239abdfae3e9af5457f52ed2b91fd0ab4d9c700\": \"0x6c6b935b8bbd400000\",\n \"0xc23b2f921ce4a37a259ee4ad8b2158d15d664f59\": \"0x1608995e8bd3f8000\",\n \"0xc24399b4bf86f7338fbf645e3b22b0e0b7973912\": \"0x6c6b935b8bbd400000\",\n \"0xc24ccebc2344cce56417fb684cf81613f0f4b9bd\": \"0x54069233bf7f780000\",\n \"0xc25266c7676632f13ef29be455ed948add567792\": \"0x487a9a304539440000\",\n \"0xc25cf826550c8eaf10af2234fef904ddb95213be\": \"0x3635c9adc5dea00000\",\n \"0xc2663f8145dbfec6c646fc5c49961345de1c9f11\": \"0x2567ac70392b880000\",\n \"0xc270456885342b640b4cfc1b520e1a544ee0d571\": \"0x62a992e53a0af00000\",\n \"0xc27376f45d21e15ede3b26f2655fcee02ccc0f2a\": \"0x1158e460913d00000\",\n \"0xc2779771f0536d79a8708f6931abc44b3035e999\": \"0x43c4f8300dcb3480000\",\n \"0xc27f4e08099d8cf39ee11601838ef9fc06d7fc41\": \"0x61093d7c2c6d380000\",\n \"0xc282e6993fbe7a912ea047153ffd9274270e285b\": \"0x7960b331247638000\",\n \"0xc2836188d9a29253e0cbda6571b058c289a0bb32\": \"0x6c6b935b8bbd400000\",\n \"0xc2aa74847e86edfdd3f3db22f8a2152feee5b7f7\": \"0x6f118886b784a20000\",\n \"0xc2b2cbe65bc6c2ee7a3c75b2e47c189c062e8d8b\": \"0x43c33c1937564800000\",\n \"0xc2bae4a233c2d85724f0dabebda0249d833e37d3\": \"0x10f0cf064dd59200000\",\n \"0xc2c13e72d268e7150dc799e7c6cf03c88954ced7\": \"0x25f273933db5700000\",\n \"0xc2cb1ada5da9a0423873814793f16144ef36b2f3\": \"0x48557e3b7017df0000\",\n \"0xc2d1778ef6ee5fe488c145f3586b6ebbe3fbb445\": \"0x3e1ff1e03b55a80000\",\n \"0xc2d9eedbc9019263d9d16cc5ae072d1d3dd9db03\": \"0x43c33c1937564800000\",\n \"0xc2e0584a71348cc314b73b2029b6230b92dbb116\": \"0x6c6b935b8bbd400000\",\n \"0xc2e2d498f70dcd0859e50b023a710a6d4b2133bd\": \"0x383911f00cbce10000\",\n \"0xc2ed5ffdd1add855a2692fe062b5d618742360d4\": \"0x410d586a20a4c00000\",\n \"0xc2ee91d3ef58c9d1a589844ea1ae3125d6c5ba69\": \"0x34957444b840e80000\",\n \"0xc2fafdd30acb6d6706e9293cb02641f9edbe07b5\": \"0x5100860b430f480000\",\n \"0xc2fd0bf7c725ef3e047e5ae1c29fe18f12a7299c\": \"0x487a9a304539440000\",\n \"0xc2fe7d75731f636dcd09dbda0671393ba0c82a7d\": \"0x77432217e683600000\",\n \"0xc3107a9af3322d5238df0132419131629539577d\": \"0x1ab4e464d414310000\",\n \"0xc3110be01dc9734cfc6e1ce07f87d77d1345b7e1\": \"0x10f0ce949e00f930000\",\n \"0xc32038ca52aee19745be5c31fcdc54148bb2c4d0\": \"0x2b5aad72c65200000\",\n \"0xc325c352801ba883b3226c5feb0df9eae2d6e653\": \"0xd5967be4fc3f100000\",\n \"0xc32ec7e42ad16ce3e2555ad4c54306eda0b26758\": \"0x6c6b935b8bbd400000\",\n \"0xc332df50b13c013490a5d7c75dbfa366da87b6d6\": \"0xd8d726b7177a800000\",\n \"0xc33acdb3ba1aab27507b86b15d67faf91ecf6293\": \"0x6c6b935b8bbd400000\",\n \"0xc33ece935a8f4ef938ea7e1bac87cb925d8490ca\": \"0x7038c16781f78480000\",\n \"0xc340f9b91c26728c31d121d5d6fc3bb56d3d8624\": \"0x6c6b935b8bbd400000\",\n \"0xc346cb1fbce2ab285d8e5401f42dd7234d37e86d\": \"0x486cb9799191e0000\",\n \"0xc3483d6e88ac1f4ae73cc4408d6c03abe0e49dca\": \"0x39992648a23c8a00000\",\n \"0xc348fc5a461323b57be303cb89361b991913df28\": \"0x152d02c7e14af6800000\",\n \"0xc34e3ba1322ed0571183a24f94204ee49c186641\": \"0x327afefa4a7bc0000\",\n \"0xc35b95a2a3737cb8f0f596b34524872bd30da234\": \"0x198be85235e2d500000\",\n \"0xc3631c7698b6c5111989bf452727b3f9395a6dea\": \"0x243275896641dbe0000\",\n \"0xc36c0b63bfd75c2f8efb060883d868cccd6cbdb4\": \"0xa2a15d09519be00000\",\n \"0xc3756bcdcc7eec74ed896adfc335275930266e08\": \"0x14542ba12a337c00000\",\n \"0xc384ac6ee27c39e2f278c220bdfa5baed626d9d3\": \"0x2086ac351052600000\",\n \"0xc3a046e3d2b2bf681488826e32d9c061518cfe8c\": \"0x8cf23f909c0fa00000\",\n \"0xc3a9226ae275df2cab312b911040634a9c9c9ef6\": \"0xd8d726b7177a800000\",\n \"0xc3b928a76fad6578f04f0555e63952cd21d1520a\": \"0x6c6b935b8bbd400000\",\n \"0xc3c2297329a6fd99117e54fc6af379b4d556547e\": \"0x14542ba12a337c00000\",\n \"0xc3c3c2510d678020485a63735d1307ec4ca6302b\": \"0x3635c9adc5dea00000\",\n \"0xc3cb6b36af443f2c6e258b4a39553a818747811f\": \"0x57473d05dabae80000\",\n \"0xc3db5657bb72f10d58f231fddf11980aff678693\": \"0x14061b9d77a5e980000\",\n \"0xc3db9fb6f46c480af34465d79753b4e2b74a67ce\": \"0x43c33c1937564800000\",\n \"0xc3dd58903886303b928625257ae1a013d71ae216\": \"0x6c6b935b8bbd400000\",\n \"0xc3e0471c64ff35fa5232cc3121d1d38d1a0fb7de\": \"0x6c6b935b8bbd400000\",\n \"0xc3e20c96df8d4e38f50b265a98a906d61bc51a71\": \"0x6c6b935b8bbd400000\",\n \"0xc3e387b03ce95ccfd7fa51dd840183bc43532809\": \"0x6c6b935b8bbd400000\",\n \"0xc3f8f67295a5cd049364d05d23502623a3e52e84\": \"0x14542ba12a337c00000\",\n \"0xc401c427cccff10decb864202f36f5808322a0a8\": \"0xb47b51a69cd4020000\",\n \"0xc4088c025f3e85013f5439fb3440a17301e544fe\": \"0x7e09db4d9f3f340000\",\n \"0xc41461a3cfbd32c9865555a4813137c076312360\": \"0x3635c6204739d98000\",\n \"0xc420388fbee84ad656dd68cdc1fbaa9392780b34\": \"0xa2dca63aaf4c58000\",\n \"0xc42250b0fe42e6b7dcd5c890a6f0c88f5f5fb574\": \"0x81ee4825359840000\",\n \"0xc42d6aeb710e3a50bfb44d6c31092969a11aa7f3\": \"0x82263cafd8cea0000\",\n \"0xc440c7ca2f964b6972ef664a2261dde892619d9c\": \"0x43c33c1937564800000\",\n \"0xc44bdec8c36c5c68baa2ddf1d431693229726c43\": \"0x152d02c7e14af6800000\",\n \"0xc44f4ab5bc60397c737eb0683391b633f83c48fa\": \"0x3635c9adc5dea00000\",\n \"0xc452e0e4b3d6ae06b836f032ca09db409ddfe0fb\": \"0x2b5e3af16b18800000\",\n \"0xc45a1ca1036b95004187cdac44a36e33a94ab5c3\": \"0xdd00f720301880000\",\n \"0xc45d47ab0c9aa98a5bd62d16223ea2471b121ca4\": \"0x202e68f2c2aee40000\",\n \"0xc4681e73bb0e32f6b726204831ff69baa4877e32\": \"0x62a992e53a0af00000\",\n \"0xc46bbdef76d4ca60d316c07f5d1a780e3b165f7e\": \"0x6c6b935b8bbd400000\",\n \"0xc47d610b399250f70ecf1389bab6292c91264f23\": \"0xfa7e7b5df3cd00000\",\n \"0xc4803bb407c762f90b7596e6fde194931e769590\": \"0xd8d726b7177a800000\",\n \"0xc48651c1d9c16bff4c9554886c3f3f26431f6f68\": \"0x23ab9599c43f080000\",\n \"0xc489c83ffbb0252ac0dbe3521217630e0f491f14\": \"0xd8d726b7177a800000\",\n \"0xc48b693cacefdbd6cb5d7895a42e3196327e261c\": \"0x3635c9adc5dea00000\",\n \"0xc493489e56c3bdd829007dc2f956412906f76bfa\": \"0x2a791488e71540000\",\n \"0xc496cbb0459a6a01600fc589a55a32b454217f9d\": \"0xeda838c4929080000\",\n \"0xc49cfaa967f3afbf55031061fc4cef88f85da584\": \"0x6c6b935b8bbd400000\",\n \"0xc4b6e5f09cc1b90df07803ce3d4d13766a9c46f4\": \"0x14542ba12a337c00000\",\n \"0xc4bec96308a20f90cab18399c493fd3d065abf45\": \"0x2f6f10780d22cc00000\",\n \"0xc4c01afc3e0f045221da1284d7878574442fb9ac\": \"0x1923c688b73ab040000\",\n \"0xc4c15318d370c73318cc18bdd466dbaa4c6603bf\": \"0x11164759ffb320000\",\n \"0xc4c6cb723dd7afa7eb535615e53f3cef14f18118\": \"0x6c6b8fce0d18798000\",\n \"0xc4cc45a2b63c27c0b4429e58cd42da59be739bd6\": \"0x3635c9adc5dea00000\",\n \"0xc4cf930e5d116ab8d13b9f9a7ec4ab5003a6abde\": \"0x1158e460913d000000\",\n \"0xc4d916574e68c49f7ef9d3d82d1638b2b7ee0985\": \"0x55a6e79ccd1d300000\",\n \"0xc4dac5a8a0264fbc1055391c509cc3ee21a6e04c\": \"0x1606b7fa039ce740000\",\n \"0xc4dd048bfb840e2bc85cb53fcb75abc443c7e90f\": \"0xc971dc07c9c7900000\",\n \"0xc4f2913b265c430fa1ab8adf26c333fc1d9b66f2\": \"0x1158e460913d00000\",\n \"0xc4f7b13ac6d4eb4db3d4e6a252af8a07bd5957da\": \"0xad78ebc5ac6200000\",\n \"0xc4f7d2e2e22084c44f70feaab6c32105f3da376f\": \"0x6acb3df27e1f880000\",\n \"0xc4ff6fbb1f09bd9e102ba033d636ac1c4c0f5304\": \"0x3635c9adc5dea00000\",\n \"0xc4ffadaaf2823fbea7bff702021bffc4853eb5c9\": \"0x24a19c1bd6f128000\",\n \"0xc500b720734ed22938d78c5e48b2ba9367a575ba\": \"0x7129e1cdf373ee00000\",\n \"0xc50fe415a641b0856c4e75bf960515441afa358d\": \"0x6c6b935b8bbd400000\",\n \"0xc5134cfbb1df7a20b0ed7057622eeed280947dad\": \"0xcdff97fabcb4600000\",\n \"0xc517d0315c878813c717e18cafa1eab2654e01da\": \"0x21e19e0c9bab2400000\",\n \"0xc518799a5925576213e21896e0539abb85b05ae3\": \"0x3635c9adc5dea00000\",\n \"0xc522e20fbf04ed7f6b05a37b4718d6fce0142e1a\": \"0xd8d726b7177a800000\",\n \"0xc524086d46c8112b128b2faf6f7c7d8160a8386c\": \"0x15af1d78b58c400000\",\n \"0xc52d1a0c73c2a1be84915185f8b34faa0adf1de3\": \"0x4be4eab3fa0fa68000\",\n \"0xc53594c7cfb2a08f284cc9d7a63bbdfc0b319732\": \"0xa6b2328ff3a62c00000\",\n \"0xc5374928cdf193705443b14cc20da423473cd9cf\": \"0x77d10509bb3af8000\",\n \"0xc538a0ff282aaa5f4b75cfb62c70037ee67d4fb5\": \"0x6c6b935b8bbd400000\",\n \"0xc53b50fd3b2b72bc6c430baf194a515585d3986d\": \"0x1158e460913d00000\",\n \"0xc53d79f7cb9b70952fd30fce58d54b9f0b59f647\": \"0x113e2d6744345f80000\",\n \"0xc549df83c6f65eec0f1dc9a0934a5c5f3a50fd88\": \"0x9dc05cce28c2b80000\",\n \"0xc55005a6c37e8ca7e543ce259973a3cace961a4a\": \"0x6c6b935b8bbd400000\",\n \"0xc555b93156f09101233c6f7cf6eb3c4f196d3346\": \"0xa2a15d09519be00000\",\n \"0xc55a6b4761fd11e8c85f15174d74767cd8bd9a68\": \"0x73f75d1a085ba0000\",\n \"0xc56e6b62ba6e40e52aab167d21df025d0055754b\": \"0x6c6b935b8bbd400000\",\n \"0xc573e841fa08174a208b060ccb7b4c0d7697127f\": \"0x243d4d18229ca20000\",\n \"0xc57612de91110c482e6f505bcd23f3c5047d1d61\": \"0xc2127af858da700000\",\n \"0xc5843399d150066bf7979c34ba294620368ad7c0\": \"0xad78ebc5ac6200000\",\n \"0xc58b9cc61dedbb98c33f224d271f0e228b583433\": \"0xd255d112e103a00000\",\n \"0xc58f62fee9711e6a05dc0910b618420aa127f288\": \"0xd7c198710e66b00000\",\n \"0xc593b546b7698710a205ad468b2c13152219a342\": \"0x54069233bf7f780000\",\n \"0xc593d6e37d14b566643ac4135f243caa0787c182\": \"0x28a857425466f800000\",\n \"0xc5a3b98e4593fea0b38c4f455a5065f051a2f815\": \"0x44cf468af25bf770000\",\n \"0xc5a48a8500f9b4e22f0eb16c6f4649687674267d\": \"0x2c0ec50385043e8000\",\n \"0xc5a629a3962552cb8eded889636aafbd0c18ce65\": \"0x21e19e0c9bab2400000\",\n \"0xc5ae86b0c6c7e3900f1368105c56537faf8d743e\": \"0xa31062beeed700000\",\n \"0xc5b009baeaf788a276bd35813ad65b400b849f3b\": \"0x3635c9adc5dea00000\",\n \"0xc5b56cd234267c28e89c6f6b2266b086a12f970c\": \"0xd8d726b7177a800000\",\n \"0xc5c6a4998a33feb764437a8be929a73ba34a0764\": \"0xa968163f0a57b400000\",\n \"0xc5c73d61cce7c8fe4c8fce29f39092cd193e0fff\": \"0x1b1ae4d6e2ef5000000\",\n \"0xc5c7590b5621ecf8358588de9b6890f2626143f1\": \"0xa2a15d09519be00000\",\n \"0xc5cdcee0e85d117dabbf536a3f4069bf443f54e7\": \"0x6ac5c62d9486070000\",\n \"0xc5d48ca2db2f85d8c555cb0e9cfe826936783f9e\": \"0xad78ebc5ac6200000\",\n \"0xc5de1203d3cc2cea31c82ee2de5916880799eafd\": \"0x10f0cf064dd59200000\",\n \"0xc5e488cf2b5677933971f64cb8202dd05752a2c0\": \"0x3635c9adc5dea00000\",\n \"0xc5e812f76f15f2e1f2f9bc4823483c8804636f67\": \"0x3f514193abb840000\",\n \"0xc5e9939334f1252ed2ba26814487dfd2982b3128\": \"0x3cb71f51fc5580000\",\n \"0xc5eb42295e9cadeaf2af12dede8a8d53c579c469\": \"0xcf152640c5c8300000\",\n \"0xc5edbbd2ca0357654ad0ea4793f8c5cecd30e254\": \"0x14542ba12a337c00000\",\n \"0xc5f64babb7033142f20e46d7aa6201ed86f67103\": \"0x6c6b935b8bbd400000\",\n \"0xc5f687717246da8a200d20e5e9bcac60b67f3861\": \"0x18d993f34aef10000\",\n \"0xc6045b3c350b4ce9ca0c6b754fb41a69b97e9900\": \"0x3224f42723d4540000\",\n \"0xc60b04654e003b4683041f1cbd6bc38fda7cdbd6\": \"0x6c6b935b8bbd400000\",\n \"0xc61446b754c24e3b1642d9e51765b4d3e46b34b6\": \"0x6c6b935b8bbd400000\",\n \"0xc618521321abaf5b26513a4a9528086f220adc6f\": \"0x176b344f2a78c0000\",\n \"0xc6234657a807384126f8968ca1708bb07baa493c\": \"0x1158e460913d00000\",\n \"0xc625f8c98d27a09a1bcabd5128b1c2a94856af30\": \"0xad78ebc5ac6200000\",\n \"0xc6355ec4768c70a49af69513cd83a5bca7e3b9cd\": \"0x14542ba12a337c00000\",\n \"0xc63ac417992e9f9b60386ed953e6d7dff2b090e8\": \"0xd8d8583fa2d52f0000\",\n \"0xc63cd7882118b8a91e074d4c8f4ba91851303b9a\": \"0xe18398e7601900000\",\n \"0xc652871d192422c6bc235fa063b44a7e1d43e385\": \"0x8670e9ec6598c0000\",\n \"0xc667441e7f29799aba616451d53b3f489f9e0f48\": \"0x2f29ace68addd800000\",\n \"0xc66ae4cee87fb3353219f77f1d6486c580280332\": \"0x19a16b06ff8cb0000\",\n \"0xc674f28c8afd073f8b799691b2f0584df942e844\": \"0x6c6b935b8bbd400000\",\n \"0xc697b70477cab42e2b8b266681f4ae7375bb2541\": \"0x12e5732baba5c980000\",\n \"0xc69b855539ce1b04714728eec25a37f367951de7\": \"0x6c6b935b8bbd400000\",\n \"0xc69be440134d6280980144a9f64d84748a37f349\": \"0x26c29e47c4844c0000\",\n \"0xc69d663c8d60908391c8d236191533fdf7775613\": \"0x1a4aba225c20740000\",\n \"0xc6a286e065c85f3af74812ed8bd3a8ce5d25e21d\": \"0xfc936392801c0000\",\n \"0xc6a30ef5bb3320f40dc5e981230d52ae3ac19322\": \"0x9ddc1e3b901180000\",\n \"0xc6ae287ddbe1149ba16ddcca4fe06aa2eaa988a9\": \"0x15af1d78b58c400000\",\n \"0xc6c7c191379897dd9c9d9a33839c4a5f62c0890d\": \"0xd8d854b22430688000\",\n \"0xc6cd68ec35362c5ad84c82ad4edc232125912d99\": \"0x5e0549c9632e1d80000\",\n \"0xc6d8954e8f3fc533d2d230ff025cb4dce14f3426\": \"0x15af1d78b58c400000\",\n \"0xc6dbdb9efd5ec1b3786e0671eb2279b253f215ed\": \"0x3635c9adc5dea00000\",\n \"0xc6df2075ebd240d44869c2be6bdf82e63d4ef1f5\": \"0x1158e460913d00000\",\n \"0xc6e2f5af979a03fd723a1b6efa728318cf9c1800\": \"0x243d4d18229ca20000\",\n \"0xc6e324beeb5b36765ecd464260f7f26006c5c62e\": \"0x6c6b935b8bbd400000\",\n \"0xc6e4cc0c7283fc1c85bc4813effaaf72b49823c0\": \"0xf031ec9c87dd30000\",\n \"0xc6ee35934229693529dc41d9bb71a2496658b88e\": \"0x42bf06b78ed3b500000\",\n \"0xc6fb1ee37417d080a0d048923bdabab095d077c6\": \"0xad78ebc5ac6200000\",\n \"0xc70527d444c490e9fc3f5cc44e66eb4f306b380f\": \"0xd8d726b7177a800000\",\n \"0xc70d856d621ec145303c0a6400cd17bbd6f5eaf7\": \"0x1158e460913d00000\",\n \"0xc70fa45576bf9c865f983893002c414926f61029\": \"0x15b4aa8e9702680000\",\n \"0xc71145e529c7a714e67903ee6206e4c3042b6727\": \"0x4d853c8f8908980000\",\n \"0xc71b2a3d7135d2a85fb5a571dcbe695e13fc43cd\": \"0x3635c9adc5dea00000\",\n \"0xc71f1d75873f33dcb2dd4b3987a12d0791a5ce27\": \"0x3708baed3d68900000\",\n \"0xc71f92a3a54a7b8c2f5ea44305fccb84eee23148\": \"0x2b59ca131d2060000\",\n \"0xc721b2a7aa44c21298e85039d00e2e460e670b9c\": \"0x7a1fe160277000000\",\n \"0xc72cb301258e91bc08998a805dd192f25c2f9a35\": \"0x2009c5c8bf6fdc0000\",\n \"0xc7368b9709a5c1b51c0adf187a65df14e12b7dba\": \"0x2026fc77f03e5ae8000\",\n \"0xc739259e7f85f2659bef5f609ed86b3d596c201e\": \"0xad78ebc5ac6200000\",\n \"0xc73e2112282215dc0762f32b7e807dcd1a7aae3e\": \"0x1760cbc623bb3500000\",\n \"0xc749668042e71123a648975e08ed6382f83e05e2\": \"0x2f6f10780d22cc00000\",\n \"0xc74a3995f807de1db01a2eb9c62e97d0548f696f\": \"0x3635c9adc5dea00000\",\n \"0xc7506c1019121ff08a2c8c1591a65eb4bdfb4a3f\": \"0x2086ac351052600000\",\n \"0xc75c37ce2da06bbc40081159c6ba0f976e3993b1\": \"0x3a7923151ecf580000\",\n \"0xc75d2259306aec7df022768c69899a652185dbc4\": \"0xd8d726b7177a800000\",\n \"0xc760971bbc181c6a7cf77441f24247d19ce9b4cf\": \"0x6c6b935b8bbd400000\",\n \"0xc76130c73cb9210238025c9df95d0be54ac67fbe\": \"0x5150ae84a8cdf00000\",\n \"0xc765e00476810947816af142d46d2ee7bca8cc4f\": \"0x1b1ae4d6e2ef500000\",\n \"0xc7675e5647b9d8daf4d3dff1e552f6b07154ac38\": \"0x9c2007651b2500000\",\n \"0xc77b01a6e911fa988d01a3ab33646beef9c138f3\": \"0x271b6fa5dbe6cc0000\",\n \"0xc7837ad0a0bf14186937ace06c5546a36aa54f46\": \"0xd8d726b7177a800000\",\n \"0xc79806032bc7d828f19ac6a640c68e3d820fa442\": \"0x1158e460913d00000\",\n \"0xc799e34e88ff88be7de28e15e4f2a63d0b33c4cb\": \"0xad78ebc5ac6200000\",\n \"0xc79d5062c796dd7761f1f13e558d73a59f82f38b\": \"0x1b1ae4d6e2ef5000000\",\n \"0xc7a018f0968a51d1f6603c5c49dc545bcb0ff293\": \"0xd8d726b7177a800000\",\n \"0xc7aff91929797489555a2ff1d14d5c695a108355\": \"0x3635c9adc5dea00000\",\n \"0xc7b1c83e63203f9547263ef6282e7da33b6ed659\": \"0xfc936392801c0000\",\n \"0xc7b39b060451000ca1049ba154bcfa00ff8af262\": \"0x152d02c7e14af6800000\",\n \"0xc7bf17c4c11f98941f507e77084fffbd2dbd3db5\": \"0x3635c9adc5dea00000\",\n \"0xc7bf2ed1ed312940ee6aded1516e268e4a604856\": \"0x14542ba12a337c00000\",\n \"0xc7d44fe32c7f8cd5f1a97427b6cd3afc9e45023e\": \"0x55a6e79ccd1d300000\",\n \"0xc7d5c7054081e918ec687b5ab36e973d18132935\": \"0x9ddc1e3b901180000\",\n \"0xc7de5e8eafb5f62b1a0af2195cf793c7894c9268\": \"0x3635c9adc5dea00000\",\n \"0xc7e330cd0c890ac99fe771fcc7e7b009b7413d8a\": \"0xd8d726b7177a800000\",\n \"0xc7eac31abce6d5f1dea42202b6a674153db47a29\": \"0x2009c5c8bf6fdc0000\",\n \"0xc7ec62b804b1f69b1e3070b5d362c62fb309b070\": \"0x2c46bf5416066110000\",\n \"0xc7f72bb758016b374714d4899bce22b4aec70a31\": \"0x3a26c9478f5e2d0000\",\n \"0xc80b36d1beafba5fcc644d60ac6e46ed2927e7dc\": \"0xb98bc829a6f90000\",\n \"0xc811c2e9aa1ac3462eba5e88fcb5120e9f6e2ca2\": \"0x4be6d887bd876e0000\",\n \"0xc817df1b91faf30fe3251571727c9711b45d8f06\": \"0x6c6acc67d7b1d40000\",\n \"0xc81fb7d20fd2800192f0aac198d6d6a37d3fcb7d\": \"0xe1149331c2dde0000\",\n \"0xc820c711f07705273807aaaa6de44d0e4b48be2e\": \"0x8670e9ec6598c0000\",\n \"0xc8231ba5a411a13e222b29bfc1083f763158f226\": \"0x3637096c4bcc690000\",\n \"0xc836e24a6fcf29943b3608e662290a215f6529ea\": \"0xfd45064eaee100000\",\n \"0xc83ba6dd9549be1d3287a5a654d106c34c6b5da2\": \"0x17b7883c06916600000\",\n \"0xc83e9d6a58253beebeb793e6f28b054a58491b74\": \"0xf46c2b6f5a9140000\",\n \"0xc841884fa4785fb773b28e9715fae99a5134305d\": \"0x6c6b935b8bbd400000\",\n \"0xc84d9bea0a7b9f140220fd8b9097cfbfd5edf564\": \"0x6ab9ec291ad7d8000\",\n \"0xc852428d2b586497acd30c56aa13fb5582f84402\": \"0x3342d60dff19600000\",\n \"0xc853215b9b9f2d2cd0741e585e987b5fb80c212e\": \"0x54069233bf7f780000\",\n \"0xc85325eab2a59b3ed863c86a5f2906a04229ffa9\": \"0x193d7f7d253de00000\",\n \"0xc85ef27d820403805fc9ed259fff64acb8d6346a\": \"0x6c6b935b8bbd400000\",\n \"0xc8616b4ec09128cdff39d6e4b9ac86eec471d5f2\": \"0x10d3aa536e2940000\",\n \"0xc86190904b8d079ec010e462cbffc90834ffaa5c\": \"0x22385a827e815500000\",\n \"0xc8710d7e8b5a3bd69a42fe0fa8b87c357fddcdc8\": \"0xd8d726b7177a800000\",\n \"0xc87352dba582ee2066b9c002a962e003134f78b1\": \"0x1b1ae4d6e2ef500000\",\n \"0xc87c77e3c24adecdcd1038a38b56e18dead3b702\": \"0x1dd0c885f9a0d800000\",\n \"0xc87d3ae3d88704d9ab0009dcc1a0067131f8ba3c\": \"0x6ac5c62d9486070000\",\n \"0xc8814e34523e38e1f927a7dce8466a447a093603\": \"0x21e19e0c9bab2400000\",\n \"0xc88255eddcf521c6f81d97f5a42181c9073d4ef1\": \"0xfc39044d00a2a8000\",\n \"0xc885a18aabf4541b7b7b7ecd30f6fae6869d9569\": \"0x6c6b935b8bbd400000\",\n \"0xc88ca1e6e5f4d558d13780f488f10d4ad3130d34\": \"0x54069233bf7f780000\",\n \"0xc88eec54d305c928cc2848c2fee23531acb96d49\": \"0x6c6ad382d4fb610000\",\n \"0xc89cf504b9f3f835181fd8424f5ccbc8e1bddf7d\": \"0x21e19e0c9bab2400000\",\n \"0xc8a2c4e59e1c7fc54805580438aed3e44afdf00e\": \"0x2629f66e0c5300000\",\n \"0xc8aa49e3809f0899f28ab57e6743709d58419033\": \"0x2fb474098f67c00000\",\n \"0xc8ab1a3cf46cb8b064df2e222d39607394203277\": \"0x6c6b935b8bbd400000\",\n \"0xc8b1850525d946f2ae84f317b15188c536a5dc86\": \"0x918ddc3a42a3d40000\",\n \"0xc8d4e1599d03b79809e0130a8dc38408f05e8cd3\": \"0x9fad06241279160000\",\n \"0xc8dd27f16bf22450f5771b9fe4ed4ffcb30936f4\": \"0xaadec983fcff40000\",\n \"0xc8de7a564c7f4012a6f6d10fd08f47890fbf07d4\": \"0x1043561a8829300000\",\n \"0xc8e2adeb545e499d982c0c117363ceb489c5b11f\": \"0x35659ef93f0fc40000\",\n \"0xc8e558a3c5697e6fb23a2594c880b7a1b68f9860\": \"0x21e19e0c9bab2400000\",\n \"0xc8f2b320e6dfd70906c597bad2f9501312c78259\": \"0x51934b8b3a57d00000\",\n \"0xc90300cb1d4077e6a6d7e169a460468cf4a492d7\": \"0x6c6b935b8bbd400000\",\n \"0xc90c3765156bca8e4897ab802419153cbe5225a9\": \"0xad78ebc5ac6200000\",\n \"0xc910a970556c9716ea53af66ddef93143124913d\": \"0x55a6e79ccd1d300000\",\n \"0xc9127b7f6629ee13fc3f60bc2f4467a20745a762\": \"0x37c9aa4e7ce421d8000\",\n \"0xc91bb562e42bd46130e2d3ae4652b6a4eb86bc0f\": \"0x1d460162f516f00000\",\n \"0xc9308879056dfe138ef8208f79a915c6bc7e70a8\": \"0x21e19e0c9bab2400000\",\n \"0xc934becaf71f225f8b4a4bf7b197f4ac9630345c\": \"0x43c33c1937564800000\",\n \"0xc93fbde8d46d2bcc0fa9b33bd8ba7f8042125565\": \"0x4be4e7267b6ae00000\",\n \"0xc94089553ae4c22ca09fbc98f57075cf2ec59504\": \"0xd8d726b7177a800000\",\n \"0xc94110e71afe578aa218e4fc286403b0330ace8d\": \"0x6c6b935b8bbd400000\",\n \"0xc946d5acc1346eba0a7279a0ac1d465c996d827e\": \"0x3783d545fdf0aa40000\",\n \"0xc94a28fb3230a9ddfa964e770f2ce3c253a7be4f\": \"0xad78ebc5ac6200000\",\n \"0xc94a585203da7bbafd93e15884e660d4b1ead854\": \"0x17b7883c06916600000\",\n \"0xc94f7c35c027d47df8ef4f9df85a9248a17dd23b\": \"0x19f8e7559924c0000\",\n \"0xc951900c341abbb3bafbf7ee2029377071dbc36a\": \"0x11c25d004d01f80000\",\n \"0xc953f934c0eb2d0f144bdab00483fd8194865ce7\": \"0x6c6b935b8bbd400000\",\n \"0xc96626728aaa4c4fb3d31c26df3af310081710d1\": \"0xb50fcfafebecb00000\",\n \"0xc96751656c0a8ef4357b7344322134b983504aca\": \"0x6c6b935b8bbd400000\",\n \"0xc98048687f2bfcc9bd90ed18736c57edd352b65d\": \"0x3635c9adc5dea00000\",\n \"0xc981d312d287d558871edd973abb76b979e5c35e\": \"0x6acb3df27e1f880000\",\n \"0xc982586d63b0d74c201b1af8418372e30c7616be\": \"0x56bc75e2d63100000\",\n \"0xc989434f825aaf9c552f685eba7c11db4a5fc73a\": \"0x1b28c58d9696b40000\",\n \"0xc989eec307e8839b9d7237cfda08822962abe487\": \"0x15af1d78b58c400000\",\n \"0xc992be59c6721caf4e028f9e8f05c25c55515bd4\": \"0x1158e460913d00000\",\n \"0xc9957ba94c1b29e5277ec36622704904c63dc023\": \"0x683efc6782642c0000\",\n \"0xc99a9cd6c9c1be3534eecd92ecc22f5c38e9515b\": \"0x105593b3a169d770000\",\n \"0xc9ac01c3fb0929033f0ccc7e1acfeaaba7945d47\": \"0x2a36a9e9ca4d2038000\",\n \"0xc9b698e898d20d4d4f408e4e4d061922aa856307\": \"0x22b1c8c1227a00000\",\n \"0xc9b6b686111691ee6aa197c7231a88dc60bd295d\": \"0x1b1ae4d6e2ef500000\",\n \"0xc9c7ac0bdd9342b5ead4360923f68c72a6ba633a\": \"0x1b1ae4d6e2ef500000\",\n \"0xc9c80dc12e7bab86e949d01e4c3ed35f2b9bba5f\": \"0x6c6b935b8bbd400000\",\n \"0xc9d76446d5aadff80b68b91b08cd9bc8f5551ac1\": \"0x26b4bd9110dce80000\",\n \"0xc9dcbb056f4db7d9da39936202c5bd8230b3b477\": \"0x43c33c1937564800000\",\n \"0xc9e02608066828848aeb28c73672a12925181f4d\": \"0x1b1b6bd7af64c70000\",\n \"0xca0432cb157b5179f02ebba5c9d1b54fec4d88ca\": \"0x3635c9adc5dea00000\",\n \"0xca122cf0f2948896b74843f49afed0ba1618eed7\": \"0x1e5b8fa8fe2ac00000\",\n \"0xca22cda3606da5cad013b8074706d7e9e721a50c\": \"0x17181c6fa3981940000\",\n \"0xca23f62dff0d6460036c62e840aec5577e0befd2\": \"0x7a1fe160277000000\",\n \"0xca25ff34934c1942e22a4e7bd56f14021a1af088\": \"0xaadec983fcff40000\",\n \"0xca373fe3c906b8c6559ee49ccd07f37cd4fb5266\": \"0x61093d7c2c6d380000\",\n \"0xca41ccac30172052d522cd2f2f957d248153409f\": \"0x6acb3df27e1f880000\",\n \"0xca4288014eddc5632f5facb5e38517a8f8bc5d98\": \"0x126e72a69a50d00000\",\n \"0xca428863a5ca30369892d612183ef9fb1a04bcea\": \"0x52663ccab1e1c00000\",\n \"0xca49a5f58adbefae23ee59eea241cf0482622eaa\": \"0x4d853c8f8908980000\",\n \"0xca4ca9e4779d530ecbacd47e6a8058cfde65d98f\": \"0x2b5e3af16b18800000\",\n \"0xca657ec06fe5bc09cf23e52af7f80cc3689e6ede\": \"0x30ca024f987b900000\",\n \"0xca66b2280fa282c5b67631ce552b62ee55ad8474\": \"0x6ac422f53492880000\",\n \"0xca6c818befd251361e02744068be99d8aa60b84a\": \"0x14542ba12a337c00000\",\n \"0xca70f4ddbf069d2143bd6bbc7f696b52789b32e7\": \"0xa2a15d09519be00000\",\n \"0xca747576446a4c8f30b08340fee198de63ec92cf\": \"0x17c8e1206722a300000\",\n \"0xca7ba3ff536c7e5f0e153800bd383db8312998e0\": \"0x931ac3d6bb2400000\",\n \"0xca8276c477b4a07b80107b843594189607b53bec\": \"0x14542ba12a337c00000\",\n \"0xca8409083e01b397cf12928a05b68455ce6201df\": \"0x56bc75e2d631000000\",\n \"0xca98c7988efa08e925ef9c9945520326e9f43b99\": \"0xd8d726b7177a800000\",\n \"0xca9a042a6a806ffc92179500d24429e8ab528117\": \"0x3ba1910bf341b00000\",\n \"0xca9dec02841adf5cc920576a5187edd2bd434a18\": \"0x1b1ae4d6e2ef500000\",\n \"0xca9faa17542fafbb388eab21bc4c94e8a7b34788\": \"0x6c6b8fce0d18798000\",\n \"0xcaaa68ee6cdf0d34454a769b0da148a1faaa1865\": \"0x1872e1de7fe52c00000\",\n \"0xcaad9dc20d589ce428d8fda3a9d53a607b7988b5\": \"0xd8d726b7177a800000\",\n \"0xcab0d32cf3767fa6b3537c84328baa9f50458136\": \"0x1e5b8fa8fe2ac000000\",\n \"0xcab9a301e6bd46e940355028eccd40ce4d5a1ac3\": \"0x15af1d78b58c400000\",\n \"0xcab9a97ada065c87816e6860a8f1426fe6b3d775\": \"0x3635c9adc5dea00000\",\n \"0xcabab6274ed15089737e287be878b757934864e2\": \"0x43c33c1937564800000\",\n \"0xcabdaf354f4720a466a764a528d60e3a482a393c\": \"0x3635c9adc5dea00000\",\n \"0xcacb675e0996235404efafbb2ecb8152271b55e0\": \"0x25f273933db5700000\",\n \"0xcad14f9ebba76680eb836b079c7f7baaf481ed6d\": \"0xcef3d7bd7d0340000\",\n \"0xcae3a253bcb2cf4e13ba80c298ab0402da7c2aa0\": \"0x124bc0ddd92e5600000\",\n \"0xcaef027b1ab504c73f41f2a10979b474f97e309f\": \"0xad78ebc5ac6200000\",\n \"0xcaf4481d9db78dc4f25f7b4ac8bd3b1ca0106b31\": \"0x10f0cf064dd59200000\",\n \"0xcafde855864c2598da3cafc05ad98df2898e8048\": \"0x300a8ed96ff4a940000\",\n \"0xcb0dd7cf4e5d8661f6028943a4b9b75c914436a7\": \"0x1969368974c05b000000\",\n \"0xcb1bb6f1da5eb10d4899f7e61d06c1b00fdfb52d\": \"0x384524cc70b7780000\",\n \"0xcb3d766c983f192bcecac70f4ee03dd9ff714d51\": \"0x56bc75e2d63100000\",\n \"0xcb42b44eb5fd60b5837e4f9eb47267523d1a229c\": \"0x2ee449550898e40000\",\n \"0xcb47bd30cfa8ec5468aaa6a94642ced9c819c8d4\": \"0xd8d726b7177a800000\",\n \"0xcb48fe8265d9af55eb7006bc335645b0a3a183be\": \"0xa2a15d09519be00000\",\n \"0xcb4a914d2bb029f32e5fef5c234c4fec2d2dd577\": \"0x6194049f30f7200000\",\n \"0xcb4abfc282aed76e5d57affda542c1f382fcacf4\": \"0x1b90f11c3183faa0000\",\n \"0xcb4ad0c723da46ab56d526da0c1d25c73daff10a\": \"0x1ba5abf9e779380000\",\n \"0xcb4bb1c623ba28dc42bdaaa6e74e1d2aa1256c2a\": \"0x6c6acc67d7b1d40000\",\n \"0xcb50587412822304ebcba07dab3a0f09fffee486\": \"0x4a4491bd6dcd280000\",\n \"0xcb58990bcd90cfbf6d8f0986f6fa600276b94e2d\": \"0x3634bf39ab98788000\",\n \"0xcb68ae5abe02dcf8cbc5aa719c25814651af8b85\": \"0x1b1ae4d6e2ef500000\",\n \"0xcb7479109b43b26657f4465f4d18c6f974be5f42\": \"0x62a992e53a0af00000\",\n \"0xcb7d2b8089e9312cc9aeaa2773f35308ec6c2a7b\": \"0x21e19e0c9bab2400000\",\n \"0xcb86edbc8bbb1f9131022be649565ebdb09e32a1\": \"0x6c6b935b8bbd400000\",\n \"0xcb93199b9c90bc4915bd859e3d42866dc8c18749\": \"0xc90df07def78c0000\",\n \"0xcb94e76febe208116733e76e805d48d112ec9fca\": \"0x3635c9adc5dea00000\",\n \"0xcb9b5103e4ce89af4f64916150bff9eecb9faa5c\": \"0x1b1ae4d6e2ef500000\",\n \"0xcba25c7a503cc8e0d04971ca05c762f9b762b48b\": \"0x1b1ae4d6e2ef500000\",\n \"0xcba288cd3c1eb4d59ddb06a6421c14c345a47b24\": \"0xd8d726b7177a800000\",\n \"0xcbb3189e4bd7f45f178b1c30c76e26314d4a4b0a\": \"0xffe0b677c65a98000\",\n \"0xcbb7be17953f2ccc93e1bc99805bf45511434e4c\": \"0xaae5b9df56d2f200000\",\n \"0xcbc04b4d8b82caf670996f160c362940d66fcf1a\": \"0x14542ba12a337c00000\",\n \"0xcbde9734b8e6aa538c291d6d7facedb0f338f857\": \"0x6c6b935b8bbd400000\",\n \"0xcbe1b948864d8474e765145858fca4550f784b92\": \"0x21e19e0c9bab2400000\",\n \"0xcbe52fc533d7dd608c92a260b37c3f45deb4eb33\": \"0x3635c9adc5dea00000\",\n \"0xcbe810fe0fecc964474a1db97728bc87e973fcbd\": \"0x21e19e0c9bab2400000\",\n \"0xcbf16a0fe2745258cd52db2bf21954c975fc6a15\": \"0x1043561a8829300000\",\n \"0xcbf37ff854a2f1ce53934494777892d3ec655782\": \"0x21e19e0c9bab2400000\",\n \"0xcbfa6af6c283b046e2772c6063b0b21553c40106\": \"0x6c6b935b8bbd400000\",\n \"0xcbfa76db04ce38fb205d37b8d377cf1380da0317\": \"0x4d853c8f8908980000\",\n \"0xcc034985d3f28c2d39b1a34bced4d3b2b6ca234e\": \"0x9ddc1e3b901180000\",\n \"0xcc043c4388d345f884c6855e71142a9f41fd6935\": \"0x1158e460913d00000\",\n \"0xcc1d6ead01aada3e8dc7b95dca25df26eefa639d\": \"0x6c6b935b8bbd400000\",\n \"0xcc2b5f448f3528d3fe41cc7d1fa9c0dc76f1b776\": \"0x340aad21b3b700000\",\n \"0xcc2d04f0a4017189b340ca77198641dcf6456b91\": \"0xd5967be4fc3f100000\",\n \"0xcc419fd9912b85135659e77a93bc3df182d45115\": \"0x21e19e0c9bab2400000\",\n \"0xcc45fb3a555bad807b388a0357c855205f7c75e8\": \"0x2ee449550898e40000\",\n \"0xcc48414d2ac4d42a5962f29eee4497092f431352\": \"0x8ba52e6fc45e40000\",\n \"0xcc4a2f2cf86cf3e43375f360a4734691195f1490\": \"0x4915053bd129098000\",\n \"0xcc4f0ff2aeb67d54ce3bc8c6510b9ae83e9d328b\": \"0x15af1d78b58c400000\",\n \"0xcc4faac00be6628f92ef6b8cb1b1e76aac81fa18\": \"0xb22a2eab0f0fd0000\",\n \"0xcc4feb72df98ff35a138e01761d1203f9b7edf0a\": \"0x17b7883c06916600000\",\n \"0xcc606f511397a38fc7872bd3b0bd03c71bbd768b\": \"0x3635c9adc5dea00000\",\n \"0xcc60f836acdef3548a1fefcca13ec6a937db44a0\": \"0x4b06dbbb40f4a0000\",\n \"0xcc6c03bd603e09de54e9c4d5ac6d41cbce715724\": \"0x556f64c1fe7fa0000\",\n \"0xcc6c2df00e86eca40f21ffda1a67a1690f477c65\": \"0xab4dcf399a3a600000\",\n \"0xcc6d7b12061bc96d104d606d65ffa32b0036eb07\": \"0x21e19e0c9bab2400000\",\n \"0xcc73dd356b4979b579b401d4cc7a31a268ddce5a\": \"0x1b1ae4d6e2ef500000\",\n \"0xcc758d071d25a6320af68c5dc9c4f6955ba94520\": \"0x14542ba12a337c00000\",\n \"0xcc7b0481cc32e6faef2386a07022bcb6d2c3b4fc\": \"0xab4dcf399a3a600000\",\n \"0xcc943be1222cd1400a2399dd1b459445cf6d54a9\": \"0x2a740ae6536fc880000\",\n \"0xcc9519d1f3985f6b255eaded12d5624a972721e1\": \"0x3635c9adc5dea00000\",\n \"0xcc9ac715cd6f2610c52b58676456884297018b29\": \"0xb98bc829a6f90000\",\n \"0xcca07bb794571d4acf041dad87f0d1ef3185b319\": \"0x6c6b935b8bbd400000\",\n \"0xccabc6048a53464424fcf76eeb9e6e1801fa23d4\": \"0x2ab7b260ff3fd0000\",\n \"0xccae0d3d852a7da3860f0636154c0a6ca31628d4\": \"0x5c6d12b6bc1a00000\",\n \"0xccca24d8c56d6e2c07db086ec07e585be267ac8d\": \"0xad78ebc5ac6200000\",\n \"0xccd521132d986cb96869842622a7dda26c3ed057\": \"0x6c6b935b8bbd400000\",\n \"0xccf43975b76bfe735fec3cb7d4dd24f805ba0962\": \"0x340aad21b3b700000\",\n \"0xccf62a663f1353ba2ef8e6521dc1ecb673ec8ef7\": \"0x83d6c7aab63600000\",\n \"0xccf7110d1bd9a74bfd1d7d7d2d9d55607e7b837d\": \"0x30ca024f987b900000\",\n \"0xccfd725760a68823ff1e062f4cc97e1360e8d997\": \"0x15ac56edc4d12c0000\",\n \"0xcd020f8edfcf524798a9b73a640334bbf72f80a5\": \"0x73f75d1a085ba0000\",\n \"0xcd06f8c1b5cdbd28e2d96b6346c3e85a0483ba24\": \"0x3635c9adc5dea00000\",\n \"0xcd072e6e1833137995196d7bb1725fef8761f655\": \"0x14542ba12a337c00000\",\n \"0xcd0a161bc367ae0927a92aac9cf6e5086714efca\": \"0x6c6b935b8bbd400000\",\n \"0xcd0af3474e22f069ec3407870dd770443d5b12b0\": \"0x8e5eb4ee77b2ef0000\",\n \"0xcd0b0257e783a3d2c2e3ba9d6e79b75ef98024d4\": \"0x9fad06241279160000\",\n \"0xcd102cd6db3df14ad6af0f87c72479861bfc3d24\": \"0x6c6b935b8bbd400000\",\n \"0xcd1e66ed539dd92fc40bbaa1fa16de8c02c14d45\": \"0xc77e4256863d80000\",\n \"0xcd1ed263fbf6f6f7b48aef8f733d329d4382c7c7\": \"0x100bd33fb98ba0000\",\n \"0xcd2a36d753e9e0ed012a584d716807587b41d56a\": \"0xe2ba75b0b1f1c0000\",\n \"0xcd32a4a8a27f1cc63954aa634f7857057334c7a3\": \"0x3ad166576c72d40000\",\n \"0xcd35ff010ec501a721a1b2f07a9ca5877dfcf95a\": \"0xd96fce90cfabcc0000\",\n \"0xcd4306d7f6947ac1744d4e13b8ef32cb657e1c00\": \"0x1b1ab319f5ec750000\",\n \"0xcd43258b7392a930839a51b2ef8ad23412f75a9f\": \"0x6c6b935b8bbd400000\",\n \"0xcd49bf185e70d04507999f92a4de4455312827d0\": \"0x3635c9adc5dea00000\",\n \"0xcd5510a242dfb0183de925fba866e312fabc1657\": \"0x821ab0d44149800000\",\n \"0xcd566ad7b883f01fd3998a9a58a9dee4724ddca5\": \"0x330ae1835be300000\",\n \"0xcd59f3dde77e09940befb6ee58031965cae7a336\": \"0x21e19e0c9bab2400000\",\n \"0xcd725d70be97e677e3c8e85c0b26ef31e9955045\": \"0x487a9a304539440000\",\n \"0xcd7e47909464d871b9a6dc76a8e9195db3485e7a\": \"0x215f835bc769da80000\",\n \"0xcd7ece086b4b619b3b369352ee38b71ddb06439a\": \"0xad78ebc5ac6200000\",\n \"0xcd7f09d7ed66d0c38bc5ad4e32b7f2b08dc1b30d\": \"0x3e3bb34da2a4700000\",\n \"0xcd9529492b5c29e475acb941402b3d3ba50686b0\": \"0x6acb3df27e1f880000\",\n \"0xcd95fa423d6fc120274aacde19f4eeb766f10420\": \"0xad78ebc5ac6200000\",\n \"0xcd9b4cef73390c83a8fd71d7b540a7f9cf8b8c92\": \"0x4e1003b28d9280000\",\n \"0xcda1741109c0265b3fb2bf8d5ec9c2b8a3346b63\": \"0x1158e460913d00000\",\n \"0xcda1b886e3a795c9ba77914e0a2fe5676f0f5ccf\": \"0x5bf60ea42c2040000\",\n \"0xcda4530f4b9bc50905b79d17c28fc46f95349bdf\": \"0x3310e04911f1f80000\",\n \"0xcdab46a5902080646fbf954204204ae88404822b\": \"0x1d8a96e5c606eb0000\",\n \"0xcdb597299030183f6e2d238533f4642aa58754b6\": \"0x15af1d78b58c400000\",\n \"0xcdd5d881a7362c9070073bdfbc75e72453ac510e\": \"0x2da518eae48ee80000\",\n \"0xcdd60d73efaad873c9bbfb178ca1b7105a81a681\": \"0x1bc16d674ec800000\",\n \"0xcdd9efac4d6d60bd71d95585dce5d59705c13564\": \"0x56bc75e2d63100000\",\n \"0xcde36d81d128c59da145652193eec2bfd96586ef\": \"0xd8d726b7177a800000\",\n \"0xcdea386f9d0fd804d02818f237b7d9fa7646d35e\": \"0xa349d36d80ec578000\",\n \"0xcdecf5675433cdb0c2e55a68db5d8bbe78419dd2\": \"0x1158e460913d00000\",\n \"0xcdfd8217339725d7ebac11a63655f265eff1cc3d\": \"0x10f0c696410e3a90000\",\n \"0xce079f51887774d8021cb3b575f58f18e9acf984\": \"0x9c2007651b2500000\",\n \"0xce1884ddbbb8e10e4dba6e44feeec2a7e5f92f05\": \"0xd8d726b7177a800000\",\n \"0xce1b0cb46aaecfd79b880cad0f2dda8a8dedd0b1\": \"0x1158e460913d00000\",\n \"0xce26f9a5305f8381094354dbfc92664e84f902b5\": \"0xc7aaab0591eec0000\",\n \"0xce2deab51c0a9ae09cd212c4fa4cc52b53cc0dec\": \"0x6c6b935b8bbd400000\",\n \"0xce2e0da8934699bb1a553e55a0b85c169435bea3\": \"0x10f0c696410e3a90000\",\n \"0xce3a61f0461b00935e85fa1ead82c45e5a64d488\": \"0x1b1ae4d6e2ef500000\",\n \"0xce4b065dbcb23047203262fb48c1188364977470\": \"0x1b1ae4d6e2ef500000\",\n \"0xce53c8cdd74296aca987b2bc19c2b875a48749d0\": \"0xa2a15d09519be00000\",\n \"0xce5e04f0184369bcfa06aca66ffa91bf59fa0fb9\": \"0x22b1c8c1227a00000\",\n \"0xce5eb63a7bf4fbc2f6e4baa0c68ab1cb4cf98fb4\": \"0x6c6b935b8bbd400000\",\n \"0xce62125adec3370ac52110953a4e760be9451e3b\": \"0x83d6c7aab63600000\",\n \"0xce71086d4c602554b82dcbfce88d20634d53cc4d\": \"0x92896529baddc880000\",\n \"0xce8a6b6d5033b1498b1ffeb41a41550405fa03a2\": \"0xd8d726b7177a800000\",\n \"0xce9786d3712fa200e9f68537eeaa1a06a6f45a4b\": \"0x61093d7c2c6d380000\",\n \"0xce9d21c692cd3c01f2011f505f870036fa8f6cd2\": \"0x15af1d78b58c400000\",\n \"0xcea2896623f4910287a2bdc5be83aea3f2e6de08\": \"0x1fb5a3751e490dc0000\",\n \"0xcea34a4dd93dd9aefd399002a97d997a1b4b89cd\": \"0x5150ae84a8cdf00000\",\n \"0xcea43f7075816b60bbfce68b993af0881270f6c4\": \"0x6c6b935b8bbd400000\",\n \"0xcea8743341533cb2f0b9c6efb8fda80d77162825\": \"0x56bc75e2d63100000\",\n \"0xceb089ec8a78337e8ef88de11b49e3dd910f748f\": \"0x3635c9adc5dea00000\",\n \"0xceb33d78e7547a9da2e87d51aec5f3441c87923a\": \"0x1158e460913d00000\",\n \"0xceb389381d48a8ae4ffc483ad0bb5e204cfdb1ec\": \"0x2827e6e4dd62ba8000\",\n \"0xcec6fc65853f9cce5f8e844676362e1579015f02\": \"0x6c6b935b8bbd400000\",\n \"0xced3c7be8de7585140952aeb501dc1f876ecafb0\": \"0xd8d726b7177a800000\",\n \"0xced81ec3533ff1bfebf3e3843ee740ad11758d3e\": \"0x6acb3df27e1f880000\",\n \"0xcedcb3a1d6843fb6bef643617deaf38f8e98dd5f\": \"0x19e2a4c818b9060000\",\n \"0xcee699c0707a7836252b292f047ce8ad289b2f55\": \"0x119a1e21aa69560000\",\n \"0xceed47ca5b899fd1623f21e9bd4db65a10e5b09d\": \"0x73877404c1eee0000\",\n \"0xcef77451dfa2c643e00b156d6c6ff84e2373eb66\": \"0xa31062beeed700000\",\n \"0xcf1169041c1745e45b172435a2fc99b49ace2b00\": \"0x1bb88baab2d7c0000\",\n \"0xcf157612764e0fd696c8cb5fba85df4c0ddc3cb0\": \"0x65a4da25d3016c00000\",\n \"0xcf1bdb799b2ea63ce134668bdc198b54840f180b\": \"0xfc936392801c0000\",\n \"0xcf2288ef4ebf88e86db13d8a0e0bf52a056582c3\": \"0x89506fbf9740740000\",\n \"0xcf264e6925130906c4d7c18591aa41b2a67f6f58\": \"0x6c6b935b8bbd400000\",\n \"0xcf26b47bd034bc508e6c4bcfd6c7d30034925761\": \"0x6194049f30f7200000\",\n \"0xcf2e2ad635e9861ae95cb9bafcca036b5281f5ce\": \"0x77432217e6836000000\",\n \"0xcf2e734042a355d05ffb2e3915b16811f45a695e\": \"0x6c6b935b8bbd400000\",\n \"0xcf348f2fe47b7e413c077a7baf3a75fbf8428692\": \"0x6c6b935b8bbd400000\",\n \"0xcf3f9128b07203a3e10d7d5755c0c4abc6e2cac2\": \"0x10f0cf064dd59200000\",\n \"0xcf3fbfa1fd32d7a6e0e6f8ef4eab57be34025c4c\": \"0x39a1c0f7594d480000\",\n \"0xcf4166746e1d3bc1f8d0714b01f17e8a62df1464\": \"0x3677036edf0af60000\",\n \"0xcf4f1138f1bd6bf5b6d485cce4c1017fcb85f07d\": \"0x2fd0bc77c32bff0000\",\n \"0xcf5a6f9df75579c644f794711215b30d77a0ce40\": \"0x6c6b935b8bbd400000\",\n \"0xcf5e0eacd1b39d0655f2f77535ef6608eb950ba0\": \"0x6c6b935b8bbd400000\",\n \"0xcf684dfb8304729355b58315e8019b1aa2ad1bac\": \"0x177224aa844c720000\",\n \"0xcf694081c76d18c64ca71382be5cd63b3cb476f8\": \"0x3635c9adc5dea00000\",\n \"0xcf6e52e6b77480b1867efec6446d9fc3cc3577e8\": \"0xc0901f6bd98790000\",\n \"0xcf883a20329667ea226a1e3c765dbb6bab32219f\": \"0xa4be3564d616660000\",\n \"0xcf8882359c0fb23387f5674074d8b17ade512f98\": \"0x14542ba12a337c00000\",\n \"0xcf89f7460ba3dfe83c5a1d3a019ee1250f242f0f\": \"0x356813cdcefd028000\",\n \"0xcf923a5d8fbc3d01aa079d1cfe4b43ce071b1611\": \"0x6c6b935b8bbd400000\",\n \"0xcf9be9b9ab86c66b59968e67b8d4dcff46b1814a\": \"0x23c757072b8dd00000\",\n \"0xcfa8b37127149bdbfee25c34d878510951ea10eb\": \"0x6c6b935b8bbd400000\",\n \"0xcfac2e1bf33205b05533691a02267ee19cd81836\": \"0x3635c9adc5dea00000\",\n \"0xcfbb32b7d024350e3321fa20c9a914035372ffc6\": \"0x15be6174e1912e0000\",\n \"0xcfc4e6f7f8b011414bfba42f23adfaa78d4ecc5e\": \"0x6449e84e47a8a80000\",\n \"0xcfd2728dfb8bdbf3bf73598a6e13eaf43052ea2b\": \"0x93739534d28680000\",\n \"0xcfd47493c9f89fe680bda5754dd7c9cfe7cb5bbe\": \"0x2f473513448fe0000\",\n \"0xcfde0fc75d6f16c443c3038217372d99f5d907f7\": \"0x83225e6396b5ec0000\",\n \"0xcfe2caaf3cec97061d0939748739bffe684ae91f\": \"0x21e19e0c9bab2400000\",\n \"0xcfeacaaed57285e0ac7268ce6a4e35ecfdb242d7\": \"0x3ae4d4240190600000\",\n \"0xcfecbea07c27002f65fe534bb8842d0925c78402\": \"0xd8d726b7177a800000\",\n \"0xcfee05c69d1f29e7714684c88de5a16098e91399\": \"0x6acb3df27e1f880000\",\n \"0xcff6a6fe3e9a922a12f21faa038156918c4fcb9c\": \"0x44591d67fecc80000\",\n \"0xcff7f89a4d4219a38295251331568210ffc1c134\": \"0x5f68e8131ecf800000\",\n \"0xcff8d06b00e3f50c191099ad56ba6ae26571cd88\": \"0x3635c9adc5dea00000\",\n \"0xcffc49c1787eebb2b56cabe92404b636147d4558\": \"0x133e0308f40a3da8000\",\n \"0xd008513b27604a89ba1763b6f84ce688b346945b\": \"0x3635c9adc5dea00000\",\n \"0xd00f067286c0fbd082f9f4a61083ec76deb3cee6\": \"0x3635c9adc5dea00000\",\n \"0xd015f6fcb84df7bb410e8c8f04894a881dcac237\": \"0x384524cc70b7780000\",\n \"0xd01af9134faf5257174e8b79186f42ee354e642d\": \"0x3635c9adc5dea00000\",\n \"0xd02108d2ae3cab10cbcf1657af223e027c8210f6\": \"0x6c6d84bccdd9ce0000\",\n \"0xd02afecf8e2ec2b62ac8ad204161fd1fae771d0e\": \"0x6c6b935b8bbd400000\",\n \"0xd0319139fbab2e8e2accc1d924d4b11df6696c5a\": \"0xad78ebc5ac6200000\",\n \"0xd037d215d11d1df3d54fbd321cd295c5465e273b\": \"0x4be4e7267b6ae00000\",\n \"0xd03a2da41e868ed3fef5745b96f5eca462ff6fda\": \"0xa2a15d09519be00000\",\n \"0xd03fc165576aaed525e5502c8e140f8b2e869639\": \"0x17356d8b32501c80000\",\n \"0xd043a011ec4270ee7ec8b968737515e503f83028\": \"0x1b1ae4d6e2ef500000\",\n \"0xd04b861b3d9acc563a901689941ab1e1861161a2\": \"0x1158e460913d00000\",\n \"0xd05a447c911dbb275bfb2e5a37e5a703a56f9997\": \"0xad78ebc5ac6200000\",\n \"0xd05ffb2b74f867204fe531653b0248e21c13544e\": \"0x3635c9adc5dea00000\",\n \"0xd062588171cf99bbeb58f126b870f9a3728d61ec\": \"0xf3f20b8dfa69d00000\",\n \"0xd0638ea57189a6a699024ad78c71d939c1c2ff8c\": \"0x8eae566710fc200000\",\n \"0xd0648a581b3508e135a2935d12c9657045d871ca\": \"0x1b2df9d219f57980000\",\n \"0xd071192966eb69c3520fca3aa4dd04297ea04b4e\": \"0x5f68e8131ecf80000\",\n \"0xd0718520eae0a4d62d70de1be0ca431c5eea2482\": \"0x6c6b935b8bbd400000\",\n \"0xd0775dba2af4c30a3a78365939cd71c2f9de95d2\": \"0x692ae8897081d00000\",\n \"0xd07be0f90997caf903c8ac1d53cde904fb190741\": \"0x36389038b699b40000\",\n \"0xd07e511864b1cf9969e3560602829e32fc4e71f5\": \"0x2b5e3af16b1880000\",\n \"0xd0809498c548047a1e2a2aa6a29cd61a0ee268bd\": \"0x6c6b935b8bbd400000\",\n \"0xd082275f745a2cac0276fbdb02d4b2a3ab1711fe\": \"0x1a055690d9db80000\",\n \"0xd08fc09a0030fd0928cd321198580182a76aae9f\": \"0x3635c9adc5dea00000\",\n \"0xd093e829819fd2e25b973800bb3d5841dd152d05\": \"0xd8d726b7177a800000\",\n \"0xd0944aa185a1337061ae20dc9dd96c83b2ba4602\": \"0xad78ebc5ac6200000\",\n \"0xd096565b7c7407d06536580355fdd6d239144aa1\": \"0xd8d726b7177a80000\",\n \"0xd09cb2e6082d693a13e8d2f68dd1dd8461f55840\": \"0x3635c9adc5dea00000\",\n \"0xd0a6c6f9e9c4b383d716b31de78d56414de8fa91\": \"0x1043561a8829300000\",\n \"0xd0a7209b80cf60db62f57d0a5d7d521a69606655\": \"0x8ac7230489e800000\",\n \"0xd0a8abd80a199b54b08b65f01d209c27fef0115b\": \"0x161c626dc61a2ef8000\",\n \"0xd0abcc70c0420e0e172f97d43b87d5e80c336ea9\": \"0x21e19e0c9bab2400000\",\n \"0xd0ae735d915e946866e1fea77e5ea466b5cadd16\": \"0x6c6b935b8bbd400000\",\n \"0xd0b11d6f2bce945e0c6a5020c3b52753f803f9d1\": \"0xad78ebc5ac6200000\",\n \"0xd0c101fd1f01c63f6b1d19bc920d9f932314b136\": \"0x43c33c1937564800000\",\n \"0xd0c55abf976fdc3db2afe9be99d499484d576c02\": \"0x3635c9adc5dea00000\",\n \"0xd0d0a2ad45f59a9dccc695d85f25ca46ed31a5a3\": \"0x2d89577d7d40200000\",\n \"0xd0d62c47ea60fb90a3639209bbfdd4d933991cc6\": \"0xa844a7424d9c80000\",\n \"0xd0db456178206f5c4430fe005063903c3d7a49a7\": \"0x26491e45a753c08000\",\n \"0xd0e194f34b1db609288509ccd2e73b6131a2538b\": \"0x36356633ebd8ea0000\",\n \"0xd0e35e047646e759f4517093d6408642517f084d\": \"0xd58fa46818eccb8000\",\n \"0xd0ee4d02cf24382c3090d3e99560de3678735cdf\": \"0x821ab0d44149800000\",\n \"0xd0f04f52109aebec9a7b1e9332761e9fe2b97bb5\": \"0xd8d726b7177a800000\",\n \"0xd0f9597811b0b992bb7d3757aa25b4c2561d32e2\": \"0x1b1ae4d6e2ef500000\",\n \"0xd10302faa1929a326904d376bf0b8dc93ad04c4c\": \"0x61093d7c2c6d380000\",\n \"0xd1100dd00fe2ddf18163ad964d0b69f1f2e9658a\": \"0x143120955b2506b0000\",\n \"0xd116f3dcd5db744bd008887687aa0ec9fd7292aa\": \"0x3635c9adc5dea00000\",\n \"0xd119417c46732cf34d1a1afb79c3e7e2cd8eece4\": \"0x6c6b935b8bbd400000\",\n \"0xd12d77ae01a92d35117bac705aacd982d02e74c1\": \"0x3635c9adc5dea00000\",\n \"0xd135794b149a18e147d16e621a6931f0a40a969a\": \"0x43c33c1937564800000\",\n \"0xd1432538e35b7664956ae495a32abdf041a7a21c\": \"0x42bf06b78ed3b500000\",\n \"0xd1438267231704fc7280d563adf4763844a80722\": \"0xad78ebc5ac6200000\",\n \"0xd1538e9a87e59ca9ec8e5826a5b793f99f96c4c3\": \"0x3635c9adc5dea00000\",\n \"0xd1648503b1ccc5b8be03fa1ec4f3ee267e6adf7b\": \"0x13befbf51eec0900000\",\n \"0xd1682c2159018dc3d07f08240a8c606daf65f8e1\": \"0x2a5a058fc295ed000000\",\n \"0xd171c3f2258aef35e599c7da1aa07300234da9a6\": \"0x6c6b935b8bbd400000\",\n \"0xd1778c13fbd968bc083cb7d1024ffe1f49d02caa\": \"0xd9ecb4fd208e500000\",\n \"0xd17fbe22d90462ed37280670a2ea0b3086a0d6d6\": \"0xad6eedd17cf3b8000\",\n \"0xd1811c55976980f083901d8a0db269222dfb5cfe\": \"0x54069233bf7f780000\",\n \"0xd18eb9e1d285dabe93e5d4bae76beefe43b521e8\": \"0x243d4d18229ca20000\",\n \"0xd193e583d6070563e7b862b9614a47e99489f3e5\": \"0x36356633ebd8ea0000\",\n \"0xd1978f2e34407fab1dc2183d95cfda6260b35982\": \"0x2ab7b260ff3fd00000\",\n \"0xd19caf39bb377fdf2cf19bd4fb52591c2631a63c\": \"0x3635c9adc5dea00000\",\n \"0xd1a396dcdab2c7494130b3fd307820340dfd8c1f\": \"0xf92250e2dfd00000\",\n \"0xd1a71b2d0858e83270085d95a3b1549650035e23\": \"0x327bb09d06aa8500000\",\n \"0xd1acb5adc1183973258d6b8524ffa28ffeb23de3\": \"0xd8d726b7177a800000\",\n \"0xd1b37f03cb107424e9c4dd575ccd4f4cee57e6cd\": \"0x6c6b935b8bbd400000\",\n \"0xd1b5a454ac3405bb4179208c6c84de006bcb9be9\": \"0x1b1ae4d6e2ef500000\",\n \"0xd1c45954a62b911ad701ff2e90131e8ceb89c95c\": \"0x4b91a2de457e880000\",\n \"0xd1c96e70f05ae0e6cd6021b2083750a7717cde56\": \"0x1b1ae4d6e2ef500000\",\n \"0xd1d5b17ffe2d7bbb79cc7d7930bcb2e518fb1bbf\": \"0xa2a15d09519be00000\",\n \"0xd1da0c8fb7c210e0f2ec618f85bdae7d3e734b1c\": \"0x6acb3df27e1f880000\",\n \"0xd1dd79fb158160e5b4e8e23f312e6a907fbc4d4e\": \"0x1b1ae4d6e2ef500000\",\n \"0xd1de5aad3a5fd803f1b1aeb6103cb8e14fe723b7\": \"0x1158e460913d00000\",\n \"0xd1e1f2b9c16c309874dee7fac32675aff129c398\": \"0x3f24d8e4a00700000\",\n \"0xd1e5e234a9f44266a4a6241a84d7a1a55ad5a7fe\": \"0x43c33c1937564800000\",\n \"0xd1ea4d72a67b5b3e0f315559f52bd0614d713069\": \"0x6c6b935b8bbd400000\",\n \"0xd1ee905957fe7cc70ec8f2868b43fe47b13febff\": \"0x2629f66e0c5300000\",\n \"0xd1f1694d22671b5aad6a94995c369fbe6133676f\": \"0x3635c9adc5dea00000\",\n \"0xd1f4dc1ddb8abb8848a8b14e25f3b55a8591c266\": \"0xd8d726b7177a80000\",\n \"0xd1fed0aee6f5dfd7e25769254c3cfad15adeccaa\": \"0x2792c8fc4b53280000\",\n \"0xd2051cb3cb6704f0548cc890ab0a19db3415b42a\": \"0x121b2e5e6464780000\",\n \"0xd206aaddb336d45e7972e93cb075471d15897b5d\": \"0x2086ac351052600000\",\n \"0xd209482bb549abc4777bea6d7f650062c9c57a1c\": \"0x11651ac3e7a7580000\",\n \"0xd20dcb0b78682b94bc3000281448d557a20bfc83\": \"0x30849ebe16369c0000\",\n \"0xd2107b353726c3a2b46566eaa7d9f80b5d21dbe3\": \"0x1158e460913d00000\",\n \"0xd211b21f1b12b5096181590de07ef81a89537ead\": \"0x6c6b935b8bbd400000\",\n \"0xd218efb4db981cdd6a797f4bd48c7c26293ceb40\": \"0xa1466b31c6431c0000\",\n \"0xd21a7341eb84fd151054e5e387bb25d36e499c09\": \"0x2f6f10780d22cc00000\",\n \"0xd224f880f9479a89d32f09e52be990b288135cef\": \"0x3a9d5baa4abf1d00000\",\n \"0xd22f0ca4cd479e661775053bcc49e390f670dd8a\": \"0x3635c9adc5dea00000\",\n \"0xd231929735132102471ba59007b6644cc0c1de3e\": \"0x3637096c4bcc690000\",\n \"0xd235d15cb5eceebb61299e0e827fa82748911d89\": \"0xd8d726b7177a800000\",\n \"0xd23a24d7f9468343c143a41d73b88f7cbe63be5e\": \"0xad78ebc5ac6200000\",\n \"0xd23d7affacdc3e9f3dae7afcb4006f58f8a44600\": \"0xc328093e61ee400000\",\n \"0xd243184c801e5d79d2063f3578dbae81e7b3a9cb\": \"0x6bdca2681e1aba0000\",\n \"0xd24b6644f439c8051dfc64d381b8c86c75c17538\": \"0x6c6b935b8bbd400000\",\n \"0xd24bf12d2ddf457decb17874efde2052b65cbb49\": \"0x2f6f10780d22cc00000\",\n \"0xd251f903ae18727259eee841a189a1f569a5fd76\": \"0x21e19e0c9bab2400000\",\n \"0xd252960b0bf6b2848fdead80136db5f507f8be02\": \"0x6c6b935b8bbd400000\",\n \"0xd2581a55ce23ab10d8ad8c44378f59079bd6f658\": \"0x1dd0c885f9a0d800000\",\n \"0xd25aecd7eb8bd6345b063b5dbd271c77d3514494\": \"0x62a992e53a0af00000\",\n \"0xd27c234ff7accace3d996708f8f9b04970f97d36\": \"0x487a9a304539440000\",\n \"0xd28298524df5ec4b24b0ffb9df85170a145a9eb5\": \"0xf98a3b9b337e20000\",\n \"0xd283b8edb10a25528a4404de1c65e7410dbcaa67\": \"0x28a857425466f800000\",\n \"0xd284a50382f83a616d39b8a9c0f396e0ebbfa95d\": \"0x3636c25e66ece70000\",\n \"0xd288e7cb7ba9f620ab0f7452e508633d1c5aa276\": \"0xd8d726b7177a800000\",\n \"0xd29dc08efbb3d72e263f78ab7610d0226de76b00\": \"0x28a857425466f800000\",\n \"0xd2a030ac8952325f9e1db378a71485a24e1b07b2\": \"0x6c6b935b8bbd400000\",\n \"0xd2a479404347c5543aab292ae1bb4a6f158357fa\": \"0xd8d726b7177a800000\",\n \"0xd2a5a024230a57ccc666760b89b0e26cafd189c7\": \"0xa96595a5c6e8a3f8000\",\n \"0xd2a80327cbe55c4c7bd51ff9dde4ca648f9eb3f8\": \"0x2b5e3af16b1880000\",\n \"0xd2a84f75675c62d80c88756c428eee2bcb185421\": \"0x410d586a20a4c00000\",\n \"0xd2abd84a181093e5e229136f42d835e8235de109\": \"0x56be03ca3e47d8000\",\n \"0xd2ac0d3a58605e1d0f0eb3de25b2cad129ed6058\": \"0xd8d726b7177a800000\",\n \"0xd2bf67a7f3c6ce56b7be41675dbbadfe7ea93a33\": \"0x15af1d78b58c400000\",\n \"0xd2dbebe89b0357aea98bbe8e496338debb28e805\": \"0xd8d726b7177a800000\",\n \"0xd2e21ed56868fab28e0947927adaf29f23ebad6c\": \"0x6c184f1355d0e80000\",\n \"0xd2e817738abf1fb486583f80c350318bed860c80\": \"0xd02cecf5f5d810000\",\n \"0xd2edd1ddd6d86dc005baeb541d22b640d5c7cae5\": \"0x1158e460913d00000\",\n \"0xd2f1998e1cb1580cec4f6c047dcd3dcec54cf73c\": \"0xad78ebc5ac6200000\",\n \"0xd2f241255dd7c3f73c07043071ec08ddd9c5cde5\": \"0x1b1ae4d6e2ef500000\",\n \"0xd2ff672016f63b2f85398f4a6fedbb60a50d3cce\": \"0x1291246f5b734a0000\",\n \"0xd30d4c43adcf55b2cb53d68323264134498d89ce\": \"0x3635c9adc5dea00000\",\n \"0xd30ee9a12b4d68abace6baca9ad7bf5cd1faf91c\": \"0x514fcb24ff9c500000\",\n \"0xd3118ea3c83505a9d893bb67e2de142d537a3ee7\": \"0x1158e460913d00000\",\n \"0xd311bcd7aa4e9b4f383ff3d0d6b6e07e21e3705d\": \"0xad78ebc5ac6200000\",\n \"0xd315deea1d8c1271f9d1311263ab47c007afb6f5\": \"0x3c81d4e654b400000\",\n \"0xd32b2c79c36478c5431901f6d700b04dbe9b8810\": \"0x15779a9de6eeb00000\",\n \"0xd32b45564614516c91b07fa9f72dcf787cce4e1c\": \"0xfc66fae3746ac0000\",\n \"0xd330728131fe8e3a15487a34573c93457e2afe95\": \"0xd8d726b7177a800000\",\n \"0xd331c823825a9e5263d052d8915d4dcde07a5c37\": \"0x1e931283ccc8500000\",\n \"0xd333627445f2d787901ef33bb2a8a3675e27ffec\": \"0x15af1d78b58c400000\",\n \"0xd33cf82bf14c592640a08608914c237079d5be34\": \"0x6c6b935b8bbd400000\",\n \"0xd34d708d7398024533a5a2b2309b19d3c55171bb\": \"0x15af1d78b58c400000\",\n \"0xd34e03d36a2bd4d19a5fa16218d1d61e3ffa0b15\": \"0x1158e460913d000000\",\n \"0xd35075ca61fe59d123969c36a82d1ab2d918aa38\": \"0x90f534608a72880000\",\n \"0xd367009ab658263b62c2333a1c9e4140498e1389\": \"0x6c6b935b8bbd400000\",\n \"0xd3679a47df2d99a49b01c98d1c3e0c987ce1e158\": \"0xf2dc7d47f15600000\",\n \"0xd38fa2c4cc147ad06ad5a2f75579281f22a7cc1f\": \"0x43c33c1937564800000\",\n \"0xd39a5da460392b940b3c69bc03757bf3f2e82489\": \"0x17c83a97d6b6ca50000\",\n \"0xd39b7cbc94003fc948f0cde27b100db8ccd6e063\": \"0x15af1d78b58c400000\",\n \"0xd3a10ec7a5c9324999dd9e9b6bde7c911e584bda\": \"0x2086ac351052600000\",\n \"0xd3a941c961e8ca8b1070f23c6d6d0d2a758a4444\": \"0xad78ebc5ac6200000\",\n \"0xd3bb59fa31258be62f8ed232f1a7d47b4a0b41ee\": \"0x56bc75e2d63100000\",\n \"0xd3bc730937fa75d8452616ad1ef1fe7fffe0d0e7\": \"0x484e4ded2eae38000\",\n \"0xd3c24d4b3a5e0ff8a4622d518edd73f16ab28610\": \"0x1158e460913d00000\",\n \"0xd3c6f1e0f50ec3d2a67e6bcd193ec7ae38f1657f\": \"0x166c5480889db770000\",\n \"0xd3d6e9fb82542fd29ed9ea3609891e151396b6f7\": \"0xb6f588aa7bcf5c00000\",\n \"0xd3dad1b6d08d4581ccae65a8732db6ac69f0c69e\": \"0x14542ba12a337c00000\",\n \"0xd3df3b53cb3b4755de54e180451cc44c9e8ae0aa\": \"0x23c49409b977828000\",\n \"0xd3f873bd9956135789ab00ebc195b922e94b259d\": \"0x6c6b935b8bbd400000\",\n \"0xd402b4f6a099ebe716cb14df4f79c0cd01c6071b\": \"0x6c6b935b8bbd400000\",\n \"0xd40d0055fd9a38488aff923fd03d35ec46d711b3\": \"0x10f08eda8e555098000\",\n \"0xd40ed66ab3ceff24ca05ecd471efb492c15f5ffa\": \"0x1b1ae4d6e2ef500000\",\n \"0xd418870bc2e4fa7b8a6121ae0872d55247b62501\": \"0x55a6e79ccd1d300000\",\n \"0xd41d7fb49fe701baac257170426cc9b38ca3a9b2\": \"0x98a7d9b8314c00000\",\n \"0xd4205592844055b3c7a1f80cefe3b8eb509bcde7\": \"0x9b3bfd342a9fc8000\",\n \"0xd42b20bd0311608b66f8a6d15b2a95e6de27c5bf\": \"0x6c6b935b8bbd400000\",\n \"0xd4344f7d5cad65d17e5c2d0e7323943d6f62fe92\": \"0xe7eeba3410b740000\",\n \"0xd43ee438d83de9a37562bb4e286cb1bd19f4964d\": \"0x3635c9adc5dea00000\",\n \"0xd44334b4e23a169a0c16bd21e866bba52d970587\": \"0x8cf23f909c0fa00000\",\n \"0xd44d81e18f46e2cfb5c1fcf5041bc8569767d100\": \"0x7b442e684f65aa40000\",\n \"0xd44f4ac5fad76bdc1537a3b3af6472319b410d9d\": \"0x56bc75e2d631000000\",\n \"0xd44f5edf2bcf2433f211dadd0cc450db1b008e14\": \"0xe7eeba3410b740000\",\n \"0xd44f6ac3923b5fd731a4c45944ec4f7ec52a6ae4\": \"0x21e19e0c9bab2400000\",\n \"0xd45b3341e8f15c80329320c3977e3b90e7826a7e\": \"0x1b1ae4d6e2ef500000\",\n \"0xd45d5daa138dd1d374c71b9019916811f4b20a4e\": \"0x1f399b1438a1000000\",\n \"0xd460a4b908dd2b056759b488850b66a838fc77a8\": \"0x6acb3df27e1f880000\",\n \"0xd467cf064c0871989b90d8b2eb14ccc63b360823\": \"0xad78ebc5ac6200000\",\n \"0xd46bae61b027e5bb422e83a3f9c93f3c8fc77d27\": \"0x6c6b935b8bbd400000\",\n \"0xd46f8223452982a1eea019a8816efc2d6fc00768\": \"0x76d41c62494840000\",\n \"0xd475477fa56390d33017518d6711027f05f28dbf\": \"0x6b111333d4fd4c0000\",\n \"0xd47c242edffea091bc54d57df5d1fdb93101476c\": \"0x9df7dfa8f760480000\",\n \"0xd47d8685faee147c520fd986709175bf2f886bef\": \"0x6c6b935b8bbd400000\",\n \"0xd47f50df89a1cff96513bef1b2ae3a2971accf2c\": \"0x2d89577d7d40200000\",\n \"0xd482e7f68e41f238fe517829de15477fe0f6dd1d\": \"0x1b1ae4d6e2ef500000\",\n \"0xd4879fd12b1f3a27f7e109761b23ca343c48e3d8\": \"0x241a9b4f617a280000\",\n \"0xd48e3f9357e303513841b3f84bda83fc89727587\": \"0x3635c9adc5dea00000\",\n \"0xd49a75bb933fca1fca9aa1303a64b6cb44ea30e1\": \"0x21e19e0c9bab2400000\",\n \"0xd4b085fb086f3d0d68bf12926b1cc3142cae8770\": \"0xc893d09c8f51500000\",\n \"0xd4b2ff3bae1993ffea4d3b180231da439f7502a2\": \"0x6c6b935b8bbd400000\",\n \"0xd4b38a5fdb63e01714e9801db47bc990bd509183\": \"0x14534d95bef905c0000\",\n \"0xd4b8bdf3df9a51b0b91d16abbea05bb4783c8661\": \"0x3635c9adc5dea00000\",\n \"0xd4c4d1a7c3c74984f6857b2f5f07e8face68056d\": \"0x6c6b935b8bbd400000\",\n \"0xd4c6ac742e7c857d4a05a04c33d4d05c1467571d\": \"0xad78ebc5ac6200000\",\n \"0xd4cb21e590c5a0e06801366aff342c7d7db16424\": \"0x1ac7a08ead02f80000\",\n \"0xd4d92c62b280e00f626d8657f1b86166cb1f740f\": \"0xad7f23634cbd60000\",\n \"0xd4ebb1929a23871cf77fe049ab9602be08be0a73\": \"0x678a932062e4180000\",\n \"0xd4ee4919fb37f2bb970c3fff54aaf1f3dda6c03f\": \"0x878678326eac9000000\",\n \"0xd4feed99e8917c5c5458635f3603ecb7e817a7d0\": \"0x1043c43cde1d398000\",\n \"0xd4ff46203efa23064b1caf00516e28704a82a4f8\": \"0x487a9a304539440000\",\n \"0xd500e4d1c9824ba9f5b635cfa3a8c2c38bbd4ced\": \"0x15af1d78b58c400000\",\n \"0xd508d39c70916f6abc4cc7f999f011f077105802\": \"0x5724d24afe77f0000\",\n \"0xd50f7fa03e389876d3908b60a537a6706304fb56\": \"0x56bc75e2d63100000\",\n \"0xd513a45080ff2febe62cd5854abe29ee4467f996\": \"0x84e13bc4fc5d80000\",\n \"0xd5276f0cd5ffd5ffb63f98b5703d5594ede0838b\": \"0x15af1d78b58c400000\",\n \"0xd5294b666242303b6df0b1c88d37429bc8c965aa\": \"0x104d0d00d2b7f60000\",\n \"0xd52aecc6493938a28ca1c367b701c21598b6a02e\": \"0x3ba1910bf341b00000\",\n \"0xd53c567f0c3ff2e08b7d59e2b5c73485437fc58d\": \"0x2086ac351052600000\",\n \"0xd541ac187ad7e090522de6da3213e9a7f4439673\": \"0x6c6b935b8bbd400000\",\n \"0xd54ba2d85681dc130e5b9b02c4e8c851391fd9b9\": \"0xd5967be4fc3f100000\",\n \"0xd55508adbbbe9be81b80f97a6ea89add68da674f\": \"0x6c6b935b8bbd400000\",\n \"0xd5550caaf743b037c56fd2558a1c8ed235130750\": \"0x121e4d49036255b0000\",\n \"0xd5586da4e59583c8d86cccf71a86197f17996749\": \"0x6c6b935b8bbd400000\",\n \"0xd55c1c8dfbe1e02cacbca60fdbdd405b09f0b75f\": \"0x6c6b935b8bbd400000\",\n \"0xd561cbbc05515de73ab8cf9eae1357341e7dfdf4\": \"0x14542ba12a337c00000\",\n \"0xd56a144d7af0ae8df649abae535a15983aa04d02\": \"0x10f0cf064dd59200000\",\n \"0xd572309169b1402ec8131a17a6aac3222f89e6eb\": \"0x2ec1978c47766a00000\",\n \"0xd5787668c2c5175b01a8ee1ac3ecc9c8b2aba95a\": \"0x6c6acc67d7b1d40000\",\n \"0xd588c3a5df228185d98ee7e60748255cdea68b01\": \"0xd8d726b7177a800000\",\n \"0xd58a52e078a805596b0d56ea4ae1335af01c66eb\": \"0xe7eeba3410b740000\",\n \"0xd5903e9978ee20a38c3f498d63d57f31a39f6a06\": \"0x232b36ffc672ab00000\",\n \"0xd59638d3c5faa7711bf085745f9d5bdc23d498d8\": \"0x6c6b935b8bbd400000\",\n \"0xd59d92d2c8701980cc073c375d720af064743c0c\": \"0x405fdf7e5af85e00000\",\n \"0xd5a7bec332adde18b3104b5792546aa59b879b52\": \"0x6c6b935b8bbd400000\",\n \"0xd5b117ec116eb846418961eb7edb629cd0dd697f\": \"0xa2a15d09519be00000\",\n \"0xd5b284040130abf7c1d163712371cc7e28ad66da\": \"0x6acb3df27e1f880000\",\n \"0xd5b9d277d8aad20697a51f76e20978996bffe055\": \"0x7c3fe3c076ab50000\",\n \"0xd5bd5e8455c130169357c471e3e681b7996a7276\": \"0x2d9e288f8abb360000\",\n \"0xd5cba5b26bea5d73fabb1abafacdef85def368cc\": \"0xad78ebc5ac6200000\",\n \"0xd5ce55d1b62f59433c2126bcec09bafc9dfaa514\": \"0xaadec983fcff40000\",\n \"0xd5e55100fbd1956bbed2ca518d4b1fa376032b0b\": \"0x56bc75e2d63100000\",\n \"0xd5e5c135d0c4c3303934711993d0d16ff9e7baa0\": \"0x6c6b935b8bbd400000\",\n \"0xd5e656a1b916f9bf45afb07dd8afaf73b4c56f41\": \"0x542253a126ce40000\",\n \"0xd5ea472cb9466018110af00c37495b5c2c713112\": \"0x10eee686c854f440000\",\n \"0xd5f07552b5c693c20067b378b809cee853b8f136\": \"0x1b67c6df88c6fa0000\",\n \"0xd5f7c41e07729dfa6dfc64c4423160a22c609fd3\": \"0x61093d7c2c6d380000\",\n \"0xd604abce4330842e3d396ca73ddb5519ed3ec03f\": \"0x8e31fe1689d8a0000\",\n \"0xd60651e393783423e5cc1bc5f889e44ef7ea243e\": \"0x159e76371129c80000\",\n \"0xd609bf4f146eea6b0dc8e06ddcf4448a1fccc9fa\": \"0x6c6b935b8bbd400000\",\n \"0xd609ec0be70d0ad26f6e67c9d4762b52ee51122c\": \"0x3635c9adc5dea00000\",\n \"0xd60a52580728520df7546bc1e283291788dbae0c\": \"0x363489ef3ff0d70000\",\n \"0xd60b247321a32a5affb96b1e279927cc584de943\": \"0x7ad020d6ddd7760000\",\n \"0xd6110276cfe31e42825a577f6b435dbcc10cf764\": \"0x3635c9adc5dea00000\",\n \"0xd612597bc31743c78633f633f239b1e9426bd925\": \"0x1017f7df96be17800000\",\n \"0xd6234aaf45c6f22e66a225ffb93add629b4ef80f\": \"0x3635c9adc5dea00000\",\n \"0xd62edb96fce2969aaf6c545e967cf1c0bc805205\": \"0x4a565536a5ada8000\",\n \"0xd6300b3215b11de762ecde4b70b7927d01291582\": \"0x6c6b935b8bbd400000\",\n \"0xd6395db5a4bb66e60f4cfbcdf0057bb4d97862e2\": \"0x3154c9729d05780000\",\n \"0xd64a2d50f8858537188a24e0f50df1681ab07ed7\": \"0x8375a2abcca24400000\",\n \"0xd6580ab5ed4c7dfa506fa6fe64ad5ce129707732\": \"0xd8d726b7177a800000\",\n \"0xd6598b1386e93c5ccb9602ff4bbbecdbd3701dc4\": \"0xc25f4ecb041f00000\",\n \"0xd6644d40e90bc97fe7dfe7cabd3269fd579ba4b3\": \"0x89e917994f71c0000\",\n \"0xd6670c036df754be43dadd8f50feea289d061fd6\": \"0x144a2903448cef78000\",\n \"0xd668523a90f0293d65c538d2dd6c57673710196e\": \"0x2242c30b853ee0000\",\n \"0xd66ab79294074c8b627d842dab41e17dd70c5de5\": \"0x3635c9adc5dea00000\",\n \"0xd66acc0d11b689cea6d9ea5ff4014c224a5dc7c4\": \"0xfc936392801c0000\",\n \"0xd66ddf1159cf22fd8c7a4bc8d5807756d433c43e\": \"0x77432217e683600000\",\n \"0xd687cec0059087fdc713d4d2d65e77daefedc15f\": \"0x340aad21b3b700000\",\n \"0xd688e785c98f00f84b3aa1533355c7a258e87948\": \"0x1b1ae4d6e2ef500000\",\n \"0xd6a22e598dabd38ea6e958bd79d48ddd9604f4df\": \"0x3635c9adc5dea00000\",\n \"0xd6a7ac4de7b510f0e8de519d973fa4c01ba83400\": \"0x65ea3db75546600000\",\n \"0xd6acc220ba2e51dfcf21d443361eea765cbd35d8\": \"0x1158e460913d00000\",\n \"0xd6acffd0bfd99c382e7bd56ff0e6144a9e52b08e\": \"0x8ac7230489e800000\",\n \"0xd6c0d0bc93a62e257174700e10f024c8b23f1f87\": \"0x6c6b935b8bbd400000\",\n \"0xd6cf5c1bcf9da662bcea2255905099f9d6e84dcc\": \"0x1c49e420157d9c20000\",\n \"0xd6d03572a45245dbd4368c4f82c95714bd2167e2\": \"0x3f00c3d66686fc0000\",\n \"0xd6d6776958ee23143a81adadeb08382009e996c2\": \"0xa2a15d09519be00000\",\n \"0xd6d9e30f0842012a7176a917d9d2048ca0738759\": \"0xd8d726b7177a800000\",\n \"0xd6e09e98fe1300332104c1ca34fbfac554364ed9\": \"0x6c6b935b8bbd400000\",\n \"0xd6e8e97ae9839b9ee507eedb28edfb7477031439\": \"0x6c6b935b8bbd400000\",\n \"0xd6eea898d4ae2b718027a19ce9a5eb7300abe3ca\": \"0x17d4aceee63db8000\",\n \"0xd6f1e55b1694089ebcb4fe7d7882aa66c8976176\": \"0x43c23bdbe929db30000\",\n \"0xd6f4a7d04e8faf20e8c6eb859cf7f78dd23d7a15\": \"0x724ded1c748140000\",\n \"0xd6fc0446c6a8d40ae3551db7e701d1fa876e4a49\": \"0x6c6b935b8bbd400000\",\n \"0xd703c6a4f11d60194579d58c2766a7ef16c30a29\": \"0x6c6b935b8bbd400000\",\n \"0xd7052519756af42590f15391b723a03fa564a951\": \"0xfa3631480d01fd8000\",\n \"0xd70a612bd6dda9eab0dddcff4aaf4122d38feae4\": \"0x1d460162f516f00000\",\n \"0xd70ad2c4e9eebfa637ef56bd486ad2a1e5bce093\": \"0xad78ebc5ac6200000\",\n \"0xd7140c8e5a4307fab0cc27badd9295018bf87970\": \"0x5f1016b5076d00000\",\n \"0xd7164aa261c09ad9b2b5068d453ed8eb6aa13083\": \"0xa2a15d09519be00000\",\n \"0xd71e43a45177ad51cbe0f72184a5cb503917285a\": \"0xad78ebc5ac6200000\",\n \"0xd71fb130f0150c565269e00efb43902b52a455a6\": \"0xad78ebc5ac6200000\",\n \"0xd7225738dcf3578438f8e7c8b3837e42e04a262f\": \"0x182b8cebbb83aa0000\",\n \"0xd7274d50804d9c77da93fa480156efe57ba501de\": \"0x692ae8897081d00000\",\n \"0xd731bb6b5f3c37395e09ceaccd14a918a6060789\": \"0xd5967be4fc3f100000\",\n \"0xd73ed2d985b5f21b55b274643bc6da031d8edd8d\": \"0xa6dd90cae5114480000\",\n \"0xd744ac7e5310be696a63b003c40bd039370561c6\": \"0x5a87e7d7f5f6580000\",\n \"0xd74a6e8d6aab34ce85976814c1327bd6ea0784d2\": \"0x152d02c7e14af6800000\",\n \"0xd75a502a5b677287470f65c5aa51b87c10150572\": \"0x3130b4646385740000\",\n \"0xd76dbaebc30d4ef67b03e6e6ecc6d84e004d502d\": \"0x6d76b9188e13850000\",\n \"0xd771d9e0ca8a08a113775731434eb3270599c40d\": \"0x1158e460913d00000\",\n \"0xd7788ef28658aa06cc53e1f3f0de58e5c371be78\": \"0x16a6502f15a1e540000\",\n \"0xd77892e2273b235d7689e430e7aeed9cbce8a1f3\": \"0x6c6b935b8bbd400000\",\n \"0xd781f7fc09184611568570b4986e2c72872b7ed0\": \"0x1159561065d5d0000\",\n \"0xd785a8f18c38b9bc4ffb9b8fa8c7727bd642ee1c\": \"0x3635c9adc5dea00000\",\n \"0xd78ecd25adc86bc2051d96f65364866b42a426b7\": \"0xd23058bf2f26120000\",\n \"0xd78f84e38944a0e0255faece48ba4950d4bd39d2\": \"0x10f0cf064dd59200000\",\n \"0xd79483f6a8444f2549d611afe02c432d15e11051\": \"0x1158e460913d00000\",\n \"0xd79835e404fb86bf845fba090d6ba25e0c8866a6\": \"0x821ab0d44149800000\",\n \"0xd79aff13ba2da75d46240cac0a2467c656949823\": \"0x5dc892aa1131c80000\",\n \"0xd79db5ab43621a7a3da795e58929f3dd25af67d9\": \"0x6c6acc67d7b1d40000\",\n \"0xd7a1431ee453d1e49a0550d1256879b4f5d10201\": \"0x5a87e7d7f5f6580000\",\n \"0xd7ad09c6d32657685355b5c6ec8e9f57b4ebb982\": \"0x6acb3df27e1f880000\",\n \"0xd7b740dff8c457668fdf74f6a266bfc1dcb723f9\": \"0x1158e460913d00000\",\n \"0xd7c2803ed7b0e0837351411a8e6637d168bc5b05\": \"0x641daf5c91bd9358000\",\n \"0xd7c6265dea11876c903b718e4cd8ab24fe265bde\": \"0x6c6b935b8bbd400000\",\n \"0xd7ca7fdcfebe4588eff5421d1522b61328df7bf3\": \"0xd8e6001e6c302b0000\",\n \"0xd7cdbd41fff20df727c70b6255c1ba7606055468\": \"0xad78ebc5ac6200000\",\n \"0xd7d157e4c0a96437a6d285741dd23ec4361fa36b\": \"0x6c6b935b8bbd400000\",\n \"0xd7d2c6fca8ad1f75395210b57de5dfd673933909\": \"0x126e72a69a50d00000\",\n \"0xd7d3c75920590438b82c3e9515be2eb6ed7a8b1a\": \"0xcb49b44ba602d800000\",\n \"0xd7d7f2caa462a41b3b30a34aeb3ba61010e2626f\": \"0x6c6b935b8bbd400000\",\n \"0xd7e74afdbad55e96cebc5a374f2c8b768680f2b0\": \"0x55de6a779bbac0000\",\n \"0xd7eb903162271c1afa35fe69e37322c8a4d29b11\": \"0x21e19e0c9bab2400000\",\n \"0xd7ebddb9f93987779b680155375438db65afcb6a\": \"0x5741afeff944c0000\",\n \"0xd7ef340e66b0d7afcce20a19cb7bfc81da33d94e\": \"0xa2a15d09519be00000\",\n \"0xd7f370d4bed9d57c6f49c999de729ee569d3f4e4\": \"0xad78ebc5ac6200000\",\n \"0xd7fa5ffb6048f96fb1aba09ef87b1c11dd7005e4\": \"0x3635c9adc5dea00000\",\n \"0xd8069f84b521493f4715037f3226b25f33b60586\": \"0x678a932062e4180000\",\n \"0xd815e1d9f4e2b5e57e34826b7cfd8881b8546890\": \"0xf015f25736420000\",\n \"0xd81bd54ba2c44a6f6beb1561d68b80b5444e6dc6\": \"0x3f170d7ee43c430000\",\n \"0xd82251456dc1380f8f5692f962828640ab9f2a03\": \"0x1088b53b2c202be0000\",\n \"0xd82c6fedbdac98af2eed10b00f32b00056ca5a6d\": \"0xad78ebc5ac6200000\",\n \"0xd82fd9fdf6996bedad2843159c06f37e0924337d\": \"0x5b8ccedc5aa7b00000\",\n \"0xd83ad260e9a6f432fb6ea28743299b4a09ad658c\": \"0x6c6b935b8bbd400000\",\n \"0xd843ee0863ce933e22f89c802d31287b9671e81c\": \"0xb98bc829a6f90000\",\n \"0xd84b922f7841fc5774f00e14604ae0df42c8551e\": \"0xd96fce90cfabcc0000\",\n \"0xd855b03ccb029a7747b1f07303e0a664793539c8\": \"0x6c6b935b8bbd400000\",\n \"0xd85fdeaf2a61f95db902f9b5a53c9b8f9266c3ac\": \"0x6cf65a7e9047280000\",\n \"0xd8715ef9176f850b2e30eb8e382707f777a6fbe9\": \"0x6c6b935b8bbd400000\",\n \"0xd874b9dfae456a929ba3b1a27e572c9b2cecdfb3\": \"0x93739534d28680000\",\n \"0xd8930a39c77357c30ad3a060f00b06046331fd62\": \"0x2c73c937742c500000\",\n \"0xd89bc271b27ba3ab6962c94a559006ae38d5f56a\": \"0x6c6b935b8bbd400000\",\n \"0xd8b77db9b81bbe90427b62f702b201ffc29ff618\": \"0x326d1e4396d45c0000\",\n \"0xd8cd64e0284eec53aa4639afc4750810b97fab56\": \"0x1158e460913d00000\",\n \"0xd8d64384249b776794063b569878d5e3b530a4b2\": \"0x9a043d0b2f9568000\",\n \"0xd8d65420c18c2327cc5af97425f857e4a9fd51b3\": \"0x5f68e8131ecf800000\",\n \"0xd8e5c9675ef4deed266b86956fc4590ea7d4a27d\": \"0x3635c9adc5dea00000\",\n \"0xd8e8474292e7a051604ca164c0707783bb2885e8\": \"0x2d4ca05e2b43ca80000\",\n \"0xd8eb78503ec31a54a90136781ae109004c743257\": \"0x3635c9adc5dea00000\",\n \"0xd8eef4cf4beb01ee20d111748b61cb4d3f641a01\": \"0x9489237adb9a500000\",\n \"0xd8f4bae6f84d910d6d7d5ac914b1e68372f94135\": \"0x56bc75e2d63100000\",\n \"0xd8f62036f03b7635b858f1103f8a1d9019a892b6\": \"0x2b5e3af16b1880000\",\n \"0xd8f665fd8cd5c2bcc6ddc0a8ae521e4dc6aa6060\": \"0x5c283d410394100000\",\n \"0xd8f9240c55cff035523c6d5bd300d370dc8f0c95\": \"0xf732b66015a540000\",\n \"0xd8f94579496725b5cb53d7985c989749aff849c0\": \"0x39992648a23c8a00000\",\n \"0xd8fdf546674738c984d8fab857880b3e4280c09e\": \"0x1158e460913d00000\",\n \"0xd8fe088fffce948f5137ee23b01d959e84ac4223\": \"0xc5b54a94fc0170000\",\n \"0xd90f3009db437e4e11c780bec8896f738d65ef0d\": \"0xd8d726b7177a800000\",\n \"0xd9103bb6b67a55a7fece2d1af62d457c2178946d\": \"0x3635c9adc5dea00000\",\n \"0xd913f0771949753c4726acaa2bd3619c5c20ff77\": \"0xa2a15d09519be00000\",\n \"0xd91d889164479ce436ece51763e22cda19b22d6b\": \"0xb66d88126800880000\",\n \"0xd929c65d69d5bbaea59762662ef418bc21ad924a\": \"0x3635c9adc5dea00000\",\n \"0xd930b27a78876485d0f48b70dd5336549679ca8f\": \"0x22b1c8c1227a00000\",\n \"0xd931ac2668ba6a84481ab139735aec14b7bfbabf\": \"0x6c6b935b8bbd400000\",\n \"0xd9383d4b6d17b3f9cd426e10fb944015c0d44bfb\": \"0x2b5e3af16b18800000\",\n \"0xd942de4784f7a48716c0fd4b9d54a6e54c5f2f3e\": \"0x43c33c1937564800000\",\n \"0xd944c8a69ff2ca1249690c1229c7192f36251062\": \"0x6acb3df27e1f880000\",\n \"0xd94a57882a52739bbe2a0647c80c24f58a2b4f1c\": \"0x48b54e2adbe12b0000\",\n \"0xd95342953c8a21e8b635eefac7819bea30f17047\": \"0x13f06c7ffef05d400000\",\n \"0xd95c90ffbe5484864780b867494a83c89256d6e4\": \"0x58e7926ee858a00000\",\n \"0xd96711540e2e998343d4f590b6fc8fac3bb8b31d\": \"0x5f5a4068b71cb00000\",\n \"0xd96ac2507409c7a383ab2eee1822a5d738b36b56\": \"0xad78ebc5ac6200000\",\n \"0xd96db33b7b5a950c3efa2dc31b10ba10a532ef87\": \"0x6c6b935b8bbd400000\",\n \"0xd9775965b716476675a8d513eb14bbf7b07cd14a\": \"0x1132e6d2d23c5e40000\",\n \"0xd97bc84abd47c05bbf457b2ef659d61ca5e5e48f\": \"0x69d17119dc5a80000\",\n \"0xd97f4526dea9b163f8e8e33a6bcf92fb907de6ec\": \"0xf654aaf4db2f00000\",\n \"0xd97fe6f53f2a58f6d76d752adf74a8a2c18e9074\": \"0x10cdf9b69a43570000\",\n \"0xd99999a2490d9494a530cae4daf38554f4dd633e\": \"0x68155a43676e00000\",\n \"0xd99df7421b9382e42c89b006c7f087702a0757c0\": \"0x1a055690d9db800000\",\n \"0xd9b783d31d32adc50fa3eacaa15d92b568eaeb47\": \"0x733af90374c1b280000\",\n \"0xd9d370fec63576ab15b318bf9e58364dc2a3552a\": \"0x56bc75e2d63100000\",\n \"0xd9d42fd13ebd4bf69cac5e9c7e82483ab46dd7e9\": \"0x121ea68c114e5100000\",\n \"0xd9e27eb07dfc71a706060c7f079238ca93e88539\": \"0x3635c9adc5dea00000\",\n \"0xd9e3857efd1e202a441770a777a49dcc45e2e0d3\": \"0xc1daf81d8a3ce0000\",\n \"0xd9ec2efe99ff5cf00d03a8317b92a24aef441f7e\": \"0x6c6b935b8bbd400000\",\n \"0xd9ec8fe69b7716c0865af888a11b2b12f720ed33\": \"0xd8d726b7177a800000\",\n \"0xd9f1b26408f0ec67ad1d0d6fe22e8515e1740624\": \"0x14d1120d7b1600000\",\n \"0xd9f547f2c1de0ed98a53d161df57635dd21a00bd\": \"0x556f64c1fe7fa0000\",\n \"0xd9ff115d01266c9f73b063c1c238ef3565e63b36\": \"0x24dce54d34a1a00000\",\n \"0xda06044e293c652c467fe74146bf185b21338a1c\": \"0x3635c9adc5dea00000\",\n \"0xda0b48e489d302b4b7bf204f957c1c9be383b0df\": \"0x6c6b935b8bbd400000\",\n \"0xda0d4b7ef91fb55ad265f251142067f10376ced6\": \"0x43c33c1937564800000\",\n \"0xda10978a39a46ff0bb848cf65dd9c77509a6d70e\": \"0x6c6b935b8bbd400000\",\n \"0xda16dd5c3d1a2714358fe3752cae53dbab2be98c\": \"0x41bad155e6512200000\",\n \"0xda214c023e2326ff696c00393168ce46ffac39ec\": \"0x3635c9adc5dea00000\",\n \"0xda2a14f9724015d79014ed8e5909681d596148f1\": \"0x2a10f0f8a91ab8000\",\n \"0xda2ad58e77deddede2187646c465945a8dc3f641\": \"0x23c757072b8dd00000\",\n \"0xda3017c150dd0dce7fcf881b0a48d0d1c756c4c7\": \"0x56bf91b1a65eb0000\",\n \"0xda34b2eae30bafe8daeccde819a794cd89e09549\": \"0x6c6b935b8bbd400000\",\n \"0xda4a5f557f3bab390a92f49b9b900af30c46ae80\": \"0x21e19e0c9bab2400000\",\n \"0xda505537537ffb33c415fec64e69bae090c5f60f\": \"0x8ac7230489e800000\",\n \"0xda698d64c65c7f2b2c7253059cd3d181d899b6b7\": \"0x1004e2e45fb7ee0000\",\n \"0xda7732f02f2e272eaf28df972ecc0ddeed9cf498\": \"0xb20bfbf6967890000\",\n \"0xda7ad025ebde25d22243cb830ea1d3f64a566323\": \"0x1b1ae4d6e2ef500000\",\n \"0xda855d53477f505ec4c8d5e8bb9180d38681119c\": \"0x12f939c99edab800000\",\n \"0xda875e4e2f3cabe4f37e0eaed7d1f6dcc6ffef43\": \"0x6c6b935b8bbd400000\",\n \"0xda8bbee182e455d2098acb338a6d45b4b17ed8b6\": \"0x6c6b935b8bbd400000\",\n \"0xda982e9643ffece723075a40fe776e5ace04b29b\": \"0x8b8b6c9999bf20000\",\n \"0xda9f55460946d7bfb570ddec757ca5773b58429a\": \"0x1b845d769eb4480000\",\n \"0xdaa1bd7a9148fb865cd612dd35f162861d0f3bdc\": \"0xa638ab72d92c138000\",\n \"0xdaa63cbda45dd487a3f1cd4a746a01bb5e060b90\": \"0x10416d9b02a89240000\",\n \"0xdaa776a6754469d7b9267a89b86725e740da0fa0\": \"0x6acb3df27e1f880000\",\n \"0xdaac91c1e859d5e57ed3084b50200f9766e2c52b\": \"0x15af1d78b58c400000\",\n \"0xdaacdaf42226d15cb1cf98fa15048c7f4ceefe69\": \"0x1043561a8829300000\",\n \"0xdab6bcdb83cf24a0ae1cb21b3b5b83c2f3824927\": \"0xa968163f0a57b400000\",\n \"0xdabb0889fc042926b05ef57b2520910abc4b4149\": \"0x6c6b935b8bbd400000\",\n \"0xdabc225042a6592cfa13ebe54efa41040878a5a2\": \"0xe11fad5d85ca30000\",\n \"0xdac0c177f11c5c3e3e78f2efd663d13221488574\": \"0x3635c9adc5dea00000\",\n \"0xdad136b88178b4837a6c780feba226b98569a94c\": \"0xad78ebc5ac6200000\",\n \"0xdadbfafd8b62b92a24efd75256dd83abdbd7bbdb\": \"0x11164759ffb320000\",\n \"0xdadc00ab7927603c2fcf31cee352f80e6c4d6351\": \"0x6c66e9a55378b80000\",\n \"0xdae0d33eaa341569fa9ff5982684854a4a328a6e\": \"0x3635c9adc5dea00000\",\n \"0xdae7201eab8c063302930d693929d07f95e71962\": \"0x91aec028b419810000\",\n \"0xdaedd4ad107b271e89486cbf80ebd621dd974578\": \"0x6c6b935b8bbd400000\",\n \"0xdb04fad9c49f9e880beb8fcf1d3a3890e4b3846f\": \"0x435ae6cc0c58e50000\",\n \"0xdb0cc78f74d9827bdc8a6473276eb84fdc976212\": \"0x6c6b935b8bbd400000\",\n \"0xdb1293a506e90cad2a59e1b8561f5e66961a6788\": \"0x6c6b935b8bbd400000\",\n \"0xdb19a3982230368f0177219cb10cb259cdb2257c\": \"0x6c6b935b8bbd400000\",\n \"0xdb23a6fef1af7b581e772cf91882deb2516fc0a7\": \"0xad78ebc5ac6200000\",\n \"0xdb244f97d9c44b158a40ed9606d9f7bd38913331\": \"0x58788cb94b1d80000\",\n \"0xdb288f80ffe232c2ba47cc94c763cf6fc9b82b0d\": \"0x49b9ca9a694340000\",\n \"0xdb2a0c9ab64df58ddfb1dbacf8ba0d89c85b31b4\": \"0xd8d726b7177a800000\",\n \"0xdb34745ede8576b499db01beb7c1ecda85cf4abe\": \"0x4563918244f400000\",\n \"0xdb3f258ab2a3c2cf339c4499f75a4bd1d3472e9e\": \"0x5150ae84a8cdf00000\",\n \"0xdb4bc83b0e6baadb1156c5cf06e0f721808c52c7\": \"0x2fb474098f67c00000\",\n \"0xdb63122de7037da4971531fae9af85867886c692\": \"0xf0425b0641f340000\",\n \"0xdb6c2a73dac7424ab0d031b66761122566c01043\": \"0xa2a15d09519be00000\",\n \"0xdb6e560c9bc620d4bea3a94d47f7880bf47f2d5f\": \"0x4da0fdfcf05760000\",\n \"0xdb6ff71b3db0928f839e05a7323bfb57d29c87aa\": \"0x3154c9729d05780000\",\n \"0xdb73460b59d8e85045d5e752e62559875e42502e\": \"0x36330322d5238c0000\",\n \"0xdb77b88dcb712fd17ee91a5b94748d720c90a994\": \"0x6c6b935b8bbd400000\",\n \"0xdb7d4037081f6c65f9476b0687d97f1e044d0a1d\": \"0x23c757072b8dd00000\",\n \"0xdb882eacedd0eff263511b312adbbc59c6b8b25b\": \"0x1ed4fde7a2236b00000\",\n \"0xdb9371b30c4c844e59e03e924be606a938d1d310\": \"0x6c6b935b8bbd400000\",\n \"0xdba4796d0ceb4d3a836b84c96f910afc103f5ba0\": \"0x908f493f737410000\",\n \"0xdbadc61ed5f0460a7f18e51b2fb2614d9264a0e0\": \"0x22b1c8c1227a00000\",\n \"0xdbb6ac484027041642bbfd8d80f9d0c1cf33c1eb\": \"0x6c6b935b8bbd400000\",\n \"0xdbbcbb79bf479a42ad71dbcab77b5adfaa872c58\": \"0x5dc892aa1131c80000\",\n \"0xdbc1ce0e49b1a705d22e2037aec878ee0d75c703\": \"0xd8d726b7177a80000\",\n \"0xdbc1d0ee2bab531140de137722cd36bdb4e47194\": \"0xad78ebc5ac6200000\",\n \"0xdbc59ed88973dead310884223af49763c05030f1\": \"0x1158e460913d00000\",\n \"0xdbc66965e426ff1ac87ad6eb78c1d95271158f9f\": \"0xfc936392801c0000\",\n \"0xdbcbcd7a57ea9db2349b878af34b1ad642a7f1d1\": \"0xad78ebc5ac6200000\",\n \"0xdbd51cdf2c3bfacdff106221de2e19ad6d420414\": \"0x5f68e8131ecf800000\",\n \"0xdbd71efa4b93c889e76593de609c3b04cbafbe08\": \"0x1158e460913d00000\",\n \"0xdbf5f061a0f48e5e69618739a77d2ec19768d201\": \"0x83d6c7aab63600000\",\n \"0xdbf8b13967f55125272de0562536c450ba5655a0\": \"0x6ef578f06e0ccb0000\",\n \"0xdbfb1bb464b8a58e500d2ed8de972c45f5f1c0fb\": \"0x56bc75e2d631000000\",\n \"0xdc067ed3e12d711ed475f5156ef7e71a80d934b9\": \"0x205b4dfa1ee74780000\",\n \"0xdc087f9390fb9e976ac23ab689544a0942ec2021\": \"0x62a992e53a0af00000\",\n \"0xdc1eb9b6e64351f56424509645f83e79eee76cf4\": \"0xd8d726b7177a800000\",\n \"0xdc1f1979615f082140b8bb78c67b27a1942713b1\": \"0x340aad21b3b700000\",\n \"0xdc23b260fcc26e7d10f4bd044af794579460d9da\": \"0x1b1b6bd7af64c70000\",\n \"0xdc29119745d2337320da51e19100c948d980b915\": \"0x8ac7230489e800000\",\n \"0xdc2d15a69f6bb33b246aef40450751c2f6756ad2\": \"0x6c341080bd1fb00000\",\n \"0xdc3dae59ed0fe18b58511e6fe2fb69b219689423\": \"0x56bc75e2d63100000\",\n \"0xdc3f0e7672f71fe7525ba30b9755183a20b9166a\": \"0x2089cf57b5b3e968000\",\n \"0xdc4345d6812e870ae90c568c67d2c567cfb4f03c\": \"0x16b352da5e0ed300000\",\n \"0xdc44275b1715baea1b0345735a29ac42c9f51b4f\": \"0x3f19beb8dd1ab00000\",\n \"0xdc46c13325cd8edf0230d068896486f007bf4ef1\": \"0x487a9a304539440000\",\n \"0xdc51b2dc9d247a1d0e5bc36ca3156f7af21ff9f6\": \"0x3635c9adc5dea00000\",\n \"0xdc5305b4020a06b49d657c7ca34c35c91c5f2c56\": \"0x17df6c10dbeba970000\",\n \"0xdc57345b38e0f067c9a31d9deac5275a10949321\": \"0xad78ebc5ac6200000\",\n \"0xdc57477dafa42f705c7fe40eae9c81756e0225f1\": \"0x1b1b8128a7416e0000\",\n \"0xdc5f5ad663a6f263327d64cac9cb133d2c960597\": \"0x6c6b935b8bbd400000\",\n \"0xdc703a5f3794c84d6cb3544918cae14a35c3bd4f\": \"0x6449e84e47a8a80000\",\n \"0xdc738fb217cead2f69594c08170de1af10c419e3\": \"0x152d02c7e14af6800000\",\n \"0xdc76e85ba50b9b31ec1e2620bce6e7c8058c0eaf\": \"0x1158e460913d00000\",\n \"0xdc83b6fd0d512131204707eaf72ea0c8c9bef976\": \"0x6c6b935b8bbd400000\",\n \"0xdc8c2912f084a6d184aa73638513ccbc326e0102\": \"0x4633bc36cbc2dc0000\",\n \"0xdc911cf7dc5dd0813656670528e9338e67034786\": \"0x6c6b935b8bbd400000\",\n \"0xdcb03bfa6c1131234e56b7ea7c4f721487546b7a\": \"0x487a9a304539440000\",\n \"0xdcb64df43758c7cf974fa660484fbb718f8c67c1\": \"0x43c33c1937564800000\",\n \"0xdcc52d8f8d9fc742a8b82767f0555387c563efff\": \"0x1b1ae4d6e2ef500000\",\n \"0xdccb370ed68aa922283043ef7cad1b9d403fc34a\": \"0xd8d726b7177a800000\",\n \"0xdccca42045ec3e16508b603fd936e7fd7de5f36a\": \"0x11164759ffb320000\",\n \"0xdcd10c55bb854f754434f1219c2c9a98ace79f03\": \"0xd8d8583fa2d52f0000\",\n \"0xdcd5bca2005395b675fde5035659b26bfefc49ee\": \"0xaadec983fcff40000\",\n \"0xdcdbbd4e2604e40e1710cc6730289dccfad3892d\": \"0xf95dd2ec27cce00000\",\n \"0xdce30c31f3ca66721ecb213c809aab561d9b52e4\": \"0x6c6b935b8bbd400000\",\n \"0xdcf33965531380163168fc11f67e89c6f1bc178a\": \"0x122776853406b08000\",\n \"0xdcf6b657266e91a4dae6033ddac15332dd8d2b34\": \"0x5f68e8131ecf800000\",\n \"0xdcf9719be87c6f46756db4891db9b611d2469c50\": \"0x3635c9adc5dea00000\",\n \"0xdcfff3e8d23c2a34b56bd1b3bd45c79374432239\": \"0x10f0cf064dd59200000\",\n \"0xdd04eee74e0bf30c3f8d6c2c7f52e0519210df93\": \"0x4563918244f400000\",\n \"0xdd26b429fd43d84ec179825324bad5bfb916b360\": \"0x116bf95bc8432980000\",\n \"0xdd2a233adede66fe1126d6c16823b62a021feddb\": \"0x6c6b935b8bbd400000\",\n \"0xdd2bdfa917c1f310e6fa35aa8af16939c233cd7d\": \"0x15af1d78b58c400000\",\n \"0xdd35cfdbcb993395537aecc9f59085a8d5ddb6f5\": \"0x3635c9adc5dea00000\",\n \"0xdd47189a3e64397167f0620e484565b762bfbbf4\": \"0x6449e84e47a8a80000\",\n \"0xdd4dd6d36033b0636fcc8d0938609f4dd64f4a86\": \"0x340aad21b3b700000\",\n \"0xdd4f5fa2111db68f6bde3589b63029395b69a92d\": \"0x8963dd8c2c5e00000\",\n \"0xdd63042f25ed32884ad26e3ad959eb94ea36bf67\": \"0x484d7fde7d593f00000\",\n \"0xdd65f6e17163b5d203641f51cc7b24b00f02c8fb\": \"0xad78ebc5ac6200000\",\n \"0xdd6c062193eac23d2fdbf997d5063a346bb3b470\": \"0x1158e460913d00000\",\n \"0xdd7bcda65924aaa49b80984ae173750258b92847\": \"0x21e19e0c9bab2400000\",\n \"0xdd7ff441ba6ffe3671f3c0dabbff1823a5043370\": \"0x6c6b935b8bbd400000\",\n \"0xdd8254121a6e942fc90828f2431f511dad7f32e6\": \"0xa39b29e1f360e80000\",\n \"0xdd8af9e7765223f4446f44d3d509819a3d3db411\": \"0x21e19e0c9bab2400000\",\n \"0xdd95dbe30f1f1877c5dd7684aeef302ab6885192\": \"0x1c5d8d6eb3e32500000\",\n \"0xdd967c4c5f8ae47e266fb416aad1964ee3e7e8c3\": \"0x1a420db02bd7d580000\",\n \"0xdd9b485a3b1cd33a6a9c62f1e5bee92701856d25\": \"0xc3383ed031b7e8000\",\n \"0xdda371e600d30688d4710e088e02fdf2b9524d5f\": \"0x177224aa844c7200000\",\n \"0xdda4ed2a58a8dd20a73275347b580d71b95bf99a\": \"0x15a13cc201e4dc0000\",\n \"0xdda4ff7de491c687df4574dd1b17ff8f246ba3d1\": \"0x42684a41abfd8400000\",\n \"0xddab6b51a9030b40fb95cf0b748a059c2417bec7\": \"0x6c6b935b8bbd400000\",\n \"0xddab75fb2ff9fecb88f89476688e2b00e367ebf9\": \"0x41bad155e6512200000\",\n \"0xddabf13c3c8ea4e3d73d78ec717afafa430e5479\": \"0x8cf23f909c0fa000000\",\n \"0xddac312a9655426a9c0c9efa3fd82559ef4505bf\": \"0x15be6174e1912e0000\",\n \"0xddac6bf4bbdd7d597d9c686d0695593bedccc7fa\": \"0x2ee449550898e40000\",\n \"0xddbd2b932c763ba5b1b7ae3b362eac3e8d40121a\": \"0x21e19e0c9bab2400000\",\n \"0xddbddd1bbd38ffade0305d30f02028d92e9f3aa8\": \"0x6c6b935b8bbd400000\",\n \"0xddbee6f094eae63420b003fb4757142aea6cd0fd\": \"0x6c6b935b8bbd400000\",\n \"0xddd69c5b9bf5eb5a39cee7c3341a120d973fdb34\": \"0x6bc14b8f8e1b350000\",\n \"0xdddd7b9e6eab409b92263ac272da801b664f8a57\": \"0x69e10de76676d0800000\",\n \"0xdde670d01639667576a22dd05d3246d61f06e083\": \"0x1731790534df20000\",\n \"0xdde77a4740ba08e7f73fbe3a1674912931742eeb\": \"0x434fe4d4382f1d48000\",\n \"0xdde8f0c31b7415511dced1cd7d46323e4bd12232\": \"0x57473d05dabae80000\",\n \"0xdde969aef34ea87ac299b7597e292b4a0155cc8a\": \"0x1032f2594a01738000\",\n \"0xddf0cce1fe996d917635f00712f4052091dff9ea\": \"0x6c6b935b8bbd400000\",\n \"0xddf3ad76353810be6a89d731b787f6f17188612b\": \"0x43c33c1937564800000\",\n \"0xddf5810a0eb2fb2e32323bb2c99509ab320f24ac\": \"0x3ca5c66d9bc44300000\",\n \"0xddf95c1e99ce2f9f5698057c19d5c94027ee4a6e\": \"0x14542ba12a337c00000\",\n \"0xddfafdbc7c90f1320e54b98f374617fbd01d109f\": \"0xb98bc829a6f90000\",\n \"0xddfcca13f934f0cfbe231da13039d70475e6a1d0\": \"0x3638221660a5aa8000\",\n \"0xde027efbb38503226ed871099cb30bdb02af1335\": \"0x3635c9adc5dea00000\",\n \"0xde06d5ea777a4eb1475e605dbcbf43444e8037ea\": \"0xa968163f0a57b400000\",\n \"0xde07fb5b7a464e3ba7fbe09e9acb271af5338c58\": \"0x2b5e3af16b1880000\",\n \"0xde1121829c9a08284087a43fbd2fc1142a3233b4\": \"0x3635c9adc5dea00000\",\n \"0xde176b5284bcee3a838ba24f67fc7cbf67d78ef6\": \"0x209ce08c962b00000\",\n \"0xde212293f8f1d231fa10e609470d512cb8ffc512\": \"0x6c6b935b8bbd400000\",\n \"0xde30e49e5ab313214d2f01dcabce8940b81b1c76\": \"0xaadec983fcff40000\",\n \"0xde33d708a3b89e909eaf653b30fdc3a5d5ccb4b3\": \"0x99c88229fd4c20000\",\n \"0xde374299c1d07d79537385190f442ef9ca24061f\": \"0x73f75d1a085ba0000\",\n \"0xde42fcd24ce4239383304367595f068f0c610740\": \"0x2722a70f1a9a00000\",\n \"0xde50868eb7e3c71937ec73fa89dd8b9ee10d45aa\": \"0x3635c9adc5dea00000\",\n \"0xde55de0458f850b37e4d78a641dd2eb2dd8f38ce\": \"0xd8d726b7177a800000\",\n \"0xde5b005fe8daae8d1f05de3eda042066c6c4691c\": \"0x3ba1910bf341b00000\",\n \"0xde612d0724e84ea4a7feaa3d2142bd5ee82d3201\": \"0x1158e460913d00000\",\n \"0xde6d363106cc6238d2f092f0f0372136d1cd50c6\": \"0x121ea68c114e5100000\",\n \"0xde7dee220f0457a7187d56c1c41f2eb00ac56021\": \"0x2225f39c85052a0000\",\n \"0xde82cc8d4a1bb1d9434392965b3e80bad3c03d4f\": \"0x50186e75de97a60000\",\n \"0xde97f4330700b48c496d437c91ca1de9c4b01ba4\": \"0x9dcc0515b56e0c0000\",\n \"0xde9eff4c798811d968dccb460d9b069cf30278e0\": \"0x15af1d78b58c400000\",\n \"0xdeb1bc34d86d4a4dde2580d8beaf074eb0e1a244\": \"0x55a6e79ccd1d300000\",\n \"0xdeb2495d6aca7b2a6a2d138b6e1a42e2dc311fdd\": \"0x6c6b935b8bbd400000\",\n \"0xdeb97254474c0d2f5a7970dcdb2f52fb1098b896\": \"0x3635c9adc5dea00000\",\n \"0xdeb9a49a43873020f0759185e20bbb4cf381bb8f\": \"0xb78edb0bf2e5e0000\",\n \"0xdebbdd831e0f20ae6e378252decdf92f7cf0c658\": \"0x6c6b935b8bbd400000\",\n \"0xdec3eec2640a752c466e2b7e7ee685afe9ac41f4\": \"0x47c99753596b288000\",\n \"0xdec82373ade8ebcf2acb6f8bc2414dd7abb70d77\": \"0xad78ebc5ac6200000\",\n \"0xdec8a1a898f1b895d8301fe64ab3ad5de941f689\": \"0x2ab4f67e8a730f8000\",\n \"0xdec99e972fca7177508c8e1a47ac22d768acab7c\": \"0x6c6b935b8bbd400000\",\n \"0xded877378407b94e781c4ef4af7cfc5bc220b516\": \"0x143179d86911020000\",\n \"0xdee942d5caf5fac11421d86b010b458e5c392990\": \"0xd8d726b7177a800000\",\n \"0xdeee2689fa9006b59cf285237de53b3a7fd01438\": \"0x186579f29e20250000\",\n \"0xdefddfd59b8d2c154eecf5c7c167bf0ba2905d3e\": \"0x512cb5e2647420000\",\n \"0xdefe9141f4704599159d7b223de42bffd80496b3\": \"0x56bc75e2d63100000\",\n \"0xdf098f5e4e3dffa51af237bda8652c4f73ed9ca6\": \"0x1b36a6444a3e180000\",\n \"0xdf0d08617bd252a911df8bd41a39b83ddf809673\": \"0x21e19e0c9bab2400000\",\n \"0xdf0ff1f3d27a8ec9fb8f6b0cb254a63bba8224a5\": \"0xecc5202945d0020000\",\n \"0xdf1fa2e20e31985ebe2c0f0c93b54c0fb67a264b\": \"0xad78ebc5ac6200000\",\n \"0xdf211cd21288d6c56fae66c3ff54625dd4b15427\": \"0x8786cd764e1f2c0000\",\n \"0xdf236bf6abf4f3293795bf0c28718f93e3b1b36b\": \"0x487a9a304539440000\",\n \"0xdf31025f5649d2c6eea41ed3bdd3471a790f759a\": \"0x1158e460913d00000\",\n \"0xdf37c22e603aedb60a627253c47d8ba866f6d972\": \"0x5150ae84a8cdf000000\",\n \"0xdf3b72c5bd71d4814e88a62321a93d4011e3578b\": \"0xd8d726b7177a800000\",\n \"0xdf3f57b8ee6434d047223def74b20f63f9e4f955\": \"0xd9462c6cb4b5a0000\",\n \"0xdf44c47fc303ac76e74f97194cca67b5bb3c023f\": \"0x2009c5c8bf6fdc0000\",\n \"0xdf47a61b72535193c561cccc75c3f3ce0804a20e\": \"0x15935c0b4e3d780000\",\n \"0xdf47a8ef95f2f49f8e6f58184154145d11f72797\": \"0x678a932062e4180000\",\n \"0xdf53003346d65c5e7a646bc034f2b7d32fcbe56a\": \"0x6c6b935b8bbd400000\",\n \"0xdf57353aaff2aadb0a04f9014e8da7884e86589c\": \"0x84886a66e4fb00000\",\n \"0xdf60f18c812a11ed4e2776e7a80ecf5e5305b3d6\": \"0x30ca024f987b900000\",\n \"0xdf6485c4297ac152b289b19dde32c77ec417f47d\": \"0x3635c9adc5dea00000\",\n \"0xdf660a91dab9f730f6190d50c8390561500756ca\": \"0x6c6b935b8bbd400000\",\n \"0xdf6ed6006a6abe886ed33d95a4de28fc12183927\": \"0x3154c9729d05780000\",\n \"0xdf8510793eee811c2dab1c93c6f4473f30fbef5b\": \"0x3635c9adc5dea00000\",\n \"0xdf8d48b1eb07b3c217790e6c2df04dc319e7e848\": \"0x1b1ae4d6e2ef500000\",\n \"0xdfa6b8b8ad3184e357da282951d79161cfb089bc\": \"0x15af1d78b58c400000\",\n \"0xdfaf31e622c03d9e18a0ddb8be60fbe3e661be0a\": \"0x21e171a3ec9f72c0000\",\n \"0xdfb1626ef48a1d7d7552a5e0298f1fc23a3b482d\": \"0x5ce895dd949efa0000\",\n \"0xdfb4d4ade52fcc818acc7a2c6bb2b00224658f78\": \"0x1a420db02bd7d580000\",\n \"0xdfbd4232c17c407a980db87ffbcda03630e5c459\": \"0x1dfc7f924923530000\",\n \"0xdfcbdf09454e1a5e4a40d3eef7c5cf1cd3de9486\": \"0xd8d726b7177a800000\",\n \"0xdfdbcec1014b96da2158ca513e9c8d3b9af1c3d0\": \"0x6c6b935b8bbd400000\",\n \"0xdfded2574b27d1613a7d98b715159b0d00baab28\": \"0x43c33c1937564800000\",\n \"0xdfdf43393c649caebe1bb18059decb39f09fb4e8\": \"0x15af1d78b58c400000\",\n \"0xdfe3c52a92c30396a4e33a50170dc900fcf8c9cf\": \"0x2b5e3af16b1880000\",\n \"0xdfe549fe8430e552c6d07cc3b92ccd43b12fb50f\": \"0x48875eaf6562a0000\",\n \"0xdfe929a61c1b38eddbe82c25c2d6753cb1e12d68\": \"0x15d1cf4176aeba0000\",\n \"0xdff1b220de3d8e9ca4c1b5be34a799bcded4f61c\": \"0x14e4e353ea39420000\",\n \"0xdff4007931786593b229efe5959f3a4e219e51af\": \"0x10afc1ade3b4ed40000\",\n \"0xdffcea5421ec15900c6ecfc777184e140e209e24\": \"0x115473824344e0000\",\n \"0xe001aba77c02e172086c1950fffbcaa30b83488f\": \"0x6acb3df27e1f880000\",\n \"0xe00484788db50fc6a48e379d123e508b0f6e5ab1\": \"0x3635c9adc5dea00000\",\n \"0xe0060462c47ff9679baef07159cae08c29f274a9\": \"0x6c6b935b8bbd400000\",\n \"0xe00d153b10369143f97f54b8d4ca229eb3e8f324\": \"0x83d6c7aab63600000\",\n \"0xe012db453827a58e16c1365608d36ed658720507\": \"0x6c6b935b8bbd400000\",\n \"0xe01547ba42fcafaf93938becf7699f74290af74f\": \"0x6c6b935b8bbd400000\",\n \"0xe016dc138e25815b90be3fe9eee8ffb2e105624f\": \"0x1b1ae4d6e2ef500000\",\n \"0xe01859f242f1a0ec602fa8a3b0b57640ec89075e\": \"0x1e162c177be5cc0000\",\n \"0xe020e86362b487752836a6de0bc02cd8d89a8b6a\": \"0x14542ba12a337c00000\",\n \"0xe023f09b2887612c7c9cf1988e3a3a602b3394c9\": \"0x6c6b935b8bbd400000\",\n \"0xe0272213e8d2fd3e96bd6217b24b4ba01b617079\": \"0x1158e460913d00000\",\n \"0xe02b74a47628be315b1f76b315054ad44ae9716f\": \"0xd8d726b7177a800000\",\n \"0xe03220c697bcd28f26ef0b74404a8beb06b2ba7b\": \"0x1b1ae4d6e2ef5000000\",\n \"0xe0352fdf819ba265f14c06a6315c4ac1fe131b2e\": \"0x3635c9adc5dea00000\",\n \"0xe0388aeddd3fe2ad56f85748e80e710a34b7c92e\": \"0x1b1ae4d6e2ef500000\",\n \"0xe03c00d00388ecbf4f263d0ac778bb41a57a40d9\": \"0x3636c9796436740000\",\n \"0xe04920dc6ecc1d6ecc084f88aa0af5db97bf893a\": \"0x9ddc1e3b901180000\",\n \"0xe04972a83ca4112bc871c72d4ae1616c2f0728db\": \"0xe81c77f29a32f0000\",\n \"0xe04ff5e5a7e2af995d8857ce0290b53a2b0eda5d\": \"0x3635c9adc5dea00000\",\n \"0xe05029aceb0778675bef1741ab2cd2931ef7c84b\": \"0x10f0dbae61009528000\",\n \"0xe056bf3ff41c26256fef51716612b9d39ade999c\": \"0x56be757a12e0a8000\",\n \"0xe061a4f2fc77b296d19ada238e49a5cb8ecbfa70\": \"0xd8d726b7177a800000\",\n \"0xe0663e8cd66792a641f56e5003660147880f018e\": \"0x6c6b935b8bbd400000\",\n \"0xe0668fa82c14d6e8d93a53113ef2862fa81581bc\": \"0x2f2f39fc6c54000000\",\n \"0xe069c0173352b10bf6834719db5bed01adf97bbc\": \"0x10634f8e5323b0000\",\n \"0xe06c29a81517e0d487b67fb0b6aabc4f57368388\": \"0x15be6174e1912e0000\",\n \"0xe06cb6294704eea7437c2fc3d30773b7bf38889a\": \"0x116dc3a8994b30000\",\n \"0xe07137ae0d116d033533c4eab496f8a9fb09569c\": \"0x4be4e7267b6ae00000\",\n \"0xe076db30ab486f79194ebbc45d8fab9a9242f654\": \"0x106607e3494baa00000\",\n \"0xe07ebbc7f4da416e42c8d4f842aba16233c12580\": \"0x6c6b935b8bbd400000\",\n \"0xe081ca1f4882db6043d5a9190703fde0ab3bf56d\": \"0x15af1d78b58c400000\",\n \"0xe083d34863e0e17f926b7928edff317e998e9c4b\": \"0x15af1d78b58c400000\",\n \"0xe08b9aba6bd9d28bc2056779d2fbf0f2855a3d9d\": \"0x6c6b935b8bbd400000\",\n \"0xe08bc29c2b48b169ff2bdc16714c586e6cb85ccf\": \"0x1158e460913d00000\",\n \"0xe08c60313106e3f9334fe6f7e7624d211130c077\": \"0x22b1c8c1227a00000\",\n \"0xe09c68e61998d9c81b14e4ee802ba7adf6d74cdb\": \"0xd8d726b7177a800000\",\n \"0xe09fea755aee1a44c0a89f03b5deb762ba33006f\": \"0x3ba289bc944ff70000\",\n \"0xe0a254ac09b9725bebc8e460431dd0732ebcabbf\": \"0x14542ba12a337c00000\",\n \"0xe0aa69365555b73f282333d1e30c1bbd072854e8\": \"0x17b7883c06916600000\",\n \"0xe0bad98eee9698dbf6d76085b7923de5754e906d\": \"0x90d972f32323c0000\",\n \"0xe0c4ab9072b4e6e3654a49f8a8db026a4b3386a9\": \"0x6c6b935b8bbd400000\",\n \"0xe0ce80a461b648a501fd0b824690c8868b0e4de8\": \"0x1b1ae4d6e2ef500000\",\n \"0xe0cf698a053327ebd16b7d7700092fe2e8542446\": \"0x52a34cbb61f578000\",\n \"0xe0d231e144ec9107386c7c9b02f1702ceaa4f700\": \"0x10f0dbae61009528000\",\n \"0xe0d76b7166b1f3a12b4091ee2b29de8caa7d07db\": \"0x6c6b935b8bbd400000\",\n \"0xe0e0b2e29dde73af75987ee4446c829a189c95bc\": \"0x813ca56906d340000\",\n \"0xe0e978753d982f7f9d1d238a18bd4889aefe451b\": \"0x20dd68aaf3289100000\",\n \"0xe0f372347c96b55f7d4306034beb83266fd90966\": \"0x15af1d78b58c400000\",\n \"0xe0f903c1e48ac421ab48528f3d4a2648080fe043\": \"0x3708baed3d68900000\",\n \"0xe0ff0bd9154439c4a5b7233e291d7d868af53f33\": \"0x1579216a51bbfb0000\",\n \"0xe10ac19c546fc2547c61c139f5d1f45a6666d5b0\": \"0x102da6fd0f73a3c0000\",\n \"0xe10c540088113fa6ec00b4b2c8824f8796e96ec4\": \"0x320f4509ab1ec7c00000\",\n \"0xe1173a247d29d8238df0922f4df25a05f2af77c3\": \"0x878c95d560f30478000\",\n \"0xe1203eb3a723e99c2220117ca6afeb66fa424f61\": \"0x200ef929e3256fe0000\",\n \"0xe131f87efc5ef07e43f0f2f4a747b551d750d9e6\": \"0x43c25e0dcc1bd1c0000\",\n \"0xe1334e998379dfe983177062791b90f80ee22d8d\": \"0x1b1ae4d6e2ef500000\",\n \"0xe13540ecee11b212e8b775dc8e71f374aae9b3f8\": \"0x6c6b935b8bbd400000\",\n \"0xe13b3d2bbfdcbc8772a23315724c1425167c5688\": \"0x37f379141ed04b8000\",\n \"0xe1443dbd95cc41237f613a48456988a04f683282\": \"0xd8d8583fa2d52f0000\",\n \"0xe14617f6022501e97e7b3e2d8836aa61f0ff2dba\": \"0xad78ebc5ac6200000\",\n \"0xe149b5726caf6d5eb5bf2acc41d4e2dc328de182\": \"0x692ae8897081d00000\",\n \"0xe154daeadb545838cbc6aa0c55751902f528682a\": \"0x10afc1ade3b4ed40000\",\n \"0xe16ce35961cd74bd590d04c4ad4a1989e05691c6\": \"0x7ea28327577080000\",\n \"0xe172dfc8f80cd1f8cd8539dc26082014f5a8e3e8\": \"0xa2a15d09519be00000\",\n \"0xe177e0c201d335ba3956929c571588b51c5223ae\": \"0x6c6b935b8bbd400000\",\n \"0xe17812f66c5e65941e186c46922b6e7b2f0eeb46\": \"0x62a992e53a0af00000\",\n \"0xe180de9e86f57bafacd7904f9826b6b4b26337a3\": \"0x2d041d705a2c600000\",\n \"0xe192489b85a982c1883246d915b229cb13207f38\": \"0x10f0cf064dd59200000\",\n \"0xe1953c6e975814c571311c34c0f6a99cdf48ab82\": \"0x2b5e3af16b1880000\",\n \"0xe1ae029b17e373cde3de5a9152201a14cac4e119\": \"0x56b55ae58ca400000\",\n \"0xe1b2aca154b8e0766c4eba30bc10c7f35036f368\": \"0x115473824344e0000\",\n \"0xe1b39b88d9900dbc4a6cdc481e1060080a8aec3c\": \"0x6c6b935b8bbd400000\",\n \"0xe1b63201fae1f129f95c7a116bd9dde5159c6cda\": \"0x4d60573a2f0c9ef0000\",\n \"0xe1bfaa5a45c504428923c4a61192a55b1400b45d\": \"0x90f534608a72880000\",\n \"0xe1c607c0a8a060da8f02a8eb38a013ea8cda5b8c\": \"0x2ba39e82ed5d740000\",\n \"0xe1cb83ec5eb6f1eeb85e99b2fc63812fde957184\": \"0x43c33c1937564800000\",\n \"0xe1d91b0954cede221d6f24c7985fc59965fb98b8\": \"0x6c6b935b8bbd400000\",\n \"0xe1dfb5cc890ee8b2877e885d267c256187d019e6\": \"0x56bc75e2d63100000\",\n \"0xe1e8c50b80a352b240ce7342bbfdf5690cc8cb14\": \"0x155bd9307f9fe80000\",\n \"0xe1f63ebbc62c7b7444040eb99623964f7667b376\": \"0x1158e460913d00000\",\n \"0xe206fb7324e9deb79e19903496d6961b9be56603\": \"0x56bc75e2d63100000\",\n \"0xe207578e1f4ddb8ff6d5867b39582d71b9812ac5\": \"0xd255d112e103a00000\",\n \"0xe208812a684098f3da4efe6aba256256adfe3fe6\": \"0x6c6b935b8bbd400000\",\n \"0xe20954d0f4108c82d4dcb2148d26bbd924f6dd24\": \"0x21e19e0c9bab2400000\",\n \"0xe20bb9f3966419e14bbbaaaa6789e92496cfa479\": \"0xbbd825030752760000\",\n \"0xe20d1bcb71286dc7128a9fc7c6ed7f733892eef5\": \"0x3664f8e7c24af40000\",\n \"0xe2191215983f33fd33e22cd4a2490054da53fddc\": \"0xdb44e049bb2c0000\",\n \"0xe2198c8ca1b399f7521561fd5384a7132fba486b\": \"0x3708baed3d68900000\",\n \"0xe21c778ef2a0d7f751ea8c074d1f812243863e4e\": \"0x11fc70e2c8c8ae18000\",\n \"0xe229e746a83f2ce253b0b03eb1472411b57e5700\": \"0x1369fb96128ac480000\",\n \"0xe22b20c77894463baf774cc256d5bddbbf7ddd09\": \"0x3635c9adc5dea00000\",\n \"0xe230fe1bff03186d0219f15d4c481b7d59be286a\": \"0x1fd741e8088970000\",\n \"0xe237baa4dbc9926e32a3d85d1264402d54db012f\": \"0x6c6b935b8bbd400000\",\n \"0xe24109be2f513d87498e926a286499754f9ed49e\": \"0x300ea8ad1f27ca0000\",\n \"0xe246683cc99db7c4a52bcbacaab0b32f6bfc93d7\": \"0x6c6b935b8bbd400000\",\n \"0xe25a167b031e84616d0f013f31bda95dcc6350b9\": \"0x23c757072b8dd000000\",\n \"0xe25b9f76b8ad023f057eb11ad94257a0862e4e8c\": \"0x6c6b935b8bbd400000\",\n \"0xe26657f0ed201ea2392c9222b80a7003608ddf30\": \"0x22b1c8c1227a00000\",\n \"0xe26bf322774e18288769d67e3107deb7447707b8\": \"0x6c6b935b8bbd400000\",\n \"0xe2728a3e8c2aaac983d05dc6877374a8f446eee9\": \"0xab640391201300000\",\n \"0xe28b062259e96eeb3c8d4104943f9eb325893cf5\": \"0x487a9a304539440000\",\n \"0xe28dbc8efd5e416a762ec0e018864bb9aa83287b\": \"0x531f200ab3e030a8000\",\n \"0xe2904b1aefa056398b6234cb35811288d736db67\": \"0x22b1c8c1227a00000\",\n \"0xe29d8ae452dcf3b6ac645e630409385551faae0a\": \"0x45a0da4adf5420000\",\n \"0xe2bbf84641e3541f6c33e6ed683a635a70bde2ec\": \"0x1b413cfcbf59b78000\",\n \"0xe2cf360aa2329eb79d2bf7ca04a27a17c532e4d8\": \"0x58788cb94b1d80000\",\n \"0xe2df23f6ea04becf4ab701748dc0963184555cdb\": \"0x6c6b935b8bbd400000\",\n \"0xe2e15c60dd381e3a4be25071ab249a4c5c5264da\": \"0x7f6bc49b81b5370000\",\n \"0xe2e26e4e1dcf30d048cc6ecf9d51ec1205a4e926\": \"0xd8d726b7177a800000\",\n \"0xe2ee691f237ee6529b6557f2fcdd3dcf0c59ec63\": \"0x127729c14687c200000\",\n \"0xe2efa5fca79538ce6068bf31d2c516d4d53c08e5\": \"0x71cc408df63400000\",\n \"0xe2efd0a9bc407ece03d67e8ec8e9d283f48d2a49\": \"0x299b33bf9c584e00000\",\n \"0xe2f40d358f5e3fe7463ec70480bd2ed398a7063b\": \"0x1158e460913d00000\",\n \"0xe2f9383d5810ea7b43182b8704b62b27f5925d39\": \"0x15af1d78b58c400000\",\n \"0xe2ff9ee4b6ecc14141cc74ca52a9e7a2ee14d908\": \"0x4be4e7267b6ae00000\",\n \"0xe30212b2011bb56bdbf1bc35690f3a4e0fd905ea\": \"0x1b2df9d219f57980000\",\n \"0xe303167f3d4960fe881b32800a2b4aeff1b088d4\": \"0x6c6b935b8bbd400000\",\n \"0xe304a32f05a83762744a9542976ff9b723fa31ea\": \"0x5572f240a346200000\",\n \"0xe308435204793764f5fcbe65eb510f5a744a655a\": \"0xad78ebc5ac6200000\",\n \"0xe309974ce39d60aadf2e69673251bf0e04760a10\": \"0xdc55fdb17647b0000\",\n \"0xe31b4eef184c24ab098e36c802714bd4743dd0d4\": \"0xad78ebc5ac6200000\",\n \"0xe321bb4a946adafdade4571fb15c0043d39ee35f\": \"0x556475382b4c9e0000\",\n \"0xe3263ce8af6db3e467584502ed7109125eae22a5\": \"0x6c6b935b8bbd400000\",\n \"0xe32b1c4725a1875449e98f970eb3e54062d15800\": \"0xad78ebc5ac6200000\",\n \"0xe32f95766d57b5cd4b173289d6876f9e64558194\": \"0x56bc75e2d63100000\",\n \"0xe33840d8bca7da98a6f3d096d83de78b70b71ef8\": \"0x6c6b935b8bbd400000\",\n \"0xe338e859fe2e8c15554848b75caecda877a0e832\": \"0x61acff81a78ad40000\",\n \"0xe33d980220fab259af6a1f4b38cf0ef3c6e2ea1a\": \"0x6c6b935b8bbd400000\",\n \"0xe33df4ce80ccb62a76b12bcdfcecc46289973aa9\": \"0x14542ba12a337c00000\",\n \"0xe33ff987541dde5cdee0a8a96dcc3f33c3f24cc2\": \"0x2a5a058fc295ed000000\",\n \"0xe3410bb7557cf91d79fa69d0dfea0aa075402651\": \"0x6c6b935b8bbd400000\",\n \"0xe341642d40d2afce2e9107c67079ac7a2660086c\": \"0x15af1d78b58c400000\",\n \"0xe35453eef2cc3c7a044d0ac134ba615908fa82ee\": \"0x7ff1ccb7561df0000\",\n \"0xe36a8ea87f1e99e8a2dc1b2608d166667c9dfa01\": \"0x56bc75e2d63100000\",\n \"0xe3712701619ca7623c55db3a0ad30e867db0168b\": \"0x1158e460913d00000\",\n \"0xe37f5fdc6ec97d2f866a1cfd0d3a4da4387b22b5\": \"0x21e19e0c9bab2400000\",\n \"0xe3878f91ca86053fced5444686a330e09cc388fb\": \"0xa844a7424d9c80000\",\n \"0xe38b91b35190b6d9deed021c30af094b953fdcaa\": \"0x1ceaf795b6b860000\",\n \"0xe38ef28a5ed984a7db24a1ae782dfb87f397dfc6\": \"0x7c0860e5a80dc0000\",\n \"0xe3925509c8d0b2a6738c5f6a72f35314491248ce\": \"0x36e9a8669a44768000\",\n \"0xe3933d61b77dcdc716407f8250bc91e4ffaeb09d\": \"0x1256986c95891c200000\",\n \"0xe3951de5aefaf0458768d774c254f7157735e505\": \"0x56c95de8e8ca1d0000\",\n \"0xe399c81a1d701b44f0b66f3399e66b275aaaf8c1\": \"0x3635c9adc5dea00000\",\n \"0xe39b11a8ab1ff5e22e5ae6517214f73c5b9b55dc\": \"0x6c6b935b8bbd400000\",\n \"0xe39e46e15d22ce56e0c32f1877b7d1a264cf94f3\": \"0x43c33c1937564800000\",\n \"0xe3a4621b66004588e31206f718cb00a319889cf0\": \"0x6c6b935b8bbd400000\",\n \"0xe3a4f83c39f85af9c8b1b312bfe5fc3423afa634\": \"0x18d993f34aef10000\",\n \"0xe3a89a1927cc4e2d43fbcda1e414d324a7d9e057\": \"0xb23e2a936dec60000\",\n \"0xe3ab3ca9b870e3f548517306bba4de2591afafc2\": \"0x410e34aecc8cd30000\",\n \"0xe3b3d2c9bf570be6a2f72adca1862c310936a43c\": \"0x56d2aa3a5c09a0000\",\n \"0xe3c0c128327a9ad80148139e269773428e638cb0\": \"0x6c6b935b8bbd400000\",\n \"0xe3c812737ac606baf7522ad817428a36050e7a34\": \"0x692ae8897081d00000\",\n \"0xe3cffe239c64e7e20388e622117391301b298696\": \"0x1b1ae4d6e2ef500000\",\n \"0xe3d3eaa299887865569e88be219be507189be1c9\": \"0x18ba6fa92e93160000\",\n \"0xe3d8bf4efe84b1616d1b89e427ddc6c8830685ae\": \"0x6c6b935b8bbd400000\",\n \"0xe3d915eda3b825d6ee4af9328d32ac18ada35497\": \"0x1b1ae4d6e2ef500000\",\n \"0xe3da4f3240844c9b6323b4996921207122454399\": \"0x27190a952df4be58000\",\n \"0xe3eb2c0a132a524f72ccc0d60fee8b41685d39e2\": \"0x6acb3df27e1f880000\",\n \"0xe3ec18a74ed43855409a26ade7830de8e42685ef\": \"0x11164759ffb320000\",\n \"0xe3ece1f632711d13bfffa1f8f6840871ee58fb27\": \"0xd8d726b7177a800000\",\n \"0xe3f80b40fb83fb97bb0d5230af4f6ed59b1c7cc8\": \"0x487a9a304539440000\",\n \"0xe3ffb02cb7d9ea5243701689afd5d417d7ed2ece\": \"0x43a77aabd00780000\",\n \"0xe400d651bb3f2d23d5f849e6f92d9c5795c43a8a\": \"0x90f534608a72880000\",\n \"0xe406f5dd72cab66d8a6ecbd6bfb494a7b6b09afe\": \"0x56bc75e2d63100000\",\n \"0xe408aa99835307eea4a6c5eb801fe694117f707d\": \"0x1b1ae4d6e2ef500000\",\n \"0xe408fceaa1b98f3c640f48fcba39f056066d6308\": \"0x21e19e0c9bab2400000\",\n \"0xe40a7c82e157540a0b00901dbb86c716e1a062da\": \"0x2b31d2425f6740000\",\n \"0xe41aea250b877d423a63ba2bce2f3a61c0248d56\": \"0xe18398e7601900000\",\n \"0xe430c0024fdbf73a82e21fccf8cbd09138421c21\": \"0xd8d726b7177a800000\",\n \"0xe4324912d64ea3aef76b3c2ff9df82c7e13ae991\": \"0x6c6b935b8bbd400000\",\n \"0xe4368bc1420b35efda95fafbc73090521916aa34\": \"0xd8d726b7177a800000\",\n \"0xe437acbe0f6227b0e36f36e4bcf7cf613335fb68\": \"0xad78ebc5ac6200000\",\n \"0xe44b7264dd836bee8e87970340ed2b9aed8ed0a5\": \"0x138e7faa01a803a0000\",\n \"0xe44ea51063405154aae736be2bf1ee3b9be639ae\": \"0xd8d726b7177a800000\",\n \"0xe4625501f52b7af52b19ed612e9d54fdd006b492\": \"0xb5a905a56ddd00000\",\n \"0xe4715956f52f15306ee9506bf82bccc406b3895e\": \"0xee79d4f48c5000000\",\n \"0xe47fbaed99fc209962604ebd20e240f74f4591f1\": \"0x6c6b935b8bbd400000\",\n \"0xe482d255ede56b04c3e8df151f56e9ca62aaa8c2\": \"0x1b1ae4d6e2ef500000\",\n \"0xe48e65125421880d42bdf1018ab9778d96928f3f\": \"0xe3aeb5737240a00000\",\n \"0xe492818aa684e5a676561b725d42f3cc56ae5198\": \"0x2b5e3af16b18800000\",\n \"0xe49936a92a8ccf710eaac342bc454b9b14ebecb1\": \"0x6c6b935b8bbd400000\",\n \"0xe49af4f34adaa2330b0e49dc74ec18ab2f92f827\": \"0x6c6b935b8bbd400000\",\n \"0xe49ba0cd96816c4607773cf8a5970bb5bc16a1e6\": \"0x5a87e7d7f5f6580000\",\n \"0xe4a47e3933246c3fd62979a1ea19ffdf8c72ef37\": \"0x809b383ea7d7e8000\",\n \"0xe4b6ae22c7735f5b89f34dd77ad0975f0acc9181\": \"0x3635c9adc5dea00000\",\n \"0xe4ca0a5238564dfc91e8bf22bade2901619a1cd4\": \"0x3635c9adc5dea00000\",\n \"0xe4cafb727fb5c6b70bb27533b8a9ccc9ef6888e1\": \"0x10497bf4af4caf8000\",\n \"0xe4dc22ed595bf0a337c01e03cc6be744255fc9e8\": \"0xa5aa85009e39c0000\",\n \"0xe4fb26d1ca1eecba3d8298d9d148119ac2bbf580\": \"0x15af1d78b58c400000\",\n \"0xe4fc13cfcbac1b17ce7783acd423a845943f6b3a\": \"0x1158e460913d00000\",\n \"0xe50b464ac9de35a5618b7cbf254674182b81b97e\": \"0xde42ee1544dd900000\",\n \"0xe5102c3b711b810344197419b1cd8a7059f13e32\": \"0x1043528d0984698000\",\n \"0xe510d6797fba3d6693835a844ea2ad540691971b\": \"0x3ae39d47383e8740000\",\n \"0xe51421f8ee2210c71ed870fe618276c8954afbe9\": \"0x487a9a304539440000\",\n \"0xe51eb87e7fb7311f5228c479b48ec9878831ac4c\": \"0x6c6b935b8bbd400000\",\n \"0xe5215631b14248d45a255296bed1fbfa0330ff35\": \"0x4703e6eb5291b80000\",\n \"0xe528a0e5a267d667e9393a6584e19b34dc9be973\": \"0x12f939c99edab800000\",\n \"0xe53425d8df1f11c341ff58ae5f1438abf1ca53cf\": \"0x1174a5cdf88bc80000\",\n \"0xe53c68796212033e4e6f9cff56e19c461eb454f9\": \"0x3635c9adc5dea00000\",\n \"0xe54102534de8f23effb093b31242ad3b233facfd\": \"0xd8d726b7177a800000\",\n \"0xe545ee84ea48e564161e9482d59bcf406a602ca2\": \"0x6449e84e47a8a80000\",\n \"0xe5481a7fed42b901bbed20789bd4ade50d5f83b9\": \"0x6c6b935b8bbd400000\",\n \"0xe559b5fd337b9c5572a9bf9e0f2521f7d446dbe4\": \"0xad78ebc5ac6200000\",\n \"0xe55c80520a1b0f755b9a2cd3ce214f7625653e8a\": \"0x6c6b935b8bbd400000\",\n \"0xe56d431324c92911a1749df292709c14b77a65cd\": \"0x1bc85dc2a89bb200000\",\n \"0xe57d2995b0ebdf3f3ca6c015eb04260dbb98b7c6\": \"0x6c6b935b8bbd400000\",\n \"0xe587b16abc8a74081e3613e14342c03375bf0847\": \"0x6c6b935b8bbd400000\",\n \"0xe589fa76984db5ec4004b46ee8a59492c30744ce\": \"0x97c9ce4cf6d5c00000\",\n \"0xe58dd23238ee6ea7c2138d385df500c325f376be\": \"0x62a992e53a0af00000\",\n \"0xe5953fea497104ef9ad2d4e5841c271f073519c2\": \"0x2629f66e0c53000000\",\n \"0xe5968797468ef767101b761d431fce14abffdbb4\": \"0x1b3d969fa411ca00000\",\n \"0xe597f083a469c4591c3d2b1d2c772787befe27b2\": \"0xf2dc7d47f15600000\",\n \"0xe59b3bd300893f97233ef947c46f7217e392f7e9\": \"0x3635c9adc5dea00000\",\n \"0xe5a365343cc4eb1e770368e1f1144a77b832d7e0\": \"0x1158e460913d00000\",\n \"0xe5a3d7eb13b15c100177236d1beb30d17ee15420\": \"0x6c6b935b8bbd400000\",\n \"0xe5aa0b833bb916dc19a8dd683f0ede241d988eba\": \"0xa2a15d09519be00000\",\n \"0xe5b7af146986c0ff8f85d22e6cc334077d84e824\": \"0x6c6b935b8bbd400000\",\n \"0xe5b826196c0e1bc1119b021cf6d259a610c99670\": \"0xad78ebc5ac6200000\",\n \"0xe5b96fc9ac03d448c1613ac91d15978145dbdfd1\": \"0xad78ebc5ac6200000\",\n \"0xe5b980d28eece2c06fca6c9473068b37d4a6d6e9\": \"0x25afd68cac2b900000\",\n \"0xe5bab4f0afd8a9d1a381b45761aa18f3d3cce105\": \"0x51bfd7c13878d10000\",\n \"0xe5bcc88c3b256f6ed5fe550e4a18198b943356ad\": \"0x6c6b935b8bbd400000\",\n \"0xe5bdf34f4ccc483e4ca530cc7cf2bb18febe92b3\": \"0x6d835a10bbcd20000\",\n \"0xe5dc9349cb52e161196122cf87a38936e2c57f34\": \"0x6c6b935b8bbd400000\",\n \"0xe5e33800a1b2e96bde1031630a959aa007f26e51\": \"0x487a9a304539440000\",\n \"0xe5e37e19408f2cfbec83349dd48153a4a795a08f\": \"0xe3aeb5737240a00000\",\n \"0xe5edc73e626f5d3441a45539b5f7a398c593edf6\": \"0x2ee449550898e40000\",\n \"0xe5edf8123f2403ce1a0299becf7aac744d075f23\": \"0xada55474b81340000\",\n \"0xe5f8ef6d970636b0dcaa4f200ffdc9e75af1741c\": \"0x6c6b935b8bbd400000\",\n \"0xe5fb31a5caee6a96de393bdbf89fbe65fe125bb3\": \"0x3635c9adc5dea00000\",\n \"0xe5fbe34984b637196f331c679d0c0c47d83410e1\": \"0x6c6c44fe47ec050000\",\n \"0xe60955dc0bc156f6c41849f6bd776ba44b0ef0a1\": \"0x10431627a0933b0000\",\n \"0xe60a55f2df996dc3aedb696c08dde039b2641de8\": \"0x6c6b935b8bbd400000\",\n \"0xe6115b13f9795f7e956502d5074567dab945ce6b\": \"0x152d02c7e14af6800000\",\n \"0xe61f280915c774a31d223cf80c069266e5adf19b\": \"0x2fb474098f67c00000\",\n \"0xe62f98650712eb158753d82972b8e99ca3f61877\": \"0x6c6b935b8bbd400000\",\n \"0xe62f9d7c64e8e2635aeb883dd73ba684ee7c1079\": \"0x1b1ae4d6e2ef5000000\",\n \"0xe63e787414b9048478a50733359ecdd7e3647aa6\": \"0x55a6e79ccd1d300000\",\n \"0xe646665872e40b0d7aa2ff82729caaba5bc3e89e\": \"0x15af1d78b58c400000\",\n \"0xe64ef012658d54f8e8609c4e9023c09fe865c83b\": \"0x18493fba64ef00000\",\n \"0xe64f6e1d6401b56c076b64a1b0867d0b2f310d4e\": \"0x2cbad71c53ae50000\",\n \"0xe667f652f957c28c0e66d0b63417c80c8c9db878\": \"0x209d922f5259c50000\",\n \"0xe677c31fd9cb720075dca49f1abccd59ec33f734\": \"0x1a6d6beb1d42ee00000\",\n \"0xe67c2c1665c88338688187629f49e99b60b2d3ba\": \"0xad78ebc5ac6200000\",\n \"0xe69a6cdb3a8a7db8e1f30c8b84cd73bae02bc0f8\": \"0x394fdc2e452f6718000\",\n \"0xe69d1c378b771e0feff051db69d966ac6779f4ed\": \"0x1dfa6aaa1497040000\",\n \"0xe69fcc26ed225f7b2e379834c524d70c1735e5bc\": \"0x6c6b935b8bbd400000\",\n \"0xe6a3010f0201bc94ff67a2f699dfc206f9e76742\": \"0x2fa7cbf66464980000\",\n \"0xe6a6f6dd6f70a456f4ec15ef7ad5e5dbb68bd7dc\": \"0xad78ebc5ac6200000\",\n \"0xe6b20f980ad853ad04cbfc887ce6601c6be0b24c\": \"0xd8d726b7177a800000\",\n \"0xe6b3ac3f5d4da5a8857d0b3f30fc4b2b692b77d7\": \"0x4f2591f896a6500000\",\n \"0xe6b9545f7ed086e552924639f9a9edbbd5540b3e\": \"0xcbd47b6eaa8cc00000\",\n \"0xe6bcd30a8fa138c5d9e5f6c7d2da806992812dcd\": \"0x370ea0d47cf61a800000\",\n \"0xe6c81ffcecb47ecdc55c0b71e4855f3e5e97fc1e\": \"0x121ea68c114e510000\",\n \"0xe6cb260b716d4c0ab726eeeb07c8707204e276ae\": \"0x3635c9adc5dea00000\",\n \"0xe6cb3f3124c9c9cc3834b1274bc3336456a38bac\": \"0x172b1de0a213ff0000\",\n \"0xe6d22209ffd0b87509ade3a8e2ef429879cb89b5\": \"0x3a7aa9e1899ca300000\",\n \"0xe6d49f86c228f47367a35e886caacb271e539429\": \"0x165ec09da7a1980000\",\n \"0xe6e621eaab01f20ef0836b7cad47464cb5fd3c96\": \"0x11219342afa24b0000\",\n \"0xe6e886317b6a66a5b4f81bf164c538c264351765\": \"0x6c6b935b8bbd400000\",\n \"0xe6e9a39d750fe994394eb68286e5ea62a6997882\": \"0x2086ac351052600000\",\n \"0xe6ec5cf0c49b9c317e1e706315ef9eb7c0bf11a7\": \"0x3a469f3467e8ec00000\",\n \"0xe6f5eb649afb99599c414b27a9c9c855357fa878\": \"0x90f534608a72880000\",\n \"0xe6fe0afb9dcedd37b2e22c451ba6feab67348033\": \"0x21e19e0c9bab2400000\",\n \"0xe710dcd09b8101f9437bd97db90a73ef993d0bf4\": \"0x14ee36c05ac2520000\",\n \"0xe727e67ef911b81f6cf9c73fcbfebc2b02b5bfc6\": \"0x6c6b935b8bbd400000\",\n \"0xe72e1d335cc29a96b9b1c02f003a16d971e90b9d\": \"0x55a6e79ccd1d300000\",\n \"0xe7311c9533f0092c7248c9739b5b2c864a34b1ce\": \"0x97f97d6cc26dfe0000\",\n \"0xe73bfeada6f0fd016fbc843ebcf6e370a65be70c\": \"0x6acb3df27e1f880000\",\n \"0xe73ccf436725c151e255ccf5210cfce5a43f13e3\": \"0x1154e53217ddb0000\",\n \"0xe742b1e6069a8ffc3c4767235defb0d49cbed222\": \"0x2b5e3af16b18800000\",\n \"0xe74608f506866ada6bfbfdf20fea440be76989ef\": \"0x6c6acc67d7b1d40000\",\n \"0xe7533e270cc61fa164ac1553455c105d04887e14\": \"0x696d8590020bb0000\",\n \"0xe75c1fb177089f3e58b1067935a6596ef1737fb5\": \"0x56a879fa775470000\",\n \"0xe75c3b38a58a3f33d55690a5a59766be185e0284\": \"0x1b1ae4d6e2ef500000\",\n \"0xe761d27fa3502cc76bb1a608740e1403cf9dfc69\": \"0xf2dc7d47f15600000\",\n \"0xe766f34ff16f3cfcc97321721f43ddf5a38b0cf4\": \"0x54069233bf7f780000\",\n \"0xe76d945aa89df1e457aa342b31028a5e9130b2ce\": \"0x3708baed3d68900000\",\n \"0xe7735ec76518fc6aa92da8715a9ee3f625788f13\": \"0x6c4d160bafa1b78000\",\n \"0xe77a89bd45dc04eeb4e41d7b596b707e6e51e74c\": \"0x28a857425466f800000\",\n \"0xe77d7deab296c8b4fa07ca3be184163d5a6d606c\": \"0x5043904b671190000\",\n \"0xe77febabdf080f0f5dca1d3f5766f2a79c0ffa7c\": \"0x4b229d28a843680000\",\n \"0xe780a56306ba1e6bb331952c22539b858af9f77d\": \"0xa968163f0a57b400000\",\n \"0xe781ec732d401202bb9bd13860910dd6c29ac0b6\": \"0x433874f632cc600000\",\n \"0xe784dcc873aa8c1513ec26ff36bc92eac6d4c968\": \"0xad78ebc5ac6200000\",\n \"0xe7912d4cf4562c573ddc5b71e37310e378ef86c9\": \"0x155bd9307f9fe80000\",\n \"0xe791d585b89936b25d298f9d35f9f9edc25a2932\": \"0x6c6b935b8bbd400000\",\n \"0xe792349ce9f6f14f81d0674096befa1f9221cdea\": \"0x5b5d234a0db4388000\",\n \"0xe796fd4e839b4c95d7510fb7c5c72b83c6c3e3c7\": \"0x1bc433f23f83140000\",\n \"0xe7a42f59fee074e4fb13ea9e57ecf1cc48282249\": \"0x43c33c1937564800000\",\n \"0xe7a4560c84b20e0fb54c49670c2903b0a96c42a4\": \"0x206aeac7a903980000\",\n \"0xe7a8e471eafb798f4554cc6e526730fd56e62c7d\": \"0x3635c9adc5dea00000\",\n \"0xe7be82c6593c1eeddd2ae0b15001ff201ab57b2f\": \"0x10910d4cdc9f60000\",\n \"0xe7c6b5fc05fc748e5b4381726449a1c0ad0fb0f1\": \"0x6c6b935b8bbd400000\",\n \"0xe7d17524d00bad82497c0f27156a647ff51d2792\": \"0x1158e460913d00000\",\n \"0xe7d213947fcb904ad738480b1eed2f5c329f27e8\": \"0x103c3b1d3e9c30000\",\n \"0xe7d6240620f42c5edbb2ede6aec43da4ed9b5757\": \"0x3635c9adc5dea00000\",\n \"0xe7da609d40cde80f00ce5b4ffb6aa9d0b03494fc\": \"0x3635c9adc5dea00000\",\n \"0xe7f06f699be31c440b43b4db0501ec0e25261644\": \"0x1b1ae4d6e2ef500000\",\n \"0xe7f4d7fe6f561f7fa1da3005fd365451ad89df89\": \"0xad78ebc5ac6200000\",\n \"0xe7fd8fd959aed2767ea7fa960ce1db53af802573\": \"0x3635c9adc5dea00000\",\n \"0xe80e7fef18a5db15b01473f3ad6b78b2a2f8acd9\": \"0x1b1ae4d6e2ef500000\",\n \"0xe8137fc1b2ec7cc7103af921899b4a39e1d959a1\": \"0x50c5e761a444080000\",\n \"0xe81c2d346c0adf4cc56708f6394ba6c8c8a64a1e\": \"0x6c6b935b8bbd400000\",\n \"0xe82c58c579431b673546b53a86459acaf1de9b93\": \"0x3635c9adc5dea00000\",\n \"0xe834c64318205ca7dd4a21abcb08266cb21ff02c\": \"0x3635c6204739d98000\",\n \"0xe83604e4ff6be7f96f6018d3ec3072ec525dff6b\": \"0x9ddc1e3b901180000\",\n \"0xe845e387c4cbdf982280f6aa01c40e4be958ddb2\": \"0x54b40b1f852bda00000\",\n \"0xe848ca7ebff5c24f9b9c316797a43bf7c356292d\": \"0x62e115c008a880000\",\n \"0xe84b55b525f1039e744b918cb3332492e45eca7a\": \"0xad78ebc5ac6200000\",\n \"0xe84f8076a0f2969ecd333eef8de41042986291f2\": \"0x176b344f2a78c00000\",\n \"0xe864fec07ed1214a65311e11e329de040d04f0fd\": \"0x59ca83f5c404968000\",\n \"0xe87dbac636a37721df54b08a32ef4959b5e4ff82\": \"0x6c6b935b8bbd400000\",\n \"0xe87e9bbfbbb71c1a740c74c723426df55d063dd9\": \"0x1b1928c00c7a6380000\",\n \"0xe87eac6d602b4109c9671bf57b950c2cfdb99d55\": \"0x2b4f21972ecce0000\",\n \"0xe881bbbe69722d81efecaa48d1952a10a2bfac8f\": \"0x3635c9adc5dea000000\",\n \"0xe89249738b7eced7cb666a663c49cbf6de8343ea\": \"0x6c6b935b8bbd400000\",\n \"0xe89c22f1a4e1d4746ecfaa59ed386fee12d51e37\": \"0x26f8e87f0a7da0000\",\n \"0xe89da96e06beaf6bd880b378f0680c43fd2e9d30\": \"0x209a1a01a56fec0000\",\n \"0xe8a91da6cf1b9d65c74a02ec1f96eecb6dd241f3\": \"0x692ae8897081d00000\",\n \"0xe8a9a41740f44f54c3688b53e1ddd42e43c9fe94\": \"0xd8d726b7177a800000\",\n \"0xe8b28acda971725769db8f563d28666d41ddab6c\": \"0x21e19e0c9bab2400000\",\n \"0xe8be24f289443ee473bc76822f55098d89b91cc5\": \"0x6c6b935b8bbd400000\",\n \"0xe8c3d3b0e17f97d1e756e684f94e1470f99c95a1\": \"0x15af1d78b58c400000\",\n \"0xe8c3f045bb7d38c9d2f395b0ba8492b253230901\": \"0x1e7e4171bf4d3a00000\",\n \"0xe8cc43bc4f8acf39bff04ebfbf42aac06a328470\": \"0x15af1d78b58c400000\",\n \"0xe8d942d82f175ecb1c16a405b10143b3f46b963a\": \"0x1ed2e8ff6d971c0000\",\n \"0xe8ddbed732ebfe754096fde9086b8ea4a4cdc616\": \"0x6c6b935b8bbd400000\",\n \"0xe8de725eca5def805ff7941d31ac1c2e342dfe95\": \"0x857e0d6f1da76a0000\",\n \"0xe8e9850586e94f5299ab494bb821a5f40c00bd04\": \"0xcf152640c5c8300000\",\n \"0xe8ead1bb90ccc3aea2b0dcc5b58056554655d1d5\": \"0x1a4aba225c207400000\",\n \"0xe8eaf12944092dc3599b3953fa7cb1c9761cc246\": \"0x6194049f30f7200000\",\n \"0xe8ed51bbb3ace69e06024b33f86844c47348db9e\": \"0x22f9ea89f4a7d6c40000\",\n \"0xe8ef100d7ce0895832f2678df72d4acf8c28b8e3\": \"0x1b1b6bd7af64c70000\",\n \"0xe8f29969e75c65e01ce3d86154207d0a9e7c76f2\": \"0xa22fa9a73a27198000\",\n \"0xe8fc36b0131ec120ac9e85afc10ce70b56d8b6ba\": \"0xad78ebc5ac6200000\",\n \"0xe90a354cec04d69e5d96ddc0c5138d3d33150aa0\": \"0x1b1a7dcf8a44d38000\",\n \"0xe9133e7d31845d5f2b66a2618792e869311acf66\": \"0x517c0cbf9a390880000\",\n \"0xe91dac0195b19e37b59b53f7c017c0b2395ba44c\": \"0x65ea3db75546600000\",\n \"0xe91fa0badaddb9a97e88d3f4db7c55d6bb7430fe\": \"0x14620c57dddae00000\",\n \"0xe923c06177b3427ea448c0a6ff019b54cc548d95\": \"0x1f780014667f28000\",\n \"0xe93d47a8ca885d540c4e526f25d5c6f2c108c4b8\": \"0x17da3a04c7b3e0000000\",\n \"0xe9458f68bb272cb5673a04f781b403556fd3a387\": \"0x34e8b88cee2d40000\",\n \"0xe94941b6036019b4016a30c1037d5a6903babaad\": \"0x2a48acab6204b00000\",\n \"0xe9495ba5842728c0ed97be37d0e422b98d69202c\": \"0x6c6b935b8bbd400000\",\n \"0xe94ded99dcb572b9bb1dcba32f6dee91e057984e\": \"0x155bd9307f9fe80000\",\n \"0xe95179527deca5916ca9a38f215c1e9ce737b4c9\": \"0x21e19e0c9bab2400000\",\n \"0xe9559185f166fc9513cc71116144ce2deb0f1d4b\": \"0x43c33c1937564800000\",\n \"0xe95e92bbc6de07bf3a660ebf5feb1c8a3527e1c5\": \"0xfc936392801c0000\",\n \"0xe965daa34039f7f0df62375a37e5ab8a72b301e7\": \"0x103fddecdb3f5700000\",\n \"0xe969ea1595edc5c4a707cfde380929633251a2b0\": \"0xad78ebc5ac6200000\",\n \"0xe96b184e1f0f54924ac874f60bbf44707446b72b\": \"0x9dcc0515b56e0c0000\",\n \"0xe96d7d4cdd15553a4e4d316d6d6480ca3cea1e38\": \"0x2955d02e1a135a00000\",\n \"0xe96e2d3813efd1165f12f602f97f4a62909d3c66\": \"0x7caee97613e6700000\",\n \"0xe97fde0b67716325cf0ecce8a191a3761b2c791d\": \"0x3677036edf0af60000\",\n \"0xe982e6f28c548f5f96f45e63f7ab708724f53fa1\": \"0x157ae829a41f3b0000\",\n \"0xe9864c1afc8eaad37f3ba56fcb7477cc622009b7\": \"0x448586170a7dc0000\",\n \"0xe987e6139e6146a717fef96bc24934a5447fe05d\": \"0x6c6b935b8bbd400000\",\n \"0xe989733ca1d58d9e7b5029ba5d444858bec03172\": \"0x1f87408313df4f8000\",\n \"0xe98c91cadd924c92579e11b41217b282956cdaa1\": \"0x75c9a8480320c0000\",\n \"0xe99aece90541cae224b87da673965e0aeb296afd\": \"0x31df9095a18f600000\",\n \"0xe99de258a4173ce9ac38ede26c0b3bea3c0973d5\": \"0x59d0b805e5bb300000\",\n \"0xe9a2b4914e8553bf0d7c00ca532369b879f931bf\": \"0x6c6b935b8bbd400000\",\n \"0xe9a39a8bac0f01c349c64cedb69897f633234ed2\": \"0xd7c198710e66b00000\",\n \"0xe9a5ae3c9e05977dd1069e9fd9d3aefbae04b8df\": \"0x6acb3df27e1f880000\",\n \"0xe9ac36376efa06109d40726307dd1a57e213eaa9\": \"0xa844a7424d9c80000\",\n \"0xe9b1f1fca3fa47269f21b061c353b7f5e96d905a\": \"0x1b1ae4d6e2ef500000\",\n \"0xe9b36fe9b51412ddca1a521d6e94bc901213dda8\": \"0x21e19e0c9bab2400000\",\n \"0xe9b4a4853577a9dbcc2e795be0310d1bed28641a\": \"0x3635c9adc5dea00000\",\n \"0xe9b6a790009bc16642c8d820b7cde0e9fd16d8f5\": \"0xc55325ca7415e00000\",\n \"0xe9b9a2747510e310241d2ece98f56b3301d757e0\": \"0x6c6b935b8bbd400000\",\n \"0xe9c35c913ca1fceab461582fe1a5815164b4fd21\": \"0x1b1ae4d6e2ef5000000\",\n \"0xe9c6dfae97f7099fc5f4e94b784db802923a1419\": \"0x2a53c6d724f100000\",\n \"0xe9c758f8da41e3346e4350e5ac3976345c6c1082\": \"0x68a0d3092826ad0000\",\n \"0xe9caf827be9d607915b365c83f0d3b7ea8c79b50\": \"0xa2a15d09519be00000\",\n \"0xe9cafe41a5e8bbd90ba02d9e06585b4eb546c57f\": \"0x6c6b935b8bbd400000\",\n \"0xe9d599456b2543e6db80ea9b210e908026e2146e\": \"0xad78ebc5ac6200000\",\n \"0xe9e1f7cb00a110edd0ebf8b377ef8a7bb856117f\": \"0xad78ebc5ac6200000\",\n \"0xea14bfda0a6e76668f8788321f07df37824ec5df\": \"0x2a5a058fc295ed000000\",\n \"0xea1ea0c599afb9cd36caacbbb52b5bbb97597377\": \"0x39fbae8d042dd00000\",\n \"0xea1efb3ce789bedec3d67c3e1b3bc0e9aa227f90\": \"0x27ca4bd719f0b80000\",\n \"0xea2c197d26e98b0da83e1b72c787618c979d3db0\": \"0x11164759ffb320000\",\n \"0xea3779d14a13f6c78566bcde403591413a6239db\": \"0x29b76432b94451200000\",\n \"0xea4e809e266ae5f13cdbe38f9d0456e6386d1274\": \"0xf3f20b8dfa69d00000\",\n \"0xea53c954f4ed97fd4810111bdab69ef981ef25b9\": \"0x3a9d5baa4abf1d00000\",\n \"0xea53d26564859d9e90bb0e53b7abf560e0162c38\": \"0x15af1d78b58c400000\",\n \"0xea60436912de6bf187d3a472ff8f5333a0f7ed06\": \"0x11164759ffb320000\",\n \"0xea60549ec7553f511d2149f2d4666cbd9243d93c\": \"0x6c6b935b8bbd400000\",\n \"0xea66e7b84dcdbf36eea3e75b85382a75f1a15d96\": \"0x5dbc9191266f118000\",\n \"0xea686c5057093c171c66db99e01b0ececb308683\": \"0x14dda85d2ce1478000\",\n \"0xea6afe2cc928ac8391eb1e165fc40040e37421e7\": \"0xa27fa063b2e2e68000\",\n \"0xea79057dabef5e64e7b44f7f18648e7e533718d2\": \"0xad78ebc5ac6200000\",\n \"0xea7c4d6dc729cd6b157c03ad237ca19a209346c3\": \"0x6c6b935b8bbd400000\",\n \"0xea8168fbf225e786459ca6bb18d963d26b505309\": \"0x1b1ae4d6e2ef500000\",\n \"0xea81ca8638540cd9d4d73d060f2cebf2241ffc3e\": \"0x6acb3df27e1f880000\",\n \"0xea8317197959424041d9d7c67a3ece1dbb78bb55\": \"0x155bd9307f9fe80000\",\n \"0xea8527febfa1ade29e26419329d393b940bbb7dc\": \"0x6c6acc67d7b1d40000\",\n \"0xea8f30b6e4c5e65290fb9864259bc5990fa8ee8a\": \"0x1158e460913d00000\",\n \"0xea94f32808a2ef8a9bf0861d1d2404f7b7be258a\": \"0x1158e460913d00000\",\n \"0xeaa45cea02d87d2cc8fda9434e2d985bd4031584\": \"0x681fc2cc6e2b8b0000\",\n \"0xeab0bd148309186cf8cbd13b7232d8095acb833a\": \"0x2439a881c6a717c0000\",\n \"0xeabb90d37989aab31feae547e0e6f3999ce6a35d\": \"0x6c6b935b8bbd400000\",\n \"0xeac0827eff0c6e3ff28a7d4a54f65cb7689d7b99\": \"0x9ad9e69f9d47520000\",\n \"0xeac1482826acb6111e19d340a45fb851576bed60\": \"0x1be8bab04d9be8000\",\n \"0xeac17b81ed5191fb0802aa54337313834107aaa4\": \"0x1b1ae4d6e2ef5000000\",\n \"0xeac3af5784927fe9a598fc4eec38b8102f37bc58\": \"0x3635c9adc5dea00000\",\n \"0xeac6b98842542ea10bb74f26d7c7488f698b6452\": \"0x43c33c1937564800000\",\n \"0xeac768bf14b8f9432e69eaa82a99fbeb94cd0c9c\": \"0x14dbb2195ca228900000\",\n \"0xead21c1deccfbf1c5cd96688a2476b69ba07ce4a\": \"0x3f24d8e4a00700000\",\n \"0xead4d2eefb76abae5533961edd11400406b298fc\": \"0xd255d112e103a00000\",\n \"0xead65262ed5d122df2b2751410f98c32d1238f51\": \"0x58317ed46b9b80000\",\n \"0xead75016e3a0815072b6b108bcc1b799acf0383e\": \"0x6c6b935b8bbd400000\",\n \"0xeaea23aa057200e7c9c15e8ff190d0e66c0c0e83\": \"0x6c6b935b8bbd400000\",\n \"0xeaed16eaf5daab5bf0295e5e077f59fb8255900b\": \"0xd8d726b7177a800000\",\n \"0xeaedcc6b8b6962d5d9288c156c579d47c0a9fcff\": \"0x49b9ca9a694340000\",\n \"0xeaf52388546ec35aca6f6c6393d8d609de3a4bf3\": \"0x1158e460913d00000\",\n \"0xeb10458daca79e4a6b24b29a8a8ada711b7f2eb6\": \"0xd8bb6549b02bb80000\",\n \"0xeb1cea7b45d1bd4d0e2a007bd3bfb354759e2c16\": \"0xabbcd4ef377580000\",\n \"0xeb25481fcd9c221f1ac7e5fd1ecd9307a16215b8\": \"0xaadec983fcff40000\",\n \"0xeb2ef3d38fe652403cd4c9d85ed7f0682cd7c2de\": \"0x90f534608a728800000\",\n \"0xeb3bdd59dcdda5a9bb2ac1641fd02180f5f36560\": \"0x165c96647b38a200000\",\n \"0xeb3ce7fc381c51db7d5fbd692f8f9e058a4c703d\": \"0xad78ebc5ac6200000\",\n \"0xeb453f5a3adddd8ab56750fadb0fe7f94d9c89e7\": \"0x1158e460913d00000\",\n \"0xeb4f00e28336ea09942588eeac921811c522143c\": \"0x6c6b935b8bbd400000\",\n \"0xeb52ab10553492329c1c54833ae610f398a65b9d\": \"0x83d6c7aab63600000\",\n \"0xeb570dba975227b1c42d6e8dea2c56c9ad960670\": \"0x6c6b935b8bbd400000\",\n \"0xeb6394a7bfa4d28911d5a5b23e93f35e340c2294\": \"0x43a77aabd00780000\",\n \"0xeb6810691d1ae0d19e47bd22cebee0b3ba27f88a\": \"0x87856315d878150000\",\n \"0xeb76424c0fd597d3e341a9642ad1ee118b2b579d\": \"0xd8d726b7177a800000\",\n \"0xeb7c202b462b7cc5855d7484755f6e26ef43a115\": \"0x6c6b935b8bbd400000\",\n \"0xeb835c1a911817878a33d167569ea3cdd387f328\": \"0x3635c9adc5dea00000\",\n \"0xeb89a882670909cf377e9e78286ee97ba78d46c2\": \"0x2b7cc2e9c3225c0000\",\n \"0xeb90c793b3539761e1c814a29671148692193eb4\": \"0x28a857425466f800000\",\n \"0xeb9cc9fe0869d2dab52cc7aae8fd57adb35f9feb\": \"0x6a93bb17af81f80000\",\n \"0xeba388b0da27c87b1cc0eac6c57b2c5a0b459c1a\": \"0x170a0f5040e50400000\",\n \"0xebaa216de9cc5a43031707d36fe6d5bedc05bdf0\": \"0x6ac5c62d9486070000\",\n \"0xebac2b4408ef5431a13b8508e86250982114e145\": \"0xd8d726b7177a800000\",\n \"0xebb62cf8e22c884b1b28c6fa88fbbc17938aa787\": \"0x2b42798403c9b80000\",\n \"0xebb7d2e11bc6b58f0a8d45c2f6de3010570ac891\": \"0x1731790534df20000\",\n \"0xebbb4f2c3da8be3eb62d1ffb1f950261cf98ecda\": \"0x6c6b935b8bbd400000\",\n \"0xebbd4db9019952d68b1b0f6d8cf0683c00387bb5\": \"0x120401563d7d910000\",\n \"0xebbeeb259184a6e01cccfc2207bbd883785ac90a\": \"0x219bc1b04783d30000\",\n \"0xebd356156a383123343d48843bffed6103e866b3\": \"0x6acb3df27e1f880000\",\n \"0xebd37b256563e30c6f9289a8e2702f0852880833\": \"0x6c6acc67d7b1d40000\",\n \"0xebe46cc3c34c32f5add6c3195bb486c4713eb918\": \"0x3635c9adc5dea00000\",\n \"0xebff84bbef423071e604c361bba677f5593def4e\": \"0x21e19e0c9bab2400000\",\n \"0xec0927bac7dc36669c28354ab1be83d7eec30934\": \"0x6c6b935b8bbd400000\",\n \"0xec0e18a01dc4dc5daae567c3fa4c7f8f9b590205\": \"0x111ffe404a41e60000\",\n \"0xec11362cec810985d0ebbd7b73451444985b369f\": \"0x65a4e49577057318000\",\n \"0xec2cb8b9378dff31aec3c22e0e6dadff314ab5dd\": \"0x6c6b935b8bbd400000\",\n \"0xec30addd895b82ee319e54fb04cb2bb03971f36b\": \"0x6c6b935b8bbd400000\",\n \"0xec3b8b58a12703e581ce5ffd7e21c57d1e5c663f\": \"0x5c283d410394100000\",\n \"0xec4867d2175ab5b9469361595546554684cda460\": \"0xa2a15d09519be00000\",\n \"0xec4d08aa2e47496dca87225de33f2b40a8a5b36f\": \"0x890b0c2e14fb80000\",\n \"0xec58bc0d0c20d8f49465664153c5c196fe59e6be\": \"0x15af1d78b58c400000\",\n \"0xec5b198a00cfb55a97b5d53644cffa8a04d2ab45\": \"0x6c6b935b8bbd400000\",\n \"0xec5df227bfa85d7ad76b426e1cee963bc7f519dd\": \"0x3635c9adc5dea00000\",\n \"0xec5feafe210c12bfc9a5d05925a123f1e73fbef8\": \"0x608fcf3d88748d000000\",\n \"0xec6904bae1f69790591709b0609783733f2573e3\": \"0x1b1ae4d6e2ef500000\",\n \"0xec73114c5e406fdbbe09b4fa621bd70ed54ea1ef\": \"0x53025cd216fce500000\",\n \"0xec73833de4b810bb027810fc8f69f544e83c12d1\": \"0x3635c9adc5dea00000\",\n \"0xec75b4a47513120ba5f86039814f1998e3817ac3\": \"0x9b0bce2e8fdba0000\",\n \"0xec76f12e57a65504033f2c0bce6fc03bd7fa0ac4\": \"0xc2127af858da700000\",\n \"0xec8014efc7cbe5b0ce50f3562cf4e67f8593cd32\": \"0xf015f25736420000\",\n \"0xec82f50d06475f684df1b392e00da341aa145444\": \"0x6c6b935b8bbd400000\",\n \"0xec83e798c396b7a55e2a2224abcd834b27ea459c\": \"0x28a857425466f800000\",\n \"0xec89f2b678a1a15b9134ec5eb70c6a62071fbaf9\": \"0xad78ebc5ac6200000\",\n \"0xec8c1d7b6aaccd429db3a91ee4c9eb1ca4f6f73c\": \"0xe664992288f2280000\",\n \"0xec9851bd917270610267d60518b54d3ca2b35b17\": \"0x878678326eac9000000\",\n \"0xec99e95dece46ffffb175eb6400fbebb08ee9b95\": \"0x56bc75e2d63100000\",\n \"0xeca5f58792b8c62d2af556717ee3ee3028be4dce\": \"0x6c6b935b8bbd400000\",\n \"0xecab5aba5b828de1705381f38bc744b32ba1b437\": \"0x32f51edbaaa3300000\",\n \"0xecaf3350b7ce144d068b186010852c84dd0ce0f0\": \"0x6c6b935b8bbd400000\",\n \"0xecb94c568bfe59ade650645f4f26306c736cace4\": \"0xe7eeba3410b740000\",\n \"0xecbe425e670d39094e20fb5643a9d818eed236de\": \"0x10f0cf064dd59200000\",\n \"0xecbe5e1c9ad2b1dccf0a305fc9522f4669dd3ae7\": \"0x10f0cf064dd59200000\",\n \"0xeccf7a0457b566b346ca673a180f444130216ac3\": \"0x56bc75e2d63100000\",\n \"0xecd1a62802351a41568d23033004acc6c005a5d3\": \"0x2b5e3af16b1880000\",\n \"0xecd276af64c79d1bd9a92b86b5e88d9a95eb88f8\": \"0x1158e460913d00000\",\n \"0xecd486fc196791b92cf612d348614f9156488b7e\": \"0x28a857425466f800000\",\n \"0xecdaf93229b45ee672f65db506fb5eca00f7fce6\": \"0x5701f96dcc40ee8000\",\n \"0xece111670b563ccdbebca52384290ecd68fe5c92\": \"0x1158e460913d00000\",\n \"0xece1152682b7598fe2d1e21ec15533885435ac85\": \"0xd8d726b7177a800000\",\n \"0xece1290877b583e361a2d41b009346e6274e2538\": \"0x1043561a8829300000\",\n \"0xecf05d07ea026e7ebf4941002335baf2fed0f002\": \"0xad78ebc5ac6200000\",\n \"0xecf24cdd7c22928c441e694de4aa31b0fab59778\": \"0x2086ac351052600000\",\n \"0xecfd004d02f36cd4d8b4a8c1a9533b6af85cd716\": \"0x10f41acb4bb3b9c0000\",\n \"0xed0206cb23315128f8caff26f6a30b985467d022\": \"0x878678326eac9000000\",\n \"0xed1065dbcf9d73c04ffc7908870d881468c1e132\": \"0x6c6b935b8bbd400000\",\n \"0xed1276513b6fc68628a74185c2e20cbbca7817bf\": \"0xa5aa85009e39c0000\",\n \"0xed12a1ba1fb8adfcb20dfa19582e525aa3b74524\": \"0x16a6502f15a1e540000\",\n \"0xed16ce39feef3bd7f5d162045e0f67c0f00046bb\": \"0x1158e460913d00000\",\n \"0xed1a5c43c574d4e934299b24f1472cdc9fd6f010\": \"0xad78ebc5ac6200000\",\n \"0xed1b24b6912d51b334ac0de6e771c7c0454695ea\": \"0x22b1c8c1227a00000\",\n \"0xed1f1e115a0d60ce02fb25df014d289e3a0cbe7d\": \"0x1b1ae4d6e2ef500000\",\n \"0xed31305c319f9273d3936d8f5b2f71e9b1b22963\": \"0x56bc75e2d63100000\",\n \"0xed327a14d5cfadd98103fc0999718d7ed70528ea\": \"0x4e1003b28d92800000\",\n \"0xed3cbc3782cebd67989b305c4133b2cde32211eb\": \"0x15af1d78b58c400000\",\n \"0xed4014538cee664a2fbcb6dc669f7ab16d0ba57c\": \"0xad78ebc5ac6200000\",\n \"0xed41e1a28f5caa843880ef4e8b08bd6c33141edf\": \"0x2ad5ddfa7a8d830000\",\n \"0xed4be04a052d7accb3dcce90319dba4020ab2c68\": \"0x7f37a70eaf362178000\",\n \"0xed52a2cc0869dc9e9f842bd0957c47a8e9b0c9ff\": \"0x205b4dfa1ee74780000\",\n \"0xed5b4c41e762d942404373caf21ed4615d25e6c1\": \"0x6d2d4f3d9525b40000\",\n \"0xed60c4ab6e540206317e35947a63a9ca6b03e2cb\": \"0x31ad9ad0b467f8000\",\n \"0xed641e06368fb0efaa1703e01fe48f4a685309eb\": \"0xad78ebc5ac6200000\",\n \"0xed6643c0e8884b2d3211853785a08bf8f33ed29f\": \"0x487a9a304539440000\",\n \"0xed70a37cdd1cbda9746d939658ae2a6181288578\": \"0x2086ac3510526000000\",\n \"0xed7346766e1a676d0d06ec821867a276a083bf31\": \"0xd98a0931cc2d490000\",\n \"0xed862616fcbfb3becb7406f73c5cbff00c940755\": \"0x5c283d410394100000\",\n \"0xed9e030ca75cb1d29ea01d0d4cdfdccd3844b6e4\": \"0x1acc116cfafb18000\",\n \"0xed9ebccba42f9815e78233266dd6e835b6afc31b\": \"0x14542ba12a337c00000\",\n \"0xed9fb1f5af2fbf7ffc5029cee42b70ff5c275bf5\": \"0xf2dc7d47f15600000\",\n \"0xeda4b2fa59d684b27a810df8978a73df308a63c2\": \"0xd8d726b7177a800000\",\n \"0xedb473353979a206879de144c10a3c51d7d7081a\": \"0x14542ba12a337c00000\",\n \"0xedb71ec41bda7dce86e766e6e8c3e9907723a69b\": \"0x1158e460913d00000\",\n \"0xedbac9527b54d6df7ae2e000cca3613ba015cae3\": \"0x6acb3df27e1f880000\",\n \"0xedc22fb92c638e1e21ff5cf039daa6e734dafb29\": \"0x102794ad20da680000\",\n \"0xeddacd94ec89a2ef968fcf977a08f1fae2757869\": \"0x1b1ae4d6e2ef5000000\",\n \"0xeddbaafbc21be8f25562f1ed6d05d6afb58f02c2\": \"0x6c6b935b8bbd400000\",\n \"0xede0147ec032c3618310c1ff25690bf172193dac\": \"0x6c6b935b8bbd400000\",\n \"0xede5de7c7fb7eee0f36e64530a41440edfbefacf\": \"0x21755ee1ef2b180000\",\n \"0xede79ae1ff4f1606d59270216fa46ab2ddd4ecaa\": \"0x7ea28327577080000\",\n \"0xede8c2cb876fbe8a4cca8290361a7ea01a69fdf8\": \"0x1a78c6b44f841838000\",\n \"0xedeb4894aadd0081bbddd3e8846804b583d19f27\": \"0x6c6b935b8bbd400000\",\n \"0xedf603890228d7d5de9309942b5cad4219ef9ad7\": \"0x10f0cf064dd59200000\",\n \"0xedf8a3e1d40f13b79ec8e3e1ecf262fd92116263\": \"0x890b0c2e14fb80000\",\n \"0xedfda2d5db98f9380714664d54b4ee971a1cae03\": \"0x22bb8ddd679be0000\",\n \"0xee0007b0960d00908a94432a737557876aac7c31\": \"0x2e0421e69c4cc8000\",\n \"0xee049af005974dd1c7b3a9ca8d9aa77175ba53aa\": \"0x1211ecb56d13488000\",\n \"0xee25b9a7032679b113588ed52c137d1a053a1e94\": \"0xad50f3f4eea8e0000\",\n \"0xee31167f9cc93b3c6465609d79db0cde90e8484c\": \"0x6c6b935b8bbd400000\",\n \"0xee34c7e7995db9f187cff156918cfb6f13f6e003\": \"0x6a4076cf7995a00000\",\n \"0xee3564f5f1ba0f94ec7bac164bddbf31c6888b55\": \"0x56bc75e2d63100000\",\n \"0xee58fb3db29070d0130188ce472be0a172b89055\": \"0x21f42dcdc58e39c0000\",\n \"0xee655bb4ee0e8d5478526fb9f15e4064e09ff3dd\": \"0xad78ebc5ac6200000\",\n \"0xee6959de2b67967b71948c891ab00d8c8f38c7dc\": \"0x6685ac1bfe32c0000\",\n \"0xee6c03429969ca1262cb3f0a4a54afa7d348d7f5\": \"0xde219f91fc18a0000\",\n \"0xee71793e3acf12a7274f563961f537529d89c7de\": \"0x6c6b935b8bbd400000\",\n \"0xee7288d91086d9e2eb910014d9ab90a02d78c2a0\": \"0x6c6b935b8bbd400000\",\n \"0xee7c3ded7c28f459c92fe13b4d95bafbab02367d\": \"0x25f273933db5700000\",\n \"0xee867d20916bd2e9c9ece08aa04385db667c912e\": \"0xa968163f0a57b400000\",\n \"0xee899b02cbcb3939cd61de1342d50482abb68532\": \"0x5f68e8131ecf800000\",\n \"0xee906d7d5f1748258174be4cbc38930302ab7b42\": \"0xad78ebc5ac6200000\",\n \"0xee97aa8ac69edf7a987d6d70979f8ec1fbca7a94\": \"0x14620c57dddae00000\",\n \"0xeea1e97988de75d821cd28ad6822b22cce988b31\": \"0x1c30731cec03200000\",\n \"0xeed28c3f068e094a304b853c950a6809ebcb03e0\": \"0x3a9d5baa4abf1d00000\",\n \"0xeed384ef2d41d9d203974e57c12328ea760e08ea\": \"0x3635c9adc5dea00000\",\n \"0xeedf6c4280e6eb05b934ace428e11d4231b5905b\": \"0xad78ebc5ac6200000\",\n \"0xeee761847e33fd61d99387ee14628694d1bfd525\": \"0x6c6b935b8bbd400000\",\n \"0xeee9d0526eda01e43116a395322dda8970578f39\": \"0x21e1999bbd5d2be0000\",\n \"0xeef1bbb1e5a83fde8248f88ee3018afa2d1332eb\": \"0xad78ebc5ac6200000\",\n \"0xeefba12dfc996742db790464ca7d273be6e81b3e\": \"0x3635c9adc5dea00000\",\n \"0xeefd05b0e3c417d55b3343060486cdd5e92aa7a6\": \"0x4d853c8f8908980000\",\n \"0xef0dc7dd7a53d612728bcbd2b27c19dd4d7d666f\": \"0x26411c5b35f05a0000\",\n \"0xef115252b1b845cd857f002d630f1b6fa37a4e50\": \"0x6acb3df27e1f880000\",\n \"0xef1c0477f1184d60accab374d374557a0a3e10f3\": \"0x83d6c7aab63600000\",\n \"0xef2c34bb487d3762c3cca782ccdd7a8fbb0a9931\": \"0x9c2007651b2500000\",\n \"0xef35f6d4b1075e6aa139151c974b2f4658f70538\": \"0x3c3bc33f94e50d8000\",\n \"0xef39ca9173df15531d73e6b72a684b51ba0f2bb4\": \"0x56a0b4756ee2380000\",\n \"0xef463c2679fb279164e20c3d2691358773a0ad95\": \"0x6c6b935b8bbd400000\",\n \"0xef47cf073e36f271d522d7fa4e7120ad5007a0bc\": \"0x878678326eac900000\",\n \"0xef61155ba009dcdebef10b28d9da3d1bc6c9ced4\": \"0x3342d60dff1960000\",\n \"0xef69781f32ffce33346f2c9ae3f08493f3e82f89\": \"0xfc936392801c0000\",\n \"0xef76a4cd8febcbc9b818f17828f8d93473f3f3cb\": \"0xd8d726b7177a800000\",\n \"0xef93818f684db0c3675ec81332b3183ecc28a495\": \"0x54069233bf7f780000\",\n \"0xef9f59aeda418c1494682d941aab4924b5f4929a\": \"0x152d02c7e14af6800000\",\n \"0xefa6b1f0db603537826891b8b4bc163984bb40cd\": \"0x35659ef93f0fc40000\",\n \"0xefbd52f97da5fd3a673a46cbf330447b7e8aad5c\": \"0x56c3c9b80a0a68000\",\n \"0xefc8cf1963c9a95267b228c086239889f4dfd467\": \"0x21e19e0c9bab2400000\",\n \"0xefcaae9ff64d2cd95b5249dcffe7faa0a0c0e44d\": \"0x15be6174e1912e0000\",\n \"0xefcce06bd6089d0e458ef561f5a689480afe7000\": \"0x2086ac351052600000\",\n \"0xefe0675da98a5dda70cd96196b87f4e726b43348\": \"0x3f19beb8dd1ab00000\",\n \"0xefe8ff87fc260e0767638dd5d02fc4672e0ec06d\": \"0x6c6b935b8bbd400000\",\n \"0xefeb1997aad277cc33430e6111ed0943594048b8\": \"0x6c6b935b8bbd400000\",\n \"0xefeea010756f81da4ba25b721787f058170befbd\": \"0x1c29c9cf770ef0000\",\n \"0xeff51d72adfae143edf3a42b1aec55a2ccdd0b90\": \"0x1043561a8829300000\",\n \"0xeff86b5123bcdc17ed4ce8e05b7e12e51393a1f7\": \"0x1b1ae4d6e2ef500000\",\n \"0xeffc15e487b1beda0a8d1325bdb4172240dc540a\": \"0x3853939eee1de0000\",\n \"0xf01195d657ef3c942e6cb83949e5a20b5cfa8b1e\": \"0x57473d05dabae800000\",\n \"0xf02796295101674288c1d93467053d042219b794\": \"0x281d901f4fdd100000\",\n \"0xf039683d7b3d225bc7d8dfadef63163441be41e2\": \"0x1dd1e4bd8d1ee0000\",\n \"0xf04a6a379708b9428d722aa2b06b77e88935cf89\": \"0x1043561a8829300000\",\n \"0xf04d2c91efb6e9c45ffbe74b434c8c5f2b028f1f\": \"0x3635c9adc5dea00000\",\n \"0xf057aa66ca767ede124a1c5b9cc5fc94ef0b0137\": \"0x70a24bcab6f45d0000\",\n \"0xf05ba8d7b68539d933300bc9289c3d9474d0419e\": \"0x6da27024dd9600000\",\n \"0xf05ceeab65410564709951773c8445ad9f4ec797\": \"0x10431627a0933b0000\",\n \"0xf05fcd4c0d73aa167e5553c8c0d6d4f2faa39757\": \"0x2d2d66c3170b2980000\",\n \"0xf067e1f1d683556a4cc4fd0c0313239f32c4cfd8\": \"0x3635c9adc5dea00000\",\n \"0xf067fb10dfb293e998abe564c055e3348f9fbf1e\": \"0x6c6b935b8bbd400000\",\n \"0xf068dfe95d15cd3a7f98ffa688b4346842be2690\": \"0x440ad819e0974c0000\",\n \"0xf06a854a3c5dc36d1c49f4c87d6db333b57e4add\": \"0x21e19e0c9bab2400000\",\n \"0xf079e1b1265f50e8c8a98ec0c7815eb3aeac9eb4\": \"0x116dc3a8994b30000\",\n \"0xf07bd0e5c2ce69c7c4a724bd26bbfa9d2a17ca03\": \"0x14061b9d77a5e980000\",\n \"0xf0832a6bb25503eeca435be31b0bf905ca1fcf57\": \"0x16a6502f15a1e540000\",\n \"0xf09b3e87f913ddfd57ae8049c731dba9b636dfc3\": \"0x20f5b1eaad8d800000\",\n \"0xf0b1340b996f6f0bf0d9561c849caf7f4430befa\": \"0x56bc75e2d63100000\",\n \"0xf0b1f9e27832c6de6914d70afc238c749995ace4\": \"0x6c6b935b8bbd400000\",\n \"0xf0b469eae89d400ce7d5d66a9695037036b88903\": \"0x43c33c1937564800000\",\n \"0xf0b9d683cea12ba600baace219b0b3c97e8c00e4\": \"0x56bc75e2d63100000\",\n \"0xf0be0faf4d7923fc444622d1980cf2d990aab307\": \"0x6c6b935b8bbd400000\",\n \"0xf0c081da52a9ae36642adf5e08205f05c54168a6\": \"0x6046f37e5945c0000\",\n \"0xf0c70d0d6dab7663aa9ed9ceea567ee2c6b02765\": \"0x71438ac5a791a08000\",\n \"0xf0cbef84e169630098d4e301b20208ef05846ac9\": \"0xe0b8345506b4e0000\",\n \"0xf0d21663d8b0176e05fde1b90ef31f8530fda95f\": \"0x6c6acc67d7b1d40000\",\n \"0xf0d5c31ccb6cbe30c7c9ea19f268d159851f8c9c\": \"0x3894f0e6f9b9f700000\",\n \"0xf0d64cf9df09741133d170485fd24b005011d520\": \"0x1b089341e14fcc0000\",\n \"0xf0d858105e1b648101ac3f85a0f8222bf4f81d6a\": \"0x2086ac351052600000\",\n \"0xf0dc43f205619127507b2b1c1cfdf32d28310920\": \"0x105eb79b9417088000\",\n \"0xf0e1dfa42adeac2f17f6fdf584c94862fd563393\": \"0x1b1ae4d6e2ef500000\",\n \"0xf0e2649c7e6a3f2c5dfe33bbfbd927ca3c350a58\": \"0x6c6b935b8bbd400000\",\n \"0xf0e7fb9e420a5340d536f40408344feaefc06aef\": \"0x3635c9adc5dea00000\",\n \"0xf10462e58fcc07f39584a187639451167e859201\": \"0x934dd5d33bc970000\",\n \"0xf10661ff94140f203e7a482572437938bec9c3f7\": \"0x43c33c1937564800000\",\n \"0xf114ff0d0f24eff896edde5471dea484824a99b3\": \"0xbe202d6a0eda0000\",\n \"0xf116b0b4680f53ab72c968ba802e10aa1be11dc8\": \"0x1158e460913d00000\",\n \"0xf11cf5d363746fee6864d3ca336dd80679bb87ae\": \"0x878678326eac9000000\",\n \"0xf11e01c7a9d12499005f4dae7716095a34176277\": \"0x15af1d78b58c400000\",\n \"0xf13b083093ba564e2dc631568cf7540d9a0ec719\": \"0x6c6acc67d7b1d40000\",\n \"0xf14f0eb86db0eb68753f16918e5d4b807437bd3e\": \"0xad78ebc5ac6200000\",\n \"0xf15178ffc43aa8070ece327e930f809ab1a54f9d\": \"0xab640391201300000\",\n \"0xf156dc0b2a981e5b55d3f2f03b8134e331dbadb7\": \"0x56bc75e2d63100000\",\n \"0xf15d9d5a21b1929e790371a17f16d95f0c69655c\": \"0x6c6b935b8bbd400000\",\n \"0xf15e182c4fbbad79bd93342242d4dccf2be58925\": \"0x692ae8897081d00000\",\n \"0xf1624d980b65336feac5a6d54125005cfcf2aacb\": \"0x6c6b935b8bbd400000\",\n \"0xf167f5868dcf4233a7830609682caf2df4b1b807\": \"0x81e542e1a7383f0000\",\n \"0xf16de1891d8196461395f9b136265b3b9546f6ef\": \"0x1b28e1f98bbce8000\",\n \"0xf17a92e0361dbacecdc5de0d1894955af6a9b606\": \"0x6c6b935b8bbd400000\",\n \"0xf17adb740f45cbbde3094e7e13716f8103f563bd\": \"0x6c6b935b8bbd400000\",\n \"0xf18b14cbf6694336d0fe12ac1f25df2da0c05dbb\": \"0xd8d4602c26bf6c0000\",\n \"0xf19b39389d47b11b8a2c3f1da9124decffbefaf7\": \"0x6c6b935b8bbd400000\",\n \"0xf19f193508393e4d2a127b20b2031f39c82581c6\": \"0xbdbd7a83bd2f6c0000\",\n \"0xf1a1f320407964fd3c8f2e2cc8a4580da94f01ea\": \"0x6c6c2177557c440000\",\n \"0xf1b4ecc63525f7432c3d834ffe2b970fbeb87212\": \"0xa2a24068facd800000\",\n \"0xf1b58faffa8794f50af8e88309c7a6265455d51a\": \"0x36330322d5238c0000\",\n \"0xf1c8c4a941b4628c0d6c30fda56452d99c7e1b64\": \"0x4e8cea1ede75040000\",\n \"0xf1da40736f99d5df3b068a5d745fafc6463fc9b1\": \"0x696ca23058da10000\",\n \"0xf1dc8ac81042c67a9c3c6792b230c46ac016ca10\": \"0xad78ebc5ac6200000\",\n \"0xf1df55dcc34a051012b575cb968bc9c458ea09c9\": \"0xd8d726b7177a800000\",\n \"0xf1e980c559a1a8e5e50a47f8fffdc773b7e06a54\": \"0x65ffbcdea04b7480000\",\n \"0xf1f391ca92808817b755a8b8f4e2ca08d1fd1108\": \"0x14542ba12a337c00000\",\n \"0xf1f766b0e46d73fcd4d52e7a72e1b9190cc632b3\": \"0x1b1ae4d6e2ef5000000\",\n \"0xf2049532fd458a83ca1bff2eebacb6d5ca63f4a4\": \"0xc48c991dc1545c8000\",\n \"0xf206d328e471d0117b246d2a4619827709e96df3\": \"0xa2af3dc00543440000\",\n \"0xf20c9a99b74759d782f25c1ceca802a27e0b436c\": \"0x5a87e7d7f5f6580000\",\n \"0xf2127d54188fedef0f338a5f38c7ff73ad9f6f42\": \"0x43c33c1937564800000\",\n \"0xf2133431d1d9a37ba2f0762bc40c5acc8aa6978e\": \"0x6c6b935b8bbd400000\",\n \"0xf21549bdd1487912f900a7523db5f7626121bba3\": \"0x21e19e0c9bab2400000\",\n \"0xf218bd848ee7f9d38bfdd1c4eb2ed2496ae4305f\": \"0x1b1ae4d6e2ef500000\",\n \"0xf224eb900b37b4490eee6a0b6420d85c947d8733\": \"0x34957444b840e80000\",\n \"0xf2294adbb6f0dcc76e632ebef48ab49f124dbba4\": \"0x4e43393600a7b10000\",\n \"0xf22f4078febbbaa8b0e78e642c8a42f35d433905\": \"0x6c6acc67d7b1d40000\",\n \"0xf237ef05261c34d79cc22b860de0f17f793c3860\": \"0xad78ebc5ac6200000\",\n \"0xf23c7b0cb8cd59b82bd890644a57daf40c85e278\": \"0x2b66aafe326ff0000\",\n \"0xf23d01589eb12d439f7448ff54307529f191858d\": \"0x6c6b935b8bbd400000\",\n \"0xf23e5c633221a8f7363e65870c9f287424d2a960\": \"0x4acf58e07257100000\",\n \"0xf242da845d42d4bf779a00f295b40750fe49ea13\": \"0x3635c9adc5dea00000\",\n \"0xf25259a5c939cd25966c9b6303d3731c53ddbc4c\": \"0xad78ebc5ac6200000\",\n \"0xf25e4c70bc465632c89e5625a832a7722f6bffab\": \"0xf34b82fd8e91200000\",\n \"0xf26bcedce3feadcea3bc3e96eb1040dfd8ffe1a0\": \"0x2a034919dfbfbc0000\",\n \"0xf270792576f05d514493ffd1f5e84bec4b2df810\": \"0x3635c9adc5dea00000\",\n \"0xf2732cf2c13b8bb8e7492a988f5f89e38273ddc8\": \"0x2086ac351052600000\",\n \"0xf2742e6859c569d5f2108351e0bf4dca352a48a8\": \"0x21e19e0c9bab2400000\",\n \"0xf2813a64c5265d020235cb9c319b6c96f906c41e\": \"0x12f939c99edab80000\",\n \"0xf287ff52f461117adb3e1daa71932d1493c65f2e\": \"0xc55325ca7415e00000\",\n \"0xf2ab1161750244d0ecd048ee0d3e51abb143a2fd\": \"0x42fe2b907373bc0000\",\n \"0xf2b4ab2c9427a9015ef6eefff5edb60139b719d1\": \"0x26db992a3b18000000\",\n \"0xf2c03e2a38998c21648760f1e5ae7ea3077d8522\": \"0x8f3f7193ab079c0000\",\n \"0xf2c2904e9fa664a11ee25656d8fd2cc0d9a522a0\": \"0xb98bc829a6f90000\",\n \"0xf2c362b0ef991bc82fb36e66ff75932ae8dd8225\": \"0x402f4cfee62e80000\",\n \"0xf2d0e986d814ea13c8f466a0538c53dc922651f0\": \"0x4acf58e07257100000\",\n \"0xf2d1b7357724ec4c03185b879b63f57e26589153\": \"0x14542ba12a337c00000\",\n \"0xf2d5763ce073127e2cedde6faba786c73ca94141\": \"0x1ac4286100191f00000\",\n \"0xf2d59c8923759073d6f415aaf8eb065ff2f3b685\": \"0x1ab2cf7c9f87e200000\",\n \"0xf2e99f5cbb836b7ad36247571a302cbe4b481c69\": \"0x6acb3df27e1f880000\",\n \"0xf2ed3e77254acb83231dc0860e1a11242ba627db\": \"0x6b56051582a9700000\",\n \"0xf2edde37f9a8c39ddea24d79f4015757d06bf786\": \"0x152d02c7e14af6800000\",\n \"0xf2efe96560c9d97b72bd36447843885c1d90c231\": \"0x6c6b935b8bbd400000\",\n \"0xf2fbb6d887f8b8cc3a869aba847f3d1f643c53d6\": \"0xd8c9460063d31c0000\",\n \"0xf3034367f87d24d3077fa9a2e38a8b0ccb1104ef\": \"0x3635c9adc5dea00000\",\n \"0xf303d5a816affd97e83d9e4dac2f79072bb0098f\": \"0x340aad21b3b7000000\",\n \"0xf3159866c2bc86bba40f9d73bb99f1eee57bb9d7\": \"0x3635c9adc5dea00000\",\n \"0xf316ef1df2ff4d6c1808dba663ec8093697968e0\": \"0x61464d6cdc80f00000\",\n \"0xf32d25eb0ea2b8b3028a4c7a155dc1aae865784d\": \"0x13593a9297fdad60000\",\n \"0xf332c0f3e05a27d9126fd0b641a8c2d4060608fd\": \"0x10f1b62c4d9644e8000\",\n \"0xf338459f32a159b23db30ac335769ab2351aa63c\": \"0x65a4da25d3016c00000\",\n \"0xf33efc6397aa65fb53a8f07a0f893aae30e8bcee\": \"0x7cf2381f619f150000\",\n \"0xf34083ecea385017aa40bdd35ef7effb4ce7762d\": \"0x15af1d78b58c400000\",\n \"0xf346d7de92741c08fc58a64db55b062dde012d14\": \"0xfff6b1f761e6d0000\",\n \"0xf355d3ec0cfb907d8dbb1bf3464e458128190bac\": \"0x10b046e7f0d80100000\",\n \"0xf36df02fbd89607347afce2969b9c4236a58a506\": \"0x6c6b935b8bbd400000\",\n \"0xf373e9daac0c8675f53b797a160f6fc034ae6b23\": \"0x56bc75e2d63100000\",\n \"0xf37b426547a1642d8033324814f0ede3114fc212\": \"0x15be6174e1912e0000\",\n \"0xf37bf78c5875154711cb640d37ea6d28cfcb1259\": \"0xad78ebc5ac6200000\",\n \"0xf382df583155d8548f3f93440cd5f68cb79d6026\": \"0x38757d027fc1fd5c0000\",\n \"0xf382e4c20410b951089e19ba96a2fee3d91cce7e\": \"0x111fa56eec2a8380000\",\n \"0xf38a6ca80168537e974d14e1c3d13990a44c2c1b\": \"0x14542ba12a337c00000\",\n \"0xf39a9d7aa3581df07ee4279ae6c312ef21033658\": \"0xd8d726b7177a800000\",\n \"0xf3b668b3f14d920ebc379092db98031b67b219b3\": \"0xad6eedd17cf3b8000\",\n \"0xf3be99b9103ce7550aa74ff1db18e09dfe32e005\": \"0x6c6b935b8bbd400000\",\n \"0xf3c1abd29dc57b41dc192d0e384d021df0b4f6d4\": \"0x97ae0cdf8f86f80000\",\n \"0xf3c4716d1ee5279a86d0163a14618181e16136c7\": \"0x3635c9adc5dea00000\",\n \"0xf3cc8bcb559465f81bfe583bd7ab0a2306453b9e\": \"0x43c33c1937564800000\",\n \"0xf3d688f06bbdbf50f9932c4145cbe48ecdf68904\": \"0x1158e460913d00000\",\n \"0xf3dbcf135acb9dee1a489c593c024f03c2bbaece\": \"0x6c6b935b8bbd400000\",\n \"0xf3de5f26ef6aded6f06d3b911346ee70401da4a0\": \"0x133ab37d9f9d030000\",\n \"0xf3df63a97199933330383b3ed7570b96c4812334\": \"0x6c6b935b8bbd400000\",\n \"0xf3e74f470c7d3a3f0033780f76a89f3ef691e6cb\": \"0xa3cfe631d143640000\",\n \"0xf3eb1948b951e22df1617829bf3b8d8680ec6b68\": \"0xd8d726b7177a800000\",\n \"0xf3f1fa3918ca34e2cf7e84670b1f4d8eca160db3\": \"0x24dce54d34a1a00000\",\n \"0xf3f24fc29e20403fc0e8f5ebbb553426f78270a2\": \"0x56bc75e2d63100000\",\n \"0xf3fa723552a5d0512e2b62f48dca7b2b8105305b\": \"0x76d41c62494840000\",\n \"0xf3fe51fde34413c73318b9c85437fe7e820f561a\": \"0x3662325cd18fe00000\",\n \"0xf400f93d5f5c7e3fc303129ac8fb0c2f786407fa\": \"0x6c6b935b8bbd400000\",\n \"0xf40b134fea22c6b29c8457f49f000f9cda789adb\": \"0x2086ac351052600000\",\n \"0xf41557dfdfb1a1bdcefefe2eba1e21fe0a4a9942\": \"0x6acb3df27e1f880000\",\n \"0xf4177a0d85d48b0e264211ce2aa2efd3f1b47f08\": \"0xc2ccca26b7e80e8000\",\n \"0xf42f905231c770f0a406f2b768877fb49eee0f21\": \"0xaadec983fcff40000\",\n \"0xf432b9dbaf11bdbd73b6519fc0a904198771aac6\": \"0x83d6c7aab63600000\",\n \"0xf43da3a4e3f5fab104ca9bc1a0f7f3bb4a56f351\": \"0x6c6acc67d7b1d40000\",\n \"0xf447108b98df64b57e871033885c1ad71db1a3f9\": \"0x176f49ead3483508000\",\n \"0xf44f8551ace933720712c5c491cdb6f2f951736c\": \"0xd8d726b7177a800000\",\n \"0xf456055a11ab91ff668e2ec922961f2a23e3db25\": \"0xfc936392801c0000\",\n \"0xf456a75bb99655a7412ce97da081816dfdb2b1f2\": \"0xad78ebc5ac6200000\",\n \"0xf45b1dcb2e41dc27ffa024daadf619c11175c087\": \"0x11164759ffb320000\",\n \"0xf463a90cb3f13e1f0643423636beab84c123b06d\": \"0x22b1c8c1227a00000\",\n \"0xf468906e7edf664ab0d8be3d83eb7ab3f7ffdc78\": \"0x5c283d410394100000\",\n \"0xf46980e3a4a9d29a6a6e90604537a3114bcb2897\": \"0x1b1ae4d6e2ef500000\",\n \"0xf46b6b9c7cb552829c1d3dfd8ffb11aabae782f6\": \"0x1236efcbcbb340000\",\n \"0xf476e1267f86247cc908816f2e7ad5388c952db0\": \"0xd8d726b7177a800000\",\n \"0xf476f2cb7208a32e051fd94ea8662992638287a2\": \"0x56bc75e2d63100000\",\n \"0xf47bb134da30a812d003af8dccb888f44bbf5724\": \"0x11959b7fe3395580000\",\n \"0xf483f607a21fcc28100a018c568ffbe140380410\": \"0x3635c9adc5dea00000\",\n \"0xf48e1f13f6af4d84b371d7de4b273d03a263278e\": \"0x2086ac351052600000\",\n \"0xf49c47b3efd86b6e6a5bc9418d1f9fec814b69ef\": \"0x43c33c1937564800000\",\n \"0xf49f6f9baabc018c8f8e119e0115f491fc92a8a4\": \"0x21e19e0c9bab2400000\",\n \"0xf4a367b166d2991a2bfda9f56463a09f252c1b1d\": \"0x6acb3df27e1f880000\",\n \"0xf4a51fce4a1d5b94b0718389ba4e7814139ca738\": \"0x1043561a8829300000\",\n \"0xf4a9d00cefa97b7a58ef9417fc6267a5069039ee\": \"0x12e89287fa7840000\",\n \"0xf4aaa3a6163e3706577b49c0767e948a681e16ee\": \"0x6c6b935b8bbd400000\",\n \"0xf4b1626e24f30bcad9273c527fcc714b5d007b8f\": \"0xad78ebc5ac6200000\",\n \"0xf4b49100757772f33c177b9a76ba95226c8f3dd8\": \"0x16b352da5e0ed300000\",\n \"0xf4b6cdcfcb24230b337d770df6034dfbd4e1503f\": \"0x405fdf7e5af85e00000\",\n \"0xf4b759cc8a1c75f80849ebbcda878dc8f0d66de4\": \"0x15af1d78b58c400000\",\n \"0xf4ba6a46d55140c439cbcf076cc657136262f4f8\": \"0x6c6b935b8bbd400000\",\n \"0xf4d67a9044b435b66e8977ff39a28dc4bd53729a\": \"0xad78ebc5ac6200000\",\n \"0xf4d97664cc4eec9edbe7fa09f4750a663b507d79\": \"0xd8d726b7177a800000\",\n \"0xf4dc7ba85480bbb3f535c09568aaa3af6f3721c6\": \"0x1871fb6307e35e50000\",\n \"0xf4ebf50bc7e54f82e9b9bd24baef29438e259ce6\": \"0x21e19e0c9bab2400000\",\n \"0xf4ec8e97a20aa5f8dd206f55207e06b813df2cc0\": \"0xad78ebc5ac6200000\",\n \"0xf4ed848ec961739c2c7e352f435ba70a7cd5db38\": \"0x6acb3df27e1f880000\",\n \"0xf4fc4d39bc0c2c4068a36de50e4ab4d4db7e340a\": \"0x16037df87ef6a0000\",\n \"0xf504943aaf16796e0b341bbcdf21d11cc586cdd1\": \"0x1e7e4171bf4d3a00000\",\n \"0xf5061ee2e5ee26b815503677130e1de07a52db07\": \"0x56bc75e2d63100000\",\n \"0xf509557e90183fbf0f0651a786487bcc428ba175\": \"0xa844a7424d9c80000\",\n \"0xf50abbd4aa45d3eb88515465a8ba0b310fd9b521\": \"0x16a6502f15a1e540000\",\n \"0xf50ae7fab4cfb5a646ee04ceadf9bf9dd5a8e540\": \"0xd8d67c2f5895480000\",\n \"0xf50cbafd397edd556c0678988cb2af5c2617e0a2\": \"0x26d07efe782bb00000\",\n \"0xf51fded80acb502890e87369741f3722514cefff\": \"0x43c3456ca3c6d110000\",\n \"0xf52a5882e8927d944b359b26366ba2b9cacfbae8\": \"0x54b41ce2fe63ba80000\",\n \"0xf52c0a7877345fe0c233bb0f04fd6ab18b6f14ba\": \"0x54cbe55989f38de00000\",\n \"0xf5437e158090b2a2d68f82b54a5864b95dd6dbea\": \"0xd96c16703b2bfe0000\",\n \"0xf54c19d9ef3873bfd1f7a622d02d86249a328f06\": \"0x960ae127af32fb28000\",\n \"0xf5500178cb998f126417831a08c2d7abfff6ab5f\": \"0x46f4f4a5875a9f8000\",\n \"0xf5534815dc635efa5cc84b2ac734723e21b29372\": \"0x55a6e79ccd1d300000\",\n \"0xf555a27bb1e2fd4e2cc784caee92939fc06e2fc9\": \"0x6c6b935b8bbd400000\",\n \"0xf558a2b2dd26dd9593aae04531fd3c3cc3854b67\": \"0xabbcd4ef377580000\",\n \"0xf56048dd2181d4a36f64fcecc6215481e42abc15\": \"0xad78ebc5ac6200000\",\n \"0xf56442f60e21691395d0bffaa9194dcaff12e2b7\": \"0xe18398e7601900000\",\n \"0xf579714a45eb8f52c3d57bbdefd2c15b2e2f11df\": \"0x54915956c409600000\",\n \"0xf593c65285ee6bbd6637f3be8f89ad40d489f655\": \"0xa2a15d09519be00000\",\n \"0xf598db2e09a8a5ee7d720d2b5c43bb126d11ecc2\": \"0xad78ebc5ac6200000\",\n \"0xf59dab1bf8df11327e61f9b7a14b563a96ec3554\": \"0x14542ba12a337c00000\",\n \"0xf59f9f02bbc98efe097eabb78210979021898bfd\": \"0x21e171a3ec9f72c0000\",\n \"0xf5a5459fcdd5e5b273830df88eea4cb77ddadfb9\": \"0x409e52b48369a0000\",\n \"0xf5a7676ad148ae9c1ef8b6f5e5a0c2c473be850b\": \"0xad78ebc5ac6200000\",\n \"0xf5b068989df29c253577d0405ade6e0e7528f89e\": \"0x57473d05dabae80000\",\n \"0xf5b6e9061a4eb096160777e26762cf48bdd8b55d\": \"0xdc55fdb17647b0000\",\n \"0xf5cffbba624e7eb321bc83c60ca68199b4e36671\": \"0x6c6b935b8bbd400000\",\n \"0xf5d14552b1dce0d6dc1f320da6ffc8a331cd6f0c\": \"0x487a9a304539440000\",\n \"0xf5d61ac4ca95475e5b7bffd5f2f690b316759615\": \"0x692ae8897081d000000\",\n \"0xf5d9cf00d658dd45517a48a9d3f5f633541a533d\": \"0x64f5fdf494f780000\",\n \"0xf5eadcd2d1b8657a121f33c458a8b13e76b65526\": \"0xd8b0f5a5ac24a0000\",\n \"0xf607c2150d3e1b99f24fa1c7d540add35c4ebe1e\": \"0xa7f1aa07fc8faa0000\",\n \"0xf60bd735543e6bfd2ea6f11bff627340bc035a23\": \"0x6c6b935b8bbd400000\",\n \"0xf60c1b45f164b9580e20275a5c39e1d71e35f891\": \"0x6c6b935b8bbd400000\",\n \"0xf60f62d73937953fef35169e11d872d2ea317eec\": \"0x121ea68c114e5100000\",\n \"0xf61283b4bd8504058ca360e993999b62cbc8cd67\": \"0xdd2d5fcf3bc9c0000\",\n \"0xf617b967b9bd485f7695d2ef51fb7792d898f500\": \"0x1b1ae4d6e2ef500000\",\n \"0xf618d9b104411480a863e623fc55232d1a4f48aa\": \"0xe689e6d44b1668000\",\n \"0xf622e584a6623eaaf99f2be49e5380c5cbcf5cd8\": \"0xad78ebc5ac6200000\",\n \"0xf632adff490da4b72d1236d04b510f74d2faa3cd\": \"0x4be4e7267b6ae00000\",\n \"0xf639ac31da9f67271bd10402b7654e5ce763bd47\": \"0x15af0f42baf9260000\",\n \"0xf63a579bc3eac2a9490410128dbcebe6d9de8243\": \"0x50c5e761a444080000\",\n \"0xf645dd7c890093e8e4c8aa92a6bb353522d3dc98\": \"0x7439fa2099e580000\",\n \"0xf648ea89c27525710172944e79edff847803b775\": \"0x152d02c7e14af6800000\",\n \"0xf64a4ac8d540a9289c68d960d5fb7cc45a77831c\": \"0x6c6b935b8bbd400000\",\n \"0xf64ecf2117931c6d535a311e4ffeaef9d49405b8\": \"0x90f534608a72880000\",\n \"0xf64fe0939a8d1eea2a0ecd9a9730fd7958e33109\": \"0x11de1e6db450c0000\",\n \"0xf65616be9c8b797e7415227c9138faa0891742d7\": \"0x2ad373ce668e980000\",\n \"0xf657fcbe682eb4e8db152ecf892456000b513d15\": \"0x692ae8897081d00000\",\n \"0xf65819ac4cc14c137f05dd7977c7dae08d1a4ab5\": \"0x58788cb94b1d80000\",\n \"0xf67bb8e2118bbcd59027666eedf6943ec9f880a5\": \"0xd8d726b7177a800000\",\n \"0xf68464bf64f2411356e4d3250efefe5c50a5f65b\": \"0x1158e460913d00000\",\n \"0xf686785b89720b61145fea80978d6acc8e0bc196\": \"0xd8d726b7177a800000\",\n \"0xf68c5e33fa97139df5b2e63886ce34ebf3e4979c\": \"0xb3fa4169e2d8e00000\",\n \"0xf6a8635757c5e8c134d20d028cf778cf8609e46a\": \"0x4f1d772faec17c0000\",\n \"0xf6b782f4dcd745a6c0e2e030600e04a24b25e542\": \"0x15af1d78b58c400000\",\n \"0xf6bc37b1d2a3788d589b6de212dc1713b2f6e78e\": \"0x10f0cf064dd59200000\",\n \"0xf6c3c48a1ac0a34799f04db86ec7a975fe7768f3\": \"0x6acb3df27e1f880000\",\n \"0xf6d25d3f3d846d239f525fa8cac97bc43578dbac\": \"0x30927f74c9de000000\",\n \"0xf6eaac7032d492ef17fd6095afc11d634f56b382\": \"0x1b1b6bd7af64c70000\",\n \"0xf6ead67dbf5b7eb13358e10f36189d53e643cfcf\": \"0x878678326eac9000000\",\n \"0xf6f1a44309051c6b25e47dff909b179bb9ab591c\": \"0x692ae8897081d00000\",\n \"0xf70328ef97625fe745faa49ee0f9d4aa3b0dfb69\": \"0x3635c9adc5dea00000\",\n \"0xf70a998a717b338d1dd99854409b1a338deea4b0\": \"0x6c6b935b8bbd400000\",\n \"0xf70d637a845c06db6cdc91e6371ce7c4388a628e\": \"0x1158e460913d00000\",\n \"0xf7155213449892744bc60f2e04400788bd041fdd\": \"0x39fbae8d042dd0000\",\n \"0xf71b4534f286e43093b1e15efea749e7597b8b57\": \"0x161c13d3341c87280000\",\n \"0xf734ec03724ddee5bb5279aa1afcf61b0cb448a1\": \"0xe5bf2cc9b097800000\",\n \"0xf736dc96760012388fe88b66c06efe57e0d7cf0a\": \"0x71d75ab9b920500000\",\n \"0xf73ac46c203be1538111b151ec8220c786d84144\": \"0xff7377817b82b8000\",\n \"0xf73dd9c142b71bce11d06e30e7e7d032f2ec9c9e\": \"0x6acb3df27e1f880000\",\n \"0xf7418aa0e713d248228776b2e7434222ae75e3a5\": \"0x6c6b935b8bbd400000\",\n \"0xf74e6e145382b4db821fe0f2d98388f45609c69f\": \"0x56bc75e2d63100000\",\n \"0xf7500c166f8bea2f82347606e5024be9e4f4ce99\": \"0x1158e460913d00000\",\n \"0xf757fc8720d3c4fa5277075e60bd5c411aebd977\": \"0x6c6b935b8bbd400000\",\n \"0xf75bb39c799779ebc04a336d260da63146ed98d0\": \"0x15af1d78b58c40000\",\n \"0xf768f321fd6433d96b4f354d3cc1652c1732f57f\": \"0x21e19e0c9bab2400000\",\n \"0xf76f69cee4faa0a63b30ae1e7881f4f715657010\": \"0xad78ebc5ac6200000\",\n \"0xf777361a3dd8ab62e5f1b9b047568cc0b555704c\": \"0x3635c9adc5dea00000\",\n \"0xf77c7b845149efba19e261bc7c75157908afa990\": \"0x6c6b935b8bbd400000\",\n \"0xf77f9587ff7a2d7295f1f571c886bd33926a527c\": \"0x6c68ccd09b022c0000\",\n \"0xf78258c12481bcdddbb72a8ca0c043097261c6c5\": \"0x1158e460913d00000\",\n \"0xf798d16da4e460c460cd485fae0fa0599708eb82\": \"0x3635c9adc5dea00000\",\n \"0xf7a1ade2d0f529123d1055f19b17919f56214e67\": \"0x1b1ae4d6e2ef500000\",\n \"0xf7acff934b84da0969dc37a8fcf643b7d7fbed41\": \"0x6c6acc67d7b1d40000\",\n \"0xf7b151cc5e571c17c76539dbe9964cbb6fe5de79\": \"0x74717cfb6883100000\",\n \"0xf7b29b82195c882dab7897c2ae95e77710f57875\": \"0x7735416132dbfc0000\",\n \"0xf7bc4c44910d5aedd66ed2355538a6b193c361ec\": \"0x541de2c2d8d620000\",\n \"0xf7c00cdb1f020310d5acab7b496aaa44b779085e\": \"0x5a87e7d7f5f6580000\",\n \"0xf7c1b443968b117b5dd9b755572fcd39ca5ec04b\": \"0x18b968c292f1b50000\",\n \"0xf7c50f922ad16b61c6d1baa045ed816815bac48f\": \"0x2a9396a9784ad7d0000\",\n \"0xf7c708015071d4fb0a3a2a09a45d156396e3349e\": \"0xa2a15d09519be00000\",\n \"0xf7cbdba6be6cfe68dbc23c2b0ff530ee05226f84\": \"0x1158e460913d00000\",\n \"0xf7d0d310acea18406138baaabbfe0571e80de85f\": \"0x487a9a304539440000\",\n \"0xf7d7af204c56f31fd94398e40df1964bd8bf123c\": \"0x821d221b5291f8000\",\n \"0xf7dc251196fbcbb77c947d7c1946b0ff65021cea\": \"0x3635c9adc5dea00000\",\n \"0xf7e45a12aa711c709acefe95f33b78612d2ad22a\": \"0xe0655e2f26bc9180000\",\n \"0xf7f4898c4c526d955f21f055cb6e47b915e51964\": \"0x7c0860e5a80dc00000\",\n \"0xf7f91e7acb5b8129a306877ce3168e6f438b66a1\": \"0x98a7d9b8314c00000\",\n \"0xf7fc45abf76f5088e2e5b5a8d132f28a4d4ec1c0\": \"0x6c6b935b8bbd400000\",\n \"0xf8063af4cc1dd9619ab5d8bff3fcd1faa8488221\": \"0x6c6b935b8bbd400000\",\n \"0xf8086e42661ea929d2dda1ab6c748ce3055d111e\": \"0x3635c9adc5dea00000\",\n \"0xf8087786b42da04ed6d1e0fe26f6c0eefe1e9f5a\": \"0x21e19e0c9bab2400000\",\n \"0xf80d3619702fa5838c48391859a839fb9ce7160f\": \"0x6c07a7d1b16e700000\",\n \"0xf814799f6ddf4dcb29c7ee870e75f9cc2d35326d\": \"0x3635c9adc5dea00000\",\n \"0xf815c10a032d13c34b8976fa6e3bd2c9131a8ba9\": \"0x487a9a304539440000\",\n \"0xf81622e55757daea6675975dd93538da7d16991e\": \"0x6c6b935b8bbd400000\",\n \"0xf824ee331e4ac3cc587693395b57ecf625a6c0c2\": \"0x56c95de8e8ca1d0000\",\n \"0xf827d56ed2d32720d4abf103d6d0ef4d3bcd559b\": \"0x16c80065791a28000\",\n \"0xf8298591523e50b103f0b701d623cbf0f74556f6\": \"0xad78ebc5ac6200000\",\n \"0xf848fce9ab611c7d99206e23fac69ad488b94fe1\": \"0x2a1129d0936720000\",\n \"0xf84f090adf3f8db7e194b350fbb77500699f66fd\": \"0x6acb3df27e1f880000\",\n \"0xf851b010f633c40af1a8f06a73ebbaab65077ab5\": \"0xee86442fcd06c00000\",\n \"0xf858171a04d357a13b4941c16e7e55ddd4941329\": \"0x246a5218f2a000000\",\n \"0xf85bab1cb3710fc05fa19ffac22e67521a0ba21d\": \"0x6c95357fa6b36c0000\",\n \"0xf86a3ea8071f7095c7db8a05ae507a8929dbb876\": \"0x1236efcbcbb3400000\",\n \"0xf8704c16d2fd5ba3a2c01d0eb20484e6ecfa3109\": \"0xad78ebc5ac6200000\",\n \"0xf870995fe1e522321d754337a45c0c9d7b38951c\": \"0x1158e460913d00000\",\n \"0xf873e57a65c93b6e18cb75f0dc077d5b8933dc5c\": \"0xaadec983fcff40000\",\n \"0xf875619d8a23e45d8998d184d480c0748970822a\": \"0xd8d726b7177a800000\",\n \"0xf87bb07b289df7301e54c0efda6a2cf291e89200\": \"0x4be4e7267b6ae00000\",\n \"0xf88900db737955b1519b1a7d170a18864ce590eb\": \"0xfc936392801c0000\",\n \"0xf88b58db37420b464c0be88b45ee2b95290f8cfa\": \"0x22b1c8c1227a00000\",\n \"0xf8962b75db5d24c7e8b7cef1068c3e67cebb30a5\": \"0xf2dc7d47f15600000\",\n \"0xf8a065f287d91d77cd626af38ffa220d9b552a2b\": \"0x678a932062e4180000\",\n \"0xf8a49ca2390c1f6d5c0e62513b079571743f7cc6\": \"0xa2a15d09519be00000\",\n \"0xf8a50cee2e688ceee3aca4d4a29725d4072cc483\": \"0x6c6b935b8bbd400000\",\n \"0xf8ac4a39b53c11307820973b441365cffe596f66\": \"0x6c6b935b8bbd400000\",\n \"0xf8ae857b67a4a2893a3fbe7c7a87ff1c01c6a6e7\": \"0xd8d726b7177a800000\",\n \"0xf8bf9c04874e5a77f38f4c38527e80c676f7b887\": \"0x6c6b935b8bbd400000\",\n \"0xf8c7f34a38b31801da43063477b12b27d0f203ff\": \"0x1ad2baba6fef480000\",\n \"0xf8ca336c8e91bd20e314c20b2dd4608b9c8b9459\": \"0x2ddc9bc5b32c780000\",\n \"0xf8d17424c767bea31205739a2b57a7277214eebe\": \"0x246ddf97976680000\",\n \"0xf8d52dcc5f96cc28007b3ecbb409f7e22a646caa\": \"0x81690e18128480000\",\n \"0xf8dce867f0a39c5bef9eeba609229efa02678b6c\": \"0x6c6b935b8bbd400000\",\n \"0xf8f226142a428434ab17a1864a2597f64aab2f06\": \"0x9598b2fb2e9f28000\",\n \"0xf8f6645e0dee644b3dad81d571ef9baf840021ad\": \"0x6c6b935b8bbd400000\",\n \"0xf901c00fc1db88b69c4bc3252b5ca70ea6ee5cf6\": \"0x15af1d78b58c400000\",\n \"0xf93d5bcb0644b0cce5fcdda343f5168ffab2877d\": \"0xb6207b67d26f90000\",\n \"0xf9570e924c95debb7061369792cf2efec2a82d5e\": \"0x1158e460913d00000\",\n \"0xf9642086b1fbae61a6804dbe5fb15ec2d2b537f4\": \"0x6c6b935b8bbd400000\",\n \"0xf96488698590dc3b2c555642b871348dfa067ad5\": \"0x1b1ae4d6e2ef500000\",\n \"0xf964d98d281730ba35b2e3a314796e7b42fedf67\": \"0x53b0876098d80c0000\",\n \"0xf9650d6989f199ab1cc479636ded30f241021f65\": \"0x2e141ea081ca080000\",\n \"0xf96883582459908c827627e86f28e646f9c7fc7a\": \"0x1c4a78737cdcfb80000\",\n \"0xf96b4c00766f53736a8574f822e6474c2f21da2d\": \"0x15af1d78b58c400000\",\n \"0xf9729d48282c9e87166d5eef2d01eda9dbf78821\": \"0x56b83ddc728548000\",\n \"0xf9767e4ecb4a5980527508d7bec3d45e4c649c13\": \"0x678a932062e4180000\",\n \"0xf978b025b64233555cc3c19ada7f4199c9348bf7\": \"0x54b40b1f852bda000000\",\n \"0xf97b56ebd5b77abc9fbacbabd494b9d2c221cd03\": \"0x6acb3df27e1f880000\",\n \"0xf9811fa19dadbf029f8bfe569adb18228c80481a\": \"0xad78ebc5ac6200000\",\n \"0xf98250730c4c61c57f129835f2680894794542f3\": \"0xd8d726b7177a800000\",\n \"0xf989346772995ec1906faffeba2a7fe7de9c6bab\": \"0x16a6502f15a1e540000\",\n \"0xf998ca3411730a6cd10e7455b0410fb0f6d3ff80\": \"0x6c6b935b8bbd400000\",\n \"0xf99aee444b5783c093cfffd1c4632cf93c6f050c\": \"0x15af1d78b58c400000\",\n \"0xf99eeece39fa7ef5076d855061384009792cf2e0\": \"0x1b1ae4d6e2ef500000\",\n \"0xf9a59c3cc5ffacbcb67be0fc7256f64c9b127cb4\": \"0x6c6b935b8bbd400000\",\n \"0xf9a94bd56198da245ed01d1e6430b24b2708dcc0\": \"0x28a77afda87ee50000\",\n \"0xf9b37825f03073d31e249378c30c795c33f83af2\": \"0xad9aabf8c9bfc0000\",\n \"0xf9b617f752edecae3e909fbb911d2f8192f84209\": \"0x90f534608a72880000\",\n \"0xf9bfb59d538afc4874d4f5941b08c9730e38e24b\": \"0x22b1c8c1227a00000\",\n \"0xf9dd239008182fb519fb30eedd2093fed1639be8\": \"0x1b1ae4d6e2ef500000\",\n \"0xf9debaecb5f339beea4894e5204bfa340d067f25\": \"0x5a42844673b1640000\",\n \"0xf9e37447406c412197b2e2aebc001d6e30c98c60\": \"0x1c479bb4349c0ee0000\",\n \"0xf9e7222faaf0f4da40c1c4a40630373a09bed7b6\": \"0x9b4fdcb09456240000\",\n \"0xf9ece022bccd2c92346911e79dd50303c01e0188\": \"0x3635c9adc5dea00000\",\n \"0xfa00c376e89c05e887817a9dd0748d96f341aa89\": \"0x104d0d00d2b7f60000\",\n \"0xfa0c1a988c8a17ad3528eb28b3409daa58225f26\": \"0xad78ebc5ac6200000\",\n \"0xfa105f1a11b6e4b1f56012a27922e2ac2da4812f\": \"0x205b4dfa1ee74780000\",\n \"0xfa142fe47eda97e6503b386b18a2bedd73ccb5b1\": \"0x2e153ad81548100000\",\n \"0xfa14b566234abee73042c31d21717182cba14aa1\": \"0x11c7ea162e78200000\",\n \"0xfa19d6f7a50f4f079893d167bf14e21d0073d196\": \"0x1cbb3a3ff08d080000\",\n \"0xfa1f1971a775c3504fef5079f640c2c4bce7ac05\": \"0x6c6b935b8bbd400000\",\n \"0xfa279bfd8767f956bf7fa0bd5660168da75686bd\": \"0x90f534608a72880000\",\n \"0xfa27cc49d00b6c987336a875ae39da58fb041b2e\": \"0x21e19e0c9bab2400000\",\n \"0xfa283299603d8758e8cab082125d2c8f7d445429\": \"0x15bcacb1e0501ae8000\",\n \"0xfa2bbca15d3fe39f8a328e91f90da14f7ac6253d\": \"0xad78ebc5ac6200000\",\n \"0xfa2fd29d03fee9a07893df3a269f56b72f2e1e64\": \"0x21e19e0c9bab2400000\",\n \"0xfa33553285a973719a0d5f956ff861b2d89ed304\": \"0x1158e460913d00000\",\n \"0xfa3a0c4b903f6ea52ea7ab7b8863b6a616ad6650\": \"0x1158e460913d00000\",\n \"0xfa3a1aa4488b351aa7560cf5ee630a2fd45c3222\": \"0x2fa47e6aa7340d0000\",\n \"0xfa410971ad229c3036f41acf852f2ac999281950\": \"0xd8b311a8ddfa7c0000\",\n \"0xfa44a855e404c86d0ca8ef3324251dfb349c539e\": \"0x542253a126ce400000\",\n \"0xfa5201fe1342af11307b9142a041243ca92e2f09\": \"0x2038116a3ac043980000\",\n \"0xfa60868aafd4ff4c5c57914b8ed58b425773dfa9\": \"0x1cfe5c808f39fbc0000\",\n \"0xfa67b67b4f37a0150915110ede073b05b853bda2\": \"0x2319ba947371ad0000\",\n \"0xfa68e0cb3edf51f0a6f211c9b2cb5e073c9bffe6\": \"0xfc936392801c00000\",\n \"0xfa6a37f018e97967937fc5e8617ba1d786dd5f77\": \"0x43c30fb0884a96c0000\",\n \"0xfa7606435b356cee257bd2fcd3d9eacb3cd1c4e1\": \"0x56bc75e2d63100000\",\n \"0xfa7adf660b8d99ce15933d7c5f072f3cbeb99d33\": \"0x14061b9d77a5e980000\",\n \"0xfa86ca27bf2854d98870837fb6f6dfe4bf6453fc\": \"0x11757e8525cf148000\",\n \"0xfa8cf4e627698c5d5788abb7880417e750231399\": \"0xe61a3696eef6100000\",\n \"0xfa8e3b1f13433900737daaf1f6299c4887f85b5f\": \"0x26c29e47c4844c0000\",\n \"0xfa9ec8efe08686fa58c181335872ba698560ecab\": \"0x6c6acc67d7b1d40000\",\n \"0xfaad905d847c7b23418aeecbe3addb8dd3f8924a\": \"0x6acb3df27e1f880000\",\n \"0xfaaeba8fc0bbda553ca72e30ef3d732e26e82041\": \"0x488d282aafc9f68000\",\n \"0xfab487500df20fb83ebed916791d561772adbebf\": \"0x6c6b4c4da6ddbe0000\",\n \"0xfac5ca94758078fbfccd19db3558da7ee8a0a768\": \"0x3728a62b0dcff60000\",\n \"0xfad96ab6ac768ad5099452ac4777bd1a47edc48f\": \"0x56bc75e2d63100000\",\n \"0xfae76719d97eac41870428e940279d97dd57b2f6\": \"0x14dbb2195ca228900000\",\n \"0xfae881937047895a660cf229760f27e66828d643\": \"0x9ddc1e3b901180000\",\n \"0xfae92c1370e9e1859a5df83b56d0f586aa3b404c\": \"0x5c5b4f3d843980000\",\n \"0xfaf5f0b7b6d558f5090d9ea1fb2d42259c586078\": \"0x15affb8420c6b640000\",\n \"0xfb126f0ec769f49dcefca2f200286451583084b8\": \"0x10fcbc2350396bf0000\",\n \"0xfb135eb15a8bac72b69915342a60bbc06b7e077c\": \"0x43c33c1937564800000\",\n \"0xfb223c1e22eac1269b32ee156a5385922ed36fb8\": \"0x6c6b935b8bbd400000\",\n \"0xfb37cf6b4f81a9e222fba22e9bd24b5098b733cf\": \"0x21a754a6dc5280000\",\n \"0xfb3860f4121c432ebdc8ec6a0331b1b709792e90\": \"0x208c394af1c8880000\",\n \"0xfb39189af876e762c71d6c3e741893df226cedd6\": \"0xd8d726b7177a800000\",\n \"0xfb3a0b0d6b6a718f6fc0292a825dc9247a90a5d0\": \"0xad6dd199e975b0000\",\n \"0xfb3fa1ac08aba9cc3bf0fe9d483820688f65b410\": \"0x65a4da25d3016c00000\",\n \"0xfb3fe09bb836861529d7518da27635f538505615\": \"0x4be39216fda0700000\",\n \"0xfb5125bf0f5eb0b6f020e56bfc2fdf3d402c097e\": \"0x14061b9d77a5e980000\",\n \"0xfb5518714cefc36d04865de5915ef0ff47dfe743\": \"0x6c6b935b8bbd400000\",\n \"0xfb5ffaa0f7615726357891475818939d2037cf96\": \"0x1158e460913d00000\",\n \"0xfb685c15e439965ef626bf0d834cd1a89f2b5695\": \"0xd5967be4fc3f100000\",\n \"0xfb744b951d094b310262c8f986c860df9ab1de65\": \"0x2d1c515f1cb4a8000\",\n \"0xfb79abdb925c55b9f98efeef64cfc9eb61f51bb1\": \"0x6140c056fb0ac80000\",\n \"0xfb8113f94d9173eefd5a3073f516803a10b286ae\": \"0x4563918244f400000\",\n \"0xfb842ca2c5ef133917a236a0d4ac40690110b038\": \"0x10969a62be15880000\",\n \"0xfb91fb1a695553f0c68e21276decf0b83909b86d\": \"0x56c003617af780000\",\n \"0xfb9473cf7712350a1fa0395273fc80560752e4fb\": \"0x6af2198ba85aa0000\",\n \"0xfb949c647fdcfd2514c7d58e31f28a532d8c5833\": \"0x43c33c1937564800000\",\n \"0xfba5486d53c6e240494241abf87e43c7600d413a\": \"0x6bbf61494948340000\",\n \"0xfbb161fe875f09290a4b262bc60110848f0d2226\": \"0x6c6b935b8bbd400000\",\n \"0xfbbbebcfbe235e57dd2306ad1a9ec581c7f9f48f\": \"0x22b1c8c1227a00000\",\n \"0xfbc01db54e47cdc3c438694ab717a856c23fe6e9\": \"0x1ca7150ab174f470000\",\n \"0xfbcfcc4a7b0f26cf26e9f3332132e2fc6a230766\": \"0x1b1ae4d6e2ef5000000\",\n \"0xfbe71622bcbd31c1a36976e7e5f670c07ffe16de\": \"0x15af1d78b58c400000\",\n \"0xfbede32c349f3300ef4cd33b4de7dc18e443d326\": \"0xab4dcf399a3a600000\",\n \"0xfbf204c813f836d83962c7870c7808ca347fd33e\": \"0x1158e460913d00000\",\n \"0xfbf75933e01b75b154ef0669076be87f62dffae1\": \"0x10846372f249d4c00000\",\n \"0xfc0096b21e95acb8d619d176a4a1d8d529badbef\": \"0x14d9693bcbec028000\",\n \"0xfc00a420a36107dfd5f495128a5fe5abb2db0f34\": \"0x143179d869110200000\",\n \"0xfc018a690ad6746dbe3acf9712ddca52b6250039\": \"0x21e19e0c9bab2400000\",\n \"0xfc02734033e57f70517e0afc7ee62461f06fad8e\": \"0x155bd9307f9fe80000\",\n \"0xfc0ee6f7c2b3714ae9916c45566605b656f32441\": \"0x5f68e8131ecf800000\",\n \"0xfc10b7a67b3268d5331bfb6a14def5ea4a162ca3\": \"0xad78ebc5ac6200000\",\n \"0xfc15cb99a8d1030b12770add033a79ee0d0c908c\": \"0x12fa00bd52e6240000\",\n \"0xfc2952b4c49fedd0bc0528a308495e6d6a1c71d6\": \"0x6c6b935b8bbd400000\",\n \"0xfc2c1f88961d019c3e9ea33009152e0693fbf88a\": \"0x1b1ae4d6e2ef5000000\",\n \"0xfc361105dd90f9ede566499d69e9130395f12ac8\": \"0x53a4fe2f204e80e00000\",\n \"0xfc372ff6927cb396d9cf29803500110da632bc52\": \"0x6c6b935b8bbd400000\",\n \"0xfc39be41094b1997d2169e8264c2c3baa6c99bc4\": \"0x6c6b935b8bbd400000\",\n \"0xfc3d226bb36a58f526568857b0bb12d109ec9301\": \"0x6c6b935b8bbd400000\",\n \"0xfc43829ac787ff88aaf183ba352aadbf5a15b193\": \"0xd6ac0a2b0552e00000\",\n \"0xfc49c1439a41d6b3cf26bb67e0365224e5e38f5f\": \"0x3636d7af5ec98e0000\",\n \"0xfc5500825105cf712a318a5e9c3bfc69c89d0c12\": \"0xd8d726b7177a800000\",\n \"0xfc66faba277f4b5de64ad45eb19c31e00ced3ed5\": \"0x131beb925ffd3200000\",\n \"0xfc7e22a503ec5abe9b08c50bd14999f520fa4884\": \"0x15a477dfbe1ea148000\",\n \"0xfc8215a0a69913f62a43bf1c8590b9ddcd0d8ddb\": \"0x6c6b935b8bbd400000\",\n \"0xfc989cb487bf1a7d17e4c1b7c4b7aafdda6b0a8d\": \"0x1158e460913d00000\",\n \"0xfc9b347464b2f9929d807e039dae48d3d98de379\": \"0x2f6f10780d22cc00000\",\n \"0xfca43bbc23a0d321ba9e46b929735ce7d8ef0c18\": \"0x1158e460913d00000\",\n \"0xfca73eff8771c0103ba3cc1a9c259448c72abf0b\": \"0x3635c9adc5dea00000\",\n \"0xfcada300283f6bcc134a91456760b0d77de410e0\": \"0x6c6b935b8bbd400000\",\n \"0xfcbc5c71ace79741450b012cf6b8d3f17db68a70\": \"0x205b4dfa1ee74780000\",\n \"0xfcbd85feea6a754fcf3449449e37ff9784f7773c\": \"0xa74ada69abd7780000\",\n \"0xfcc9d4a4262e7a027ab7519110d802c495ceea39\": \"0x1595182224b26480000\",\n \"0xfccd0d1ecee27addea95f6857aeec8c7a04b28ee\": \"0x21e19e0c9bab2400000\",\n \"0xfcd0b4827cd208ffbf5e759dba8c3cc61d8c2c3c\": \"0x1b1ae4d6e2ef5000000\",\n \"0xfce089635ce97abac06b44819be5bb0a3e2e0b37\": \"0x503920a7630a78000\",\n \"0xfcf199f8b854222f182e4e1d099d4e323e2aae01\": \"0x3635c9adc5dea00000\",\n \"0xfcfc3a5004d678613f0b36a642269a7f371c3f6a\": \"0x3635c9adc5dea00000\",\n \"0xfd191a35157d781373fb411bf9f25290047c5eef\": \"0x3635c9adc5dea00000\",\n \"0xfd1faa347b0fcc804c2da86c36d5f1d18b7087bb\": \"0x2d6eb247a96f60000\",\n \"0xfd1fb5a89a89a721b8797068fbc47f3e9d52e149\": \"0xcd0b5837fc6580000\",\n \"0xfd204f4f4aba2525ba728afdf78792cbdeb735ae\": \"0x6c6b935b8bbd400000\",\n \"0xfd2757cc3551a095878d97875615fe0c6a32aa8a\": \"0x206db15299beac0000\",\n \"0xfd2872d19e57853cfa16effe93d0b1d47b4f93fb\": \"0xd8d726b7177a800000\",\n \"0xfd2929271e9d2095a264767e7b0df52ea0d1d400\": \"0xa2a1eb251b5ae40000\",\n \"0xfd377a385272900cb436a3bb7962cdffe93f5dad\": \"0x6c6b935b8bbd400000\",\n \"0xfd40242bb34a70855ef0fd90f3802dec2136b327\": \"0x68a875073e29240000\",\n \"0xfd452c3969ece3801c542020f1cdcaa1c71ed23d\": \"0x152d02c7e14af6800000\",\n \"0xfd4b551f6fdbcda6c511b5bb372250a6b783e534\": \"0x11de1e6db450c0000\",\n \"0xfd4b989558ae11be0c3b36e2d6f2a54a9343ca2e\": \"0x6c6b935b8bbd400000\",\n \"0xfd4de8e3748a289cf7d060517d9d38388db01fb8\": \"0xd8d726b7177a80000\",\n \"0xfd5a63157f914fd398eab19c137dd9550bb7715c\": \"0x56bc75e2d63100000\",\n \"0xfd60d2b5af3d35f7aaf0c393052e79c4d823d985\": \"0x30eb50d2e14080000\",\n \"0xfd686de53fa97f99639e2568549720bc588c9efc\": \"0x6ac5c62d9486070000\",\n \"0xfd7ede8f5240a06541eb699d782c2f9afb2170f6\": \"0x487a9a304539440000\",\n \"0xfd812bc69fb170ef57e2327e80affd14f8e4b6d2\": \"0x6c6b935b8bbd400000\",\n \"0xfd88d114220f081cb3d5e15be8152ab07366576a\": \"0x1043561a8829300000\",\n \"0xfd918536a8efa6f6cefe1fa1153995fef5e33d3b\": \"0x1b1ae4d6e2ef500000\",\n \"0xfd920f722682afb5af451b0544d4f41b3b9d5742\": \"0x7e52056a123f3c0000\",\n \"0xfd9579f119bbc819a02b61e38d8803c942f24d32\": \"0x5b97e9081d9400000\",\n \"0xfda0ce15330707f10bce3201172d2018b9ddea74\": \"0x2d041d705a2c60000\",\n \"0xfda3042819af3e662900e1b92b4358eda6e92590\": \"0x1907a284d58f63e00000\",\n \"0xfda6810ea5ac985d6ffbf1c511f1c142edcfddf7\": \"0xd8d726b7177a800000\",\n \"0xfdb33944f2360615e5be239577c8a19ba52d9887\": \"0x209d922f5259c50000\",\n \"0xfdba5359f7ec3bc770ac49975d844ec9716256f1\": \"0x3635c9adc5dea00000\",\n \"0xfdc4d4765a942f5bf96931a9e8cc7ab8b757ff4c\": \"0x126c478a0e3ea8600000\",\n \"0xfdcd5d80b105897a57abc47865768b2900524295\": \"0x15af1d78b58c4000000\",\n \"0xfdd1195f797d4f35717d15e6f9810a9a3ff55460\": \"0xfc936392801c0000\",\n \"0xfdd502a74e813bcfa355ceda3c176f6a6871af7f\": \"0x15af1d78b58c400000\",\n \"0xfde395bc0b6d5cbb4c1d8fea3e0b4bff635e9db7\": \"0x6c6b935b8bbd400000\",\n \"0xfdeaac2acf1d138e19f2fc3f9fb74592e3ed818a\": \"0x243d4d18229ca20000\",\n \"0xfdecc82ddfc56192e26f563c3d68cb544a96bfed\": \"0x17da3a04c7b3e00000\",\n \"0xfdf42343019b0b0c6bf260b173afab7e45b9d621\": \"0x6c6acc67d7b1d40000\",\n \"0xfdf449f108c6fb4f5a2b081eed7e45e6919e4d25\": \"0x6c6b935b8bbd400000\",\n \"0xfdfd6134c04a8ab7eb16f00643f8fed7daaaecb2\": \"0x15af1d78b58c400000\",\n \"0xfe00bf439911a553982db638039245bcf032dbdc\": \"0x155bd9307f9fe80000\",\n \"0xfe016ec17ec5f10e3bb98ff4a1eda045157682ab\": \"0x145f5402e7b2e60000\",\n \"0xfe0e30e214290d743dd30eb082f1f0a5225ade61\": \"0xad78ebc5ac6200000\",\n \"0xfe210b8f04dc6d4f76216acfcbd59ba83be9b630\": \"0x1158e460913d00000\",\n \"0xfe22a0b388668d1ae2643e771dacf38a434223cc\": \"0xd8db5ebd7b26380000\",\n \"0xfe362688845fa244cc807e4b1130eb3741a8051e\": \"0x3635c9adc5dea00000\",\n \"0xfe3827d57630cf8761d512797b0b858e478bbd12\": \"0x1158e460913d00000\",\n \"0xfe418b421a9c6d373602790475d2303e11a75930\": \"0x3708baed3d68900000\",\n \"0xfe4249127950e2f896ec0e7e2e3d055aab10550f\": \"0x243d4d18229ca20000\",\n \"0xfe4d8403216fd571572bf1bdb01d00578978d688\": \"0x215f835bc769da80000\",\n \"0xfe53b94989d89964da2061539526bbe979dd2ea9\": \"0x68a875073e29240000\",\n \"0xfe549bbfe64740189892932538daaf46d2b61d4f\": \"0x22b1c8c1227a00000\",\n \"0xfe615d975c0887e0c9113ec7298420a793af8b96\": \"0x1b1ae4d6e2ef5000000\",\n \"0xfe65c4188d7922576909642044fdc52395560165\": \"0xd8d726b7177a800000\",\n \"0xfe697ff22ca547bfc95e33d960da605c6763f35b\": \"0x47d4119fd960940000\",\n \"0xfe6a895b795cb4bf85903d3ce09c5aa43953d3bf\": \"0xb8507a820728200000\",\n \"0xfe6f5f42b6193b1ad16206e4afb5239d4d7db45e\": \"0x5dc892aa1131c80000\",\n \"0xfe7011b698bf3371132d7445b19eb5b094356aee\": \"0x6c6b935b8bbd400000\",\n \"0xfe80e9232deaff19baf99869883a4bdf0004e53c\": \"0x2e62f20a69be400000\",\n \"0xfe8e6e3665570dff7a1bda697aa589c0b4e9024a\": \"0x6c6b935b8bbd400000\",\n \"0xfe8f1fdcab7fbec9a6a3fcc507619600505c36a3\": \"0x11164759ffb320000\",\n \"0xfe91eccf2bd566afa11696c5049fa84c69630a52\": \"0x692ae8897081d00000\",\n \"0xfe96c4cd381562401aa32a86e65b9d52fa8aee27\": \"0x8f1d5c1cae37400000\",\n \"0xfe98c664c3e447a95e69bd582171b7176ea2a685\": \"0xd8d726b7177a800000\",\n \"0xfe9ad12ef05d6d90261f96c8340a0381974df477\": \"0x6c6b935b8bbd400000\",\n \"0xfe9c0fffefb803081256c0cf4d6659e6d33eb4fb\": \"0x52d542804f1ce00000\",\n \"0xfe9cfc3bb293ddb285e625f3582f74a6b0a5a6cd\": \"0x6acb3df27e1f880000\",\n \"0xfe9e1197d7974a7648dcc7a03112a88edbc9045d\": \"0x10afc1ade3b4ed40000\",\n \"0xfeaca2ac74624bf348dac9985143cfd652a4be55\": \"0x5897fcbb02914088000\",\n \"0xfead1803e5e737a68e18472d9ac715f0994cc2be\": \"0x1b1ae4d6e2ef500000\",\n \"0xfeb8b8e2af716ae41fc7c04bcf29540156461e6b\": \"0x545174a528a77a0000\",\n \"0xfeb92d30bf01ff9a1901666c5573532bfa07eeec\": \"0x3635c9adc5dea00000\",\n \"0xfebc3173bc9072136354002b7b4fb3bfc53f22f1\": \"0x140ec80fa7ee880000\",\n \"0xfebd48d0ffdbd5656cd5e686363a61145228f279\": \"0x97c9ce4cf6d5c00000\",\n \"0xfebd9f81cf78bd5fb6c4b9a24bd414bb9bfa4c4e\": \"0x6be10fb8ed6e138000\",\n \"0xfec06fe27b44c784b2396ec92f7b923ad17e9077\": \"0x6c6b935b8bbd400000\",\n \"0xfec14e5485de2b3eef5e74c46146db8e454e0335\": \"0x9b41fbf9e0aec0000\",\n \"0xfed8476d10d584b38bfa6737600ef19d35c41ed8\": \"0x62a992e53a0af00000\",\n \"0xfeef3b6eabc94affd3310c1c4d0e65375e131119\": \"0x1158e460913d00000\",\n \"0xfef09d70243f39ed8cd800bf9651479e8f4aca3c\": \"0xad78ebc5ac6200000\",\n \"0xfef3b3dead1a6926d49aa32b12c22af54d9ff985\": \"0x3635c9adc5dea00000\",\n \"0xff0b7cb71da9d4c1ea6ecc28ebda504c63f82fd1\": \"0x388a885df2fc6c0000\",\n \"0xff0c3c7798e8733dd2668152891bab80a8be955c\": \"0x45946b0f9e9d60000\",\n \"0xff0cb06c42e3d88948e45bd7b0d4e291aefeea51\": \"0x678a932062e4180000\",\n \"0xff0cc8dac824fa24fc3caa2169e6e057cf638ad6\": \"0xd8d726b7177a800000\",\n \"0xff0e2fec304207467e1e3307f64cbf30af8fd9cd\": \"0x6c6b935b8bbd400000\",\n \"0xff128f4b355be1dc4a6f94fa510d7f15d53c2aff\": \"0x93739534d286800000\",\n \"0xff12e49d8e06aa20f886293c0b98ed7eff788805\": \"0xd8d726b7177a800000\",\n \"0xff207308ced238a6c01ad0213ca9eb4465d42590\": \"0x6c6acc67d7b1d40000\",\n \"0xff26138330274df4e0a3081e6df7dd983ec6e78f\": \"0x6c6b935b8bbd400000\",\n \"0xff2726294148b86c78a9372497e459898ed3fee3\": \"0x6acb3df27e1f880000\",\n \"0xff3ded7a40d3aff0d7a8c45fa6136aa0433db457\": \"0x6c68ccd09b022c0000\",\n \"0xff3eee57c34d6dae970d8b311117c53586cd3502\": \"0x5c283d410394100000\",\n \"0xff3ef6ba151c21b59986ae64f6e8228bc9a2c733\": \"0x6c6b935b8bbd400000\",\n \"0xff41d9e1b4effe18d8b0d1f63fc4255fb4e06c3d\": \"0x487a9a304539440000\",\n \"0xff45cb34c928364d9cc9d8bb00373474618f06f3\": \"0x56bc75e2d63100000\",\n \"0xff49a775814ec00051a795a875de24592ea400d4\": \"0x2a5a058fc295ed000000\",\n \"0xff4a408f50e9e72146a28ce4fc8d90271f116e84\": \"0x6acb3df27e1f880000\",\n \"0xff4d9c8484c43c42ff2c5ab759996498d323994d\": \"0xd8d726b7177a800000\",\n \"0xff4fc66069046c525658c337a917f2d4b832b409\": \"0x6c6b935b8bbd400000\",\n \"0xff5162f2354dc492c75fd6e3a107268660eecb47\": \"0x5c283d410394100000\",\n \"0xff545bbb66fbd00eb5e6373ff4e326f5feb5fe12\": \"0x1158e460913d00000\",\n \"0xff5e7ee7d5114821e159dca5e81f18f1bfffbff9\": \"0x6c6b935b8bbd400000\",\n \"0xff61c9c1b7a3d8b53bba20b34466544b7b216644\": \"0x6c6b935b8bbd400000\",\n \"0xff65511cada259260c1ddc41974ecaecd32d6357\": \"0x5f68e8131ecf800000\",\n \"0xff7843c7010aa7e61519b762dfe49124a76b0e4e\": \"0xc5b17924412b9bb00000\",\n \"0xff78541756ab2b706e0d70b18adb700fc4f1643d\": \"0x92896529baddc880000\",\n \"0xff83855051ee8ffb70b4817dba3211ed2355869d\": \"0x15af1d78b58c400000\",\n \"0xff850e3be1eb6a4d726c08fa73aad358f39706da\": \"0x692ae8897081d00000\",\n \"0xff86e5e8e15b53909600e41308dab75f0e24e46b\": \"0x30eb50d2e140800000\",\n \"0xff88ebacc41b3687f39e4b59e159599b80cba33f\": \"0x15af1d78b58c400000\",\n \"0xff8a2ca5a81333f19998255f203256e1a819c0aa\": \"0xc249fdd3277800000\",\n \"0xff8eb07de3d49d9d52bbe8e5b26dbe1d160fa834\": \"0xd814dcb94453080000\",\n \"0xffa4aff1a37f984b0a67272149273ae9bd41e3bc\": \"0x21e19e0c9bab2400000\",\n \"0xffa696ecbd787e66abae4fe87b635f07ca57d848\": \"0x487a9a304539440000\",\n \"0xffac3db879a6c7158e8dec603b407463ba0d31cf\": \"0x6acb3df27e1f880000\",\n \"0xffad3dd74e2c1f796ac640de56dc99b4c792a402\": \"0x10f0cf064dd59200000\",\n \"0xffb04726dfa41afdc819168418610472970d7bfc\": \"0xd8d726b7177a800000\",\n \"0xffb3bcc3196a8c3cb834cec94c34fed35b3e1054\": \"0x48a43c54602f700000\",\n \"0xffb974673367f5c07be5fd270dc4b7138b074d57\": \"0x85ebc8bdb9066d8000\",\n \"0xffb9c7217e66743031eb377af65c77db7359dcda\": \"0x22b1c8c1227a00000\",\n \"0xffbc3da0381ec339c1c049eb1ed9ee34fdcea6ca\": \"0xd8d726b7177a800000\",\n \"0xffc5fc4b7e8a0293ff39a3a0f7d60d2646d37a74\": \"0x6c6b935b8bbd400000\",\n \"0xffc9cc3094b041ad0e076f968a0de3b167255866\": \"0x1770c1650beee80000\",\n \"0xffd5170fd1a8118d558e7511e364b24906c4f6b3\": \"0x341d8cd27f1588000\",\n \"0xffd6da958eecbc016bab91058440d39b41c7be83\": \"0x43c33c1937564800000\",\n \"0xffe0e997f1977a615f5a315af413fd4869343ba0\": \"0x56cd55fc64dfe0000\",\n \"0xffe28db53c9044b4ecd4053fd1b4b10d7056c688\": \"0x56bc75e2d63100000\",\n \"0xffe2e28c3fb74749d7e780dc8a5d422538e6e451\": \"0xdbb81e05bc12d8000\",\n \"0xffe8cbc1681e5e9db74a0f93f8ed25897519120f\": \"0x51b1d3839261ac0000\",\n \"0xffeac0305ede3a915295ec8e61c7f881006f4474\": \"0x556f64c1fe7fa0000\",\n \"0xffec0913c635baca2f5e57a37aa9fb7b6c9b6e26\": \"0x2ba39e82ed5d740000\",\n \"0xfff33a3bd36abdbd412707b8e310d6011454a7ae\": \"0x1b1ae4d6e2ef5000000\",\n \"0xfff4bad596633479a2a29f9a8b3f78eefd07e6ee\": \"0x56bc75e2d63100000\",\n \"0xfff7ac99c8e4feb60c9750054bdc14ce1857f181\": \"0x3635c9adc5dea00000\"\n}\n","{\n \"0x0000000000000000000000000000000000000000\": \"0x1\",\n \"0x0000000000000000000000000000000000000001\": \"0x1\",\n \"0x0000000000000000000000000000000000000002\": \"0x1\",\n \"0x0000000000000000000000000000000000000003\": \"0x1\",\n \"0x0000000000000000000000000000000000000004\": \"0x1\",\n \"0x0000000000000000000000000000000000000005\": \"0x1\",\n \"0x0000000000000000000000000000000000000006\": \"0x1\",\n \"0x0000000000000000000000000000000000000007\": \"0x1\",\n \"0x0000000000000000000000000000000000000008\": \"0x1\",\n \"0x0000000000000000000000000000000000000009\": \"0x1\",\n \"0x000000000000000000000000000000000000000a\": \"0x0\",\n \"0x000000000000000000000000000000000000000b\": \"0x0\",\n \"0x000000000000000000000000000000000000000c\": \"0x0\",\n \"0x000000000000000000000000000000000000000d\": \"0x0\",\n \"0x000000000000000000000000000000000000000e\": \"0x0\",\n \"0x000000000000000000000000000000000000000f\": \"0x0\",\n \"0x0000000000000000000000000000000000000010\": \"0x0\",\n \"0x0000000000000000000000000000000000000011\": \"0x0\",\n \"0x0000000000000000000000000000000000000012\": \"0x0\",\n \"0x0000000000000000000000000000000000000013\": \"0x0\",\n \"0x0000000000000000000000000000000000000014\": \"0x0\",\n \"0x0000000000000000000000000000000000000015\": \"0x0\",\n \"0x0000000000000000000000000000000000000016\": \"0x0\",\n \"0x0000000000000000000000000000000000000017\": \"0x0\",\n \"0x0000000000000000000000000000000000000018\": \"0x0\",\n \"0x0000000000000000000000000000000000000019\": \"0x0\",\n \"0x000000000000000000000000000000000000001a\": \"0x0\",\n \"0x000000000000000000000000000000000000001b\": \"0x0\",\n \"0x000000000000000000000000000000000000001c\": \"0x0\",\n \"0x000000000000000000000000000000000000001d\": \"0x0\",\n \"0x000000000000000000000000000000000000001e\": \"0x0\",\n \"0x000000000000000000000000000000000000001f\": \"0x0\",\n \"0x0000000000000000000000000000000000000020\": \"0x0\",\n \"0x0000000000000000000000000000000000000021\": \"0x0\",\n \"0x0000000000000000000000000000000000000022\": \"0x0\",\n \"0x0000000000000000000000000000000000000023\": \"0x0\",\n \"0x0000000000000000000000000000000000000024\": \"0x0\",\n \"0x0000000000000000000000000000000000000025\": \"0x0\",\n \"0x0000000000000000000000000000000000000026\": \"0x0\",\n \"0x0000000000000000000000000000000000000027\": \"0x0\",\n \"0x0000000000000000000000000000000000000028\": \"0x0\",\n \"0x0000000000000000000000000000000000000029\": \"0x0\",\n \"0x000000000000000000000000000000000000002a\": \"0x0\",\n \"0x000000000000000000000000000000000000002b\": \"0x0\",\n \"0x000000000000000000000000000000000000002c\": \"0x0\",\n \"0x000000000000000000000000000000000000002d\": \"0x0\",\n \"0x000000000000000000000000000000000000002e\": \"0x0\",\n \"0x000000000000000000000000000000000000002f\": \"0x0\",\n \"0x0000000000000000000000000000000000000030\": \"0x0\",\n \"0x0000000000000000000000000000000000000031\": \"0x0\",\n \"0x0000000000000000000000000000000000000032\": \"0x0\",\n \"0x0000000000000000000000000000000000000033\": \"0x0\",\n \"0x0000000000000000000000000000000000000034\": \"0x0\",\n \"0x0000000000000000000000000000000000000035\": \"0x0\",\n \"0x0000000000000000000000000000000000000036\": \"0x0\",\n \"0x0000000000000000000000000000000000000037\": \"0x0\",\n \"0x0000000000000000000000000000000000000038\": \"0x0\",\n \"0x0000000000000000000000000000000000000039\": \"0x0\",\n \"0x000000000000000000000000000000000000003a\": \"0x0\",\n \"0x000000000000000000000000000000000000003b\": \"0x0\",\n \"0x000000000000000000000000000000000000003c\": \"0x0\",\n \"0x000000000000000000000000000000000000003d\": \"0x0\",\n \"0x000000000000000000000000000000000000003e\": \"0x0\",\n \"0x000000000000000000000000000000000000003f\": \"0x0\",\n \"0x0000000000000000000000000000000000000040\": \"0x0\",\n \"0x0000000000000000000000000000000000000041\": \"0x0\",\n \"0x0000000000000000000000000000000000000042\": \"0x0\",\n \"0x0000000000000000000000000000000000000043\": \"0x0\",\n \"0x0000000000000000000000000000000000000044\": \"0x0\",\n \"0x0000000000000000000000000000000000000045\": \"0x0\",\n \"0x0000000000000000000000000000000000000046\": \"0x0\",\n \"0x0000000000000000000000000000000000000047\": \"0x0\",\n \"0x0000000000000000000000000000000000000048\": \"0x0\",\n \"0x0000000000000000000000000000000000000049\": \"0x0\",\n \"0x000000000000000000000000000000000000004a\": \"0x0\",\n \"0x000000000000000000000000000000000000004b\": \"0x0\",\n \"0x000000000000000000000000000000000000004c\": \"0x0\",\n \"0x000000000000000000000000000000000000004d\": \"0x0\",\n \"0x000000000000000000000000000000000000004e\": \"0x0\",\n \"0x000000000000000000000000000000000000004f\": \"0x0\",\n \"0x0000000000000000000000000000000000000050\": \"0x0\",\n \"0x0000000000000000000000000000000000000051\": \"0x0\",\n \"0x0000000000000000000000000000000000000052\": \"0x0\",\n \"0x0000000000000000000000000000000000000053\": \"0x0\",\n \"0x0000000000000000000000000000000000000054\": \"0x0\",\n \"0x0000000000000000000000000000000000000055\": \"0x0\",\n \"0x0000000000000000000000000000000000000056\": \"0x0\",\n \"0x0000000000000000000000000000000000000057\": \"0x0\",\n \"0x0000000000000000000000000000000000000058\": \"0x0\",\n \"0x0000000000000000000000000000000000000059\": \"0x0\",\n \"0x000000000000000000000000000000000000005a\": \"0x0\",\n \"0x000000000000000000000000000000000000005b\": \"0x0\",\n \"0x000000000000000000000000000000000000005c\": \"0x0\",\n \"0x000000000000000000000000000000000000005d\": \"0x0\",\n \"0x000000000000000000000000000000000000005e\": \"0x0\",\n \"0x000000000000000000000000000000000000005f\": \"0x0\",\n \"0x0000000000000000000000000000000000000060\": \"0x0\",\n \"0x0000000000000000000000000000000000000061\": \"0x0\",\n \"0x0000000000000000000000000000000000000062\": \"0x0\",\n \"0x0000000000000000000000000000000000000063\": \"0x0\",\n \"0x0000000000000000000000000000000000000064\": \"0x0\",\n \"0x0000000000000000000000000000000000000065\": \"0x0\",\n \"0x0000000000000000000000000000000000000066\": \"0x0\",\n \"0x0000000000000000000000000000000000000067\": \"0x0\",\n \"0x0000000000000000000000000000000000000068\": \"0x0\",\n \"0x0000000000000000000000000000000000000069\": \"0x0\",\n \"0x000000000000000000000000000000000000006a\": \"0x0\",\n \"0x000000000000000000000000000000000000006b\": \"0x0\",\n \"0x000000000000000000000000000000000000006c\": \"0x0\",\n \"0x000000000000000000000000000000000000006d\": \"0x0\",\n \"0x000000000000000000000000000000000000006e\": \"0x0\",\n \"0x000000000000000000000000000000000000006f\": \"0x0\",\n \"0x0000000000000000000000000000000000000070\": \"0x0\",\n \"0x0000000000000000000000000000000000000071\": \"0x0\",\n \"0x0000000000000000000000000000000000000072\": \"0x0\",\n \"0x0000000000000000000000000000000000000073\": \"0x0\",\n \"0x0000000000000000000000000000000000000074\": \"0x0\",\n \"0x0000000000000000000000000000000000000075\": \"0x0\",\n \"0x0000000000000000000000000000000000000076\": \"0x0\",\n \"0x0000000000000000000000000000000000000077\": \"0x0\",\n \"0x0000000000000000000000000000000000000078\": \"0x0\",\n \"0x0000000000000000000000000000000000000079\": \"0x0\",\n \"0x000000000000000000000000000000000000007a\": \"0x0\",\n \"0x000000000000000000000000000000000000007b\": \"0x0\",\n \"0x000000000000000000000000000000000000007c\": \"0x0\",\n \"0x000000000000000000000000000000000000007d\": \"0x0\",\n \"0x000000000000000000000000000000000000007e\": \"0x0\",\n \"0x000000000000000000000000000000000000007f\": \"0x0\",\n \"0x0000000000000000000000000000000000000080\": \"0x0\",\n \"0x0000000000000000000000000000000000000081\": \"0x0\",\n \"0x0000000000000000000000000000000000000082\": \"0x0\",\n \"0x0000000000000000000000000000000000000083\": \"0x0\",\n \"0x0000000000000000000000000000000000000084\": \"0x0\",\n \"0x0000000000000000000000000000000000000085\": \"0x0\",\n \"0x0000000000000000000000000000000000000086\": \"0x0\",\n \"0x0000000000000000000000000000000000000087\": \"0x0\",\n \"0x0000000000000000000000000000000000000088\": \"0x0\",\n \"0x0000000000000000000000000000000000000089\": \"0x0\",\n \"0x000000000000000000000000000000000000008a\": \"0x0\",\n \"0x000000000000000000000000000000000000008b\": \"0x0\",\n \"0x000000000000000000000000000000000000008c\": \"0x0\",\n \"0x000000000000000000000000000000000000008d\": \"0x0\",\n \"0x000000000000000000000000000000000000008e\": \"0x0\",\n \"0x000000000000000000000000000000000000008f\": \"0x0\",\n \"0x0000000000000000000000000000000000000090\": \"0x0\",\n \"0x0000000000000000000000000000000000000091\": \"0x0\",\n \"0x0000000000000000000000000000000000000092\": \"0x0\",\n \"0x0000000000000000000000000000000000000093\": \"0x0\",\n \"0x0000000000000000000000000000000000000094\": \"0x0\",\n \"0x0000000000000000000000000000000000000095\": \"0x0\",\n \"0x0000000000000000000000000000000000000096\": \"0x0\",\n \"0x0000000000000000000000000000000000000097\": \"0x0\",\n \"0x0000000000000000000000000000000000000098\": \"0x0\",\n \"0x0000000000000000000000000000000000000099\": \"0x0\",\n \"0x000000000000000000000000000000000000009a\": \"0x0\",\n \"0x000000000000000000000000000000000000009b\": \"0x0\",\n \"0x000000000000000000000000000000000000009c\": \"0x0\",\n \"0x000000000000000000000000000000000000009d\": \"0x0\",\n \"0x000000000000000000000000000000000000009e\": \"0x0\",\n \"0x000000000000000000000000000000000000009f\": \"0x0\",\n \"0x00000000000000000000000000000000000000a0\": \"0x0\",\n \"0x00000000000000000000000000000000000000a1\": \"0x0\",\n \"0x00000000000000000000000000000000000000a2\": \"0x0\",\n \"0x00000000000000000000000000000000000000a3\": \"0x0\",\n \"0x00000000000000000000000000000000000000a4\": \"0x0\",\n \"0x00000000000000000000000000000000000000a5\": \"0x0\",\n \"0x00000000000000000000000000000000000000a6\": \"0x0\",\n \"0x00000000000000000000000000000000000000a7\": \"0x0\",\n \"0x00000000000000000000000000000000000000a8\": \"0x0\",\n \"0x00000000000000000000000000000000000000a9\": \"0x0\",\n \"0x00000000000000000000000000000000000000aa\": \"0x0\",\n \"0x00000000000000000000000000000000000000ab\": \"0x0\",\n \"0x00000000000000000000000000000000000000ac\": \"0x0\",\n \"0x00000000000000000000000000000000000000ad\": \"0x0\",\n \"0x00000000000000000000000000000000000000ae\": \"0x0\",\n \"0x00000000000000000000000000000000000000af\": \"0x0\",\n \"0x00000000000000000000000000000000000000b0\": \"0x0\",\n \"0x00000000000000000000000000000000000000b1\": \"0x0\",\n \"0x00000000000000000000000000000000000000b2\": \"0x0\",\n \"0x00000000000000000000000000000000000000b3\": \"0x0\",\n \"0x00000000000000000000000000000000000000b4\": \"0x0\",\n \"0x00000000000000000000000000000000000000b5\": \"0x0\",\n \"0x00000000000000000000000000000000000000b6\": \"0x0\",\n \"0x00000000000000000000000000000000000000b7\": \"0x0\",\n \"0x00000000000000000000000000000000000000b8\": \"0x0\",\n \"0x00000000000000000000000000000000000000b9\": \"0x0\",\n \"0x00000000000000000000000000000000000000ba\": \"0x0\",\n \"0x00000000000000000000000000000000000000bb\": \"0x0\",\n \"0x00000000000000000000000000000000000000bc\": \"0x0\",\n \"0x00000000000000000000000000000000000000bd\": \"0x0\",\n \"0x00000000000000000000000000000000000000be\": \"0x0\",\n \"0x00000000000000000000000000000000000000bf\": \"0x0\",\n \"0x00000000000000000000000000000000000000c0\": \"0x0\",\n \"0x00000000000000000000000000000000000000c1\": \"0x0\",\n \"0x00000000000000000000000000000000000000c2\": \"0x0\",\n \"0x00000000000000000000000000000000000000c3\": \"0x0\",\n \"0x00000000000000000000000000000000000000c4\": \"0x0\",\n \"0x00000000000000000000000000000000000000c5\": \"0x0\",\n \"0x00000000000000000000000000000000000000c6\": \"0x0\",\n \"0x00000000000000000000000000000000000000c7\": \"0x0\",\n \"0x00000000000000000000000000000000000000c8\": \"0x0\",\n \"0x00000000000000000000000000000000000000c9\": \"0x0\",\n \"0x00000000000000000000000000000000000000ca\": \"0x0\",\n \"0x00000000000000000000000000000000000000cb\": \"0x0\",\n \"0x00000000000000000000000000000000000000cc\": \"0x0\",\n \"0x00000000000000000000000000000000000000cd\": \"0x0\",\n \"0x00000000000000000000000000000000000000ce\": \"0x0\",\n \"0x00000000000000000000000000000000000000cf\": \"0x0\",\n \"0x00000000000000000000000000000000000000d0\": \"0x0\",\n \"0x00000000000000000000000000000000000000d1\": \"0x0\",\n \"0x00000000000000000000000000000000000000d2\": \"0x0\",\n \"0x00000000000000000000000000000000000000d3\": \"0x0\",\n \"0x00000000000000000000000000000000000000d4\": \"0x0\",\n \"0x00000000000000000000000000000000000000d5\": \"0x0\",\n \"0x00000000000000000000000000000000000000d6\": \"0x0\",\n \"0x00000000000000000000000000000000000000d7\": \"0x0\",\n \"0x00000000000000000000000000000000000000d8\": \"0x0\",\n \"0x00000000000000000000000000000000000000d9\": \"0x0\",\n \"0x00000000000000000000000000000000000000da\": \"0x0\",\n \"0x00000000000000000000000000000000000000db\": \"0x0\",\n \"0x00000000000000000000000000000000000000dc\": \"0x0\",\n \"0x00000000000000000000000000000000000000dd\": \"0x0\",\n \"0x00000000000000000000000000000000000000de\": \"0x0\",\n \"0x00000000000000000000000000000000000000df\": \"0x0\",\n \"0x00000000000000000000000000000000000000e0\": \"0x0\",\n \"0x00000000000000000000000000000000000000e1\": \"0x0\",\n \"0x00000000000000000000000000000000000000e2\": \"0x0\",\n \"0x00000000000000000000000000000000000000e3\": \"0x0\",\n \"0x00000000000000000000000000000000000000e4\": \"0x0\",\n \"0x00000000000000000000000000000000000000e5\": \"0x0\",\n \"0x00000000000000000000000000000000000000e6\": \"0x0\",\n \"0x00000000000000000000000000000000000000e7\": \"0x0\",\n \"0x00000000000000000000000000000000000000e8\": \"0x0\",\n \"0x00000000000000000000000000000000000000e9\": \"0x0\",\n \"0x00000000000000000000000000000000000000ea\": \"0x0\",\n \"0x00000000000000000000000000000000000000eb\": \"0x0\",\n \"0x00000000000000000000000000000000000000ec\": \"0x0\",\n \"0x00000000000000000000000000000000000000ed\": \"0x0\",\n \"0x00000000000000000000000000000000000000ee\": \"0x0\",\n \"0x00000000000000000000000000000000000000ef\": \"0x0\",\n \"0x00000000000000000000000000000000000000f0\": \"0x0\",\n \"0x00000000000000000000000000000000000000f1\": \"0x0\",\n \"0x00000000000000000000000000000000000000f2\": \"0x0\",\n \"0x00000000000000000000000000000000000000f3\": \"0x0\",\n \"0x00000000000000000000000000000000000000f4\": \"0x0\",\n \"0x00000000000000000000000000000000000000f5\": \"0x0\",\n \"0x00000000000000000000000000000000000000f6\": \"0x0\",\n \"0x00000000000000000000000000000000000000f7\": \"0x0\",\n \"0x00000000000000000000000000000000000000f8\": \"0x0\",\n \"0x00000000000000000000000000000000000000f9\": \"0x0\",\n \"0x00000000000000000000000000000000000000fa\": \"0x0\",\n \"0x00000000000000000000000000000000000000fb\": \"0x0\",\n \"0x00000000000000000000000000000000000000fc\": \"0x0\",\n \"0x00000000000000000000000000000000000000fd\": \"0x0\",\n \"0x00000000000000000000000000000000000000fe\": \"0x0\",\n \"0x00000000000000000000000000000000000000ff\": \"0x0\",\n \"0x874b54a8bd152966d63f706bae1ffeb0411921e5\": \"0xc9f2c9cd04674edea40000000\"\n}\n","{\n \"0x0000000000000000000000000000000000000000\": \"0x1\",\n \"0x0000000000000000000000000000000000000001\": \"0x1\",\n \"0x0000000000000000000000000000000000000002\": \"0x1\",\n \"0x0000000000000000000000000000000000000003\": \"0x1\",\n \"0x0000000000000000000000000000000000000004\": \"0x1\",\n \"0x0000000000000000000000000000000000000005\": \"0x1\",\n \"0x0000000000000000000000000000000000000006\": \"0x1\",\n \"0x0000000000000000000000000000000000000007\": \"0x1\",\n \"0x0000000000000000000000000000000000000008\": \"0x1\",\n \"0x0000000000000000000000000000000000000009\": \"0x1\",\n \"0x000000000000000000000000000000000000000a\": \"0x1\",\n \"0x000000000000000000000000000000000000000b\": \"0x1\",\n \"0x000000000000000000000000000000000000000c\": \"0x1\",\n \"0x000000000000000000000000000000000000000d\": \"0x1\",\n \"0x000000000000000000000000000000000000000e\": \"0x1\",\n \"0x000000000000000000000000000000000000000f\": \"0x1\",\n \"0x0000000000000000000000000000000000000010\": \"0x1\",\n \"0x0000000000000000000000000000000000000011\": \"0x1\",\n \"0x0000000000000000000000000000000000000012\": \"0x1\",\n \"0x0000000000000000000000000000000000000013\": \"0x1\",\n \"0x0000000000000000000000000000000000000014\": \"0x1\",\n \"0x0000000000000000000000000000000000000015\": \"0x1\",\n \"0x0000000000000000000000000000000000000016\": \"0x1\",\n \"0x0000000000000000000000000000000000000017\": \"0x1\",\n \"0x0000000000000000000000000000000000000018\": \"0x1\",\n \"0x0000000000000000000000000000000000000019\": \"0x1\",\n \"0x000000000000000000000000000000000000001a\": \"0x1\",\n \"0x000000000000000000000000000000000000001b\": \"0x1\",\n \"0x000000000000000000000000000000000000001c\": \"0x1\",\n \"0x000000000000000000000000000000000000001d\": \"0x1\",\n \"0x000000000000000000000000000000000000001e\": \"0x1\",\n \"0x000000000000000000000000000000000000001f\": \"0x1\",\n \"0x0000000000000000000000000000000000000020\": \"0x1\",\n \"0x0000000000000000000000000000000000000021\": \"0x1\",\n \"0x0000000000000000000000000000000000000022\": \"0x1\",\n \"0x0000000000000000000000000000000000000023\": \"0x1\",\n \"0x0000000000000000000000000000000000000024\": \"0x1\",\n \"0x0000000000000000000000000000000000000025\": \"0x1\",\n \"0x0000000000000000000000000000000000000026\": \"0x1\",\n \"0x0000000000000000000000000000000000000027\": \"0x1\",\n \"0x0000000000000000000000000000000000000028\": \"0x1\",\n \"0x0000000000000000000000000000000000000029\": \"0x1\",\n \"0x000000000000000000000000000000000000002a\": \"0x1\",\n \"0x000000000000000000000000000000000000002b\": \"0x1\",\n \"0x000000000000000000000000000000000000002c\": \"0x1\",\n \"0x000000000000000000000000000000000000002d\": \"0x1\",\n \"0x000000000000000000000000000000000000002e\": \"0x1\",\n \"0x000000000000000000000000000000000000002f\": \"0x1\",\n \"0x0000000000000000000000000000000000000030\": \"0x1\",\n \"0x0000000000000000000000000000000000000031\": \"0x1\",\n \"0x0000000000000000000000000000000000000032\": \"0x1\",\n \"0x0000000000000000000000000000000000000033\": \"0x1\",\n \"0x0000000000000000000000000000000000000034\": \"0x1\",\n \"0x0000000000000000000000000000000000000035\": \"0x1\",\n \"0x0000000000000000000000000000000000000036\": \"0x1\",\n \"0x0000000000000000000000000000000000000037\": \"0x1\",\n \"0x0000000000000000000000000000000000000038\": \"0x1\",\n \"0x0000000000000000000000000000000000000039\": \"0x1\",\n \"0x000000000000000000000000000000000000003a\": \"0x1\",\n \"0x000000000000000000000000000000000000003b\": \"0x1\",\n \"0x000000000000000000000000000000000000003c\": \"0x1\",\n \"0x000000000000000000000000000000000000003d\": \"0x1\",\n \"0x000000000000000000000000000000000000003e\": \"0x1\",\n \"0x000000000000000000000000000000000000003f\": \"0x1\",\n \"0x0000000000000000000000000000000000000040\": \"0x1\",\n \"0x0000000000000000000000000000000000000041\": \"0x1\",\n \"0x0000000000000000000000000000000000000042\": \"0x1\",\n \"0x0000000000000000000000000000000000000043\": \"0x1\",\n \"0x0000000000000000000000000000000000000044\": \"0x1\",\n \"0x0000000000000000000000000000000000000045\": \"0x1\",\n \"0x0000000000000000000000000000000000000046\": \"0x1\",\n \"0x0000000000000000000000000000000000000047\": \"0x1\",\n \"0x0000000000000000000000000000000000000048\": \"0x1\",\n \"0x0000000000000000000000000000000000000049\": \"0x1\",\n \"0x000000000000000000000000000000000000004a\": \"0x1\",\n \"0x000000000000000000000000000000000000004b\": \"0x1\",\n \"0x000000000000000000000000000000000000004c\": \"0x1\",\n \"0x000000000000000000000000000000000000004d\": \"0x1\",\n \"0x000000000000000000000000000000000000004e\": \"0x1\",\n \"0x000000000000000000000000000000000000004f\": \"0x1\",\n \"0x0000000000000000000000000000000000000050\": \"0x1\",\n \"0x0000000000000000000000000000000000000051\": \"0x1\",\n \"0x0000000000000000000000000000000000000052\": \"0x1\",\n \"0x0000000000000000000000000000000000000053\": \"0x1\",\n \"0x0000000000000000000000000000000000000054\": \"0x1\",\n \"0x0000000000000000000000000000000000000055\": \"0x1\",\n \"0x0000000000000000000000000000000000000056\": \"0x1\",\n \"0x0000000000000000000000000000000000000057\": \"0x1\",\n \"0x0000000000000000000000000000000000000058\": \"0x1\",\n \"0x0000000000000000000000000000000000000059\": \"0x1\",\n \"0x000000000000000000000000000000000000005a\": \"0x1\",\n \"0x000000000000000000000000000000000000005b\": \"0x1\",\n \"0x000000000000000000000000000000000000005c\": \"0x1\",\n \"0x000000000000000000000000000000000000005d\": \"0x1\",\n \"0x000000000000000000000000000000000000005e\": \"0x1\",\n \"0x000000000000000000000000000000000000005f\": \"0x1\",\n \"0x0000000000000000000000000000000000000060\": \"0x1\",\n \"0x0000000000000000000000000000000000000061\": \"0x1\",\n \"0x0000000000000000000000000000000000000062\": \"0x1\",\n \"0x0000000000000000000000000000000000000063\": \"0x1\",\n \"0x0000000000000000000000000000000000000064\": \"0x1\",\n \"0x0000000000000000000000000000000000000065\": \"0x1\",\n \"0x0000000000000000000000000000000000000066\": \"0x1\",\n \"0x0000000000000000000000000000000000000067\": \"0x1\",\n \"0x0000000000000000000000000000000000000068\": \"0x1\",\n \"0x0000000000000000000000000000000000000069\": \"0x1\",\n \"0x000000000000000000000000000000000000006a\": \"0x1\",\n \"0x000000000000000000000000000000000000006b\": \"0x1\",\n \"0x000000000000000000000000000000000000006c\": \"0x1\",\n \"0x000000000000000000000000000000000000006d\": \"0x1\",\n \"0x000000000000000000000000000000000000006e\": \"0x1\",\n \"0x000000000000000000000000000000000000006f\": \"0x1\",\n \"0x0000000000000000000000000000000000000070\": \"0x1\",\n \"0x0000000000000000000000000000000000000071\": \"0x1\",\n \"0x0000000000000000000000000000000000000072\": \"0x1\",\n \"0x0000000000000000000000000000000000000073\": \"0x1\",\n \"0x0000000000000000000000000000000000000074\": \"0x1\",\n \"0x0000000000000000000000000000000000000075\": \"0x1\",\n \"0x0000000000000000000000000000000000000076\": \"0x1\",\n \"0x0000000000000000000000000000000000000077\": \"0x1\",\n \"0x0000000000000000000000000000000000000078\": \"0x1\",\n \"0x0000000000000000000000000000000000000079\": \"0x1\",\n \"0x000000000000000000000000000000000000007a\": \"0x1\",\n \"0x000000000000000000000000000000000000007b\": \"0x1\",\n \"0x000000000000000000000000000000000000007c\": \"0x1\",\n \"0x000000000000000000000000000000000000007d\": \"0x1\",\n \"0x000000000000000000000000000000000000007e\": \"0x1\",\n \"0x000000000000000000000000000000000000007f\": \"0x1\",\n \"0x0000000000000000000000000000000000000080\": \"0x1\",\n \"0x0000000000000000000000000000000000000081\": \"0x1\",\n \"0x0000000000000000000000000000000000000082\": \"0x1\",\n \"0x0000000000000000000000000000000000000083\": \"0x1\",\n \"0x0000000000000000000000000000000000000084\": \"0x1\",\n \"0x0000000000000000000000000000000000000085\": \"0x1\",\n \"0x0000000000000000000000000000000000000086\": \"0x1\",\n \"0x0000000000000000000000000000000000000087\": \"0x1\",\n \"0x0000000000000000000000000000000000000088\": \"0x1\",\n \"0x0000000000000000000000000000000000000089\": \"0x1\",\n \"0x000000000000000000000000000000000000008a\": \"0x1\",\n \"0x000000000000000000000000000000000000008b\": \"0x1\",\n \"0x000000000000000000000000000000000000008c\": \"0x1\",\n \"0x000000000000000000000000000000000000008d\": \"0x1\",\n \"0x000000000000000000000000000000000000008e\": \"0x1\",\n \"0x000000000000000000000000000000000000008f\": \"0x1\",\n \"0x0000000000000000000000000000000000000090\": \"0x1\",\n \"0x0000000000000000000000000000000000000091\": \"0x1\",\n \"0x0000000000000000000000000000000000000092\": \"0x1\",\n \"0x0000000000000000000000000000000000000093\": \"0x1\",\n \"0x0000000000000000000000000000000000000094\": \"0x1\",\n \"0x0000000000000000000000000000000000000095\": \"0x1\",\n \"0x0000000000000000000000000000000000000096\": \"0x1\",\n \"0x0000000000000000000000000000000000000097\": \"0x1\",\n \"0x0000000000000000000000000000000000000098\": \"0x1\",\n \"0x0000000000000000000000000000000000000099\": \"0x1\",\n \"0x000000000000000000000000000000000000009a\": \"0x1\",\n \"0x000000000000000000000000000000000000009b\": \"0x1\",\n \"0x000000000000000000000000000000000000009c\": \"0x1\",\n \"0x000000000000000000000000000000000000009d\": \"0x1\",\n \"0x000000000000000000000000000000000000009e\": \"0x1\",\n \"0x000000000000000000000000000000000000009f\": \"0x1\",\n \"0x00000000000000000000000000000000000000a0\": \"0x1\",\n \"0x00000000000000000000000000000000000000a1\": \"0x1\",\n \"0x00000000000000000000000000000000000000a2\": \"0x1\",\n \"0x00000000000000000000000000000000000000a3\": \"0x1\",\n \"0x00000000000000000000000000000000000000a4\": \"0x1\",\n \"0x00000000000000000000000000000000000000a5\": \"0x1\",\n \"0x00000000000000000000000000000000000000a6\": \"0x1\",\n \"0x00000000000000000000000000000000000000a7\": \"0x1\",\n \"0x00000000000000000000000000000000000000a8\": \"0x1\",\n \"0x00000000000000000000000000000000000000a9\": \"0x1\",\n \"0x00000000000000000000000000000000000000aa\": \"0x1\",\n \"0x00000000000000000000000000000000000000ab\": \"0x1\",\n \"0x00000000000000000000000000000000000000ac\": \"0x1\",\n \"0x00000000000000000000000000000000000000ad\": \"0x1\",\n \"0x00000000000000000000000000000000000000ae\": \"0x1\",\n \"0x00000000000000000000000000000000000000af\": \"0x1\",\n \"0x00000000000000000000000000000000000000b0\": \"0x1\",\n \"0x00000000000000000000000000000000000000b1\": \"0x1\",\n \"0x00000000000000000000000000000000000000b2\": \"0x1\",\n \"0x00000000000000000000000000000000000000b3\": \"0x1\",\n \"0x00000000000000000000000000000000000000b4\": \"0x1\",\n \"0x00000000000000000000000000000000000000b5\": \"0x1\",\n \"0x00000000000000000000000000000000000000b6\": \"0x1\",\n \"0x00000000000000000000000000000000000000b7\": \"0x1\",\n \"0x00000000000000000000000000000000000000b8\": \"0x1\",\n \"0x00000000000000000000000000000000000000b9\": \"0x1\",\n \"0x00000000000000000000000000000000000000ba\": \"0x1\",\n \"0x00000000000000000000000000000000000000bb\": \"0x1\",\n \"0x00000000000000000000000000000000000000bc\": \"0x1\",\n \"0x00000000000000000000000000000000000000bd\": \"0x1\",\n \"0x00000000000000000000000000000000000000be\": \"0x1\",\n \"0x00000000000000000000000000000000000000bf\": \"0x1\",\n \"0x00000000000000000000000000000000000000c0\": \"0x1\",\n \"0x00000000000000000000000000000000000000c1\": \"0x1\",\n \"0x00000000000000000000000000000000000000c2\": \"0x1\",\n \"0x00000000000000000000000000000000000000c3\": \"0x1\",\n \"0x00000000000000000000000000000000000000c4\": \"0x1\",\n \"0x00000000000000000000000000000000000000c5\": \"0x1\",\n \"0x00000000000000000000000000000000000000c6\": \"0x1\",\n \"0x00000000000000000000000000000000000000c7\": \"0x1\",\n \"0x00000000000000000000000000000000000000c8\": \"0x1\",\n \"0x00000000000000000000000000000000000000c9\": \"0x1\",\n \"0x00000000000000000000000000000000000000ca\": \"0x1\",\n \"0x00000000000000000000000000000000000000cb\": \"0x1\",\n \"0x00000000000000000000000000000000000000cc\": \"0x1\",\n \"0x00000000000000000000000000000000000000cd\": \"0x1\",\n \"0x00000000000000000000000000000000000000ce\": \"0x1\",\n \"0x00000000000000000000000000000000000000cf\": \"0x1\",\n \"0x00000000000000000000000000000000000000d0\": \"0x1\",\n \"0x00000000000000000000000000000000000000d1\": \"0x1\",\n \"0x00000000000000000000000000000000000000d2\": \"0x1\",\n \"0x00000000000000000000000000000000000000d3\": \"0x1\",\n \"0x00000000000000000000000000000000000000d4\": \"0x1\",\n \"0x00000000000000000000000000000000000000d5\": \"0x1\",\n \"0x00000000000000000000000000000000000000d6\": \"0x1\",\n \"0x00000000000000000000000000000000000000d7\": \"0x1\",\n \"0x00000000000000000000000000000000000000d8\": \"0x1\",\n \"0x00000000000000000000000000000000000000d9\": \"0x1\",\n \"0x00000000000000000000000000000000000000da\": \"0x1\",\n \"0x00000000000000000000000000000000000000db\": \"0x1\",\n \"0x00000000000000000000000000000000000000dc\": \"0x1\",\n \"0x00000000000000000000000000000000000000dd\": \"0x1\",\n \"0x00000000000000000000000000000000000000de\": \"0x1\",\n \"0x00000000000000000000000000000000000000df\": \"0x1\",\n \"0x00000000000000000000000000000000000000e0\": \"0x1\",\n \"0x00000000000000000000000000000000000000e1\": \"0x1\",\n \"0x00000000000000000000000000000000000000e2\": \"0x1\",\n \"0x00000000000000000000000000000000000000e3\": \"0x1\",\n \"0x00000000000000000000000000000000000000e4\": \"0x1\",\n \"0x00000000000000000000000000000000000000e5\": \"0x1\",\n \"0x00000000000000000000000000000000000000e6\": \"0x1\",\n \"0x00000000000000000000000000000000000000e7\": \"0x1\",\n \"0x00000000000000000000000000000000000000e8\": \"0x1\",\n \"0x00000000000000000000000000000000000000e9\": \"0x1\",\n \"0x00000000000000000000000000000000000000ea\": \"0x1\",\n \"0x00000000000000000000000000000000000000eb\": \"0x1\",\n \"0x00000000000000000000000000000000000000ec\": \"0x1\",\n \"0x00000000000000000000000000000000000000ed\": \"0x1\",\n \"0x00000000000000000000000000000000000000ee\": \"0x1\",\n \"0x00000000000000000000000000000000000000ef\": \"0x1\",\n \"0x00000000000000000000000000000000000000f0\": \"0x1\",\n \"0x00000000000000000000000000000000000000f1\": \"0x1\",\n \"0x00000000000000000000000000000000000000f2\": \"0x1\",\n \"0x00000000000000000000000000000000000000f3\": \"0x1\",\n \"0x00000000000000000000000000000000000000f4\": \"0x1\",\n \"0x00000000000000000000000000000000000000f5\": \"0x1\",\n \"0x00000000000000000000000000000000000000f6\": \"0x1\",\n \"0x00000000000000000000000000000000000000f7\": \"0x1\",\n \"0x00000000000000000000000000000000000000f8\": \"0x1\",\n \"0x00000000000000000000000000000000000000f9\": \"0x1\",\n \"0x00000000000000000000000000000000000000fa\": \"0x1\",\n \"0x00000000000000000000000000000000000000fb\": \"0x1\",\n \"0x00000000000000000000000000000000000000fc\": \"0x1\",\n \"0x00000000000000000000000000000000000000fd\": \"0x1\",\n \"0x00000000000000000000000000000000000000fe\": \"0x1\",\n \"0x00000000000000000000000000000000000000ff\": \"0x1\",\n \"0x31b98d14007bdee637298086988a0bbd31184523\": \"0x200000000000000000000000000000000000000000000000000000000000000\"\n}\n","{\n \"0x0000000000000000000000000000000000000001\": \"0x1\",\n \"0x0000000000000000000000000000000000000002\": \"0x1\",\n \"0x0000000000000000000000000000000000000003\": \"0x1\",\n \"0x0000000000000000000000000000000000000004\": \"0x1\",\n \"0x00521965e7bd230323c423d96c657db5b79d099f\": \"0x100000000000000000000000000000000000000000000000000\"\n}\n","{\n \"0x0000000000000000000000000000000000000000\": \"0x1\",\n \"0x0000000000000000000000000000000000000001\": \"0x1\",\n \"0x0000000000000000000000000000000000000002\": \"0x1\",\n \"0x0000000000000000000000000000000000000003\": \"0x1\",\n \"0x0000000000000000000000000000000000000004\": \"0x1\",\n \"0x0000000000000000000000000000000000000005\": \"0x1\",\n \"0x0000000000000000000000000000000000000006\": \"0x1\",\n \"0x0000000000000000000000000000000000000007\": \"0x1\",\n \"0x0000000000000000000000000000000000000008\": \"0x1\",\n \"0x0000000000000000000000000000000000000009\": \"0x1\",\n \"0x000000000000000000000000000000000000000a\": \"0x1\",\n \"0x000000000000000000000000000000000000000b\": \"0x1\",\n \"0x000000000000000000000000000000000000000c\": \"0x1\",\n \"0x000000000000000000000000000000000000000d\": \"0x1\",\n \"0x000000000000000000000000000000000000000e\": \"0x1\",\n \"0x000000000000000000000000000000000000000f\": \"0x1\",\n \"0x0000000000000000000000000000000000000010\": \"0x1\",\n \"0x0000000000000000000000000000000000000011\": \"0x1\",\n \"0x0000000000000000000000000000000000000012\": \"0x1\",\n \"0x0000000000000000000000000000000000000013\": \"0x1\",\n \"0x0000000000000000000000000000000000000014\": \"0x1\",\n \"0x0000000000000000000000000000000000000015\": \"0x1\",\n \"0x0000000000000000000000000000000000000016\": \"0x1\",\n \"0x0000000000000000000000000000000000000017\": \"0x1\",\n \"0x0000000000000000000000000000000000000018\": \"0x1\",\n \"0x0000000000000000000000000000000000000019\": \"0x1\",\n \"0x000000000000000000000000000000000000001a\": \"0x1\",\n \"0x000000000000000000000000000000000000001b\": \"0x1\",\n \"0x000000000000000000000000000000000000001c\": \"0x1\",\n \"0x000000000000000000000000000000000000001d\": \"0x1\",\n \"0x000000000000000000000000000000000000001e\": \"0x1\",\n \"0x000000000000000000000000000000000000001f\": \"0x1\",\n \"0x0000000000000000000000000000000000000020\": \"0x1\",\n \"0x0000000000000000000000000000000000000021\": \"0x1\",\n \"0x0000000000000000000000000000000000000022\": \"0x1\",\n \"0x0000000000000000000000000000000000000023\": \"0x1\",\n \"0x0000000000000000000000000000000000000024\": \"0x1\",\n \"0x0000000000000000000000000000000000000025\": \"0x1\",\n \"0x0000000000000000000000000000000000000026\": \"0x1\",\n \"0x0000000000000000000000000000000000000027\": \"0x1\",\n \"0x0000000000000000000000000000000000000028\": \"0x1\",\n \"0x0000000000000000000000000000000000000029\": \"0x1\",\n \"0x000000000000000000000000000000000000002a\": \"0x1\",\n \"0x000000000000000000000000000000000000002b\": \"0x1\",\n \"0x000000000000000000000000000000000000002c\": \"0x1\",\n \"0x000000000000000000000000000000000000002d\": \"0x1\",\n \"0x000000000000000000000000000000000000002e\": \"0x1\",\n \"0x000000000000000000000000000000000000002f\": \"0x1\",\n \"0x0000000000000000000000000000000000000030\": \"0x1\",\n \"0x0000000000000000000000000000000000000031\": \"0x1\",\n \"0x0000000000000000000000000000000000000032\": \"0x1\",\n \"0x0000000000000000000000000000000000000033\": \"0x1\",\n \"0x0000000000000000000000000000000000000034\": \"0x1\",\n \"0x0000000000000000000000000000000000000035\": \"0x1\",\n \"0x0000000000000000000000000000000000000036\": \"0x1\",\n \"0x0000000000000000000000000000000000000037\": \"0x1\",\n \"0x0000000000000000000000000000000000000038\": \"0x1\",\n \"0x0000000000000000000000000000000000000039\": \"0x1\",\n \"0x000000000000000000000000000000000000003a\": \"0x1\",\n \"0x000000000000000000000000000000000000003b\": \"0x1\",\n \"0x000000000000000000000000000000000000003c\": \"0x1\",\n \"0x000000000000000000000000000000000000003d\": \"0x1\",\n \"0x000000000000000000000000000000000000003e\": \"0x1\",\n \"0x000000000000000000000000000000000000003f\": \"0x1\",\n \"0x0000000000000000000000000000000000000040\": \"0x1\",\n \"0x0000000000000000000000000000000000000041\": \"0x1\",\n \"0x0000000000000000000000000000000000000042\": \"0x1\",\n \"0x0000000000000000000000000000000000000043\": \"0x1\",\n \"0x0000000000000000000000000000000000000044\": \"0x1\",\n \"0x0000000000000000000000000000000000000045\": \"0x1\",\n \"0x0000000000000000000000000000000000000046\": \"0x1\",\n \"0x0000000000000000000000000000000000000047\": \"0x1\",\n \"0x0000000000000000000000000000000000000048\": \"0x1\",\n \"0x0000000000000000000000000000000000000049\": \"0x1\",\n \"0x000000000000000000000000000000000000004a\": \"0x1\",\n \"0x000000000000000000000000000000000000004b\": \"0x1\",\n \"0x000000000000000000000000000000000000004c\": \"0x1\",\n \"0x000000000000000000000000000000000000004d\": \"0x1\",\n \"0x000000000000000000000000000000000000004e\": \"0x1\",\n \"0x000000000000000000000000000000000000004f\": \"0x1\",\n \"0x0000000000000000000000000000000000000050\": \"0x1\",\n \"0x0000000000000000000000000000000000000051\": \"0x1\",\n \"0x0000000000000000000000000000000000000052\": \"0x1\",\n \"0x0000000000000000000000000000000000000053\": \"0x1\",\n \"0x0000000000000000000000000000000000000054\": \"0x1\",\n \"0x0000000000000000000000000000000000000055\": \"0x1\",\n \"0x0000000000000000000000000000000000000056\": \"0x1\",\n \"0x0000000000000000000000000000000000000057\": \"0x1\",\n \"0x0000000000000000000000000000000000000058\": \"0x1\",\n \"0x0000000000000000000000000000000000000059\": \"0x1\",\n \"0x000000000000000000000000000000000000005a\": \"0x1\",\n \"0x000000000000000000000000000000000000005b\": \"0x1\",\n \"0x000000000000000000000000000000000000005c\": \"0x1\",\n \"0x000000000000000000000000000000000000005d\": \"0x1\",\n \"0x000000000000000000000000000000000000005e\": \"0x1\",\n \"0x000000000000000000000000000000000000005f\": \"0x1\",\n \"0x0000000000000000000000000000000000000060\": \"0x1\",\n \"0x0000000000000000000000000000000000000061\": \"0x1\",\n \"0x0000000000000000000000000000000000000062\": \"0x1\",\n \"0x0000000000000000000000000000000000000063\": \"0x1\",\n \"0x0000000000000000000000000000000000000064\": \"0x1\",\n \"0x0000000000000000000000000000000000000065\": \"0x1\",\n \"0x0000000000000000000000000000000000000066\": \"0x1\",\n \"0x0000000000000000000000000000000000000067\": \"0x1\",\n \"0x0000000000000000000000000000000000000068\": \"0x1\",\n \"0x0000000000000000000000000000000000000069\": \"0x1\",\n \"0x000000000000000000000000000000000000006a\": \"0x1\",\n \"0x000000000000000000000000000000000000006b\": \"0x1\",\n \"0x000000000000000000000000000000000000006c\": \"0x1\",\n \"0x000000000000000000000000000000000000006d\": \"0x1\",\n \"0x000000000000000000000000000000000000006e\": \"0x1\",\n \"0x000000000000000000000000000000000000006f\": \"0x1\",\n \"0x0000000000000000000000000000000000000070\": \"0x1\",\n \"0x0000000000000000000000000000000000000071\": \"0x1\",\n \"0x0000000000000000000000000000000000000072\": \"0x1\",\n \"0x0000000000000000000000000000000000000073\": \"0x1\",\n \"0x0000000000000000000000000000000000000074\": \"0x1\",\n \"0x0000000000000000000000000000000000000075\": \"0x1\",\n \"0x0000000000000000000000000000000000000076\": \"0x1\",\n \"0x0000000000000000000000000000000000000077\": \"0x1\",\n \"0x0000000000000000000000000000000000000078\": \"0x1\",\n \"0x0000000000000000000000000000000000000079\": \"0x1\",\n \"0x000000000000000000000000000000000000007a\": \"0x1\",\n \"0x000000000000000000000000000000000000007b\": \"0x1\",\n \"0x000000000000000000000000000000000000007c\": \"0x1\",\n \"0x000000000000000000000000000000000000007d\": \"0x1\",\n \"0x000000000000000000000000000000000000007e\": \"0x1\",\n \"0x000000000000000000000000000000000000007f\": \"0x1\",\n \"0x0000000000000000000000000000000000000080\": \"0x1\",\n \"0x0000000000000000000000000000000000000081\": \"0x1\",\n \"0x0000000000000000000000000000000000000082\": \"0x1\",\n \"0x0000000000000000000000000000000000000083\": \"0x1\",\n \"0x0000000000000000000000000000000000000084\": \"0x1\",\n \"0x0000000000000000000000000000000000000085\": \"0x1\",\n \"0x0000000000000000000000000000000000000086\": \"0x1\",\n \"0x0000000000000000000000000000000000000087\": \"0x1\",\n \"0x0000000000000000000000000000000000000088\": \"0x1\",\n \"0x0000000000000000000000000000000000000089\": \"0x1\",\n \"0x000000000000000000000000000000000000008a\": \"0x1\",\n \"0x000000000000000000000000000000000000008b\": \"0x1\",\n \"0x000000000000000000000000000000000000008c\": \"0x1\",\n \"0x000000000000000000000000000000000000008d\": \"0x1\",\n \"0x000000000000000000000000000000000000008e\": \"0x1\",\n \"0x000000000000000000000000000000000000008f\": \"0x1\",\n \"0x0000000000000000000000000000000000000090\": \"0x1\",\n \"0x0000000000000000000000000000000000000091\": \"0x1\",\n \"0x0000000000000000000000000000000000000092\": \"0x1\",\n \"0x0000000000000000000000000000000000000093\": \"0x1\",\n \"0x0000000000000000000000000000000000000094\": \"0x1\",\n \"0x0000000000000000000000000000000000000095\": \"0x1\",\n \"0x0000000000000000000000000000000000000096\": \"0x1\",\n \"0x0000000000000000000000000000000000000097\": \"0x1\",\n \"0x0000000000000000000000000000000000000098\": \"0x1\",\n \"0x0000000000000000000000000000000000000099\": \"0x1\",\n \"0x000000000000000000000000000000000000009a\": \"0x1\",\n \"0x000000000000000000000000000000000000009b\": \"0x1\",\n \"0x000000000000000000000000000000000000009c\": \"0x1\",\n \"0x000000000000000000000000000000000000009d\": \"0x1\",\n \"0x000000000000000000000000000000000000009e\": \"0x1\",\n \"0x000000000000000000000000000000000000009f\": \"0x1\",\n \"0x00000000000000000000000000000000000000a0\": \"0x1\",\n \"0x00000000000000000000000000000000000000a1\": \"0x1\",\n \"0x00000000000000000000000000000000000000a2\": \"0x1\",\n \"0x00000000000000000000000000000000000000a3\": \"0x1\",\n \"0x00000000000000000000000000000000000000a4\": \"0x1\",\n \"0x00000000000000000000000000000000000000a5\": \"0x1\",\n \"0x00000000000000000000000000000000000000a6\": \"0x1\",\n \"0x00000000000000000000000000000000000000a7\": \"0x1\",\n \"0x00000000000000000000000000000000000000a8\": \"0x1\",\n \"0x00000000000000000000000000000000000000a9\": \"0x1\",\n \"0x00000000000000000000000000000000000000aa\": \"0x1\",\n \"0x00000000000000000000000000000000000000ab\": \"0x1\",\n \"0x00000000000000000000000000000000000000ac\": \"0x1\",\n \"0x00000000000000000000000000000000000000ad\": \"0x1\",\n \"0x00000000000000000000000000000000000000ae\": \"0x1\",\n \"0x00000000000000000000000000000000000000af\": \"0x1\",\n \"0x00000000000000000000000000000000000000b0\": \"0x1\",\n \"0x00000000000000000000000000000000000000b1\": \"0x1\",\n \"0x00000000000000000000000000000000000000b2\": \"0x1\",\n \"0x00000000000000000000000000000000000000b3\": \"0x1\",\n \"0x00000000000000000000000000000000000000b4\": \"0x1\",\n \"0x00000000000000000000000000000000000000b5\": \"0x1\",\n \"0x00000000000000000000000000000000000000b6\": \"0x1\",\n \"0x00000000000000000000000000000000000000b7\": \"0x1\",\n \"0x00000000000000000000000000000000000000b8\": \"0x1\",\n \"0x00000000000000000000000000000000000000b9\": \"0x1\",\n \"0x00000000000000000000000000000000000000ba\": \"0x1\",\n \"0x00000000000000000000000000000000000000bb\": \"0x1\",\n \"0x00000000000000000000000000000000000000bc\": \"0x1\",\n \"0x00000000000000000000000000000000000000bd\": \"0x1\",\n \"0x00000000000000000000000000000000000000be\": \"0x1\",\n \"0x00000000000000000000000000000000000000bf\": \"0x1\",\n \"0x00000000000000000000000000000000000000c0\": \"0x1\",\n \"0x00000000000000000000000000000000000000c1\": \"0x1\",\n \"0x00000000000000000000000000000000000000c2\": \"0x1\",\n \"0x00000000000000000000000000000000000000c3\": \"0x1\",\n \"0x00000000000000000000000000000000000000c4\": \"0x1\",\n \"0x00000000000000000000000000000000000000c5\": \"0x1\",\n \"0x00000000000000000000000000000000000000c6\": \"0x1\",\n \"0x00000000000000000000000000000000000000c7\": \"0x1\",\n \"0x00000000000000000000000000000000000000c8\": \"0x1\",\n \"0x00000000000000000000000000000000000000c9\": \"0x1\",\n \"0x00000000000000000000000000000000000000ca\": \"0x1\",\n \"0x00000000000000000000000000000000000000cb\": \"0x1\",\n \"0x00000000000000000000000000000000000000cc\": \"0x1\",\n \"0x00000000000000000000000000000000000000cd\": \"0x1\",\n \"0x00000000000000000000000000000000000000ce\": \"0x1\",\n \"0x00000000000000000000000000000000000000cf\": \"0x1\",\n \"0x00000000000000000000000000000000000000d0\": \"0x1\",\n \"0x00000000000000000000000000000000000000d1\": \"0x1\",\n \"0x00000000000000000000000000000000000000d2\": \"0x1\",\n \"0x00000000000000000000000000000000000000d3\": \"0x1\",\n \"0x00000000000000000000000000000000000000d4\": \"0x1\",\n \"0x00000000000000000000000000000000000000d5\": \"0x1\",\n \"0x00000000000000000000000000000000000000d6\": \"0x1\",\n \"0x00000000000000000000000000000000000000d7\": \"0x1\",\n \"0x00000000000000000000000000000000000000d8\": \"0x1\",\n \"0x00000000000000000000000000000000000000d9\": \"0x1\",\n \"0x00000000000000000000000000000000000000da\": \"0x1\",\n \"0x00000000000000000000000000000000000000db\": \"0x1\",\n \"0x00000000000000000000000000000000000000dc\": \"0x1\",\n \"0x00000000000000000000000000000000000000dd\": \"0x1\",\n \"0x00000000000000000000000000000000000000de\": \"0x1\",\n \"0x00000000000000000000000000000000000000df\": \"0x1\",\n \"0x00000000000000000000000000000000000000e0\": \"0x1\",\n \"0x00000000000000000000000000000000000000e1\": \"0x1\",\n \"0x00000000000000000000000000000000000000e2\": \"0x1\",\n \"0x00000000000000000000000000000000000000e3\": \"0x1\",\n \"0x00000000000000000000000000000000000000e4\": \"0x1\",\n \"0x00000000000000000000000000000000000000e5\": \"0x1\",\n \"0x00000000000000000000000000000000000000e6\": \"0x1\",\n \"0x00000000000000000000000000000000000000e7\": \"0x1\",\n \"0x00000000000000000000000000000000000000e8\": \"0x1\",\n \"0x00000000000000000000000000000000000000e9\": \"0x1\",\n \"0x00000000000000000000000000000000000000ea\": \"0x1\",\n \"0x00000000000000000000000000000000000000eb\": \"0x1\",\n \"0x00000000000000000000000000000000000000ec\": \"0x1\",\n \"0x00000000000000000000000000000000000000ed\": \"0x1\",\n \"0x00000000000000000000000000000000000000ee\": \"0x1\",\n \"0x00000000000000000000000000000000000000ef\": \"0x1\",\n \"0x00000000000000000000000000000000000000f0\": \"0x1\",\n \"0x00000000000000000000000000000000000000f1\": \"0x1\",\n \"0x00000000000000000000000000000000000000f2\": \"0x1\",\n \"0x00000000000000000000000000000000000000f3\": \"0x1\",\n \"0x00000000000000000000000000000000000000f4\": \"0x1\",\n \"0x00000000000000000000000000000000000000f5\": \"0x1\",\n \"0x00000000000000000000000000000000000000f6\": \"0x1\",\n \"0x00000000000000000000000000000000000000f7\": \"0x1\",\n \"0x00000000000000000000000000000000000000f8\": \"0x1\",\n \"0x00000000000000000000000000000000000000f9\": \"0x1\",\n \"0x00000000000000000000000000000000000000fa\": \"0x1\",\n \"0x00000000000000000000000000000000000000fb\": \"0x1\",\n \"0x00000000000000000000000000000000000000fc\": \"0x1\",\n \"0x00000000000000000000000000000000000000fd\": \"0x1\",\n \"0x00000000000000000000000000000000000000fe\": \"0x1\",\n \"0x00000000000000000000000000000000000000ff\": \"0x1\",\n \"0x4c2ae482593505f0163cdefc073e81c63cda4107\": \"0x152d02c7e14af6800000\",\n \"0xa8e8f14732658e4b51e8711931053a8a69baf2b1\": \"0x152d02c7e14af6800000\",\n \"0xd9a5179f091d85051d3c982785efd1455cec8699\": \"0x84595161401484a000000\",\n \"0xe0a2bd4258d2768837baa26a28fe71dc079f84c7\": \"0x4a47e3c12448f4ad000000\"\n}\n","{\n \"0xa2A6d93439144FFE4D27c9E088dCD8b783946263\": \"0xD3C21BCECCEDA1000000\",\n \"0xBc11295936Aa79d594139de1B2e12629414F3BDB\": \"0xD3C21BCECCEDA1000000\",\n \"0x7cF5b79bfe291A67AB02b393E456cCc4c266F753\": \"0xD3C21BCECCEDA1000000\",\n \"0xaaec86394441f915bce3e6ab399977e9906f3b69\": \"0xD3C21BCECCEDA1000000\",\n \"0xF47CaE1CF79ca6758Bfc787dbD21E6bdBe7112B8\": \"0xD3C21BCECCEDA1000000\",\n \"0xd7eDDB78ED295B3C9629240E8924fb8D8874ddD8\": \"0xD3C21BCECCEDA1000000\",\n \"0x8b7F0977Bb4f0fBE7076FA22bC24acA043583F5e\": \"0xD3C21BCECCEDA1000000\",\n \"0xe2e2659028143784d557bcec6ff3a0721048880a\": \"0xD3C21BCECCEDA1000000\",\n \"0xd9a5179f091d85051d3c982785efd1455cec8699\": \"0xD3C21BCECCEDA1000000\",\n \"0xbeef32ca5b9a198d27B4e02F4c70439fE60356Cf\": \"0xD3C21BCECCEDA1000000\",\n \"0x0000006916a87b82333f4245046623b23794c65c\": \"0x84595161401484A000000\",\n \"0xb21c33de1fab3fa15499c62b59fe0cc3250020d1\": \"0x52B7D2DCC80CD2E4000000\",\n \"0x10F5d45854e038071485AC9e402308cF80D2d2fE\": \"0x52B7D2DCC80CD2E4000000\",\n \"0xd7d76c58b3a519e9fA6Cc4D22dC017259BC49F1E\": \"0x52B7D2DCC80CD2E4000000\",\n \"0x799D329e5f583419167cD722962485926E338F4a\": \"0xDE0B6B3A7640000\"\n}\n","\"use strict\";\n\nvar __extends = this && this.__extends || function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __values = this && this.__values || function (o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ConsensusAlgorithm = exports.ConsensusType = exports.Hardfork = exports.Chain = exports.CustomChain = void 0;\nvar events_1 = require(\"events\");\nvar crc_32_1 = require(\"crc-32\");\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar chains_1 = require(\"./chains\");\nvar hardforks_1 = require(\"./hardforks\");\nvar eips_1 = require(\"./eips\");\nvar CustomChain;\n(function (CustomChain) {\n /**\n * Polygon (Matic) Mainnet\n *\n * - [Documentation](https://docs.matic.network/docs/develop/network-details/network)\n */\n CustomChain[\"PolygonMainnet\"] = \"polygon-mainnet\";\n /**\n * Polygon (Matic) Mumbai Testnet\n *\n * - [Documentation](https://docs.matic.network/docs/develop/network-details/network)\n */\n CustomChain[\"PolygonMumbai\"] = \"polygon-mumbai\";\n /**\n * Arbitrum Rinkeby Testnet\n *\n * - [Documentation](https://developer.offchainlabs.com/docs/public_testnet)\n */\n CustomChain[\"ArbitrumRinkebyTestnet\"] = \"arbitrum-rinkeby-testnet\";\n /**\n * xDai EVM sidechain with a native stable token\n *\n * - [Documentation](https://www.xdaichain.com/)\n */\n CustomChain[\"xDaiChain\"] = \"x-dai-chain\";\n /**\n * Optimistic Kovan - testnet for Optimism roll-up\n *\n * - [Documentation](https://community.optimism.io/docs/developers/tutorials.html)\n */\n CustomChain[\"OptimisticKovan\"] = \"optimistic-kovan\";\n /**\n * Optimistic Ethereum - mainnet for Optimism roll-up\n *\n * - [Documentation](https://community.optimism.io/docs/developers/tutorials.html)\n */\n CustomChain[\"OptimisticEthereum\"] = \"optimistic-ethereum\";\n})(CustomChain = exports.CustomChain || (exports.CustomChain = {}));\nvar Chain;\n(function (Chain) {\n Chain[Chain[\"Mainnet\"] = 1] = \"Mainnet\";\n Chain[Chain[\"Ropsten\"] = 3] = \"Ropsten\";\n Chain[Chain[\"Rinkeby\"] = 4] = \"Rinkeby\";\n Chain[Chain[\"Kovan\"] = 42] = \"Kovan\";\n Chain[Chain[\"Goerli\"] = 5] = \"Goerli\";\n Chain[Chain[\"Sepolia\"] = 11155111] = \"Sepolia\";\n})(Chain = exports.Chain || (exports.Chain = {}));\nvar Hardfork;\n(function (Hardfork) {\n Hardfork[\"Chainstart\"] = \"chainstart\";\n Hardfork[\"Homestead\"] = \"homestead\";\n Hardfork[\"Dao\"] = \"dao\";\n Hardfork[\"TangerineWhistle\"] = \"tangerineWhistle\";\n Hardfork[\"SpuriousDragon\"] = \"spuriousDragon\";\n Hardfork[\"Byzantium\"] = \"byzantium\";\n Hardfork[\"Constantinople\"] = \"constantinople\";\n Hardfork[\"Petersburg\"] = \"petersburg\";\n Hardfork[\"Istanbul\"] = \"istanbul\";\n Hardfork[\"MuirGlacier\"] = \"muirGlacier\";\n Hardfork[\"Berlin\"] = \"berlin\";\n Hardfork[\"London\"] = \"london\";\n Hardfork[\"ArrowGlacier\"] = \"arrowGlacier\";\n Hardfork[\"GrayGlacier\"] = \"grayGlacier\";\n Hardfork[\"MergeForkIdTransition\"] = \"mergeForkIdTransition\";\n Hardfork[\"Merge\"] = \"merge\";\n Hardfork[\"Shanghai\"] = \"shanghai\";\n})(Hardfork = exports.Hardfork || (exports.Hardfork = {}));\nvar ConsensusType;\n(function (ConsensusType) {\n ConsensusType[\"ProofOfStake\"] = \"pos\";\n ConsensusType[\"ProofOfWork\"] = \"pow\";\n ConsensusType[\"ProofOfAuthority\"] = \"poa\";\n})(ConsensusType = exports.ConsensusType || (exports.ConsensusType = {}));\nvar ConsensusAlgorithm;\n(function (ConsensusAlgorithm) {\n ConsensusAlgorithm[\"Ethash\"] = \"ethash\";\n ConsensusAlgorithm[\"Clique\"] = \"clique\";\n ConsensusAlgorithm[\"Casper\"] = \"casper\";\n})(ConsensusAlgorithm = exports.ConsensusAlgorithm || (exports.ConsensusAlgorithm = {}));\n/**\n * Common class to access chain and hardfork parameters and to provide\n * a unified and shared view on the network and hardfork state.\n *\n * Use the {@link Common.custom} static constructor for creating simple\n * custom chain {@link Common} objects (more complete custom chain setups\n * can be created via the main constructor and the {@link CommonOpts.customChains} parameter).\n */\nvar Common = /** @class */function (_super) {\n __extends(Common, _super);\n /**\n *\n * @constructor\n */\n function Common(opts) {\n var e_1, _a;\n var _this = this;\n var _b, _c;\n _this = _super.call(this) || this;\n _this._supportedHardforks = [];\n _this._eips = [];\n _this._customChains = (_b = opts.customChains) !== null && _b !== void 0 ? _b : [];\n _this._chainParams = _this.setChain(opts.chain);\n _this.DEFAULT_HARDFORK = (_c = _this._chainParams.defaultHardfork) !== null && _c !== void 0 ? _c : Hardfork.Istanbul;\n try {\n for (var _d = __values(_this._chainParams.hardforks), _e = _d.next(); !_e.done; _e = _d.next()) {\n var hf = _e.value;\n if (!hf.forkHash) {\n hf.forkHash = _this._calcForkHash(hf.name);\n }\n }\n } catch (e_1_1) {\n e_1 = {\n error: e_1_1\n };\n } finally {\n try {\n if (_e && !_e.done && (_a = _d.return)) _a.call(_d);\n } finally {\n if (e_1) throw e_1.error;\n }\n }\n _this._hardfork = _this.DEFAULT_HARDFORK;\n if (opts.supportedHardforks) {\n _this._supportedHardforks = opts.supportedHardforks;\n }\n if (opts.hardfork) {\n _this.setHardfork(opts.hardfork);\n }\n if (opts.eips) {\n _this.setEIPs(opts.eips);\n }\n return _this;\n }\n /**\n * Creates a {@link Common} object for a custom chain, based on a standard one.\n *\n * It uses all the {@link Chain} parameters from the {@link baseChain} option except the ones overridden\n * in a provided {@link chainParamsOrName} dictionary. Some usage example:\n *\n * ```javascript\n * Common.custom({chainId: 123})\n * ```\n *\n * There are also selected supported custom chains which can be initialized by using one of the\n * {@link CustomChains} for {@link chainParamsOrName}, e.g.:\n *\n * ```javascript\n * Common.custom(CustomChains.MaticMumbai)\n * ```\n *\n * Note that these supported custom chains only provide some base parameters (usually the chain and\n * network ID and a name) and can only be used for selected use cases (e.g. sending a tx with\n * the `@ethereumjs/tx` library to a Layer-2 chain).\n *\n * @param chainParamsOrName Custom parameter dict (`name` will default to `custom-chain`) or string with name of a supported custom chain\n * @param opts Custom chain options to set the {@link CustomCommonOpts.baseChain}, selected {@link CustomCommonOpts.hardfork} and others\n */\n Common.custom = function (chainParamsOrName, opts) {\n var _a;\n if (opts === void 0) {\n opts = {};\n }\n var baseChain = (_a = opts.baseChain) !== null && _a !== void 0 ? _a : 'mainnet';\n var standardChainParams = __assign({}, Common._getChainParams(baseChain));\n standardChainParams['name'] = 'custom-chain';\n if (typeof chainParamsOrName !== 'string') {\n return new Common(__assign({\n chain: __assign(__assign({}, standardChainParams), chainParamsOrName)\n }, opts));\n } else {\n if (chainParamsOrName === CustomChain.PolygonMainnet) {\n return Common.custom({\n name: CustomChain.PolygonMainnet,\n chainId: 137,\n networkId: 137\n }, opts);\n }\n if (chainParamsOrName === CustomChain.PolygonMumbai) {\n return Common.custom({\n name: CustomChain.PolygonMumbai,\n chainId: 80001,\n networkId: 80001\n }, opts);\n }\n if (chainParamsOrName === CustomChain.ArbitrumRinkebyTestnet) {\n return Common.custom({\n name: CustomChain.ArbitrumRinkebyTestnet,\n chainId: 421611,\n networkId: 421611\n }, opts);\n }\n if (chainParamsOrName === CustomChain.xDaiChain) {\n return Common.custom({\n name: CustomChain.xDaiChain,\n chainId: 100,\n networkId: 100\n }, opts);\n }\n if (chainParamsOrName === CustomChain.OptimisticKovan) {\n return Common.custom({\n name: CustomChain.OptimisticKovan,\n chainId: 69,\n networkId: 69\n }, __assign({\n hardfork: Hardfork.Berlin\n }, opts));\n }\n if (chainParamsOrName === CustomChain.OptimisticEthereum) {\n return Common.custom({\n name: CustomChain.OptimisticEthereum,\n chainId: 10,\n networkId: 10\n }, __assign({\n hardfork: Hardfork.Berlin\n }, opts));\n }\n throw new Error(\"Custom chain \".concat(chainParamsOrName, \" not supported\"));\n }\n };\n /**\n * Creates a {@link Common} object for a custom chain, based on a standard one. It uses all the `Chain`\n * params from {@link baseChain} except the ones overridden in {@link customChainParams}.\n *\n * @deprecated Use {@link Common.custom} instead\n *\n * @param baseChain The name (`mainnet`) or id (`1`) of a standard chain used to base the custom\n * chain params on.\n * @param customChainParams The custom parameters of the chain.\n * @param hardfork String identifier ('byzantium') for hardfork (optional)\n * @param supportedHardforks Limit parameter returns to the given hardforks (optional)\n */\n Common.forCustomChain = function (baseChain, customChainParams, hardfork, supportedHardforks) {\n var standardChainParams = Common._getChainParams(baseChain);\n return new Common({\n chain: __assign(__assign({}, standardChainParams), customChainParams),\n hardfork: hardfork,\n supportedHardforks: supportedHardforks\n });\n };\n /**\n * Static method to determine if a {@link chainId} is supported as a standard chain\n * @param chainId BN id (`1`) of a standard chain\n * @returns boolean\n */\n Common.isSupportedChainId = function (chainId) {\n var initializedChains = (0, chains_1._getInitializedChains)();\n return Boolean(initializedChains['names'][chainId.toString()]);\n };\n Common._getChainParams = function (chain, customChains) {\n var initializedChains = (0, chains_1._getInitializedChains)(customChains);\n if (typeof chain === 'number' || ethereumjs_util_1.BN.isBN(chain)) {\n chain = chain.toString();\n if (initializedChains['names'][chain]) {\n var name_1 = initializedChains['names'][chain];\n return initializedChains[name_1];\n }\n throw new Error(\"Chain with ID \".concat(chain, \" not supported\"));\n }\n if (initializedChains[chain]) {\n return initializedChains[chain];\n }\n throw new Error(\"Chain with name \".concat(chain, \" not supported\"));\n };\n /**\n * Sets the chain\n * @param chain String ('mainnet') or Number (1) chain\n * representation. Or, a Dictionary of chain parameters for a private network.\n * @returns The dictionary with parameters set as chain\n */\n Common.prototype.setChain = function (chain) {\n var e_2, _a;\n if (typeof chain === 'number' || typeof chain === 'string' || ethereumjs_util_1.BN.isBN(chain)) {\n // Filter out genesis states if passed in to customChains\n var plainCustomChains = void 0;\n if (this._customChains && this._customChains.length > 0 && Array.isArray(this._customChains[0])) {\n plainCustomChains = this._customChains.map(function (e) {\n return e[0];\n });\n } else {\n plainCustomChains = this._customChains;\n }\n this._chainParams = Common._getChainParams(chain, plainCustomChains);\n } else if (typeof chain === 'object') {\n if (this._customChains.length > 0) {\n throw new Error('Chain must be a string, number, or BN when initialized with customChains passed in');\n }\n var required = ['networkId', 'genesis', 'hardforks', 'bootstrapNodes'];\n try {\n for (var required_1 = __values(required), required_1_1 = required_1.next(); !required_1_1.done; required_1_1 = required_1.next()) {\n var param = required_1_1.value;\n if (chain[param] === undefined) {\n throw new Error(\"Missing required chain parameter: \".concat(param));\n }\n }\n } catch (e_2_1) {\n e_2 = {\n error: e_2_1\n };\n } finally {\n try {\n if (required_1_1 && !required_1_1.done && (_a = required_1.return)) _a.call(required_1);\n } finally {\n if (e_2) throw e_2.error;\n }\n }\n this._chainParams = chain;\n } else {\n throw new Error('Wrong input format');\n }\n return this._chainParams;\n };\n /**\n * Sets the hardfork to get params for\n * @param hardfork String identifier (e.g. 'byzantium') or {@link Hardfork} enum\n */\n Common.prototype.setHardfork = function (hardfork) {\n var e_3, _a;\n if (!this._isSupportedHardfork(hardfork)) {\n throw new Error(\"Hardfork \".concat(hardfork, \" not set as supported in supportedHardforks\"));\n }\n var existing = false;\n try {\n for (var HARDFORK_CHANGES_1 = __values(hardforks_1.hardforks), HARDFORK_CHANGES_1_1 = HARDFORK_CHANGES_1.next(); !HARDFORK_CHANGES_1_1.done; HARDFORK_CHANGES_1_1 = HARDFORK_CHANGES_1.next()) {\n var hfChanges = HARDFORK_CHANGES_1_1.value;\n if (hfChanges[0] === hardfork) {\n if (this._hardfork !== hardfork) {\n this._hardfork = hardfork;\n this.emit('hardforkChanged', hardfork);\n }\n existing = true;\n }\n }\n } catch (e_3_1) {\n e_3 = {\n error: e_3_1\n };\n } finally {\n try {\n if (HARDFORK_CHANGES_1_1 && !HARDFORK_CHANGES_1_1.done && (_a = HARDFORK_CHANGES_1.return)) _a.call(HARDFORK_CHANGES_1);\n } finally {\n if (e_3) throw e_3.error;\n }\n }\n if (!existing) {\n throw new Error(\"Hardfork with name \".concat(hardfork, \" not supported\"));\n }\n };\n /**\n * Returns the hardfork based on the block number or an optional\n * total difficulty (Merge HF) provided.\n *\n * An optional TD takes precedence in case the corresponding HF block\n * is set to `null` or otherwise needs to match (if not an error\n * will be thrown).\n *\n * @param blockNumber\n * @param td\n * @returns The name of the HF\n */\n Common.prototype.getHardforkByBlockNumber = function (blockNumber, td) {\n var e_4, _a;\n blockNumber = (0, ethereumjs_util_1.toType)(blockNumber, ethereumjs_util_1.TypeOutput.BN);\n td = (0, ethereumjs_util_1.toType)(td, ethereumjs_util_1.TypeOutput.BN);\n var hardfork = Hardfork.Chainstart;\n var minTdHF;\n var maxTdHF;\n var previousHF;\n try {\n for (var _b = __values(this.hardforks()), _c = _b.next(); !_c.done; _c = _b.next()) {\n var hf = _c.value;\n // Skip comparison for not applied HFs\n if (hf.block === null) {\n if (td !== undefined && td !== null && hf.td !== undefined && hf.td !== null) {\n if (td.gte(new ethereumjs_util_1.BN(hf.td))) {\n return hf.name;\n }\n }\n continue;\n }\n if (blockNumber.gte(new ethereumjs_util_1.BN(hf.block))) {\n hardfork = hf.name;\n }\n if (td && hf.td) {\n if (td.gte(new ethereumjs_util_1.BN(hf.td))) {\n minTdHF = hf.name;\n } else {\n maxTdHF = previousHF;\n }\n }\n previousHF = hf.name;\n }\n } catch (e_4_1) {\n e_4 = {\n error: e_4_1\n };\n } finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n } finally {\n if (e_4) throw e_4.error;\n }\n }\n if (td) {\n var msgAdd = \"block number: \".concat(blockNumber, \" (-> \").concat(hardfork, \"), \");\n if (minTdHF) {\n if (!this.hardforkGteHardfork(hardfork, minTdHF)) {\n var msg = 'HF determined by block number is lower than the minimum total difficulty HF';\n msgAdd += \"total difficulty: \".concat(td, \" (-> \").concat(minTdHF, \")\");\n throw new Error(\"\".concat(msg, \": \").concat(msgAdd));\n }\n }\n if (maxTdHF) {\n if (!this.hardforkGteHardfork(maxTdHF, hardfork)) {\n var msg = 'Maximum HF determined by total difficulty is lower than the block number HF';\n msgAdd += \"total difficulty: \".concat(td, \" (-> \").concat(maxTdHF, \")\");\n throw new Error(\"\".concat(msg, \": \").concat(msgAdd));\n }\n }\n }\n return hardfork;\n };\n /**\n * Sets a new hardfork based on the block number or an optional\n * total difficulty (Merge HF) provided.\n *\n * An optional TD takes precedence in case the corresponding HF block\n * is set to `null` or otherwise needs to match (if not an error\n * will be thrown).\n *\n * @param blockNumber\n * @param td\n * @returns The name of the HF set\n */\n Common.prototype.setHardforkByBlockNumber = function (blockNumber, td) {\n var hardfork = this.getHardforkByBlockNumber(blockNumber, td);\n this.setHardfork(hardfork);\n return hardfork;\n };\n /**\n * Internal helper function to choose between hardfork set and hardfork provided as param\n * @param hardfork Hardfork given to function as a parameter\n * @returns Hardfork chosen to be used\n */\n Common.prototype._chooseHardfork = function (hardfork, onlySupported) {\n if (onlySupported === void 0) {\n onlySupported = true;\n }\n if (!hardfork) {\n hardfork = this._hardfork;\n } else if (onlySupported && !this._isSupportedHardfork(hardfork)) {\n throw new Error(\"Hardfork \".concat(hardfork, \" not set as supported in supportedHardforks\"));\n }\n return hardfork;\n };\n /**\n * Internal helper function, returns the params for the given hardfork for the chain set\n * @param hardfork Hardfork name\n * @returns Dictionary with hardfork params\n */\n Common.prototype._getHardfork = function (hardfork) {\n var e_5, _a;\n var hfs = this.hardforks();\n try {\n for (var hfs_1 = __values(hfs), hfs_1_1 = hfs_1.next(); !hfs_1_1.done; hfs_1_1 = hfs_1.next()) {\n var hf = hfs_1_1.value;\n if (hf['name'] === hardfork) return hf;\n }\n } catch (e_5_1) {\n e_5 = {\n error: e_5_1\n };\n } finally {\n try {\n if (hfs_1_1 && !hfs_1_1.done && (_a = hfs_1.return)) _a.call(hfs_1);\n } finally {\n if (e_5) throw e_5.error;\n }\n }\n throw new Error(\"Hardfork \".concat(hardfork, \" not defined for chain \").concat(this.chainName()));\n };\n /**\n * Internal helper function to check if a hardfork is set to be supported by the library\n * @param hardfork Hardfork name\n * @returns True if hardfork is supported\n */\n Common.prototype._isSupportedHardfork = function (hardfork) {\n var e_6, _a;\n if (this._supportedHardforks.length > 0) {\n try {\n for (var _b = __values(this._supportedHardforks), _c = _b.next(); !_c.done; _c = _b.next()) {\n var supportedHf = _c.value;\n if (hardfork === supportedHf) return true;\n }\n } catch (e_6_1) {\n e_6 = {\n error: e_6_1\n };\n } finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n } finally {\n if (e_6) throw e_6.error;\n }\n }\n } else {\n return true;\n }\n return false;\n };\n /**\n * Sets the active EIPs\n * @param eips\n */\n Common.prototype.setEIPs = function (eips) {\n var e_7, _a;\n var _this = this;\n if (eips === void 0) {\n eips = [];\n }\n var _loop_1 = function (eip) {\n if (!(eip in eips_1.EIPs)) {\n throw new Error(\"\".concat(eip, \" not supported\"));\n }\n var minHF = this_1.gteHardfork(eips_1.EIPs[eip]['minimumHardfork']);\n if (!minHF) {\n throw new Error(\"\".concat(eip, \" cannot be activated on hardfork \").concat(this_1.hardfork(), \", minimumHardfork: \").concat(minHF));\n }\n if (eips_1.EIPs[eip].requiredEIPs) {\n ;\n eips_1.EIPs[eip].requiredEIPs.forEach(function (elem) {\n if (!(eips.includes(elem) || _this.isActivatedEIP(elem))) {\n throw new Error(\"\".concat(eip, \" requires EIP \").concat(elem, \", but is not included in the EIP list\"));\n }\n });\n }\n };\n var this_1 = this;\n try {\n for (var eips_2 = __values(eips), eips_2_1 = eips_2.next(); !eips_2_1.done; eips_2_1 = eips_2.next()) {\n var eip = eips_2_1.value;\n _loop_1(eip);\n }\n } catch (e_7_1) {\n e_7 = {\n error: e_7_1\n };\n } finally {\n try {\n if (eips_2_1 && !eips_2_1.done && (_a = eips_2.return)) _a.call(eips_2);\n } finally {\n if (e_7) throw e_7.error;\n }\n }\n this._eips = eips;\n };\n /**\n * Returns a parameter for the current chain setup\n *\n * If the parameter is present in an EIP, the EIP always takes precendence.\n * Otherwise the parameter if taken from the latest applied HF with\n * a change on the respective parameter.\n *\n * @param topic Parameter topic ('gasConfig', 'gasPrices', 'vm', 'pow')\n * @param name Parameter name (e.g. 'minGasLimit' for 'gasConfig' topic)\n * @returns The value requested or `null` if not found\n */\n Common.prototype.param = function (topic, name) {\n var e_8, _a;\n // TODO: consider the case that different active EIPs\n // can change the same parameter\n var value = null;\n try {\n for (var _b = __values(this._eips), _c = _b.next(); !_c.done; _c = _b.next()) {\n var eip = _c.value;\n value = this.paramByEIP(topic, name, eip);\n if (value !== null) {\n return value;\n }\n }\n } catch (e_8_1) {\n e_8 = {\n error: e_8_1\n };\n } finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n } finally {\n if (e_8) throw e_8.error;\n }\n }\n return this.paramByHardfork(topic, name, this._hardfork);\n };\n /**\n * Returns the parameter corresponding to a hardfork\n * @param topic Parameter topic ('gasConfig', 'gasPrices', 'vm', 'pow')\n * @param name Parameter name (e.g. 'minGasLimit' for 'gasConfig' topic)\n * @param hardfork Hardfork name\n * @returns The value requested or `null` if not found\n */\n Common.prototype.paramByHardfork = function (topic, name, hardfork) {\n var e_9, _a, e_10, _b;\n hardfork = this._chooseHardfork(hardfork);\n var value = null;\n try {\n for (var HARDFORK_CHANGES_2 = __values(hardforks_1.hardforks), HARDFORK_CHANGES_2_1 = HARDFORK_CHANGES_2.next(); !HARDFORK_CHANGES_2_1.done; HARDFORK_CHANGES_2_1 = HARDFORK_CHANGES_2.next()) {\n var hfChanges = HARDFORK_CHANGES_2_1.value;\n // EIP-referencing HF file (e.g. berlin.json)\n if ('eips' in hfChanges[1]) {\n var hfEIPs = hfChanges[1]['eips'];\n try {\n for (var hfEIPs_1 = (e_10 = void 0, __values(hfEIPs)), hfEIPs_1_1 = hfEIPs_1.next(); !hfEIPs_1_1.done; hfEIPs_1_1 = hfEIPs_1.next()) {\n var eip = hfEIPs_1_1.value;\n var valueEIP = this.paramByEIP(topic, name, eip);\n value = valueEIP !== null ? valueEIP : value;\n }\n } catch (e_10_1) {\n e_10 = {\n error: e_10_1\n };\n } finally {\n try {\n if (hfEIPs_1_1 && !hfEIPs_1_1.done && (_b = hfEIPs_1.return)) _b.call(hfEIPs_1);\n } finally {\n if (e_10) throw e_10.error;\n }\n }\n // Paramater-inlining HF file (e.g. istanbul.json)\n } else {\n if (!hfChanges[1][topic]) {\n throw new Error(\"Topic \".concat(topic, \" not defined\"));\n }\n if (hfChanges[1][topic][name] !== undefined) {\n value = hfChanges[1][topic][name].v;\n }\n }\n if (hfChanges[0] === hardfork) break;\n }\n } catch (e_9_1) {\n e_9 = {\n error: e_9_1\n };\n } finally {\n try {\n if (HARDFORK_CHANGES_2_1 && !HARDFORK_CHANGES_2_1.done && (_a = HARDFORK_CHANGES_2.return)) _a.call(HARDFORK_CHANGES_2);\n } finally {\n if (e_9) throw e_9.error;\n }\n }\n return value;\n };\n /**\n * Returns a parameter corresponding to an EIP\n * @param topic Parameter topic ('gasConfig', 'gasPrices', 'vm', 'pow')\n * @param name Parameter name (e.g. 'minGasLimit' for 'gasConfig' topic)\n * @param eip Number of the EIP\n * @returns The value requested or `null` if not found\n */\n Common.prototype.paramByEIP = function (topic, name, eip) {\n if (!(eip in eips_1.EIPs)) {\n throw new Error(\"\".concat(eip, \" not supported\"));\n }\n var eipParams = eips_1.EIPs[eip];\n if (!(topic in eipParams)) {\n throw new Error(\"Topic \".concat(topic, \" not defined\"));\n }\n if (eipParams[topic][name] === undefined) {\n return null;\n }\n var value = eipParams[topic][name].v;\n return value;\n };\n /**\n * Returns a parameter for the hardfork active on block number\n * @param topic Parameter topic\n * @param name Parameter name\n * @param blockNumber Block number\n */\n Common.prototype.paramByBlock = function (topic, name, blockNumber) {\n var activeHfs = this.activeHardforks(blockNumber);\n var hardfork = activeHfs[activeHfs.length - 1]['name'];\n return this.paramByHardfork(topic, name, hardfork);\n };\n /**\n * Checks if an EIP is activated by either being included in the EIPs\n * manually passed in with the {@link CommonOpts.eips} or in a\n * hardfork currently being active\n *\n * Note: this method only works for EIPs being supported\n * by the {@link CommonOpts.eips} constructor option\n * @param eip\n */\n Common.prototype.isActivatedEIP = function (eip) {\n var e_11, _a;\n if (this.eips().includes(eip)) {\n return true;\n }\n try {\n for (var HARDFORK_CHANGES_3 = __values(hardforks_1.hardforks), HARDFORK_CHANGES_3_1 = HARDFORK_CHANGES_3.next(); !HARDFORK_CHANGES_3_1.done; HARDFORK_CHANGES_3_1 = HARDFORK_CHANGES_3.next()) {\n var hfChanges = HARDFORK_CHANGES_3_1.value;\n var hf = hfChanges[1];\n if (this.gteHardfork(hf['name']) && 'eips' in hf) {\n if (hf['eips'].includes(eip)) {\n return true;\n }\n }\n }\n } catch (e_11_1) {\n e_11 = {\n error: e_11_1\n };\n } finally {\n try {\n if (HARDFORK_CHANGES_3_1 && !HARDFORK_CHANGES_3_1.done && (_a = HARDFORK_CHANGES_3.return)) _a.call(HARDFORK_CHANGES_3);\n } finally {\n if (e_11) throw e_11.error;\n }\n }\n return false;\n };\n /**\n * Checks if set or provided hardfork is active on block number\n * @param hardfork Hardfork name or null (for HF set)\n * @param blockNumber\n * @param opts Hardfork options (onlyActive unused)\n * @returns True if HF is active on block number\n */\n Common.prototype.hardforkIsActiveOnBlock = function (hardfork, blockNumber, opts) {\n var _a;\n if (opts === void 0) {\n opts = {};\n }\n blockNumber = (0, ethereumjs_util_1.toType)(blockNumber, ethereumjs_util_1.TypeOutput.BN);\n var onlySupported = (_a = opts.onlySupported) !== null && _a !== void 0 ? _a : false;\n hardfork = this._chooseHardfork(hardfork, onlySupported);\n var hfBlock = this.hardforkBlockBN(hardfork);\n if (hfBlock && blockNumber.gte(hfBlock)) {\n return true;\n }\n return false;\n };\n /**\n * Alias to hardforkIsActiveOnBlock when hardfork is set\n * @param blockNumber\n * @param opts Hardfork options (onlyActive unused)\n * @returns True if HF is active on block number\n */\n Common.prototype.activeOnBlock = function (blockNumber, opts) {\n return this.hardforkIsActiveOnBlock(null, blockNumber, opts);\n };\n /**\n * Sequence based check if given or set HF1 is greater than or equal HF2\n * @param hardfork1 Hardfork name or null (if set)\n * @param hardfork2 Hardfork name\n * @param opts Hardfork options\n * @returns True if HF1 gte HF2\n */\n Common.prototype.hardforkGteHardfork = function (hardfork1, hardfork2, opts) {\n var e_12, _a;\n if (opts === void 0) {\n opts = {};\n }\n var onlyActive = opts.onlyActive === undefined ? false : opts.onlyActive;\n hardfork1 = this._chooseHardfork(hardfork1, opts.onlySupported);\n var hardforks;\n if (onlyActive) {\n hardforks = this.activeHardforks(null, opts);\n } else {\n hardforks = this.hardforks();\n }\n var posHf1 = -1,\n posHf2 = -1;\n var index = 0;\n try {\n for (var hardforks_2 = __values(hardforks), hardforks_2_1 = hardforks_2.next(); !hardforks_2_1.done; hardforks_2_1 = hardforks_2.next()) {\n var hf = hardforks_2_1.value;\n if (hf['name'] === hardfork1) posHf1 = index;\n if (hf['name'] === hardfork2) posHf2 = index;\n index += 1;\n }\n } catch (e_12_1) {\n e_12 = {\n error: e_12_1\n };\n } finally {\n try {\n if (hardforks_2_1 && !hardforks_2_1.done && (_a = hardforks_2.return)) _a.call(hardforks_2);\n } finally {\n if (e_12) throw e_12.error;\n }\n }\n return posHf1 >= posHf2 && posHf2 !== -1;\n };\n /**\n * Alias to hardforkGteHardfork when hardfork is set\n * @param hardfork Hardfork name\n * @param opts Hardfork options\n * @returns True if hardfork set is greater than hardfork provided\n */\n Common.prototype.gteHardfork = function (hardfork, opts) {\n return this.hardforkGteHardfork(null, hardfork, opts);\n };\n /**\n * Checks if given or set hardfork is active on the chain\n * @param hardfork Hardfork name, optional if HF set\n * @param opts Hardfork options (onlyActive unused)\n * @returns True if hardfork is active on the chain\n */\n Common.prototype.hardforkIsActiveOnChain = function (hardfork, opts) {\n var e_13, _a;\n var _b;\n if (opts === void 0) {\n opts = {};\n }\n var onlySupported = (_b = opts.onlySupported) !== null && _b !== void 0 ? _b : false;\n hardfork = this._chooseHardfork(hardfork, onlySupported);\n try {\n for (var _c = __values(this.hardforks()), _d = _c.next(); !_d.done; _d = _c.next()) {\n var hf = _d.value;\n if (hf['name'] === hardfork && hf['block'] !== null) return true;\n }\n } catch (e_13_1) {\n e_13 = {\n error: e_13_1\n };\n } finally {\n try {\n if (_d && !_d.done && (_a = _c.return)) _a.call(_c);\n } finally {\n if (e_13) throw e_13.error;\n }\n }\n return false;\n };\n /**\n * Returns the active hardfork switches for the current chain\n * @param blockNumber up to block if provided, otherwise for the whole chain\n * @param opts Hardfork options (onlyActive unused)\n * @return Array with hardfork arrays\n */\n Common.prototype.activeHardforks = function (blockNumber, opts) {\n var e_14, _a;\n if (opts === void 0) {\n opts = {};\n }\n var activeHardforks = [];\n var hfs = this.hardforks();\n try {\n for (var hfs_2 = __values(hfs), hfs_2_1 = hfs_2.next(); !hfs_2_1.done; hfs_2_1 = hfs_2.next()) {\n var hf = hfs_2_1.value;\n if (hf['block'] === null) continue;\n if (blockNumber !== undefined && blockNumber !== null && blockNumber < hf['block']) break;\n if (opts.onlySupported && !this._isSupportedHardfork(hf['name'])) continue;\n activeHardforks.push(hf);\n }\n } catch (e_14_1) {\n e_14 = {\n error: e_14_1\n };\n } finally {\n try {\n if (hfs_2_1 && !hfs_2_1.done && (_a = hfs_2.return)) _a.call(hfs_2);\n } finally {\n if (e_14) throw e_14.error;\n }\n }\n return activeHardforks;\n };\n /**\n * Returns the latest active hardfork name for chain or block or throws if unavailable\n * @param blockNumber up to block if provided, otherwise for the whole chain\n * @param opts Hardfork options (onlyActive unused)\n * @return Hardfork name\n */\n Common.prototype.activeHardfork = function (blockNumber, opts) {\n if (opts === void 0) {\n opts = {};\n }\n var activeHardforks = this.activeHardforks(blockNumber, opts);\n if (activeHardforks.length > 0) {\n return activeHardforks[activeHardforks.length - 1]['name'];\n } else {\n throw new Error(\"No (supported) active hardfork found\");\n }\n };\n /**\n * Returns the hardfork change block for hardfork provided or set\n * @param hardfork Hardfork name, optional if HF set\n * @returns Block number or null if unscheduled\n * @deprecated Please use {@link Common.hardforkBlockBN} for large number support\n */\n Common.prototype.hardforkBlock = function (hardfork) {\n var block = this.hardforkBlockBN(hardfork);\n return (0, ethereumjs_util_1.toType)(block, ethereumjs_util_1.TypeOutput.Number);\n };\n /**\n * Returns the hardfork change block for hardfork provided or set\n * @param hardfork Hardfork name, optional if HF set\n * @returns Block number or null if unscheduled\n */\n Common.prototype.hardforkBlockBN = function (hardfork) {\n hardfork = this._chooseHardfork(hardfork, false);\n var block = this._getHardfork(hardfork)['block'];\n if (block === undefined || block === null) {\n return null;\n }\n return new ethereumjs_util_1.BN(block);\n };\n /**\n * Returns the hardfork change total difficulty (Merge HF) for hardfork provided or set\n * @param hardfork Hardfork name, optional if HF set\n * @returns Total difficulty or null if no set\n */\n Common.prototype.hardforkTD = function (hardfork) {\n hardfork = this._chooseHardfork(hardfork, false);\n var td = this._getHardfork(hardfork)['td'];\n if (td === undefined || td === null) {\n return null;\n }\n return new ethereumjs_util_1.BN(td);\n };\n /**\n * True if block number provided is the hardfork (given or set) change block\n * @param blockNumber Number of the block to check\n * @param hardfork Hardfork name, optional if HF set\n * @returns True if blockNumber is HF block\n */\n Common.prototype.isHardforkBlock = function (blockNumber, hardfork) {\n blockNumber = (0, ethereumjs_util_1.toType)(blockNumber, ethereumjs_util_1.TypeOutput.BN);\n hardfork = this._chooseHardfork(hardfork, false);\n var block = this.hardforkBlockBN(hardfork);\n return block ? block.eq(blockNumber) : false;\n };\n /**\n * Returns the change block for the next hardfork after the hardfork provided or set\n * @param hardfork Hardfork name, optional if HF set\n * @returns Block number or null if not available\n * @deprecated Please use {@link Common.nextHardforkBlockBN} for large number support\n */\n Common.prototype.nextHardforkBlock = function (hardfork) {\n var block = this.nextHardforkBlockBN(hardfork);\n return (0, ethereumjs_util_1.toType)(block, ethereumjs_util_1.TypeOutput.Number);\n };\n /**\n * Returns the change block for the next hardfork after the hardfork provided or set\n * @param hardfork Hardfork name, optional if HF set\n * @returns Block number or null if not available\n */\n Common.prototype.nextHardforkBlockBN = function (hardfork) {\n hardfork = this._chooseHardfork(hardfork, false);\n var hfBlock = this.hardforkBlockBN(hardfork);\n if (hfBlock === null) {\n return null;\n }\n // Next fork block number or null if none available\n // Logic: if accumulator is still null and on the first occurrence of\n // a block greater than the current hfBlock set the accumulator,\n // pass on the accumulator as the final result from this time on\n var nextHfBlock = this.hardforks().reduce(function (acc, hf) {\n var block = new ethereumjs_util_1.BN(hf.block);\n return block.gt(hfBlock) && acc === null ? block : acc;\n }, null);\n return nextHfBlock;\n };\n /**\n * True if block number provided is the hardfork change block following the hardfork given or set\n * @param blockNumber Number of the block to check\n * @param hardfork Hardfork name, optional if HF set\n * @returns True if blockNumber is HF block\n */\n Common.prototype.isNextHardforkBlock = function (blockNumber, hardfork) {\n blockNumber = (0, ethereumjs_util_1.toType)(blockNumber, ethereumjs_util_1.TypeOutput.BN);\n hardfork = this._chooseHardfork(hardfork, false);\n var nextHardforkBlock = this.nextHardforkBlockBN(hardfork);\n return nextHardforkBlock === null ? false : nextHardforkBlock.eq(blockNumber);\n };\n /**\n * Internal helper function to calculate a fork hash\n * @param hardfork Hardfork name\n * @returns Fork hash as hex string\n */\n Common.prototype._calcForkHash = function (hardfork) {\n var e_15, _a;\n var genesis = Buffer.from(this.genesis().hash.substr(2), 'hex');\n var hfBuffer = Buffer.alloc(0);\n var prevBlock = 0;\n try {\n for (var _b = __values(this.hardforks()), _c = _b.next(); !_c.done; _c = _b.next()) {\n var hf = _c.value;\n var block = hf.block;\n // Skip for chainstart (0), not applied HFs (null) and\n // when already applied on same block number HFs\n if (block !== 0 && block !== null && block !== prevBlock) {\n var hfBlockBuffer = Buffer.from(block.toString(16).padStart(16, '0'), 'hex');\n hfBuffer = Buffer.concat([hfBuffer, hfBlockBuffer]);\n }\n if (hf.name === hardfork) break;\n if (block !== null) {\n prevBlock = block;\n }\n }\n } catch (e_15_1) {\n e_15 = {\n error: e_15_1\n };\n } finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n } finally {\n if (e_15) throw e_15.error;\n }\n }\n var inputBuffer = Buffer.concat([genesis, hfBuffer]);\n // CRC32 delivers result as signed (negative) 32-bit integer,\n // convert to hex string\n var forkhash = (0, ethereumjs_util_1.intToBuffer)((0, crc_32_1.buf)(inputBuffer) >>> 0).toString('hex');\n return \"0x\".concat(forkhash);\n };\n /**\n * Returns an eth/64 compliant fork hash (EIP-2124)\n * @param hardfork Hardfork name, optional if HF set\n */\n Common.prototype.forkHash = function (hardfork) {\n hardfork = this._chooseHardfork(hardfork, false);\n var data = this._getHardfork(hardfork);\n if (data['block'] === null && data['td'] === undefined) {\n var msg = 'No fork hash calculation possible for future hardfork';\n throw new Error(msg);\n }\n if (data['forkHash'] !== undefined) {\n return data['forkHash'];\n }\n return this._calcForkHash(hardfork);\n };\n /**\n *\n * @param forkHash Fork hash as a hex string\n * @returns Array with hardfork data (name, block, forkHash)\n */\n Common.prototype.hardforkForForkHash = function (forkHash) {\n var resArray = this.hardforks().filter(function (hf) {\n return hf.forkHash === forkHash;\n });\n return resArray.length >= 1 ? resArray[resArray.length - 1] : null;\n };\n /**\n * Returns the Genesis parameters of the current chain\n * @returns Genesis dictionary\n */\n Common.prototype.genesis = function () {\n return this._chainParams['genesis'];\n };\n /**\n * Returns the Genesis state of the current chain,\n * all values are provided as hex-prefixed strings.\n */\n Common.prototype.genesisState = function () {\n var e_16, _a;\n // Use require statements here in favor of import statements\n // to load json files on demand\n // (high memory usage by large mainnet.json genesis state file)\n switch (this.chainName()) {\n case 'mainnet':\n return require('./genesisStates/mainnet.json');\n case 'ropsten':\n return require('./genesisStates/ropsten.json');\n case 'rinkeby':\n return require('./genesisStates/rinkeby.json');\n case 'kovan':\n return require('./genesisStates/kovan.json');\n case 'goerli':\n return require('./genesisStates/goerli.json');\n case 'sepolia':\n return require('./genesisStates/sepolia.json');\n }\n // Custom chains with genesis state provided\n if (this._customChains && this._customChains.length > 0 && Array.isArray(this._customChains[0])) {\n try {\n for (var _b = __values(this._customChains), _c = _b.next(); !_c.done; _c = _b.next()) {\n var chainArrayWithGenesis = _c.value;\n if (chainArrayWithGenesis[0].name === this.chainName()) {\n return chainArrayWithGenesis[1];\n }\n }\n } catch (e_16_1) {\n e_16 = {\n error: e_16_1\n };\n } finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n } finally {\n if (e_16) throw e_16.error;\n }\n }\n }\n return {};\n };\n /**\n * Returns the hardforks for current chain\n * @returns {Array} Array with arrays of hardforks\n */\n Common.prototype.hardforks = function () {\n return this._chainParams['hardforks'];\n };\n /**\n * Returns bootstrap nodes for the current chain\n * @returns {Dictionary} Dict with bootstrap nodes\n */\n Common.prototype.bootstrapNodes = function () {\n return this._chainParams['bootstrapNodes'];\n };\n /**\n * Returns DNS networks for the current chain\n * @returns {String[]} Array of DNS ENR urls\n */\n Common.prototype.dnsNetworks = function () {\n return this._chainParams['dnsNetworks'];\n };\n /**\n * Returns the hardfork set\n * @returns Hardfork name\n */\n Common.prototype.hardfork = function () {\n return this._hardfork;\n };\n /**\n * Returns the Id of current chain\n * @returns chain Id\n * @deprecated Please use {@link Common.chainIdBN} for large number support\n */\n Common.prototype.chainId = function () {\n return (0, ethereumjs_util_1.toType)(this.chainIdBN(), ethereumjs_util_1.TypeOutput.Number);\n };\n /**\n * Returns the Id of current chain\n * @returns chain Id\n */\n Common.prototype.chainIdBN = function () {\n return new ethereumjs_util_1.BN(this._chainParams['chainId']);\n };\n /**\n * Returns the name of current chain\n * @returns chain name (lower case)\n */\n Common.prototype.chainName = function () {\n return this._chainParams['name'];\n };\n /**\n * Returns the Id of current network\n * @returns network Id\n * @deprecated Please use {@link Common.networkIdBN} for large number support\n */\n Common.prototype.networkId = function () {\n return (0, ethereumjs_util_1.toType)(this.networkIdBN(), ethereumjs_util_1.TypeOutput.Number);\n };\n /**\n * Returns the Id of current network\n * @returns network Id\n */\n Common.prototype.networkIdBN = function () {\n return new ethereumjs_util_1.BN(this._chainParams['networkId']);\n };\n /**\n * Returns the active EIPs\n * @returns List of EIPs\n */\n Common.prototype.eips = function () {\n return this._eips;\n };\n /**\n * Returns the consensus type of the network\n * Possible values: \"pow\"|\"poa\"|\"pos\"\n *\n * Note: This value can update along a hardfork.\n */\n Common.prototype.consensusType = function () {\n var e_17, _a;\n var hardfork = this.hardfork();\n var value;\n try {\n for (var HARDFORK_CHANGES_4 = __values(hardforks_1.hardforks), HARDFORK_CHANGES_4_1 = HARDFORK_CHANGES_4.next(); !HARDFORK_CHANGES_4_1.done; HARDFORK_CHANGES_4_1 = HARDFORK_CHANGES_4.next()) {\n var hfChanges = HARDFORK_CHANGES_4_1.value;\n if ('consensus' in hfChanges[1]) {\n value = hfChanges[1]['consensus']['type'];\n }\n if (hfChanges[0] === hardfork) break;\n }\n } catch (e_17_1) {\n e_17 = {\n error: e_17_1\n };\n } finally {\n try {\n if (HARDFORK_CHANGES_4_1 && !HARDFORK_CHANGES_4_1.done && (_a = HARDFORK_CHANGES_4.return)) _a.call(HARDFORK_CHANGES_4);\n } finally {\n if (e_17) throw e_17.error;\n }\n }\n if (value) {\n return value;\n }\n return this._chainParams['consensus']['type'];\n };\n /**\n * Returns the concrete consensus implementation\n * algorithm or protocol for the network\n * e.g. \"ethash\" for \"pow\" consensus type,\n * \"clique\" for \"poa\" consensus type or\n * \"casper\" for \"pos\" consensus type.\n *\n * Note: This value can update along a hardfork.\n */\n Common.prototype.consensusAlgorithm = function () {\n var e_18, _a;\n var hardfork = this.hardfork();\n var value;\n try {\n for (var HARDFORK_CHANGES_5 = __values(hardforks_1.hardforks), HARDFORK_CHANGES_5_1 = HARDFORK_CHANGES_5.next(); !HARDFORK_CHANGES_5_1.done; HARDFORK_CHANGES_5_1 = HARDFORK_CHANGES_5.next()) {\n var hfChanges = HARDFORK_CHANGES_5_1.value;\n if ('consensus' in hfChanges[1]) {\n value = hfChanges[1]['consensus']['algorithm'];\n }\n if (hfChanges[0] === hardfork) break;\n }\n } catch (e_18_1) {\n e_18 = {\n error: e_18_1\n };\n } finally {\n try {\n if (HARDFORK_CHANGES_5_1 && !HARDFORK_CHANGES_5_1.done && (_a = HARDFORK_CHANGES_5.return)) _a.call(HARDFORK_CHANGES_5);\n } finally {\n if (e_18) throw e_18.error;\n }\n }\n if (value) {\n return value;\n }\n return this._chainParams['consensus']['algorithm'];\n };\n /**\n * Returns a dictionary with consensus configuration\n * parameters based on the consensus algorithm\n *\n * Expected returns (parameters must be present in\n * the respective chain json files):\n *\n * ethash: -\n * clique: period, epoch\n * aura: -\n * casper: -\n *\n * Note: This value can update along a hardfork.\n */\n Common.prototype.consensusConfig = function () {\n var e_19, _a;\n var hardfork = this.hardfork();\n var value;\n try {\n for (var HARDFORK_CHANGES_6 = __values(hardforks_1.hardforks), HARDFORK_CHANGES_6_1 = HARDFORK_CHANGES_6.next(); !HARDFORK_CHANGES_6_1.done; HARDFORK_CHANGES_6_1 = HARDFORK_CHANGES_6.next()) {\n var hfChanges = HARDFORK_CHANGES_6_1.value;\n if ('consensus' in hfChanges[1]) {\n // The config parameter is named after the respective consensus algorithm\n value = hfChanges[1]['consensus'][hfChanges[1]['consensus']['algorithm']];\n }\n if (hfChanges[0] === hardfork) break;\n }\n } catch (e_19_1) {\n e_19 = {\n error: e_19_1\n };\n } finally {\n try {\n if (HARDFORK_CHANGES_6_1 && !HARDFORK_CHANGES_6_1.done && (_a = HARDFORK_CHANGES_6.return)) _a.call(HARDFORK_CHANGES_6);\n } finally {\n if (e_19) throw e_19.error;\n }\n }\n if (value) {\n return value;\n }\n var consensusAlgorithm = this.consensusAlgorithm();\n return this._chainParams['consensus'][consensusAlgorithm];\n };\n /**\n * Returns a deep copy of this {@link Common} instance.\n */\n Common.prototype.copy = function () {\n var copy = Object.assign(Object.create(Object.getPrototypeOf(this)), this);\n copy.removeAllListeners();\n return copy;\n };\n return Common;\n}(events_1.EventEmitter);\nexports.default = Common;\n","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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 __setModuleDefault = this && this.__setModuleDefault || (Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __values = this && this.__values || function (o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nvar __read = this && this.__read || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.BaseTransaction = void 0;\nvar common_1 = __importStar(require(\"@ethereumjs/common\"));\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar types_1 = require(\"./types\");\n/**\n * This base class will likely be subject to further\n * refactoring along the introduction of additional tx types\n * on the Ethereum network.\n *\n * It is therefore not recommended to use directly.\n */\nvar BaseTransaction = /** @class */function () {\n function BaseTransaction(txData, opts) {\n this.cache = {\n hash: undefined,\n dataFee: undefined\n };\n /**\n * List of tx type defining EIPs,\n * e.g. 1559 (fee market) and 2930 (access lists)\n * for FeeMarketEIP1559Transaction objects\n */\n this.activeCapabilities = [];\n /**\n * The default chain the tx falls back to if no Common\n * is provided and if the chain can't be derived from\n * a passed in chainId (only EIP-2718 typed txs) or\n * EIP-155 signature (legacy txs).\n *\n * @hidden\n */\n this.DEFAULT_CHAIN = common_1.Chain.Mainnet;\n /**\n * The default HF if the tx type is active on that HF\n * or the first greater HF where the tx is active.\n *\n * @hidden\n */\n this.DEFAULT_HARDFORK = common_1.Hardfork.Istanbul;\n var nonce = txData.nonce,\n gasLimit = txData.gasLimit,\n to = txData.to,\n value = txData.value,\n data = txData.data,\n v = txData.v,\n r = txData.r,\n s = txData.s,\n type = txData.type;\n this._type = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(type)).toNumber();\n this.txOptions = opts;\n var toB = (0, ethereumjs_util_1.toBuffer)(to === '' ? '0x' : to);\n var vB = (0, ethereumjs_util_1.toBuffer)(v === '' ? '0x' : v);\n var rB = (0, ethereumjs_util_1.toBuffer)(r === '' ? '0x' : r);\n var sB = (0, ethereumjs_util_1.toBuffer)(s === '' ? '0x' : s);\n this.nonce = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(nonce === '' ? '0x' : nonce));\n this.gasLimit = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(gasLimit === '' ? '0x' : gasLimit));\n this.to = toB.length > 0 ? new ethereumjs_util_1.Address(toB) : undefined;\n this.value = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(value === '' ? '0x' : value));\n this.data = (0, ethereumjs_util_1.toBuffer)(data === '' ? '0x' : data);\n this.v = vB.length > 0 ? new ethereumjs_util_1.BN(vB) : undefined;\n this.r = rB.length > 0 ? new ethereumjs_util_1.BN(rB) : undefined;\n this.s = sB.length > 0 ? new ethereumjs_util_1.BN(sB) : undefined;\n this._validateCannotExceedMaxInteger({\n value: this.value,\n r: this.r,\n s: this.s\n });\n // geth limits gasLimit to 2^64-1\n this._validateCannotExceedMaxInteger({\n gasLimit: this.gasLimit\n }, 64);\n // EIP-2681 limits nonce to 2^64-1 (cannot equal 2^64-1)\n this._validateCannotExceedMaxInteger({\n nonce: this.nonce\n }, 64, true);\n }\n Object.defineProperty(BaseTransaction.prototype, \"transactionType\", {\n /**\n * Alias for {@link BaseTransaction.type}\n *\n * @deprecated Use `type` instead\n */\n get: function () {\n return this.type;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(BaseTransaction.prototype, \"type\", {\n /**\n * Returns the transaction type.\n *\n * Note: legacy txs will return tx type `0`.\n */\n get: function () {\n return this._type;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Checks if a tx type defining capability is active\n * on a tx, for example the EIP-1559 fee market mechanism\n * or the EIP-2930 access list feature.\n *\n * Note that this is different from the tx type itself,\n * so EIP-2930 access lists can very well be active\n * on an EIP-1559 tx for example.\n *\n * This method can be useful for feature checks if the\n * tx type is unknown (e.g. when instantiated with\n * the tx factory).\n *\n * See `Capabilites` in the `types` module for a reference\n * on all supported capabilities.\n */\n BaseTransaction.prototype.supports = function (capability) {\n return this.activeCapabilities.includes(capability);\n };\n BaseTransaction.prototype.validate = function (stringError) {\n if (stringError === void 0) {\n stringError = false;\n }\n var errors = [];\n if (this.getBaseFee().gt(this.gasLimit)) {\n errors.push(\"gasLimit is too low. given \".concat(this.gasLimit, \", need at least \").concat(this.getBaseFee()));\n }\n if (this.isSigned() && !this.verifySignature()) {\n errors.push('Invalid Signature');\n }\n return stringError ? errors : errors.length === 0;\n };\n /**\n * The minimum amount of gas the tx must have (DataFee + TxFee + Creation Fee)\n */\n BaseTransaction.prototype.getBaseFee = function () {\n var fee = this.getDataFee().addn(this.common.param('gasPrices', 'tx'));\n if (this.common.gteHardfork('homestead') && this.toCreationAddress()) {\n fee.iaddn(this.common.param('gasPrices', 'txCreation'));\n }\n return fee;\n };\n /**\n * The amount of gas paid for the data in this tx\n */\n BaseTransaction.prototype.getDataFee = function () {\n var txDataZero = this.common.param('gasPrices', 'txDataZero');\n var txDataNonZero = this.common.param('gasPrices', 'txDataNonZero');\n var cost = 0;\n for (var i = 0; i < this.data.length; i++) {\n this.data[i] === 0 ? cost += txDataZero : cost += txDataNonZero;\n }\n cost = new ethereumjs_util_1.BN(cost);\n if ((this.to === undefined || this.to === null) && this.common.isActivatedEIP(3860)) {\n var dataLength = Math.ceil(this.data.length / 32);\n var initCodeCost = new ethereumjs_util_1.BN(this.common.param('gasPrices', 'initCodeWordCost')).imuln(dataLength);\n cost.iadd(initCodeCost);\n }\n return cost;\n };\n /**\n * If the tx's `to` is to the creation address\n */\n BaseTransaction.prototype.toCreationAddress = function () {\n return this.to === undefined || this.to.buf.length === 0;\n };\n BaseTransaction.prototype.isSigned = function () {\n var _a = this,\n v = _a.v,\n r = _a.r,\n s = _a.s;\n if (this.type === 0) {\n if (!v || !r || !s) {\n return false;\n } else {\n return true;\n }\n } else {\n if (v === undefined || !r || !s) {\n return false;\n } else {\n return true;\n }\n }\n };\n /**\n * Determines if the signature is valid\n */\n BaseTransaction.prototype.verifySignature = function () {\n try {\n // Main signature verification is done in `getSenderPublicKey()`\n var publicKey = this.getSenderPublicKey();\n return (0, ethereumjs_util_1.unpadBuffer)(publicKey).length !== 0;\n } catch (e) {\n return false;\n }\n };\n /**\n * Returns the sender's address\n */\n BaseTransaction.prototype.getSenderAddress = function () {\n return new ethereumjs_util_1.Address((0, ethereumjs_util_1.publicToAddress)(this.getSenderPublicKey()));\n };\n /**\n * Signs a transaction.\n *\n * Note that the signed tx is returned as a new object,\n * use as follows:\n * ```javascript\n * const signedTx = tx.sign(privateKey)\n * ```\n */\n BaseTransaction.prototype.sign = function (privateKey) {\n if (privateKey.length !== 32) {\n var msg = this._errorMsg('Private key must be 32 bytes in length.');\n throw new Error(msg);\n }\n // Hack for the constellation that we have got a legacy tx after spuriousDragon with a non-EIP155 conforming signature\n // and want to recreate a signature (where EIP155 should be applied)\n // Leaving this hack lets the legacy.spec.ts -> sign(), verifySignature() test fail\n // 2021-06-23\n var hackApplied = false;\n if (this.type === 0 && this.common.gteHardfork('spuriousDragon') && !this.supports(types_1.Capability.EIP155ReplayProtection)) {\n this.activeCapabilities.push(types_1.Capability.EIP155ReplayProtection);\n hackApplied = true;\n }\n var msgHash = this.getMessageToSign(true);\n var _a = (0, ethereumjs_util_1.ecsign)(msgHash, privateKey),\n v = _a.v,\n r = _a.r,\n s = _a.s;\n var tx = this._processSignature(v, r, s);\n // Hack part 2\n if (hackApplied) {\n var index = this.activeCapabilities.indexOf(types_1.Capability.EIP155ReplayProtection);\n if (index > -1) {\n this.activeCapabilities.splice(index, 1);\n }\n }\n return tx;\n };\n /**\n * Does chain ID checks on common and returns a common\n * to be used on instantiation\n * @hidden\n *\n * @param common - {@link Common} instance from tx options\n * @param chainId - Chain ID from tx options (typed txs) or signature (legacy tx)\n */\n BaseTransaction.prototype._getCommon = function (common, chainId) {\n var _a;\n // Chain ID provided\n if (chainId) {\n var chainIdBN = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(chainId));\n if (common) {\n if (!common.chainIdBN().eq(chainIdBN)) {\n var msg = this._errorMsg('The chain ID does not match the chain ID of Common');\n throw new Error(msg);\n }\n // Common provided, chain ID does match\n // -> Return provided Common\n return common.copy();\n } else {\n if (common_1.default.isSupportedChainId(chainIdBN)) {\n // No Common, chain ID supported by Common\n // -> Instantiate Common with chain ID\n return new common_1.default({\n chain: chainIdBN,\n hardfork: this.DEFAULT_HARDFORK\n });\n } else {\n // No Common, chain ID not supported by Common\n // -> Instantiate custom Common derived from DEFAULT_CHAIN\n return common_1.default.forCustomChain(this.DEFAULT_CHAIN, {\n name: 'custom-chain',\n networkId: chainIdBN,\n chainId: chainIdBN\n }, this.DEFAULT_HARDFORK);\n }\n }\n } else {\n // No chain ID provided\n // -> return Common provided or create new default Common\n return (_a = common === null || common === void 0 ? void 0 : common.copy()) !== null && _a !== void 0 ? _a : new common_1.default({\n chain: this.DEFAULT_CHAIN,\n hardfork: this.DEFAULT_HARDFORK\n });\n }\n };\n /**\n * Validates that an object with BN values cannot exceed the specified bit limit.\n * @param values Object containing string keys and BN values\n * @param bits Number of bits to check (64 or 256)\n * @param cannotEqual Pass true if the number also cannot equal one less the maximum value\n */\n BaseTransaction.prototype._validateCannotExceedMaxInteger = function (values, bits, cannotEqual) {\n var e_1, _a;\n if (bits === void 0) {\n bits = 256;\n }\n if (cannotEqual === void 0) {\n cannotEqual = false;\n }\n try {\n for (var _b = __values(Object.entries(values)), _c = _b.next(); !_c.done; _c = _b.next()) {\n var _d = __read(_c.value, 2),\n key = _d[0],\n value = _d[1];\n switch (bits) {\n case 64:\n if (cannotEqual) {\n if (value === null || value === void 0 ? void 0 : value.gte(ethereumjs_util_1.MAX_UINT64)) {\n var msg = this._errorMsg(\"\".concat(key, \" cannot equal or exceed MAX_UINT64 (2^64-1), given \").concat(value));\n throw new Error(msg);\n }\n } else {\n if (value === null || value === void 0 ? void 0 : value.gt(ethereumjs_util_1.MAX_UINT64)) {\n var msg = this._errorMsg(\"\".concat(key, \" cannot exceed MAX_UINT64 (2^64-1), given \").concat(value));\n throw new Error(msg);\n }\n }\n break;\n case 256:\n if (cannotEqual) {\n if (value === null || value === void 0 ? void 0 : value.gte(ethereumjs_util_1.MAX_INTEGER)) {\n var msg = this._errorMsg(\"\".concat(key, \" cannot equal or exceed MAX_INTEGER (2^256-1), given \").concat(value));\n throw new Error(msg);\n }\n } else {\n if (value === null || value === void 0 ? void 0 : value.gt(ethereumjs_util_1.MAX_INTEGER)) {\n var msg = this._errorMsg(\"\".concat(key, \" cannot exceed MAX_INTEGER (2^256-1), given \").concat(value));\n throw new Error(msg);\n }\n }\n break;\n default:\n {\n var msg = this._errorMsg('unimplemented bits value');\n throw new Error(msg);\n }\n }\n }\n } catch (e_1_1) {\n e_1 = {\n error: e_1_1\n };\n } finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n } finally {\n if (e_1) throw e_1.error;\n }\n }\n };\n /**\n * Returns the shared error postfix part for _error() method\n * tx type implementations.\n */\n BaseTransaction.prototype._getSharedErrorPostfix = function () {\n var hash = '';\n try {\n hash = this.isSigned() ? (0, ethereumjs_util_1.bufferToHex)(this.hash()) : 'not available (unsigned)';\n } catch (e) {\n hash = 'error';\n }\n var isSigned = '';\n try {\n isSigned = this.isSigned().toString();\n } catch (e) {\n hash = 'error';\n }\n var hf = '';\n try {\n hf = this.common.hardfork();\n } catch (e) {\n hf = 'error';\n }\n var postfix = \"tx type=\".concat(this.type, \" hash=\").concat(hash, \" nonce=\").concat(this.nonce, \" value=\").concat(this.value, \" \");\n postfix += \"signed=\".concat(isSigned, \" hf=\").concat(hf);\n return postfix;\n };\n return BaseTransaction;\n}();\nexports.BaseTransaction = BaseTransaction;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AccessLists = exports.checkMaxInitCodeSize = void 0;\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar types_1 = require(\"./types\");\nfunction checkMaxInitCodeSize(common, length) {\n if (length > common.param('vm', 'maxInitCodeSize')) {\n throw new Error(\"the initcode size of this transaction is too large: it is \".concat(length, \" while the max is \").concat(common.param('vm', 'maxInitCodeSize')));\n }\n}\nexports.checkMaxInitCodeSize = checkMaxInitCodeSize;\nvar AccessLists = /** @class */function () {\n function AccessLists() {}\n AccessLists.getAccessListData = function (accessList) {\n var AccessListJSON;\n var bufferAccessList;\n if (accessList && (0, types_1.isAccessList)(accessList)) {\n AccessListJSON = accessList;\n var newAccessList = [];\n for (var i = 0; i < accessList.length; i++) {\n var item = accessList[i];\n var addressBuffer = (0, ethereumjs_util_1.toBuffer)(item.address);\n var storageItems = [];\n for (var index = 0; index < item.storageKeys.length; index++) {\n storageItems.push((0, ethereumjs_util_1.toBuffer)(item.storageKeys[index]));\n }\n newAccessList.push([addressBuffer, storageItems]);\n }\n bufferAccessList = newAccessList;\n } else {\n bufferAccessList = accessList !== null && accessList !== void 0 ? accessList : [];\n // build the JSON\n var json = [];\n for (var i = 0; i < bufferAccessList.length; i++) {\n var data = bufferAccessList[i];\n var address = (0, ethereumjs_util_1.bufferToHex)(data[0]);\n var storageKeys = [];\n for (var item = 0; item < data[1].length; item++) {\n storageKeys.push((0, ethereumjs_util_1.bufferToHex)(data[1][item]));\n }\n var jsonItem = {\n address: address,\n storageKeys: storageKeys\n };\n json.push(jsonItem);\n }\n AccessListJSON = json;\n }\n return {\n AccessListJSON: AccessListJSON,\n accessList: bufferAccessList\n };\n };\n AccessLists.verifyAccessList = function (accessList) {\n for (var key = 0; key < accessList.length; key++) {\n var accessListItem = accessList[key];\n var address = accessListItem[0];\n var storageSlots = accessListItem[1];\n if (accessListItem[2] !== undefined) {\n throw new Error('Access list item cannot have 3 elements. It can only have an address, and an array of storage slots.');\n }\n if (address.length != 20) {\n throw new Error('Invalid EIP-2930 transaction: address length should be 20 bytes');\n }\n for (var storageSlot = 0; storageSlot < storageSlots.length; storageSlot++) {\n if (storageSlots[storageSlot].length != 32) {\n throw new Error('Invalid EIP-2930 transaction: storage slot length should be 32 bytes');\n }\n }\n }\n };\n AccessLists.getAccessListJSON = function (accessList) {\n var accessListJSON = [];\n for (var index = 0; index < accessList.length; index++) {\n var item = accessList[index];\n var JSONItem = {\n address: '0x' + (0, ethereumjs_util_1.setLengthLeft)(item[0], 20).toString('hex'),\n storageKeys: []\n };\n var storageSlots = item[1];\n for (var slot = 0; slot < storageSlots.length; slot++) {\n var storageSlot = storageSlots[slot];\n JSONItem.storageKeys.push('0x' + (0, ethereumjs_util_1.setLengthLeft)(storageSlot, 32).toString('hex'));\n }\n accessListJSON.push(JSONItem);\n }\n return accessListJSON;\n };\n AccessLists.getDataFeeEIP2930 = function (accessList, common) {\n var accessListStorageKeyCost = common.param('gasPrices', 'accessListStorageKeyCost');\n var accessListAddressCost = common.param('gasPrices', 'accessListAddressCost');\n var slots = 0;\n for (var index = 0; index < accessList.length; index++) {\n var item = accessList[index];\n var storageSlots = item[1];\n slots += storageSlots.length;\n }\n var addresses = accessList.length;\n return addresses * accessListAddressCost + slots * accessListStorageKeyCost;\n };\n return AccessLists;\n}();\nexports.AccessLists = AccessLists;\n","\"use strict\";\n\nvar __extends = this && this.__extends || function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __read = this && this.__read || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar types_1 = require(\"./types\");\nvar baseTransaction_1 = require(\"./baseTransaction\");\nvar util_1 = require(\"./util\");\nvar TRANSACTION_TYPE = 0;\n/**\n * An Ethereum non-typed (legacy) transaction\n */\nvar Transaction = /** @class */function (_super) {\n __extends(Transaction, _super);\n /**\n * This constructor takes the values, validates them, assigns them and freezes the object.\n *\n * It is not recommended to use this constructor directly. Instead use\n * the static factory methods to assist in creating a Transaction object from\n * varying data types.\n */\n function Transaction(txData, opts) {\n if (opts === void 0) {\n opts = {};\n }\n var _this = this;\n var _a;\n _this = _super.call(this, __assign(__assign({}, txData), {\n type: TRANSACTION_TYPE\n }), opts) || this;\n _this.common = _this._validateTxV(_this.v, opts.common);\n _this.gasPrice = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(txData.gasPrice === '' ? '0x' : txData.gasPrice));\n if (_this.gasPrice.mul(_this.gasLimit).gt(ethereumjs_util_1.MAX_INTEGER)) {\n var msg = _this._errorMsg('gas limit * gasPrice cannot exceed MAX_INTEGER (2^256-1)');\n throw new Error(msg);\n }\n _this._validateCannotExceedMaxInteger({\n gasPrice: _this.gasPrice\n });\n if (_this.common.gteHardfork('spuriousDragon')) {\n if (!_this.isSigned()) {\n _this.activeCapabilities.push(types_1.Capability.EIP155ReplayProtection);\n } else {\n // EIP155 spec:\n // If block.number >= 2,675,000 and v = CHAIN_ID * 2 + 35 or v = CHAIN_ID * 2 + 36\n // then when computing the hash of a transaction for purposes of signing or recovering\n // instead of hashing only the first six elements (i.e. nonce, gasprice, startgas, to, value, data)\n // hash nine elements, with v replaced by CHAIN_ID, r = 0 and s = 0.\n var v = _this.v;\n var chainIdDoubled = _this.common.chainIdBN().muln(2);\n // v and chain ID meet EIP-155 conditions\n if (v.eq(chainIdDoubled.addn(35)) || v.eq(chainIdDoubled.addn(36))) {\n _this.activeCapabilities.push(types_1.Capability.EIP155ReplayProtection);\n }\n }\n }\n if (_this.common.isActivatedEIP(3860)) {\n (0, util_1.checkMaxInitCodeSize)(_this.common, _this.data.length);\n }\n var freeze = (_a = opts === null || opts === void 0 ? void 0 : opts.freeze) !== null && _a !== void 0 ? _a : true;\n if (freeze) {\n Object.freeze(_this);\n }\n return _this;\n }\n /**\n * Instantiate a transaction from a data dictionary.\n *\n * Format: { nonce, gasPrice, gasLimit, to, value, data, v, r, s }\n *\n * Notes:\n * - All parameters are optional and have some basic default values\n */\n Transaction.fromTxData = function (txData, opts) {\n if (opts === void 0) {\n opts = {};\n }\n return new Transaction(txData, opts);\n };\n /**\n * Instantiate a transaction from the serialized tx.\n *\n * Format: `rlp([nonce, gasPrice, gasLimit, to, value, data, v, r, s])`\n */\n Transaction.fromSerializedTx = function (serialized, opts) {\n if (opts === void 0) {\n opts = {};\n }\n var values = ethereumjs_util_1.rlp.decode(serialized);\n if (!Array.isArray(values)) {\n throw new Error('Invalid serialized tx input. Must be array');\n }\n return this.fromValuesArray(values, opts);\n };\n /**\n * Instantiate a transaction from the serialized tx.\n * (alias of {@link Transaction.fromSerializedTx})\n *\n * @deprecated this constructor alias is deprecated and will be removed\n * in favor of the {@link Transaction.fromSerializedTx} constructor\n */\n Transaction.fromRlpSerializedTx = function (serialized, opts) {\n if (opts === void 0) {\n opts = {};\n }\n return Transaction.fromSerializedTx(serialized, opts);\n };\n /**\n * Create a transaction from a values array.\n *\n * Format: `[nonce, gasPrice, gasLimit, to, value, data, v, r, s]`\n */\n Transaction.fromValuesArray = function (values, opts) {\n if (opts === void 0) {\n opts = {};\n }\n // If length is not 6, it has length 9. If v/r/s are empty Buffers, it is still an unsigned transaction\n // This happens if you get the RLP data from `raw()`\n if (values.length !== 6 && values.length !== 9) {\n throw new Error('Invalid transaction. Only expecting 6 values (for unsigned tx) or 9 values (for signed tx).');\n }\n var _a = __read(values, 9),\n nonce = _a[0],\n gasPrice = _a[1],\n gasLimit = _a[2],\n to = _a[3],\n value = _a[4],\n data = _a[5],\n v = _a[6],\n r = _a[7],\n s = _a[8];\n (0, ethereumjs_util_1.validateNoLeadingZeroes)({\n nonce: nonce,\n gasPrice: gasPrice,\n gasLimit: gasLimit,\n value: value,\n v: v,\n r: r,\n s: s\n });\n return new Transaction({\n nonce: nonce,\n gasPrice: gasPrice,\n gasLimit: gasLimit,\n to: to,\n value: value,\n data: data,\n v: v,\n r: r,\n s: s\n }, opts);\n };\n /**\n * Returns a Buffer Array of the raw Buffers of the legacy transaction, in order.\n *\n * Format: `[nonce, gasPrice, gasLimit, to, value, data, v, r, s]`\n *\n * For legacy txs this is also the correct format to add transactions\n * to a block with {@link Block.fromValuesArray} (use the `serialize()` method\n * for typed txs).\n *\n * For an unsigned tx this method returns the empty Buffer values\n * for the signature parameters `v`, `r` and `s`. For an EIP-155 compliant\n * representation have a look at {@link Transaction.getMessageToSign}.\n */\n Transaction.prototype.raw = function () {\n return [(0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.nonce), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.gasPrice), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.gasLimit), this.to !== undefined ? this.to.buf : Buffer.from([]), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.value), this.data, this.v !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.v) : Buffer.from([]), this.r !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.r) : Buffer.from([]), this.s !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.s) : Buffer.from([])];\n };\n /**\n * Returns the serialized encoding of the legacy transaction.\n *\n * Format: `rlp([nonce, gasPrice, gasLimit, to, value, data, v, r, s])`\n *\n * For an unsigned tx this method uses the empty Buffer values for the\n * signature parameters `v`, `r` and `s` for encoding. For an EIP-155 compliant\n * representation for external signing use {@link Transaction.getMessageToSign}.\n */\n Transaction.prototype.serialize = function () {\n return ethereumjs_util_1.rlp.encode(this.raw());\n };\n Transaction.prototype._getMessageToSign = function () {\n var values = [(0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.nonce), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.gasPrice), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.gasLimit), this.to !== undefined ? this.to.buf : Buffer.from([]), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.value), this.data];\n if (this.supports(types_1.Capability.EIP155ReplayProtection)) {\n values.push((0, ethereumjs_util_1.toBuffer)(this.common.chainIdBN()));\n values.push((0, ethereumjs_util_1.unpadBuffer)((0, ethereumjs_util_1.toBuffer)(0)));\n values.push((0, ethereumjs_util_1.unpadBuffer)((0, ethereumjs_util_1.toBuffer)(0)));\n }\n return values;\n };\n Transaction.prototype.getMessageToSign = function (hashMessage) {\n if (hashMessage === void 0) {\n hashMessage = true;\n }\n var message = this._getMessageToSign();\n if (hashMessage) {\n return (0, ethereumjs_util_1.rlphash)(message);\n } else {\n return message;\n }\n };\n /**\n * The amount of gas paid for the data in this tx\n */\n Transaction.prototype.getDataFee = function () {\n if (this.cache.dataFee && this.cache.dataFee.hardfork === this.common.hardfork()) {\n return this.cache.dataFee.value;\n }\n if (Object.isFrozen(this)) {\n this.cache.dataFee = {\n value: _super.prototype.getDataFee.call(this),\n hardfork: this.common.hardfork()\n };\n }\n return _super.prototype.getDataFee.call(this);\n };\n /**\n * The up front amount that an account must have for this transaction to be valid\n */\n Transaction.prototype.getUpfrontCost = function () {\n return this.gasLimit.mul(this.gasPrice).add(this.value);\n };\n /**\n * Computes a sha3-256 hash of the serialized tx.\n *\n * This method can only be used for signed txs (it throws otherwise).\n * Use {@link Transaction.getMessageToSign} to get a tx hash for the purpose of signing.\n */\n Transaction.prototype.hash = function () {\n // In contrast to the tx type transaction implementations the `hash()` function\n // for the legacy tx does not throw if the tx is not signed.\n // This has been considered for inclusion but lead to unexpected backwards\n // compatibility problems (no concrete reference found, needs validation).\n //\n // For context see also https://github.com/ethereumjs/ethereumjs-monorepo/pull/1445,\n // September, 2021 as well as work done before.\n //\n // This should be updated along the next major version release by adding:\n //\n //if (!this.isSigned()) {\n // const msg = this._errorMsg('Cannot call hash method if transaction is not signed')\n // throw new Error(msg)\n //}\n if (Object.isFrozen(this)) {\n if (!this.cache.hash) {\n this.cache.hash = (0, ethereumjs_util_1.rlphash)(this.raw());\n }\n return this.cache.hash;\n }\n return (0, ethereumjs_util_1.rlphash)(this.raw());\n };\n /**\n * Computes a sha3-256 hash which can be used to verify the signature\n */\n Transaction.prototype.getMessageToVerifySignature = function () {\n if (!this.isSigned()) {\n var msg = this._errorMsg('This transaction is not signed');\n throw new Error(msg);\n }\n var message = this._getMessageToSign();\n return (0, ethereumjs_util_1.rlphash)(message);\n };\n /**\n * Returns the public key of the sender\n */\n Transaction.prototype.getSenderPublicKey = function () {\n var _a;\n var msgHash = this.getMessageToVerifySignature();\n // EIP-2: All transaction signatures whose s-value is greater than secp256k1n/2 are considered invalid.\n // Reasoning: https://ethereum.stackexchange.com/a/55728\n if (this.common.gteHardfork('homestead') && ((_a = this.s) === null || _a === void 0 ? void 0 : _a.gt(types_1.N_DIV_2))) {\n var msg = this._errorMsg('Invalid Signature: s-values greater than secp256k1n/2 are considered invalid');\n throw new Error(msg);\n }\n var _b = this,\n v = _b.v,\n r = _b.r,\n s = _b.s;\n try {\n return (0, ethereumjs_util_1.ecrecover)(msgHash, v, (0, ethereumjs_util_1.bnToUnpaddedBuffer)(r), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(s), this.supports(types_1.Capability.EIP155ReplayProtection) ? this.common.chainIdBN() : undefined);\n } catch (e) {\n var msg = this._errorMsg('Invalid Signature');\n throw new Error(msg);\n }\n };\n /**\n * Process the v, r, s values from the `sign` method of the base transaction.\n */\n Transaction.prototype._processSignature = function (v, r, s) {\n var vBN = new ethereumjs_util_1.BN(v);\n if (this.supports(types_1.Capability.EIP155ReplayProtection)) {\n vBN.iadd(this.common.chainIdBN().muln(2).addn(8));\n }\n var opts = __assign(__assign({}, this.txOptions), {\n common: this.common\n });\n return Transaction.fromTxData({\n nonce: this.nonce,\n gasPrice: this.gasPrice,\n gasLimit: this.gasLimit,\n to: this.to,\n value: this.value,\n data: this.data,\n v: vBN,\n r: new ethereumjs_util_1.BN(r),\n s: new ethereumjs_util_1.BN(s)\n }, opts);\n };\n /**\n * Returns an object with the JSON representation of the transaction.\n */\n Transaction.prototype.toJSON = function () {\n return {\n nonce: (0, ethereumjs_util_1.bnToHex)(this.nonce),\n gasPrice: (0, ethereumjs_util_1.bnToHex)(this.gasPrice),\n gasLimit: (0, ethereumjs_util_1.bnToHex)(this.gasLimit),\n to: this.to !== undefined ? this.to.toString() : undefined,\n value: (0, ethereumjs_util_1.bnToHex)(this.value),\n data: '0x' + this.data.toString('hex'),\n v: this.v !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.v) : undefined,\n r: this.r !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.r) : undefined,\n s: this.s !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.s) : undefined\n };\n };\n /**\n * Validates tx's `v` value\n */\n Transaction.prototype._validateTxV = function (v, common) {\n // Check for valid v values in the scope of a signed legacy tx\n if (v !== undefined) {\n // v is 1. not matching the EIP-155 chainId included case and...\n // v is 2. not matching the classic v=27 or v=28 case\n if (v.ltn(37) && !v.eqn(27) && !v.eqn(28)) {\n throw new Error(\"Legacy txs need either v = 27/28 or v >= 37 (EIP-155 replay protection), got v = \".concat(v));\n }\n }\n var chainIdBN;\n // No unsigned tx and EIP-155 activated and chain ID included\n if (v !== undefined && (!common || common.gteHardfork('spuriousDragon')) && !v.eqn(27) && !v.eqn(28)) {\n if (common) {\n var chainIdDoubled = common.chainIdBN().muln(2);\n var isValidEIP155V = v.eq(chainIdDoubled.addn(35)) || v.eq(chainIdDoubled.addn(36));\n if (!isValidEIP155V) {\n throw new Error(\"Incompatible EIP155-based V \".concat(v, \" and chain id \").concat(common.chainIdBN(), \". See the Common parameter of the Transaction constructor to set the chain id.\"));\n }\n } else {\n // Derive the original chain ID\n var numSub = void 0;\n if (v.subn(35).isEven()) {\n numSub = 35;\n } else {\n numSub = 36;\n }\n // Use derived chain ID to create a proper Common\n chainIdBN = v.subn(numSub).divn(2);\n }\n }\n return this._getCommon(common, chainIdBN);\n };\n /**\n * @deprecated if you have called this internal method please use `tx.supports(Capabilities.EIP155ReplayProtection)` instead\n */\n Transaction.prototype._unsignedTxImplementsEIP155 = function () {\n return this.common.gteHardfork('spuriousDragon');\n };\n /**\n * @deprecated if you have called this internal method please use `tx.supports(Capabilities.EIP155ReplayProtection)` instead\n */\n Transaction.prototype._signedTxImplementsEIP155 = function () {\n if (!this.isSigned()) {\n var msg = this._errorMsg('This transaction is not signed');\n throw new Error(msg);\n }\n var onEIP155BlockOrLater = this.common.gteHardfork('spuriousDragon');\n // EIP155 spec:\n // If block.number >= 2,675,000 and v = CHAIN_ID * 2 + 35 or v = CHAIN_ID * 2 + 36, then when computing the hash of a transaction for purposes of signing or recovering, instead of hashing only the first six elements (i.e. nonce, gasprice, startgas, to, value, data), hash nine elements, with v replaced by CHAIN_ID, r = 0 and s = 0.\n var v = this.v;\n var chainIdDoubled = this.common.chainIdBN().muln(2);\n var vAndChainIdMeetEIP155Conditions = v.eq(chainIdDoubled.addn(35)) || v.eq(chainIdDoubled.addn(36));\n return vAndChainIdMeetEIP155Conditions && onEIP155BlockOrLater;\n };\n /**\n * Return a compact error string representation of the object\n */\n Transaction.prototype.errorStr = function () {\n var errorStr = this._getSharedErrorPostfix();\n errorStr += \" gasPrice=\".concat(this.gasPrice);\n return errorStr;\n };\n /**\n * Internal helper function to create an annotated error message\n *\n * @param msg Base error message\n * @hidden\n */\n Transaction.prototype._errorMsg = function (msg) {\n return \"\".concat(msg, \" (\").concat(this.errorStr(), \")\");\n };\n return Transaction;\n}(baseTransaction_1.BaseTransaction);\nexports.default = Transaction;\n","\"use strict\";\n\nvar __extends = this && this.__extends || function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __read = this && this.__read || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar baseTransaction_1 = require(\"./baseTransaction\");\nvar types_1 = require(\"./types\");\nvar util_1 = require(\"./util\");\nvar TRANSACTION_TYPE = 1;\nvar TRANSACTION_TYPE_BUFFER = Buffer.from(TRANSACTION_TYPE.toString(16).padStart(2, '0'), 'hex');\n/**\n * Typed transaction with optional access lists\n *\n * - TransactionType: 1\n * - EIP: [EIP-2930](https://eips.ethereum.org/EIPS/eip-2930)\n */\nvar AccessListEIP2930Transaction = /** @class */function (_super) {\n __extends(AccessListEIP2930Transaction, _super);\n /**\n * This constructor takes the values, validates them, assigns them and freezes the object.\n *\n * It is not recommended to use this constructor directly. Instead use\n * the static factory methods to assist in creating a Transaction object from\n * varying data types.\n */\n function AccessListEIP2930Transaction(txData, opts) {\n if (opts === void 0) {\n opts = {};\n }\n var _this = this;\n var _a, _b;\n _this = _super.call(this, __assign(__assign({}, txData), {\n type: TRANSACTION_TYPE\n }), opts) || this;\n /**\n * The default HF if the tx type is active on that HF\n * or the first greater HF where the tx is active.\n *\n * @hidden\n */\n _this.DEFAULT_HARDFORK = 'berlin';\n var chainId = txData.chainId,\n accessList = txData.accessList,\n gasPrice = txData.gasPrice;\n _this.common = _this._getCommon(opts.common, chainId);\n _this.chainId = _this.common.chainIdBN();\n // EIP-2718 check is done in Common\n if (!_this.common.isActivatedEIP(2930)) {\n throw new Error('EIP-2930 not enabled on Common');\n }\n _this.activeCapabilities = _this.activeCapabilities.concat([2718, 2930]);\n // Populate the access list fields\n var accessListData = util_1.AccessLists.getAccessListData(accessList !== null && accessList !== void 0 ? accessList : []);\n _this.accessList = accessListData.accessList;\n _this.AccessListJSON = accessListData.AccessListJSON;\n // Verify the access list format.\n util_1.AccessLists.verifyAccessList(_this.accessList);\n _this.gasPrice = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(gasPrice === '' ? '0x' : gasPrice));\n _this._validateCannotExceedMaxInteger({\n gasPrice: _this.gasPrice\n });\n if (_this.gasPrice.mul(_this.gasLimit).gt(ethereumjs_util_1.MAX_INTEGER)) {\n var msg = _this._errorMsg('gasLimit * gasPrice cannot exceed MAX_INTEGER');\n throw new Error(msg);\n }\n if (_this.v && !_this.v.eqn(0) && !_this.v.eqn(1)) {\n var msg = _this._errorMsg('The y-parity of the transaction should either be 0 or 1');\n throw new Error(msg);\n }\n if (_this.common.gteHardfork('homestead') && ((_a = _this.s) === null || _a === void 0 ? void 0 : _a.gt(types_1.N_DIV_2))) {\n var msg = _this._errorMsg('Invalid Signature: s-values greater than secp256k1n/2 are considered invalid');\n throw new Error(msg);\n }\n if (_this.common.isActivatedEIP(3860)) {\n (0, util_1.checkMaxInitCodeSize)(_this.common, _this.data.length);\n }\n var freeze = (_b = opts === null || opts === void 0 ? void 0 : opts.freeze) !== null && _b !== void 0 ? _b : true;\n if (freeze) {\n Object.freeze(_this);\n }\n return _this;\n }\n Object.defineProperty(AccessListEIP2930Transaction.prototype, \"senderR\", {\n /**\n * EIP-2930 alias for `r`\n *\n * @deprecated use `r` instead\n */\n get: function () {\n return this.r;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(AccessListEIP2930Transaction.prototype, \"senderS\", {\n /**\n * EIP-2930 alias for `s`\n *\n * @deprecated use `s` instead\n */\n get: function () {\n return this.s;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(AccessListEIP2930Transaction.prototype, \"yParity\", {\n /**\n * EIP-2930 alias for `v`\n *\n * @deprecated use `v` instead\n */\n get: function () {\n return this.v;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Instantiate a transaction from a data dictionary.\n *\n * Format: { chainId, nonce, gasPrice, gasLimit, to, value, data, accessList,\n * v, r, s }\n *\n * Notes:\n * - `chainId` will be set automatically if not provided\n * - All parameters are optional and have some basic default values\n */\n AccessListEIP2930Transaction.fromTxData = function (txData, opts) {\n if (opts === void 0) {\n opts = {};\n }\n return new AccessListEIP2930Transaction(txData, opts);\n };\n /**\n * Instantiate a transaction from the serialized tx.\n *\n * Format: `0x01 || rlp([chainId, nonce, gasPrice, gasLimit, to, value, data, accessList,\n * signatureYParity (v), signatureR (r), signatureS (s)])`\n */\n AccessListEIP2930Transaction.fromSerializedTx = function (serialized, opts) {\n if (opts === void 0) {\n opts = {};\n }\n if (!serialized.slice(0, 1).equals(TRANSACTION_TYPE_BUFFER)) {\n throw new Error(\"Invalid serialized tx input: not an EIP-2930 transaction (wrong tx type, expected: \".concat(TRANSACTION_TYPE, \", received: \").concat(serialized.slice(0, 1).toString('hex')));\n }\n var values = ethereumjs_util_1.rlp.decode(serialized.slice(1));\n if (!Array.isArray(values)) {\n throw new Error('Invalid serialized tx input: must be array');\n }\n return AccessListEIP2930Transaction.fromValuesArray(values, opts);\n };\n /**\n * Instantiate a transaction from the serialized tx.\n * (alias of {@link AccessListEIP2930Transaction.fromSerializedTx})\n *\n * Note: This means that the Buffer should start with 0x01.\n *\n * @deprecated this constructor alias is deprecated and will be removed\n * in favor of the {@link AccessListEIP2930Transaction.fromSerializedTx} constructor\n */\n AccessListEIP2930Transaction.fromRlpSerializedTx = function (serialized, opts) {\n if (opts === void 0) {\n opts = {};\n }\n return AccessListEIP2930Transaction.fromSerializedTx(serialized, opts);\n };\n /**\n * Create a transaction from a values array.\n *\n * Format: `[chainId, nonce, gasPrice, gasLimit, to, value, data, accessList,\n * signatureYParity (v), signatureR (r), signatureS (s)]`\n */\n AccessListEIP2930Transaction.fromValuesArray = function (values, opts) {\n if (opts === void 0) {\n opts = {};\n }\n if (values.length !== 8 && values.length !== 11) {\n throw new Error('Invalid EIP-2930 transaction. Only expecting 8 values (for unsigned tx) or 11 values (for signed tx).');\n }\n var _a = __read(values, 11),\n chainId = _a[0],\n nonce = _a[1],\n gasPrice = _a[2],\n gasLimit = _a[3],\n to = _a[4],\n value = _a[5],\n data = _a[6],\n accessList = _a[7],\n v = _a[8],\n r = _a[9],\n s = _a[10];\n (0, ethereumjs_util_1.validateNoLeadingZeroes)({\n nonce: nonce,\n gasPrice: gasPrice,\n gasLimit: gasLimit,\n value: value,\n v: v,\n r: r,\n s: s\n });\n var emptyAccessList = [];\n return new AccessListEIP2930Transaction({\n chainId: new ethereumjs_util_1.BN(chainId),\n nonce: nonce,\n gasPrice: gasPrice,\n gasLimit: gasLimit,\n to: to,\n value: value,\n data: data,\n accessList: accessList !== null && accessList !== void 0 ? accessList : emptyAccessList,\n v: v !== undefined ? new ethereumjs_util_1.BN(v) : undefined,\n r: r,\n s: s\n }, opts);\n };\n /**\n * The amount of gas paid for the data in this tx\n */\n AccessListEIP2930Transaction.prototype.getDataFee = function () {\n if (this.cache.dataFee && this.cache.dataFee.hardfork === this.common.hardfork()) {\n return this.cache.dataFee.value;\n }\n var cost = _super.prototype.getDataFee.call(this);\n cost.iaddn(util_1.AccessLists.getDataFeeEIP2930(this.accessList, this.common));\n if (Object.isFrozen(this)) {\n this.cache.dataFee = {\n value: cost,\n hardfork: this.common.hardfork()\n };\n }\n return cost;\n };\n /**\n * The up front amount that an account must have for this transaction to be valid\n */\n AccessListEIP2930Transaction.prototype.getUpfrontCost = function () {\n return this.gasLimit.mul(this.gasPrice).add(this.value);\n };\n /**\n * Returns a Buffer Array of the raw Buffers of the EIP-2930 transaction, in order.\n *\n * Format: `[chainId, nonce, gasPrice, gasLimit, to, value, data, accessList,\n * signatureYParity (v), signatureR (r), signatureS (s)]`\n *\n * Use {@link AccessListEIP2930Transaction.serialize} to add a transaction to a block\n * with {@link Block.fromValuesArray}.\n *\n * For an unsigned tx this method uses the empty Buffer values for the\n * signature parameters `v`, `r` and `s` for encoding. For an EIP-155 compliant\n * representation for external signing use {@link AccessListEIP2930Transaction.getMessageToSign}.\n */\n AccessListEIP2930Transaction.prototype.raw = function () {\n return [(0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.chainId), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.nonce), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.gasPrice), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.gasLimit), this.to !== undefined ? this.to.buf : Buffer.from([]), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.value), this.data, this.accessList, this.v !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.v) : Buffer.from([]), this.r !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.r) : Buffer.from([]), this.s !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.s) : Buffer.from([])];\n };\n /**\n * Returns the serialized encoding of the EIP-2930 transaction.\n *\n * Format: `0x01 || rlp([chainId, nonce, gasPrice, gasLimit, to, value, data, accessList,\n * signatureYParity (v), signatureR (r), signatureS (s)])`\n *\n * Note that in contrast to the legacy tx serialization format this is not\n * valid RLP any more due to the raw tx type preceding and concatenated to\n * the RLP encoding of the values.\n */\n AccessListEIP2930Transaction.prototype.serialize = function () {\n var base = this.raw();\n return Buffer.concat([TRANSACTION_TYPE_BUFFER, ethereumjs_util_1.rlp.encode(base)]);\n };\n /**\n * Returns the serialized unsigned tx (hashed or raw), which can be used\n * to sign the transaction (e.g. for sending to a hardware wallet).\n *\n * Note: in contrast to the legacy tx the raw message format is already\n * serialized and doesn't need to be RLP encoded any more.\n *\n * ```javascript\n * const serializedMessage = tx.getMessageToSign(false) // use this for the HW wallet input\n * ```\n *\n * @param hashMessage - Return hashed message if set to true (default: true)\n */\n AccessListEIP2930Transaction.prototype.getMessageToSign = function (hashMessage) {\n if (hashMessage === void 0) {\n hashMessage = true;\n }\n var base = this.raw().slice(0, 8);\n var message = Buffer.concat([TRANSACTION_TYPE_BUFFER, ethereumjs_util_1.rlp.encode(base)]);\n if (hashMessage) {\n return (0, ethereumjs_util_1.keccak256)(message);\n } else {\n return message;\n }\n };\n /**\n * Computes a sha3-256 hash of the serialized tx.\n *\n * This method can only be used for signed txs (it throws otherwise).\n * Use {@link AccessListEIP2930Transaction.getMessageToSign} to get a tx hash for the purpose of signing.\n */\n AccessListEIP2930Transaction.prototype.hash = function () {\n if (!this.isSigned()) {\n var msg = this._errorMsg('Cannot call hash method if transaction is not signed');\n throw new Error(msg);\n }\n if (Object.isFrozen(this)) {\n if (!this.cache.hash) {\n this.cache.hash = (0, ethereumjs_util_1.keccak256)(this.serialize());\n }\n return this.cache.hash;\n }\n return (0, ethereumjs_util_1.keccak256)(this.serialize());\n };\n /**\n * Computes a sha3-256 hash which can be used to verify the signature\n */\n AccessListEIP2930Transaction.prototype.getMessageToVerifySignature = function () {\n return this.getMessageToSign();\n };\n /**\n * Returns the public key of the sender\n */\n AccessListEIP2930Transaction.prototype.getSenderPublicKey = function () {\n var _a;\n if (!this.isSigned()) {\n var msg = this._errorMsg('Cannot call this method if transaction is not signed');\n throw new Error(msg);\n }\n var msgHash = this.getMessageToVerifySignature();\n // EIP-2: All transaction signatures whose s-value is greater than secp256k1n/2 are considered invalid.\n // Reasoning: https://ethereum.stackexchange.com/a/55728\n if (this.common.gteHardfork('homestead') && ((_a = this.s) === null || _a === void 0 ? void 0 : _a.gt(types_1.N_DIV_2))) {\n var msg = this._errorMsg('Invalid Signature: s-values greater than secp256k1n/2 are considered invalid');\n throw new Error(msg);\n }\n var _b = this,\n yParity = _b.yParity,\n r = _b.r,\n s = _b.s;\n try {\n return (0, ethereumjs_util_1.ecrecover)(msgHash, yParity.addn(27),\n // Recover the 27 which was stripped from ecsign\n (0, ethereumjs_util_1.bnToUnpaddedBuffer)(r), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(s));\n } catch (e) {\n var msg = this._errorMsg('Invalid Signature');\n throw new Error(msg);\n }\n };\n AccessListEIP2930Transaction.prototype._processSignature = function (v, r, s) {\n var opts = __assign(__assign({}, this.txOptions), {\n common: this.common\n });\n return AccessListEIP2930Transaction.fromTxData({\n chainId: this.chainId,\n nonce: this.nonce,\n gasPrice: this.gasPrice,\n gasLimit: this.gasLimit,\n to: this.to,\n value: this.value,\n data: this.data,\n accessList: this.accessList,\n v: new ethereumjs_util_1.BN(v - 27),\n r: new ethereumjs_util_1.BN(r),\n s: new ethereumjs_util_1.BN(s)\n }, opts);\n };\n /**\n * Returns an object with the JSON representation of the transaction\n */\n AccessListEIP2930Transaction.prototype.toJSON = function () {\n var accessListJSON = util_1.AccessLists.getAccessListJSON(this.accessList);\n return {\n chainId: (0, ethereumjs_util_1.bnToHex)(this.chainId),\n nonce: (0, ethereumjs_util_1.bnToHex)(this.nonce),\n gasPrice: (0, ethereumjs_util_1.bnToHex)(this.gasPrice),\n gasLimit: (0, ethereumjs_util_1.bnToHex)(this.gasLimit),\n to: this.to !== undefined ? this.to.toString() : undefined,\n value: (0, ethereumjs_util_1.bnToHex)(this.value),\n data: '0x' + this.data.toString('hex'),\n accessList: accessListJSON,\n v: this.v !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.v) : undefined,\n r: this.r !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.r) : undefined,\n s: this.s !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.s) : undefined\n };\n };\n /**\n * Return a compact error string representation of the object\n */\n AccessListEIP2930Transaction.prototype.errorStr = function () {\n var _a, _b;\n var errorStr = this._getSharedErrorPostfix();\n // Keep ? for this.accessList since this otherwise causes Hardhat E2E tests to fail\n errorStr += \" gasPrice=\".concat(this.gasPrice, \" accessListCount=\").concat((_b = (_a = this.accessList) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0);\n return errorStr;\n };\n /**\n * Internal helper function to create an annotated error message\n *\n * @param msg Base error message\n * @hidden\n */\n AccessListEIP2930Transaction.prototype._errorMsg = function (msg) {\n return \"\".concat(msg, \" (\").concat(this.errorStr(), \")\");\n };\n return AccessListEIP2930Transaction;\n}(baseTransaction_1.BaseTransaction);\nexports.default = AccessListEIP2930Transaction;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar _1 = require(\".\");\nvar TransactionFactory = /** @class */function () {\n // It is not possible to instantiate a TransactionFactory object.\n function TransactionFactory() {}\n /**\n * Create a transaction from a `txData` object\n *\n * @param txData - The transaction data. The `type` field will determine which transaction type is returned (if undefined, creates a legacy transaction)\n * @param txOptions - Options to pass on to the constructor of the transaction\n */\n TransactionFactory.fromTxData = function (txData, txOptions) {\n if (txOptions === void 0) {\n txOptions = {};\n }\n if (!('type' in txData) || txData.type === undefined) {\n // Assume legacy transaction\n return _1.Transaction.fromTxData(txData, txOptions);\n } else {\n var txType = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(txData.type)).toNumber();\n if (txType === 0) {\n return _1.Transaction.fromTxData(txData, txOptions);\n } else if (txType === 1) {\n return _1.AccessListEIP2930Transaction.fromTxData(txData, txOptions);\n } else if (txType === 2) {\n return _1.FeeMarketEIP1559Transaction.fromTxData(txData, txOptions);\n } else {\n throw new Error(\"Tx instantiation with type \".concat(txType, \" not supported\"));\n }\n }\n };\n /**\n * This method tries to decode serialized data.\n *\n * @param data - The data Buffer\n * @param txOptions - The transaction options\n */\n TransactionFactory.fromSerializedData = function (data, txOptions) {\n if (txOptions === void 0) {\n txOptions = {};\n }\n if (data[0] <= 0x7f) {\n // Determine the type.\n var EIP = void 0;\n switch (data[0]) {\n case 1:\n EIP = 2930;\n break;\n case 2:\n EIP = 1559;\n break;\n default:\n throw new Error(\"TypedTransaction with ID \".concat(data[0], \" unknown\"));\n }\n if (EIP === 1559) {\n return _1.FeeMarketEIP1559Transaction.fromSerializedTx(data, txOptions);\n } else {\n // EIP === 2930\n return _1.AccessListEIP2930Transaction.fromSerializedTx(data, txOptions);\n }\n } else {\n return _1.Transaction.fromSerializedTx(data, txOptions);\n }\n };\n /**\n * When decoding a BlockBody, in the transactions field, a field is either:\n * A Buffer (a TypedTransaction - encoded as TransactionType || rlp(TransactionPayload))\n * A Buffer[] (Legacy Transaction)\n * This method returns the right transaction.\n *\n * @param data - A Buffer or Buffer[]\n * @param txOptions - The transaction options\n */\n TransactionFactory.fromBlockBodyData = function (data, txOptions) {\n if (txOptions === void 0) {\n txOptions = {};\n }\n if (Buffer.isBuffer(data)) {\n return this.fromSerializedData(data, txOptions);\n } else if (Array.isArray(data)) {\n // It is a legacy transaction\n return _1.Transaction.fromValuesArray(data, txOptions);\n } else {\n throw new Error('Cannot decode transaction: unknown type input');\n }\n };\n /**\n * This helper method allows one to retrieve the class which matches the transactionID\n * If transactionID is undefined, returns the legacy transaction class.\n * @deprecated - This method is deprecated and will be removed on the next major release\n * @param transactionID\n * @param _common - This option is not used\n */\n TransactionFactory.getTransactionClass = function (transactionID, _common) {\n if (transactionID === void 0) {\n transactionID = 0;\n }\n var legacyTxn = transactionID == 0 || transactionID >= 0x80 && transactionID <= 0xff;\n if (legacyTxn) {\n return _1.Transaction;\n }\n switch (transactionID) {\n case 1:\n return _1.AccessListEIP2930Transaction;\n case 2:\n return _1.FeeMarketEIP1559Transaction;\n default:\n throw new Error(\"TypedTransaction with ID \".concat(transactionID, \" unknown\"));\n }\n };\n return TransactionFactory;\n}();\nexports.default = TransactionFactory;\n","\"use strict\";\n\nvar __extends = this && this.__extends || function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n}();\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __read = this && this.__read || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar baseTransaction_1 = require(\"./baseTransaction\");\nvar types_1 = require(\"./types\");\nvar util_1 = require(\"./util\");\nvar TRANSACTION_TYPE = 2;\nvar TRANSACTION_TYPE_BUFFER = Buffer.from(TRANSACTION_TYPE.toString(16).padStart(2, '0'), 'hex');\n/**\n * Typed transaction with a new gas fee market mechanism\n *\n * - TransactionType: 2\n * - EIP: [EIP-1559](https://eips.ethereum.org/EIPS/eip-1559)\n */\nvar FeeMarketEIP1559Transaction = /** @class */function (_super) {\n __extends(FeeMarketEIP1559Transaction, _super);\n /**\n * This constructor takes the values, validates them, assigns them and freezes the object.\n *\n * It is not recommended to use this constructor directly. Instead use\n * the static factory methods to assist in creating a Transaction object from\n * varying data types.\n */\n function FeeMarketEIP1559Transaction(txData, opts) {\n if (opts === void 0) {\n opts = {};\n }\n var _this = this;\n var _a, _b;\n _this = _super.call(this, __assign(__assign({}, txData), {\n type: TRANSACTION_TYPE\n }), opts) || this;\n /**\n * The default HF if the tx type is active on that HF\n * or the first greater HF where the tx is active.\n *\n * @hidden\n */\n _this.DEFAULT_HARDFORK = 'london';\n var chainId = txData.chainId,\n accessList = txData.accessList,\n maxFeePerGas = txData.maxFeePerGas,\n maxPriorityFeePerGas = txData.maxPriorityFeePerGas;\n _this.common = _this._getCommon(opts.common, chainId);\n _this.chainId = _this.common.chainIdBN();\n if (!_this.common.isActivatedEIP(1559)) {\n throw new Error('EIP-1559 not enabled on Common');\n }\n _this.activeCapabilities = _this.activeCapabilities.concat([1559, 2718, 2930]);\n // Populate the access list fields\n var accessListData = util_1.AccessLists.getAccessListData(accessList !== null && accessList !== void 0 ? accessList : []);\n _this.accessList = accessListData.accessList;\n _this.AccessListJSON = accessListData.AccessListJSON;\n // Verify the access list format.\n util_1.AccessLists.verifyAccessList(_this.accessList);\n _this.maxFeePerGas = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(maxFeePerGas === '' ? '0x' : maxFeePerGas));\n _this.maxPriorityFeePerGas = new ethereumjs_util_1.BN((0, ethereumjs_util_1.toBuffer)(maxPriorityFeePerGas === '' ? '0x' : maxPriorityFeePerGas));\n _this._validateCannotExceedMaxInteger({\n maxFeePerGas: _this.maxFeePerGas,\n maxPriorityFeePerGas: _this.maxPriorityFeePerGas\n });\n if (_this.gasLimit.mul(_this.maxFeePerGas).gt(ethereumjs_util_1.MAX_INTEGER)) {\n var msg = _this._errorMsg('gasLimit * maxFeePerGas cannot exceed MAX_INTEGER (2^256-1)');\n throw new Error(msg);\n }\n if (_this.maxFeePerGas.lt(_this.maxPriorityFeePerGas)) {\n var msg = _this._errorMsg('maxFeePerGas cannot be less than maxPriorityFeePerGas (The total must be the larger of the two)');\n throw new Error(msg);\n }\n if (_this.v && !_this.v.eqn(0) && !_this.v.eqn(1)) {\n var msg = _this._errorMsg('The y-parity of the transaction should either be 0 or 1');\n throw new Error(msg);\n }\n if (_this.common.gteHardfork('homestead') && ((_a = _this.s) === null || _a === void 0 ? void 0 : _a.gt(types_1.N_DIV_2))) {\n var msg = _this._errorMsg('Invalid Signature: s-values greater than secp256k1n/2 are considered invalid');\n throw new Error(msg);\n }\n if (_this.common.isActivatedEIP(3860)) {\n (0, util_1.checkMaxInitCodeSize)(_this.common, _this.data.length);\n }\n var freeze = (_b = opts === null || opts === void 0 ? void 0 : opts.freeze) !== null && _b !== void 0 ? _b : true;\n if (freeze) {\n Object.freeze(_this);\n }\n return _this;\n }\n Object.defineProperty(FeeMarketEIP1559Transaction.prototype, \"senderR\", {\n /**\n * EIP-2930 alias for `r`\n *\n * @deprecated use `r` instead\n */\n get: function () {\n return this.r;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(FeeMarketEIP1559Transaction.prototype, \"senderS\", {\n /**\n * EIP-2930 alias for `s`\n *\n * @deprecated use `s` instead\n */\n get: function () {\n return this.s;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(FeeMarketEIP1559Transaction.prototype, \"yParity\", {\n /**\n * EIP-2930 alias for `v`\n *\n * @deprecated use `v` instead\n */\n get: function () {\n return this.v;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Instantiate a transaction from a data dictionary.\n *\n * Format: { chainId, nonce, maxPriorityFeePerGas, maxFeePerGas, gasLimit, to, value, data,\n * accessList, v, r, s }\n *\n * Notes:\n * - `chainId` will be set automatically if not provided\n * - All parameters are optional and have some basic default values\n */\n FeeMarketEIP1559Transaction.fromTxData = function (txData, opts) {\n if (opts === void 0) {\n opts = {};\n }\n return new FeeMarketEIP1559Transaction(txData, opts);\n };\n /**\n * Instantiate a transaction from the serialized tx.\n *\n * Format: `0x02 || rlp([chainId, nonce, maxPriorityFeePerGas, maxFeePerGas, gasLimit, to, value, data,\n * accessList, signatureYParity, signatureR, signatureS])`\n */\n FeeMarketEIP1559Transaction.fromSerializedTx = function (serialized, opts) {\n if (opts === void 0) {\n opts = {};\n }\n if (!serialized.slice(0, 1).equals(TRANSACTION_TYPE_BUFFER)) {\n throw new Error(\"Invalid serialized tx input: not an EIP-1559 transaction (wrong tx type, expected: \".concat(TRANSACTION_TYPE, \", received: \").concat(serialized.slice(0, 1).toString('hex')));\n }\n var values = ethereumjs_util_1.rlp.decode(serialized.slice(1));\n if (!Array.isArray(values)) {\n throw new Error('Invalid serialized tx input: must be array');\n }\n return FeeMarketEIP1559Transaction.fromValuesArray(values, opts);\n };\n /**\n * Instantiate a transaction from the serialized tx.\n * (alias of {@link FeeMarketEIP1559Transaction.fromSerializedTx})\n *\n * Note: This means that the Buffer should start with 0x01.\n *\n * @deprecated this constructor alias is deprecated and will be removed\n * in favor of the {@link FeeMarketEIP1559Transaction.fromSerializedTx} constructor\n */\n FeeMarketEIP1559Transaction.fromRlpSerializedTx = function (serialized, opts) {\n if (opts === void 0) {\n opts = {};\n }\n return FeeMarketEIP1559Transaction.fromSerializedTx(serialized, opts);\n };\n /**\n * Create a transaction from a values array.\n *\n * Format: `[chainId, nonce, maxPriorityFeePerGas, maxFeePerGas, gasLimit, to, value, data,\n * accessList, signatureYParity, signatureR, signatureS]`\n */\n FeeMarketEIP1559Transaction.fromValuesArray = function (values, opts) {\n if (opts === void 0) {\n opts = {};\n }\n if (values.length !== 9 && values.length !== 12) {\n throw new Error('Invalid EIP-1559 transaction. Only expecting 9 values (for unsigned tx) or 12 values (for signed tx).');\n }\n var _a = __read(values, 12),\n chainId = _a[0],\n nonce = _a[1],\n maxPriorityFeePerGas = _a[2],\n maxFeePerGas = _a[3],\n gasLimit = _a[4],\n to = _a[5],\n value = _a[6],\n data = _a[7],\n accessList = _a[8],\n v = _a[9],\n r = _a[10],\n s = _a[11];\n (0, ethereumjs_util_1.validateNoLeadingZeroes)({\n nonce: nonce,\n maxPriorityFeePerGas: maxPriorityFeePerGas,\n maxFeePerGas: maxFeePerGas,\n gasLimit: gasLimit,\n value: value,\n v: v,\n r: r,\n s: s\n });\n return new FeeMarketEIP1559Transaction({\n chainId: new ethereumjs_util_1.BN(chainId),\n nonce: nonce,\n maxPriorityFeePerGas: maxPriorityFeePerGas,\n maxFeePerGas: maxFeePerGas,\n gasLimit: gasLimit,\n to: to,\n value: value,\n data: data,\n accessList: accessList !== null && accessList !== void 0 ? accessList : [],\n v: v !== undefined ? new ethereumjs_util_1.BN(v) : undefined,\n r: r,\n s: s\n }, opts);\n };\n /**\n * The amount of gas paid for the data in this tx\n */\n FeeMarketEIP1559Transaction.prototype.getDataFee = function () {\n if (this.cache.dataFee && this.cache.dataFee.hardfork === this.common.hardfork()) {\n return this.cache.dataFee.value;\n }\n var cost = _super.prototype.getDataFee.call(this);\n cost.iaddn(util_1.AccessLists.getDataFeeEIP2930(this.accessList, this.common));\n if (Object.isFrozen(this)) {\n this.cache.dataFee = {\n value: cost,\n hardfork: this.common.hardfork()\n };\n }\n return cost;\n };\n /**\n * The up front amount that an account must have for this transaction to be valid\n * @param baseFee The base fee of the block (will be set to 0 if not provided)\n */\n FeeMarketEIP1559Transaction.prototype.getUpfrontCost = function (baseFee) {\n if (baseFee === void 0) {\n baseFee = new ethereumjs_util_1.BN(0);\n }\n var inclusionFeePerGas = ethereumjs_util_1.BN.min(this.maxPriorityFeePerGas, this.maxFeePerGas.sub(baseFee));\n var gasPrice = inclusionFeePerGas.add(baseFee);\n return this.gasLimit.mul(gasPrice).add(this.value);\n };\n /**\n * Returns a Buffer Array of the raw Buffers of the EIP-1559 transaction, in order.\n *\n * Format: `[chainId, nonce, maxPriorityFeePerGas, maxFeePerGas, gasLimit, to, value, data,\n * accessList, signatureYParity, signatureR, signatureS]`\n *\n * Use {@link FeeMarketEIP1559Transaction.serialize} to add a transaction to a block\n * with {@link Block.fromValuesArray}.\n *\n * For an unsigned tx this method uses the empty Buffer values for the\n * signature parameters `v`, `r` and `s` for encoding. For an EIP-155 compliant\n * representation for external signing use {@link FeeMarketEIP1559Transaction.getMessageToSign}.\n */\n FeeMarketEIP1559Transaction.prototype.raw = function () {\n return [(0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.chainId), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.nonce), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.maxPriorityFeePerGas), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.maxFeePerGas), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.gasLimit), this.to !== undefined ? this.to.buf : Buffer.from([]), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.value), this.data, this.accessList, this.v !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.v) : Buffer.from([]), this.r !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.r) : Buffer.from([]), this.s !== undefined ? (0, ethereumjs_util_1.bnToUnpaddedBuffer)(this.s) : Buffer.from([])];\n };\n /**\n * Returns the serialized encoding of the EIP-1559 transaction.\n *\n * Format: `0x02 || rlp([chainId, nonce, maxPriorityFeePerGas, maxFeePerGas, gasLimit, to, value, data,\n * accessList, signatureYParity, signatureR, signatureS])`\n *\n * Note that in contrast to the legacy tx serialization format this is not\n * valid RLP any more due to the raw tx type preceding and concatenated to\n * the RLP encoding of the values.\n */\n FeeMarketEIP1559Transaction.prototype.serialize = function () {\n var base = this.raw();\n return Buffer.concat([TRANSACTION_TYPE_BUFFER, ethereumjs_util_1.rlp.encode(base)]);\n };\n /**\n * Returns the serialized unsigned tx (hashed or raw), which can be used\n * to sign the transaction (e.g. for sending to a hardware wallet).\n *\n * Note: in contrast to the legacy tx the raw message format is already\n * serialized and doesn't need to be RLP encoded any more.\n *\n * ```javascript\n * const serializedMessage = tx.getMessageToSign(false) // use this for the HW wallet input\n * ```\n *\n * @param hashMessage - Return hashed message if set to true (default: true)\n */\n FeeMarketEIP1559Transaction.prototype.getMessageToSign = function (hashMessage) {\n if (hashMessage === void 0) {\n hashMessage = true;\n }\n var base = this.raw().slice(0, 9);\n var message = Buffer.concat([TRANSACTION_TYPE_BUFFER, ethereumjs_util_1.rlp.encode(base)]);\n if (hashMessage) {\n return (0, ethereumjs_util_1.keccak256)(message);\n } else {\n return message;\n }\n };\n /**\n * Computes a sha3-256 hash of the serialized tx.\n *\n * This method can only be used for signed txs (it throws otherwise).\n * Use {@link FeeMarketEIP1559Transaction.getMessageToSign} to get a tx hash for the purpose of signing.\n */\n FeeMarketEIP1559Transaction.prototype.hash = function () {\n if (!this.isSigned()) {\n var msg = this._errorMsg('Cannot call hash method if transaction is not signed');\n throw new Error(msg);\n }\n if (Object.isFrozen(this)) {\n if (!this.cache.hash) {\n this.cache.hash = (0, ethereumjs_util_1.keccak256)(this.serialize());\n }\n return this.cache.hash;\n }\n return (0, ethereumjs_util_1.keccak256)(this.serialize());\n };\n /**\n * Computes a sha3-256 hash which can be used to verify the signature\n */\n FeeMarketEIP1559Transaction.prototype.getMessageToVerifySignature = function () {\n return this.getMessageToSign();\n };\n /**\n * Returns the public key of the sender\n */\n FeeMarketEIP1559Transaction.prototype.getSenderPublicKey = function () {\n var _a;\n if (!this.isSigned()) {\n var msg = this._errorMsg('Cannot call this method if transaction is not signed');\n throw new Error(msg);\n }\n var msgHash = this.getMessageToVerifySignature();\n // EIP-2: All transaction signatures whose s-value is greater than secp256k1n/2 are considered invalid.\n // Reasoning: https://ethereum.stackexchange.com/a/55728\n if (this.common.gteHardfork('homestead') && ((_a = this.s) === null || _a === void 0 ? void 0 : _a.gt(types_1.N_DIV_2))) {\n var msg = this._errorMsg('Invalid Signature: s-values greater than secp256k1n/2 are considered invalid');\n throw new Error(msg);\n }\n var _b = this,\n v = _b.v,\n r = _b.r,\n s = _b.s;\n try {\n return (0, ethereumjs_util_1.ecrecover)(msgHash, v.addn(27),\n // Recover the 27 which was stripped from ecsign\n (0, ethereumjs_util_1.bnToUnpaddedBuffer)(r), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(s));\n } catch (e) {\n var msg = this._errorMsg('Invalid Signature');\n throw new Error(msg);\n }\n };\n FeeMarketEIP1559Transaction.prototype._processSignature = function (v, r, s) {\n var opts = __assign(__assign({}, this.txOptions), {\n common: this.common\n });\n return FeeMarketEIP1559Transaction.fromTxData({\n chainId: this.chainId,\n nonce: this.nonce,\n maxPriorityFeePerGas: this.maxPriorityFeePerGas,\n maxFeePerGas: this.maxFeePerGas,\n gasLimit: this.gasLimit,\n to: this.to,\n value: this.value,\n data: this.data,\n accessList: this.accessList,\n v: new ethereumjs_util_1.BN(v - 27),\n r: new ethereumjs_util_1.BN(r),\n s: new ethereumjs_util_1.BN(s)\n }, opts);\n };\n /**\n * Returns an object with the JSON representation of the transaction\n */\n FeeMarketEIP1559Transaction.prototype.toJSON = function () {\n var accessListJSON = util_1.AccessLists.getAccessListJSON(this.accessList);\n return {\n chainId: (0, ethereumjs_util_1.bnToHex)(this.chainId),\n nonce: (0, ethereumjs_util_1.bnToHex)(this.nonce),\n maxPriorityFeePerGas: (0, ethereumjs_util_1.bnToHex)(this.maxPriorityFeePerGas),\n maxFeePerGas: (0, ethereumjs_util_1.bnToHex)(this.maxFeePerGas),\n gasLimit: (0, ethereumjs_util_1.bnToHex)(this.gasLimit),\n to: this.to !== undefined ? this.to.toString() : undefined,\n value: (0, ethereumjs_util_1.bnToHex)(this.value),\n data: '0x' + this.data.toString('hex'),\n accessList: accessListJSON,\n v: this.v !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.v) : undefined,\n r: this.r !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.r) : undefined,\n s: this.s !== undefined ? (0, ethereumjs_util_1.bnToHex)(this.s) : undefined\n };\n };\n /**\n * Return a compact error string representation of the object\n */\n FeeMarketEIP1559Transaction.prototype.errorStr = function () {\n var errorStr = this._getSharedErrorPostfix();\n errorStr += \" maxFeePerGas=\".concat(this.maxFeePerGas, \" maxPriorityFeePerGas=\").concat(this.maxPriorityFeePerGas);\n return errorStr;\n };\n /**\n * Internal helper function to create an annotated error message\n *\n * @param msg Base error message\n * @hidden\n */\n FeeMarketEIP1559Transaction.prototype._errorMsg = function (msg) {\n return \"\".concat(msg, \" (\").concat(this.errorStr(), \")\");\n };\n return FeeMarketEIP1559Transaction;\n}(baseTransaction_1.BaseTransaction);\nexports.default = FeeMarketEIP1559Transaction;\n","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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};\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FeeMarketEIP1559Transaction = exports.TransactionFactory = exports.AccessListEIP2930Transaction = exports.Transaction = void 0;\nvar legacyTransaction_1 = require(\"./legacyTransaction\");\nObject.defineProperty(exports, \"Transaction\", {\n enumerable: true,\n get: function () {\n return __importDefault(legacyTransaction_1).default;\n }\n});\nvar eip2930Transaction_1 = require(\"./eip2930Transaction\");\nObject.defineProperty(exports, \"AccessListEIP2930Transaction\", {\n enumerable: true,\n get: function () {\n return __importDefault(eip2930Transaction_1).default;\n }\n});\nvar transactionFactory_1 = require(\"./transactionFactory\");\nObject.defineProperty(exports, \"TransactionFactory\", {\n enumerable: true,\n get: function () {\n return __importDefault(transactionFactory_1).default;\n }\n});\nvar eip1559Transaction_1 = require(\"./eip1559Transaction\");\nObject.defineProperty(exports, \"FeeMarketEIP1559Transaction\", {\n enumerable: true,\n get: function () {\n return __importDefault(eip1559Transaction_1).default;\n }\n});\n__exportStar(require(\"./types\"), exports);\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert(val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits(ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN(number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n BN.BN = BN;\n BN.wordSize = 26;\n var Buffer;\n try {\n Buffer = require('buf' + 'fer').Buffer;\n } catch (e) {}\n BN.isBN = function isBN(num) {\n if (num instanceof BN) {\n return true;\n }\n return num !== null && typeof num === 'object' && num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n BN.max = function max(left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n BN.min = function min(left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n BN.prototype._init = function init(number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n }\n if (base === 16) {\n this._parseHex(number, start);\n } else {\n this._parseBase(number, base, start);\n }\n if (number[0] === '-') {\n this.negative = 1;\n }\n this.strip();\n if (endian !== 'le') return;\n this._initArray(this.toArray(), base, endian);\n };\n BN.prototype._initNumber = function _initNumber(number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff, 1];\n this.length = 3;\n }\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n BN.prototype._initArray = function _initArray(number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | number[i - 1] << 8 | number[i - 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | number[i + 1] << 8 | number[i + 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n function parseHex(str, start, end) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n r <<= 4;\n\n // 'a' - 'f'\n if (c >= 49 && c <= 54) {\n r |= c - 49 + 0xa;\n\n // 'A' - 'F'\n } else if (c >= 17 && c <= 22) {\n r |= c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r |= c & 0xf;\n }\n }\n return r;\n }\n BN.prototype._parseHex = function _parseHex(number, start) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n var j, w;\n // Scan 24-bit chunks and add them to the number\n var off = 0;\n for (i = number.length - 6, j = 0; i >= start; i -= 6) {\n w = parseHex(number, i, i + 6);\n this.words[j] |= w << off & 0x3ffffff;\n // NOTE: `0x3fffff` is intentional here, 26bits max shift + 24bit hex limb\n this.words[j + 1] |= w >>> 26 - off & 0x3fffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n if (i + 6 !== start) {\n w = parseHex(number, start, i + 6);\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] |= w >>> 26 - off & 0x3fffff;\n }\n this.strip();\n };\n function parseBase(str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n BN.prototype._parseBase = function _parseBase(number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = limbPow / base | 0;\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n };\n BN.prototype.copy = function copy(dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n BN.prototype.clone = function clone() {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n BN.prototype._expand = function _expand(size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip() {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n BN.prototype._normSign = function _normSign() {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n BN.prototype.inspect = function inspect() {\n return (this.red ? '';\n };\n\n /*\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n */\n\n var zeros = ['', '0', '00', '000', '0000', '00000', '000000', '0000000', '00000000', '000000000', '0000000000', '00000000000', '000000000000', '0000000000000', '00000000000000', '000000000000000', '0000000000000000', '00000000000000000', '000000000000000000', '0000000000000000000', '00000000000000000000', '000000000000000000000', '0000000000000000000000', '00000000000000000000000', '000000000000000000000000', '0000000000000000000000000'];\n var groupSizes = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5];\n var groupBases = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];\n BN.prototype.toString = function toString(base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = ((w << off | carry) & 0xffffff).toString(16);\n carry = w >>> 24 - off & 0xffffff;\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n assert(false, 'Base should be between 2 and 36');\n };\n BN.prototype.toNumber = function toNumber() {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + this.words[1] * 0x4000000;\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return this.negative !== 0 ? -ret : ret;\n };\n BN.prototype.toJSON = function toJSON() {\n return this.toString(16);\n };\n BN.prototype.toBuffer = function toBuffer(endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n BN.prototype.toArray = function toArray(endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n BN.prototype.toArrayLike = function toArrayLike(ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[i] = b;\n }\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n return res;\n };\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits(w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits(w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n BN.prototype._zeroBits = function _zeroBits(w) {\n // Short-cut\n if (w === 0) return 26;\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength() {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n function toBitArray(num) {\n var w = new Array(num.bitLength());\n for (var bit = 0; bit < w.length; bit++) {\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n w[bit] = (num.words[off] & 1 << wbit) >>> wbit;\n }\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits() {\n if (this.isZero()) return 0;\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n BN.prototype.byteLength = function byteLength() {\n return Math.ceil(this.bitLength() / 8);\n };\n BN.prototype.toTwos = function toTwos(width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n BN.prototype.fromTwos = function fromTwos(width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n BN.prototype.isNeg = function isNeg() {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg() {\n return this.clone().ineg();\n };\n BN.prototype.ineg = function ineg() {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor(num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n return this.strip();\n };\n BN.prototype.ior = function ior(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or(num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n BN.prototype.uor = function uor(num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand(num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n this.length = b.length;\n return this.strip();\n };\n BN.prototype.iand = function iand(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and(num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n BN.prototype.uand = function uand(num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor(num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = a.length;\n return this.strip();\n };\n BN.prototype.ixor = function ixor(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor(num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n BN.prototype.uxor = function uxor(num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn(width) {\n assert(typeof width === 'number' && width >= 0);\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & 0x3ffffff >> 26 - bitsLeft;\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n BN.prototype.notn = function notn(width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn(bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n this._expand(off + 1);\n if (val) {\n this.words[off] = this.words[off] | 1 << wbit;\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd(num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add(num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n if (this.length > num.length) return this.clone().iadd(num);\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub(num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = Math.max(this.length, i);\n if (a !== this) {\n this.negative = 1;\n }\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub(num) {\n return this.clone().isub(num);\n };\n function smallMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = self.length + num.length | 0;\n out.length = len;\n len = len - 1 | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n var carry = r / 0x4000000 | 0;\n out.words[0] = lo;\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += r / 0x4000000 | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo(self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = mid + Math.imul(ah0, bl0) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w0 >>> 26) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = mid + Math.imul(ah1, bl0) | 0;\n hi = Math.imul(ah1, bh0);\n lo = lo + Math.imul(al0, bl1) | 0;\n mid = mid + Math.imul(al0, bh1) | 0;\n mid = mid + Math.imul(ah0, bl1) | 0;\n hi = hi + Math.imul(ah0, bh1) | 0;\n var w1 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w1 >>> 26) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = mid + Math.imul(ah2, bl0) | 0;\n hi = Math.imul(ah2, bh0);\n lo = lo + Math.imul(al1, bl1) | 0;\n mid = mid + Math.imul(al1, bh1) | 0;\n mid = mid + Math.imul(ah1, bl1) | 0;\n hi = hi + Math.imul(ah1, bh1) | 0;\n lo = lo + Math.imul(al0, bl2) | 0;\n mid = mid + Math.imul(al0, bh2) | 0;\n mid = mid + Math.imul(ah0, bl2) | 0;\n hi = hi + Math.imul(ah0, bh2) | 0;\n var w2 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w2 >>> 26) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = mid + Math.imul(ah3, bl0) | 0;\n hi = Math.imul(ah3, bh0);\n lo = lo + Math.imul(al2, bl1) | 0;\n mid = mid + Math.imul(al2, bh1) | 0;\n mid = mid + Math.imul(ah2, bl1) | 0;\n hi = hi + Math.imul(ah2, bh1) | 0;\n lo = lo + Math.imul(al1, bl2) | 0;\n mid = mid + Math.imul(al1, bh2) | 0;\n mid = mid + Math.imul(ah1, bl2) | 0;\n hi = hi + Math.imul(ah1, bh2) | 0;\n lo = lo + Math.imul(al0, bl3) | 0;\n mid = mid + Math.imul(al0, bh3) | 0;\n mid = mid + Math.imul(ah0, bl3) | 0;\n hi = hi + Math.imul(ah0, bh3) | 0;\n var w3 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w3 >>> 26) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = mid + Math.imul(ah4, bl0) | 0;\n hi = Math.imul(ah4, bh0);\n lo = lo + Math.imul(al3, bl1) | 0;\n mid = mid + Math.imul(al3, bh1) | 0;\n mid = mid + Math.imul(ah3, bl1) | 0;\n hi = hi + Math.imul(ah3, bh1) | 0;\n lo = lo + Math.imul(al2, bl2) | 0;\n mid = mid + Math.imul(al2, bh2) | 0;\n mid = mid + Math.imul(ah2, bl2) | 0;\n hi = hi + Math.imul(ah2, bh2) | 0;\n lo = lo + Math.imul(al1, bl3) | 0;\n mid = mid + Math.imul(al1, bh3) | 0;\n mid = mid + Math.imul(ah1, bl3) | 0;\n hi = hi + Math.imul(ah1, bh3) | 0;\n lo = lo + Math.imul(al0, bl4) | 0;\n mid = mid + Math.imul(al0, bh4) | 0;\n mid = mid + Math.imul(ah0, bl4) | 0;\n hi = hi + Math.imul(ah0, bh4) | 0;\n var w4 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w4 >>> 26) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = mid + Math.imul(ah5, bl0) | 0;\n hi = Math.imul(ah5, bh0);\n lo = lo + Math.imul(al4, bl1) | 0;\n mid = mid + Math.imul(al4, bh1) | 0;\n mid = mid + Math.imul(ah4, bl1) | 0;\n hi = hi + Math.imul(ah4, bh1) | 0;\n lo = lo + Math.imul(al3, bl2) | 0;\n mid = mid + Math.imul(al3, bh2) | 0;\n mid = mid + Math.imul(ah3, bl2) | 0;\n hi = hi + Math.imul(ah3, bh2) | 0;\n lo = lo + Math.imul(al2, bl3) | 0;\n mid = mid + Math.imul(al2, bh3) | 0;\n mid = mid + Math.imul(ah2, bl3) | 0;\n hi = hi + Math.imul(ah2, bh3) | 0;\n lo = lo + Math.imul(al1, bl4) | 0;\n mid = mid + Math.imul(al1, bh4) | 0;\n mid = mid + Math.imul(ah1, bl4) | 0;\n hi = hi + Math.imul(ah1, bh4) | 0;\n lo = lo + Math.imul(al0, bl5) | 0;\n mid = mid + Math.imul(al0, bh5) | 0;\n mid = mid + Math.imul(ah0, bl5) | 0;\n hi = hi + Math.imul(ah0, bh5) | 0;\n var w5 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w5 >>> 26) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = mid + Math.imul(ah6, bl0) | 0;\n hi = Math.imul(ah6, bh0);\n lo = lo + Math.imul(al5, bl1) | 0;\n mid = mid + Math.imul(al5, bh1) | 0;\n mid = mid + Math.imul(ah5, bl1) | 0;\n hi = hi + Math.imul(ah5, bh1) | 0;\n lo = lo + Math.imul(al4, bl2) | 0;\n mid = mid + Math.imul(al4, bh2) | 0;\n mid = mid + Math.imul(ah4, bl2) | 0;\n hi = hi + Math.imul(ah4, bh2) | 0;\n lo = lo + Math.imul(al3, bl3) | 0;\n mid = mid + Math.imul(al3, bh3) | 0;\n mid = mid + Math.imul(ah3, bl3) | 0;\n hi = hi + Math.imul(ah3, bh3) | 0;\n lo = lo + Math.imul(al2, bl4) | 0;\n mid = mid + Math.imul(al2, bh4) | 0;\n mid = mid + Math.imul(ah2, bl4) | 0;\n hi = hi + Math.imul(ah2, bh4) | 0;\n lo = lo + Math.imul(al1, bl5) | 0;\n mid = mid + Math.imul(al1, bh5) | 0;\n mid = mid + Math.imul(ah1, bl5) | 0;\n hi = hi + Math.imul(ah1, bh5) | 0;\n lo = lo + Math.imul(al0, bl6) | 0;\n mid = mid + Math.imul(al0, bh6) | 0;\n mid = mid + Math.imul(ah0, bl6) | 0;\n hi = hi + Math.imul(ah0, bh6) | 0;\n var w6 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w6 >>> 26) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = mid + Math.imul(ah7, bl0) | 0;\n hi = Math.imul(ah7, bh0);\n lo = lo + Math.imul(al6, bl1) | 0;\n mid = mid + Math.imul(al6, bh1) | 0;\n mid = mid + Math.imul(ah6, bl1) | 0;\n hi = hi + Math.imul(ah6, bh1) | 0;\n lo = lo + Math.imul(al5, bl2) | 0;\n mid = mid + Math.imul(al5, bh2) | 0;\n mid = mid + Math.imul(ah5, bl2) | 0;\n hi = hi + Math.imul(ah5, bh2) | 0;\n lo = lo + Math.imul(al4, bl3) | 0;\n mid = mid + Math.imul(al4, bh3) | 0;\n mid = mid + Math.imul(ah4, bl3) | 0;\n hi = hi + Math.imul(ah4, bh3) | 0;\n lo = lo + Math.imul(al3, bl4) | 0;\n mid = mid + Math.imul(al3, bh4) | 0;\n mid = mid + Math.imul(ah3, bl4) | 0;\n hi = hi + Math.imul(ah3, bh4) | 0;\n lo = lo + Math.imul(al2, bl5) | 0;\n mid = mid + Math.imul(al2, bh5) | 0;\n mid = mid + Math.imul(ah2, bl5) | 0;\n hi = hi + Math.imul(ah2, bh5) | 0;\n lo = lo + Math.imul(al1, bl6) | 0;\n mid = mid + Math.imul(al1, bh6) | 0;\n mid = mid + Math.imul(ah1, bl6) | 0;\n hi = hi + Math.imul(ah1, bh6) | 0;\n lo = lo + Math.imul(al0, bl7) | 0;\n mid = mid + Math.imul(al0, bh7) | 0;\n mid = mid + Math.imul(ah0, bl7) | 0;\n hi = hi + Math.imul(ah0, bh7) | 0;\n var w7 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w7 >>> 26) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = mid + Math.imul(ah8, bl0) | 0;\n hi = Math.imul(ah8, bh0);\n lo = lo + Math.imul(al7, bl1) | 0;\n mid = mid + Math.imul(al7, bh1) | 0;\n mid = mid + Math.imul(ah7, bl1) | 0;\n hi = hi + Math.imul(ah7, bh1) | 0;\n lo = lo + Math.imul(al6, bl2) | 0;\n mid = mid + Math.imul(al6, bh2) | 0;\n mid = mid + Math.imul(ah6, bl2) | 0;\n hi = hi + Math.imul(ah6, bh2) | 0;\n lo = lo + Math.imul(al5, bl3) | 0;\n mid = mid + Math.imul(al5, bh3) | 0;\n mid = mid + Math.imul(ah5, bl3) | 0;\n hi = hi + Math.imul(ah5, bh3) | 0;\n lo = lo + Math.imul(al4, bl4) | 0;\n mid = mid + Math.imul(al4, bh4) | 0;\n mid = mid + Math.imul(ah4, bl4) | 0;\n hi = hi + Math.imul(ah4, bh4) | 0;\n lo = lo + Math.imul(al3, bl5) | 0;\n mid = mid + Math.imul(al3, bh5) | 0;\n mid = mid + Math.imul(ah3, bl5) | 0;\n hi = hi + Math.imul(ah3, bh5) | 0;\n lo = lo + Math.imul(al2, bl6) | 0;\n mid = mid + Math.imul(al2, bh6) | 0;\n mid = mid + Math.imul(ah2, bl6) | 0;\n hi = hi + Math.imul(ah2, bh6) | 0;\n lo = lo + Math.imul(al1, bl7) | 0;\n mid = mid + Math.imul(al1, bh7) | 0;\n mid = mid + Math.imul(ah1, bl7) | 0;\n hi = hi + Math.imul(ah1, bh7) | 0;\n lo = lo + Math.imul(al0, bl8) | 0;\n mid = mid + Math.imul(al0, bh8) | 0;\n mid = mid + Math.imul(ah0, bl8) | 0;\n hi = hi + Math.imul(ah0, bh8) | 0;\n var w8 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w8 >>> 26) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = mid + Math.imul(ah9, bl0) | 0;\n hi = Math.imul(ah9, bh0);\n lo = lo + Math.imul(al8, bl1) | 0;\n mid = mid + Math.imul(al8, bh1) | 0;\n mid = mid + Math.imul(ah8, bl1) | 0;\n hi = hi + Math.imul(ah8, bh1) | 0;\n lo = lo + Math.imul(al7, bl2) | 0;\n mid = mid + Math.imul(al7, bh2) | 0;\n mid = mid + Math.imul(ah7, bl2) | 0;\n hi = hi + Math.imul(ah7, bh2) | 0;\n lo = lo + Math.imul(al6, bl3) | 0;\n mid = mid + Math.imul(al6, bh3) | 0;\n mid = mid + Math.imul(ah6, bl3) | 0;\n hi = hi + Math.imul(ah6, bh3) | 0;\n lo = lo + Math.imul(al5, bl4) | 0;\n mid = mid + Math.imul(al5, bh4) | 0;\n mid = mid + Math.imul(ah5, bl4) | 0;\n hi = hi + Math.imul(ah5, bh4) | 0;\n lo = lo + Math.imul(al4, bl5) | 0;\n mid = mid + Math.imul(al4, bh5) | 0;\n mid = mid + Math.imul(ah4, bl5) | 0;\n hi = hi + Math.imul(ah4, bh5) | 0;\n lo = lo + Math.imul(al3, bl6) | 0;\n mid = mid + Math.imul(al3, bh6) | 0;\n mid = mid + Math.imul(ah3, bl6) | 0;\n hi = hi + Math.imul(ah3, bh6) | 0;\n lo = lo + Math.imul(al2, bl7) | 0;\n mid = mid + Math.imul(al2, bh7) | 0;\n mid = mid + Math.imul(ah2, bl7) | 0;\n hi = hi + Math.imul(ah2, bh7) | 0;\n lo = lo + Math.imul(al1, bl8) | 0;\n mid = mid + Math.imul(al1, bh8) | 0;\n mid = mid + Math.imul(ah1, bl8) | 0;\n hi = hi + Math.imul(ah1, bh8) | 0;\n lo = lo + Math.imul(al0, bl9) | 0;\n mid = mid + Math.imul(al0, bh9) | 0;\n mid = mid + Math.imul(ah0, bl9) | 0;\n hi = hi + Math.imul(ah0, bh9) | 0;\n var w9 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w9 >>> 26) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = mid + Math.imul(ah9, bl1) | 0;\n hi = Math.imul(ah9, bh1);\n lo = lo + Math.imul(al8, bl2) | 0;\n mid = mid + Math.imul(al8, bh2) | 0;\n mid = mid + Math.imul(ah8, bl2) | 0;\n hi = hi + Math.imul(ah8, bh2) | 0;\n lo = lo + Math.imul(al7, bl3) | 0;\n mid = mid + Math.imul(al7, bh3) | 0;\n mid = mid + Math.imul(ah7, bl3) | 0;\n hi = hi + Math.imul(ah7, bh3) | 0;\n lo = lo + Math.imul(al6, bl4) | 0;\n mid = mid + Math.imul(al6, bh4) | 0;\n mid = mid + Math.imul(ah6, bl4) | 0;\n hi = hi + Math.imul(ah6, bh4) | 0;\n lo = lo + Math.imul(al5, bl5) | 0;\n mid = mid + Math.imul(al5, bh5) | 0;\n mid = mid + Math.imul(ah5, bl5) | 0;\n hi = hi + Math.imul(ah5, bh5) | 0;\n lo = lo + Math.imul(al4, bl6) | 0;\n mid = mid + Math.imul(al4, bh6) | 0;\n mid = mid + Math.imul(ah4, bl6) | 0;\n hi = hi + Math.imul(ah4, bh6) | 0;\n lo = lo + Math.imul(al3, bl7) | 0;\n mid = mid + Math.imul(al3, bh7) | 0;\n mid = mid + Math.imul(ah3, bl7) | 0;\n hi = hi + Math.imul(ah3, bh7) | 0;\n lo = lo + Math.imul(al2, bl8) | 0;\n mid = mid + Math.imul(al2, bh8) | 0;\n mid = mid + Math.imul(ah2, bl8) | 0;\n hi = hi + Math.imul(ah2, bh8) | 0;\n lo = lo + Math.imul(al1, bl9) | 0;\n mid = mid + Math.imul(al1, bh9) | 0;\n mid = mid + Math.imul(ah1, bl9) | 0;\n hi = hi + Math.imul(ah1, bh9) | 0;\n var w10 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w10 >>> 26) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = mid + Math.imul(ah9, bl2) | 0;\n hi = Math.imul(ah9, bh2);\n lo = lo + Math.imul(al8, bl3) | 0;\n mid = mid + Math.imul(al8, bh3) | 0;\n mid = mid + Math.imul(ah8, bl3) | 0;\n hi = hi + Math.imul(ah8, bh3) | 0;\n lo = lo + Math.imul(al7, bl4) | 0;\n mid = mid + Math.imul(al7, bh4) | 0;\n mid = mid + Math.imul(ah7, bl4) | 0;\n hi = hi + Math.imul(ah7, bh4) | 0;\n lo = lo + Math.imul(al6, bl5) | 0;\n mid = mid + Math.imul(al6, bh5) | 0;\n mid = mid + Math.imul(ah6, bl5) | 0;\n hi = hi + Math.imul(ah6, bh5) | 0;\n lo = lo + Math.imul(al5, bl6) | 0;\n mid = mid + Math.imul(al5, bh6) | 0;\n mid = mid + Math.imul(ah5, bl6) | 0;\n hi = hi + Math.imul(ah5, bh6) | 0;\n lo = lo + Math.imul(al4, bl7) | 0;\n mid = mid + Math.imul(al4, bh7) | 0;\n mid = mid + Math.imul(ah4, bl7) | 0;\n hi = hi + Math.imul(ah4, bh7) | 0;\n lo = lo + Math.imul(al3, bl8) | 0;\n mid = mid + Math.imul(al3, bh8) | 0;\n mid = mid + Math.imul(ah3, bl8) | 0;\n hi = hi + Math.imul(ah3, bh8) | 0;\n lo = lo + Math.imul(al2, bl9) | 0;\n mid = mid + Math.imul(al2, bh9) | 0;\n mid = mid + Math.imul(ah2, bl9) | 0;\n hi = hi + Math.imul(ah2, bh9) | 0;\n var w11 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w11 >>> 26) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = mid + Math.imul(ah9, bl3) | 0;\n hi = Math.imul(ah9, bh3);\n lo = lo + Math.imul(al8, bl4) | 0;\n mid = mid + Math.imul(al8, bh4) | 0;\n mid = mid + Math.imul(ah8, bl4) | 0;\n hi = hi + Math.imul(ah8, bh4) | 0;\n lo = lo + Math.imul(al7, bl5) | 0;\n mid = mid + Math.imul(al7, bh5) | 0;\n mid = mid + Math.imul(ah7, bl5) | 0;\n hi = hi + Math.imul(ah7, bh5) | 0;\n lo = lo + Math.imul(al6, bl6) | 0;\n mid = mid + Math.imul(al6, bh6) | 0;\n mid = mid + Math.imul(ah6, bl6) | 0;\n hi = hi + Math.imul(ah6, bh6) | 0;\n lo = lo + Math.imul(al5, bl7) | 0;\n mid = mid + Math.imul(al5, bh7) | 0;\n mid = mid + Math.imul(ah5, bl7) | 0;\n hi = hi + Math.imul(ah5, bh7) | 0;\n lo = lo + Math.imul(al4, bl8) | 0;\n mid = mid + Math.imul(al4, bh8) | 0;\n mid = mid + Math.imul(ah4, bl8) | 0;\n hi = hi + Math.imul(ah4, bh8) | 0;\n lo = lo + Math.imul(al3, bl9) | 0;\n mid = mid + Math.imul(al3, bh9) | 0;\n mid = mid + Math.imul(ah3, bl9) | 0;\n hi = hi + Math.imul(ah3, bh9) | 0;\n var w12 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w12 >>> 26) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = mid + Math.imul(ah9, bl4) | 0;\n hi = Math.imul(ah9, bh4);\n lo = lo + Math.imul(al8, bl5) | 0;\n mid = mid + Math.imul(al8, bh5) | 0;\n mid = mid + Math.imul(ah8, bl5) | 0;\n hi = hi + Math.imul(ah8, bh5) | 0;\n lo = lo + Math.imul(al7, bl6) | 0;\n mid = mid + Math.imul(al7, bh6) | 0;\n mid = mid + Math.imul(ah7, bl6) | 0;\n hi = hi + Math.imul(ah7, bh6) | 0;\n lo = lo + Math.imul(al6, bl7) | 0;\n mid = mid + Math.imul(al6, bh7) | 0;\n mid = mid + Math.imul(ah6, bl7) | 0;\n hi = hi + Math.imul(ah6, bh7) | 0;\n lo = lo + Math.imul(al5, bl8) | 0;\n mid = mid + Math.imul(al5, bh8) | 0;\n mid = mid + Math.imul(ah5, bl8) | 0;\n hi = hi + Math.imul(ah5, bh8) | 0;\n lo = lo + Math.imul(al4, bl9) | 0;\n mid = mid + Math.imul(al4, bh9) | 0;\n mid = mid + Math.imul(ah4, bl9) | 0;\n hi = hi + Math.imul(ah4, bh9) | 0;\n var w13 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w13 >>> 26) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = mid + Math.imul(ah9, bl5) | 0;\n hi = Math.imul(ah9, bh5);\n lo = lo + Math.imul(al8, bl6) | 0;\n mid = mid + Math.imul(al8, bh6) | 0;\n mid = mid + Math.imul(ah8, bl6) | 0;\n hi = hi + Math.imul(ah8, bh6) | 0;\n lo = lo + Math.imul(al7, bl7) | 0;\n mid = mid + Math.imul(al7, bh7) | 0;\n mid = mid + Math.imul(ah7, bl7) | 0;\n hi = hi + Math.imul(ah7, bh7) | 0;\n lo = lo + Math.imul(al6, bl8) | 0;\n mid = mid + Math.imul(al6, bh8) | 0;\n mid = mid + Math.imul(ah6, bl8) | 0;\n hi = hi + Math.imul(ah6, bh8) | 0;\n lo = lo + Math.imul(al5, bl9) | 0;\n mid = mid + Math.imul(al5, bh9) | 0;\n mid = mid + Math.imul(ah5, bl9) | 0;\n hi = hi + Math.imul(ah5, bh9) | 0;\n var w14 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w14 >>> 26) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = mid + Math.imul(ah9, bl6) | 0;\n hi = Math.imul(ah9, bh6);\n lo = lo + Math.imul(al8, bl7) | 0;\n mid = mid + Math.imul(al8, bh7) | 0;\n mid = mid + Math.imul(ah8, bl7) | 0;\n hi = hi + Math.imul(ah8, bh7) | 0;\n lo = lo + Math.imul(al7, bl8) | 0;\n mid = mid + Math.imul(al7, bh8) | 0;\n mid = mid + Math.imul(ah7, bl8) | 0;\n hi = hi + Math.imul(ah7, bh8) | 0;\n lo = lo + Math.imul(al6, bl9) | 0;\n mid = mid + Math.imul(al6, bh9) | 0;\n mid = mid + Math.imul(ah6, bl9) | 0;\n hi = hi + Math.imul(ah6, bh9) | 0;\n var w15 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w15 >>> 26) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = mid + Math.imul(ah9, bl7) | 0;\n hi = Math.imul(ah9, bh7);\n lo = lo + Math.imul(al8, bl8) | 0;\n mid = mid + Math.imul(al8, bh8) | 0;\n mid = mid + Math.imul(ah8, bl8) | 0;\n hi = hi + Math.imul(ah8, bh8) | 0;\n lo = lo + Math.imul(al7, bl9) | 0;\n mid = mid + Math.imul(al7, bh9) | 0;\n mid = mid + Math.imul(ah7, bl9) | 0;\n hi = hi + Math.imul(ah7, bh9) | 0;\n var w16 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w16 >>> 26) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = mid + Math.imul(ah9, bl8) | 0;\n hi = Math.imul(ah9, bh8);\n lo = lo + Math.imul(al8, bl9) | 0;\n mid = mid + Math.imul(al8, bh9) | 0;\n mid = mid + Math.imul(ah8, bl9) | 0;\n hi = hi + Math.imul(ah8, bh9) | 0;\n var w17 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w17 >>> 26) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = mid + Math.imul(ah9, bl9) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w18 >>> 26) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n function bigMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n ncarry = ncarry + (r / 0x4000000 | 0) | 0;\n lo = lo + rword | 0;\n rword = lo & 0x3ffffff;\n ncarry = ncarry + (lo >>> 26) | 0;\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n return out.strip();\n }\n function jumboMulTo(self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n BN.prototype.mulTo = function mulTo(num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM(x, y) {\n this.x = x;\n this.y = y;\n }\n FFTM.prototype.makeRBT = function makeRBT(N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin(x, l, N) {\n if (x === 0 || x === N - 1) return x;\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << l - i - 1;\n x >>= 1;\n }\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute(rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n FFTM.prototype.transform = function transform(rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n var rx = rtwdf_ * ro - itwdf_ * io;\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n FFTM.prototype.guessLen13b = function guessLen13b(n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n return 1 << i + 1 + odd;\n };\n FFTM.prototype.conjugate = function conjugate(rws, iws, N) {\n if (N <= 1) return;\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n t = iws[i];\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n FFTM.prototype.normalize13b = function normalize13b(ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 + Math.round(ws[2 * i] / N) + carry;\n ws[i] = w & 0x3ffffff;\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n return ws;\n };\n FFTM.prototype.convert13b = function convert13b(ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n rws[2 * i] = carry & 0x1fff;\n carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff;\n carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n FFTM.prototype.stub = function stub(N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n return ph;\n };\n FFTM.prototype.mulp = function mulp(x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n var rbt = this.makeRBT(N);\n var _ = this.stub(N);\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n var rmws = out.words;\n rmws.length = N;\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul(num) {\n return this.clone().mulTo(num, this);\n };\n BN.prototype.imuln = function imuln(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += w / 0x4000000 | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.muln = function muln(num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr() {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr() {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow(num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n res = res.mul(q);\n }\n }\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = 0x3ffffff >>> 26 - r << 26 - r;\n var i;\n if (r !== 0) {\n var carry = 0;\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = (this.words[i] | 0) - newCarry << r;\n this.words[i] = c | carry;\n carry = newCarry >>> 26 - r;\n }\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n this.length += s;\n }\n return this.strip();\n };\n BN.prototype.ishln = function ishln(bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn(bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - hint % 26) / 26;\n } else {\n h = 0;\n }\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n var maskedWords = extended;\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = carry << 26 - r | word >>> r;\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n return this.strip();\n };\n BN.prototype.ishrn = function ishrn(bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln(bits) {\n return this.clone().ishln(bits);\n };\n BN.prototype.ushln = function ushln(bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn(bits) {\n return this.clone().ishrn(bits);\n };\n BN.prototype.ushrn = function ushrn(bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn(bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n if (this.length <= s) {\n return this;\n }\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n if (r !== 0) {\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n this.words[this.length - 1] &= mask;\n }\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn(bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n BN.prototype._iaddn = function _iaddn(num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n this.words[0] -= num;\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n return this.strip();\n };\n BN.prototype.addn = function addn(num) {\n return this.clone().iaddn(num);\n };\n BN.prototype.subn = function subn(num) {\n return this.clone().isubn(num);\n };\n BN.prototype.iabs = function iabs() {\n this.negative = 0;\n return this;\n };\n BN.prototype.abs = function abs() {\n return this.clone().iabs();\n };\n BN.prototype._ishlnsubmul = function _ishlnsubmul(num, mul, shift) {\n var len = num.length + shift;\n var i;\n this._expand(len);\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - (right / 0x4000000 | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n return this.strip();\n };\n BN.prototype._wordDiv = function _wordDiv(num, mode) {\n var shift = this.length - num.length;\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 + (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min(qj / bhi | 0, 0x3ffffff);\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod(num, mode, positive) {\n assert(!num.isZero());\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n return {\n div: div,\n mod: mod\n };\n }\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n return {\n div: div,\n mod: res.mod\n };\n }\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div(num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod(num) {\n return this.divmod(num, 'mod', false).mod;\n };\n BN.prototype.umod = function umod(num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound(num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n BN.prototype.modn = function modn(num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn(num) {\n assert(num <= 0x3ffffff);\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = w / num | 0;\n carry = w % num;\n }\n return this.strip();\n };\n BN.prototype.divn = function divn(num) {\n return this.clone().idivn(num);\n };\n BN.prototype.egcd = function egcd(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var x = this;\n var y = p.clone();\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n var g = 0;\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n var yp = y.clone();\n var xp = x.clone();\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var a = this;\n var b = p.clone();\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n var x1 = new BN(1);\n var x2 = new BN(0);\n var delta = b.clone();\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n x1.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n x2.iushrn(1);\n }\n }\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n return res;\n };\n BN.prototype.gcd = function gcd(num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n a.isub(b);\n } while (true);\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm(num) {\n return this.egcd(num).a.umod(num);\n };\n BN.prototype.isEven = function isEven() {\n return (this.words[0] & 1) === 0;\n };\n BN.prototype.isOdd = function isOdd() {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln(num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn(bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.isZero = function isZero() {\n return this.length === 1 && this.words[0] === 0;\n };\n BN.prototype.cmpn = function cmpn(num) {\n var negative = num < 0;\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n this.strip();\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n assert(num <= 0x3ffffff, 'Number is too big');\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp(num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp(num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n BN.prototype.gtn = function gtn(num) {\n return this.cmpn(num) === 1;\n };\n BN.prototype.gt = function gt(num) {\n return this.cmp(num) === 1;\n };\n BN.prototype.gten = function gten(num) {\n return this.cmpn(num) >= 0;\n };\n BN.prototype.gte = function gte(num) {\n return this.cmp(num) >= 0;\n };\n BN.prototype.ltn = function ltn(num) {\n return this.cmpn(num) === -1;\n };\n BN.prototype.lt = function lt(num) {\n return this.cmp(num) === -1;\n };\n BN.prototype.lten = function lten(num) {\n return this.cmpn(num) <= 0;\n };\n BN.prototype.lte = function lte(num) {\n return this.cmp(num) <= 0;\n };\n BN.prototype.eqn = function eqn(num) {\n return this.cmpn(num) === 0;\n };\n BN.prototype.eq = function eq(num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red(num) {\n return new Red(num);\n };\n BN.prototype.toRed = function toRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n BN.prototype.fromRed = function fromRed() {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n BN.prototype._forceRed = function _forceRed(ctx) {\n this.red = ctx;\n return this;\n };\n BN.prototype.forceRed = function forceRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n BN.prototype.redAdd = function redAdd(num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n BN.prototype.redIAdd = function redIAdd(num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n BN.prototype.redSub = function redSub(num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n BN.prototype.redISub = function redISub(num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n BN.prototype.redShl = function redShl(num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n BN.prototype.redMul = function redMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n BN.prototype.redIMul = function redIMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n BN.prototype.redSqr = function redSqr() {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n BN.prototype.redISqr = function redISqr() {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt() {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n BN.prototype.redInvm = function redInvm() {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg() {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n BN.prototype.redPow = function redPow(num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime(name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n this.tmp = this._tmp();\n }\n MPrime.prototype._tmp = function _tmp() {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n MPrime.prototype.ireduce = function ireduce(num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n r.strip();\n }\n return r;\n };\n MPrime.prototype.split = function split(input, out) {\n input.iushrn(this.n, 0, out);\n };\n MPrime.prototype.imulK = function imulK(num) {\n return num.imul(this.k);\n };\n function K256() {\n MPrime.call(this, 'k256', 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n K256.prototype.split = function split(input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = (next & mask) << 4 | prev >>> 22;\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n K256.prototype.imulK = function imulK(num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + (lo / 0x4000000 | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n function P224() {\n MPrime.call(this, 'p224', 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n function P192() {\n MPrime.call(this, 'p192', 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n function P25519() {\n // 2 ^ 255 - 19\n MPrime.call(this, '25519', '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n P25519.prototype.imulK = function imulK(num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime(name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red(m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n Red.prototype._verify1 = function _verify1(a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n Red.prototype._verify2 = function _verify2(a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red, 'red works only with red numbers');\n };\n Red.prototype.imod = function imod(a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n Red.prototype.neg = function neg(a) {\n if (a.isZero()) {\n return a.clone();\n }\n return this.m.sub(a)._forceRed(this);\n };\n Red.prototype.add = function add(a, b) {\n this._verify2(a, b);\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.iadd = function iadd(a, b) {\n this._verify2(a, b);\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n Red.prototype.sub = function sub(a, b) {\n this._verify2(a, b);\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.isub = function isub(a, b) {\n this._verify2(a, b);\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n Red.prototype.shl = function shl(a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n Red.prototype.imul = function imul(a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n Red.prototype.mul = function mul(a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n Red.prototype.isqr = function isqr(a) {\n return this.imul(a, a.clone());\n };\n Red.prototype.sqr = function sqr(a) {\n return this.mul(a, a);\n };\n Red.prototype.sqrt = function sqrt(a) {\n if (a.isZero()) return a.clone();\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n return r;\n };\n Red.prototype.invm = function invm(a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n Red.prototype.pow = function pow(a, num) {\n if (num.isZero()) return new BN(1);\n if (num.cmpn(1) === 0) return a.clone();\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = word >> j & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n return res;\n };\n Red.prototype.convertTo = function convertTo(num) {\n var r = num.umod(this.m);\n return r === num ? r.clone() : r;\n };\n Red.prototype.convertFrom = function convertFrom(num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont(num) {\n return new Mont(num);\n };\n function Mont(m) {\n Red.call(this, m);\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - this.shift % 26;\n }\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n Mont.prototype.convertTo = function convertTo(num) {\n return this.imod(num.ushln(this.shift));\n };\n Mont.prototype.convertFrom = function convertFrom(num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n Mont.prototype.imul = function imul(a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.mul = function mul(a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.invm = function invm(a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);","/**\n * Returns a `Boolean` on whether or not the a `String` starts with '0x'\n * @param {String} str the string input value\n * @return {Boolean} a boolean if it is or is not hex prefixed\n * @throws if the str input is not a string\n */\nmodule.exports = function isHexPrefixed(str) {\n if (typeof str !== 'string') {\n throw new Error(\"[is-hex-prefixed] value must be type 'string', is currently type \" + typeof str + \", while checking isHexPrefixed.\");\n }\n return str.slice(0, 2) === '0x';\n};","var isHexPrefixed = require('is-hex-prefixed');\n\n/**\n * Removes '0x' from a given `String` is present\n * @param {String} str the string value\n * @return {String|Optional} a string by pass if necessary\n */\nmodule.exports = function stripHexPrefix(str) {\n if (typeof str !== 'string') {\n return str;\n }\n return isHexPrefixed(str) ? str.slice(2) : str;\n};","var BN = require('bn.js');\nvar stripHexPrefix = require('strip-hex-prefix');\n\n/**\n * Returns a BN object, converts a number value to a BN\n * @param {String|Number|Object} `arg` input a string number, hex string number, number, BigNumber or BN object\n * @return {Object} `output` BN object of the number\n * @throws if the argument is not an array, object that isn't a bignumber, not a string number or number\n */\nmodule.exports = function numberToBN(arg) {\n if (typeof arg === 'string' || typeof arg === 'number') {\n var multiplier = new BN(1); // eslint-disable-line\n var formattedString = String(arg).toLowerCase().trim();\n var isHexPrefixed = formattedString.substr(0, 2) === '0x' || formattedString.substr(0, 3) === '-0x';\n var stringArg = stripHexPrefix(formattedString); // eslint-disable-line\n if (stringArg.substr(0, 1) === '-') {\n stringArg = stripHexPrefix(stringArg.slice(1));\n multiplier = new BN(-1, 10);\n }\n stringArg = stringArg === '' ? '0' : stringArg;\n if (!stringArg.match(/^-?[0-9]+$/) && stringArg.match(/^[0-9A-Fa-f]+$/) || stringArg.match(/^[a-fA-F]+$/) || isHexPrefixed === true && stringArg.match(/^[0-9A-Fa-f]+$/)) {\n return new BN(stringArg, 16).mul(multiplier);\n }\n if ((stringArg.match(/^-?[0-9]+$/) || stringArg === '') && isHexPrefixed === false) {\n return new BN(stringArg, 10).mul(multiplier);\n }\n } else if (typeof arg === 'object' && arg.toString && !arg.pop && !arg.push) {\n if (arg.toString(10).match(/^-?[0-9]+$/) && (arg.mul || arg.dividedToIntegerBy)) {\n return new BN(arg.toString(10), 10);\n }\n }\n throw new Error('[number-to-bn] while converting number ' + JSON.stringify(arg) + ' to BN.js instance, error: invalid number value. Value must be an integer, hex string, BN or BigNumber instance. Note, decimals are not supported.');\n};","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert(val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits(ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN(number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n BN.BN = BN;\n BN.wordSize = 26;\n var Buffer;\n try {\n Buffer = require('buf' + 'fer').Buffer;\n } catch (e) {}\n BN.isBN = function isBN(num) {\n if (num instanceof BN) {\n return true;\n }\n return num !== null && typeof num === 'object' && num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n BN.max = function max(left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n BN.min = function min(left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n BN.prototype._init = function init(number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n }\n if (base === 16) {\n this._parseHex(number, start);\n } else {\n this._parseBase(number, base, start);\n }\n if (number[0] === '-') {\n this.negative = 1;\n }\n this.strip();\n if (endian !== 'le') return;\n this._initArray(this.toArray(), base, endian);\n };\n BN.prototype._initNumber = function _initNumber(number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff, 1];\n this.length = 3;\n }\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n BN.prototype._initArray = function _initArray(number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | number[i - 1] << 8 | number[i - 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | number[i + 1] << 8 | number[i + 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n function parseHex(str, start, end) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n r <<= 4;\n\n // 'a' - 'f'\n if (c >= 49 && c <= 54) {\n r |= c - 49 + 0xa;\n\n // 'A' - 'F'\n } else if (c >= 17 && c <= 22) {\n r |= c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r |= c & 0xf;\n }\n }\n return r;\n }\n BN.prototype._parseHex = function _parseHex(number, start) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n var j, w;\n // Scan 24-bit chunks and add them to the number\n var off = 0;\n for (i = number.length - 6, j = 0; i >= start; i -= 6) {\n w = parseHex(number, i, i + 6);\n this.words[j] |= w << off & 0x3ffffff;\n // NOTE: `0x3fffff` is intentional here, 26bits max shift + 24bit hex limb\n this.words[j + 1] |= w >>> 26 - off & 0x3fffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n if (i + 6 !== start) {\n w = parseHex(number, start, i + 6);\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] |= w >>> 26 - off & 0x3fffff;\n }\n this.strip();\n };\n function parseBase(str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n BN.prototype._parseBase = function _parseBase(number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = limbPow / base | 0;\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n };\n BN.prototype.copy = function copy(dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n BN.prototype.clone = function clone() {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n BN.prototype._expand = function _expand(size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip() {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n BN.prototype._normSign = function _normSign() {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n BN.prototype.inspect = function inspect() {\n return (this.red ? '';\n };\n\n /*\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n */\n\n var zeros = ['', '0', '00', '000', '0000', '00000', '000000', '0000000', '00000000', '000000000', '0000000000', '00000000000', '000000000000', '0000000000000', '00000000000000', '000000000000000', '0000000000000000', '00000000000000000', '000000000000000000', '0000000000000000000', '00000000000000000000', '000000000000000000000', '0000000000000000000000', '00000000000000000000000', '000000000000000000000000', '0000000000000000000000000'];\n var groupSizes = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5];\n var groupBases = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];\n BN.prototype.toString = function toString(base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = ((w << off | carry) & 0xffffff).toString(16);\n carry = w >>> 24 - off & 0xffffff;\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n assert(false, 'Base should be between 2 and 36');\n };\n BN.prototype.toNumber = function toNumber() {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + this.words[1] * 0x4000000;\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return this.negative !== 0 ? -ret : ret;\n };\n BN.prototype.toJSON = function toJSON() {\n return this.toString(16);\n };\n BN.prototype.toBuffer = function toBuffer(endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n BN.prototype.toArray = function toArray(endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n BN.prototype.toArrayLike = function toArrayLike(ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[i] = b;\n }\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n return res;\n };\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits(w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits(w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n BN.prototype._zeroBits = function _zeroBits(w) {\n // Short-cut\n if (w === 0) return 26;\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength() {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n function toBitArray(num) {\n var w = new Array(num.bitLength());\n for (var bit = 0; bit < w.length; bit++) {\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n w[bit] = (num.words[off] & 1 << wbit) >>> wbit;\n }\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits() {\n if (this.isZero()) return 0;\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n BN.prototype.byteLength = function byteLength() {\n return Math.ceil(this.bitLength() / 8);\n };\n BN.prototype.toTwos = function toTwos(width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n BN.prototype.fromTwos = function fromTwos(width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n BN.prototype.isNeg = function isNeg() {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg() {\n return this.clone().ineg();\n };\n BN.prototype.ineg = function ineg() {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor(num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n return this.strip();\n };\n BN.prototype.ior = function ior(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or(num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n BN.prototype.uor = function uor(num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand(num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n this.length = b.length;\n return this.strip();\n };\n BN.prototype.iand = function iand(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and(num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n BN.prototype.uand = function uand(num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor(num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = a.length;\n return this.strip();\n };\n BN.prototype.ixor = function ixor(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor(num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n BN.prototype.uxor = function uxor(num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn(width) {\n assert(typeof width === 'number' && width >= 0);\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & 0x3ffffff >> 26 - bitsLeft;\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n BN.prototype.notn = function notn(width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn(bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n this._expand(off + 1);\n if (val) {\n this.words[off] = this.words[off] | 1 << wbit;\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd(num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add(num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n if (this.length > num.length) return this.clone().iadd(num);\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub(num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = Math.max(this.length, i);\n if (a !== this) {\n this.negative = 1;\n }\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub(num) {\n return this.clone().isub(num);\n };\n function smallMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = self.length + num.length | 0;\n out.length = len;\n len = len - 1 | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n var carry = r / 0x4000000 | 0;\n out.words[0] = lo;\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += r / 0x4000000 | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo(self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = mid + Math.imul(ah0, bl0) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w0 >>> 26) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = mid + Math.imul(ah1, bl0) | 0;\n hi = Math.imul(ah1, bh0);\n lo = lo + Math.imul(al0, bl1) | 0;\n mid = mid + Math.imul(al0, bh1) | 0;\n mid = mid + Math.imul(ah0, bl1) | 0;\n hi = hi + Math.imul(ah0, bh1) | 0;\n var w1 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w1 >>> 26) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = mid + Math.imul(ah2, bl0) | 0;\n hi = Math.imul(ah2, bh0);\n lo = lo + Math.imul(al1, bl1) | 0;\n mid = mid + Math.imul(al1, bh1) | 0;\n mid = mid + Math.imul(ah1, bl1) | 0;\n hi = hi + Math.imul(ah1, bh1) | 0;\n lo = lo + Math.imul(al0, bl2) | 0;\n mid = mid + Math.imul(al0, bh2) | 0;\n mid = mid + Math.imul(ah0, bl2) | 0;\n hi = hi + Math.imul(ah0, bh2) | 0;\n var w2 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w2 >>> 26) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = mid + Math.imul(ah3, bl0) | 0;\n hi = Math.imul(ah3, bh0);\n lo = lo + Math.imul(al2, bl1) | 0;\n mid = mid + Math.imul(al2, bh1) | 0;\n mid = mid + Math.imul(ah2, bl1) | 0;\n hi = hi + Math.imul(ah2, bh1) | 0;\n lo = lo + Math.imul(al1, bl2) | 0;\n mid = mid + Math.imul(al1, bh2) | 0;\n mid = mid + Math.imul(ah1, bl2) | 0;\n hi = hi + Math.imul(ah1, bh2) | 0;\n lo = lo + Math.imul(al0, bl3) | 0;\n mid = mid + Math.imul(al0, bh3) | 0;\n mid = mid + Math.imul(ah0, bl3) | 0;\n hi = hi + Math.imul(ah0, bh3) | 0;\n var w3 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w3 >>> 26) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = mid + Math.imul(ah4, bl0) | 0;\n hi = Math.imul(ah4, bh0);\n lo = lo + Math.imul(al3, bl1) | 0;\n mid = mid + Math.imul(al3, bh1) | 0;\n mid = mid + Math.imul(ah3, bl1) | 0;\n hi = hi + Math.imul(ah3, bh1) | 0;\n lo = lo + Math.imul(al2, bl2) | 0;\n mid = mid + Math.imul(al2, bh2) | 0;\n mid = mid + Math.imul(ah2, bl2) | 0;\n hi = hi + Math.imul(ah2, bh2) | 0;\n lo = lo + Math.imul(al1, bl3) | 0;\n mid = mid + Math.imul(al1, bh3) | 0;\n mid = mid + Math.imul(ah1, bl3) | 0;\n hi = hi + Math.imul(ah1, bh3) | 0;\n lo = lo + Math.imul(al0, bl4) | 0;\n mid = mid + Math.imul(al0, bh4) | 0;\n mid = mid + Math.imul(ah0, bl4) | 0;\n hi = hi + Math.imul(ah0, bh4) | 0;\n var w4 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w4 >>> 26) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = mid + Math.imul(ah5, bl0) | 0;\n hi = Math.imul(ah5, bh0);\n lo = lo + Math.imul(al4, bl1) | 0;\n mid = mid + Math.imul(al4, bh1) | 0;\n mid = mid + Math.imul(ah4, bl1) | 0;\n hi = hi + Math.imul(ah4, bh1) | 0;\n lo = lo + Math.imul(al3, bl2) | 0;\n mid = mid + Math.imul(al3, bh2) | 0;\n mid = mid + Math.imul(ah3, bl2) | 0;\n hi = hi + Math.imul(ah3, bh2) | 0;\n lo = lo + Math.imul(al2, bl3) | 0;\n mid = mid + Math.imul(al2, bh3) | 0;\n mid = mid + Math.imul(ah2, bl3) | 0;\n hi = hi + Math.imul(ah2, bh3) | 0;\n lo = lo + Math.imul(al1, bl4) | 0;\n mid = mid + Math.imul(al1, bh4) | 0;\n mid = mid + Math.imul(ah1, bl4) | 0;\n hi = hi + Math.imul(ah1, bh4) | 0;\n lo = lo + Math.imul(al0, bl5) | 0;\n mid = mid + Math.imul(al0, bh5) | 0;\n mid = mid + Math.imul(ah0, bl5) | 0;\n hi = hi + Math.imul(ah0, bh5) | 0;\n var w5 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w5 >>> 26) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = mid + Math.imul(ah6, bl0) | 0;\n hi = Math.imul(ah6, bh0);\n lo = lo + Math.imul(al5, bl1) | 0;\n mid = mid + Math.imul(al5, bh1) | 0;\n mid = mid + Math.imul(ah5, bl1) | 0;\n hi = hi + Math.imul(ah5, bh1) | 0;\n lo = lo + Math.imul(al4, bl2) | 0;\n mid = mid + Math.imul(al4, bh2) | 0;\n mid = mid + Math.imul(ah4, bl2) | 0;\n hi = hi + Math.imul(ah4, bh2) | 0;\n lo = lo + Math.imul(al3, bl3) | 0;\n mid = mid + Math.imul(al3, bh3) | 0;\n mid = mid + Math.imul(ah3, bl3) | 0;\n hi = hi + Math.imul(ah3, bh3) | 0;\n lo = lo + Math.imul(al2, bl4) | 0;\n mid = mid + Math.imul(al2, bh4) | 0;\n mid = mid + Math.imul(ah2, bl4) | 0;\n hi = hi + Math.imul(ah2, bh4) | 0;\n lo = lo + Math.imul(al1, bl5) | 0;\n mid = mid + Math.imul(al1, bh5) | 0;\n mid = mid + Math.imul(ah1, bl5) | 0;\n hi = hi + Math.imul(ah1, bh5) | 0;\n lo = lo + Math.imul(al0, bl6) | 0;\n mid = mid + Math.imul(al0, bh6) | 0;\n mid = mid + Math.imul(ah0, bl6) | 0;\n hi = hi + Math.imul(ah0, bh6) | 0;\n var w6 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w6 >>> 26) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = mid + Math.imul(ah7, bl0) | 0;\n hi = Math.imul(ah7, bh0);\n lo = lo + Math.imul(al6, bl1) | 0;\n mid = mid + Math.imul(al6, bh1) | 0;\n mid = mid + Math.imul(ah6, bl1) | 0;\n hi = hi + Math.imul(ah6, bh1) | 0;\n lo = lo + Math.imul(al5, bl2) | 0;\n mid = mid + Math.imul(al5, bh2) | 0;\n mid = mid + Math.imul(ah5, bl2) | 0;\n hi = hi + Math.imul(ah5, bh2) | 0;\n lo = lo + Math.imul(al4, bl3) | 0;\n mid = mid + Math.imul(al4, bh3) | 0;\n mid = mid + Math.imul(ah4, bl3) | 0;\n hi = hi + Math.imul(ah4, bh3) | 0;\n lo = lo + Math.imul(al3, bl4) | 0;\n mid = mid + Math.imul(al3, bh4) | 0;\n mid = mid + Math.imul(ah3, bl4) | 0;\n hi = hi + Math.imul(ah3, bh4) | 0;\n lo = lo + Math.imul(al2, bl5) | 0;\n mid = mid + Math.imul(al2, bh5) | 0;\n mid = mid + Math.imul(ah2, bl5) | 0;\n hi = hi + Math.imul(ah2, bh5) | 0;\n lo = lo + Math.imul(al1, bl6) | 0;\n mid = mid + Math.imul(al1, bh6) | 0;\n mid = mid + Math.imul(ah1, bl6) | 0;\n hi = hi + Math.imul(ah1, bh6) | 0;\n lo = lo + Math.imul(al0, bl7) | 0;\n mid = mid + Math.imul(al0, bh7) | 0;\n mid = mid + Math.imul(ah0, bl7) | 0;\n hi = hi + Math.imul(ah0, bh7) | 0;\n var w7 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w7 >>> 26) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = mid + Math.imul(ah8, bl0) | 0;\n hi = Math.imul(ah8, bh0);\n lo = lo + Math.imul(al7, bl1) | 0;\n mid = mid + Math.imul(al7, bh1) | 0;\n mid = mid + Math.imul(ah7, bl1) | 0;\n hi = hi + Math.imul(ah7, bh1) | 0;\n lo = lo + Math.imul(al6, bl2) | 0;\n mid = mid + Math.imul(al6, bh2) | 0;\n mid = mid + Math.imul(ah6, bl2) | 0;\n hi = hi + Math.imul(ah6, bh2) | 0;\n lo = lo + Math.imul(al5, bl3) | 0;\n mid = mid + Math.imul(al5, bh3) | 0;\n mid = mid + Math.imul(ah5, bl3) | 0;\n hi = hi + Math.imul(ah5, bh3) | 0;\n lo = lo + Math.imul(al4, bl4) | 0;\n mid = mid + Math.imul(al4, bh4) | 0;\n mid = mid + Math.imul(ah4, bl4) | 0;\n hi = hi + Math.imul(ah4, bh4) | 0;\n lo = lo + Math.imul(al3, bl5) | 0;\n mid = mid + Math.imul(al3, bh5) | 0;\n mid = mid + Math.imul(ah3, bl5) | 0;\n hi = hi + Math.imul(ah3, bh5) | 0;\n lo = lo + Math.imul(al2, bl6) | 0;\n mid = mid + Math.imul(al2, bh6) | 0;\n mid = mid + Math.imul(ah2, bl6) | 0;\n hi = hi + Math.imul(ah2, bh6) | 0;\n lo = lo + Math.imul(al1, bl7) | 0;\n mid = mid + Math.imul(al1, bh7) | 0;\n mid = mid + Math.imul(ah1, bl7) | 0;\n hi = hi + Math.imul(ah1, bh7) | 0;\n lo = lo + Math.imul(al0, bl8) | 0;\n mid = mid + Math.imul(al0, bh8) | 0;\n mid = mid + Math.imul(ah0, bl8) | 0;\n hi = hi + Math.imul(ah0, bh8) | 0;\n var w8 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w8 >>> 26) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = mid + Math.imul(ah9, bl0) | 0;\n hi = Math.imul(ah9, bh0);\n lo = lo + Math.imul(al8, bl1) | 0;\n mid = mid + Math.imul(al8, bh1) | 0;\n mid = mid + Math.imul(ah8, bl1) | 0;\n hi = hi + Math.imul(ah8, bh1) | 0;\n lo = lo + Math.imul(al7, bl2) | 0;\n mid = mid + Math.imul(al7, bh2) | 0;\n mid = mid + Math.imul(ah7, bl2) | 0;\n hi = hi + Math.imul(ah7, bh2) | 0;\n lo = lo + Math.imul(al6, bl3) | 0;\n mid = mid + Math.imul(al6, bh3) | 0;\n mid = mid + Math.imul(ah6, bl3) | 0;\n hi = hi + Math.imul(ah6, bh3) | 0;\n lo = lo + Math.imul(al5, bl4) | 0;\n mid = mid + Math.imul(al5, bh4) | 0;\n mid = mid + Math.imul(ah5, bl4) | 0;\n hi = hi + Math.imul(ah5, bh4) | 0;\n lo = lo + Math.imul(al4, bl5) | 0;\n mid = mid + Math.imul(al4, bh5) | 0;\n mid = mid + Math.imul(ah4, bl5) | 0;\n hi = hi + Math.imul(ah4, bh5) | 0;\n lo = lo + Math.imul(al3, bl6) | 0;\n mid = mid + Math.imul(al3, bh6) | 0;\n mid = mid + Math.imul(ah3, bl6) | 0;\n hi = hi + Math.imul(ah3, bh6) | 0;\n lo = lo + Math.imul(al2, bl7) | 0;\n mid = mid + Math.imul(al2, bh7) | 0;\n mid = mid + Math.imul(ah2, bl7) | 0;\n hi = hi + Math.imul(ah2, bh7) | 0;\n lo = lo + Math.imul(al1, bl8) | 0;\n mid = mid + Math.imul(al1, bh8) | 0;\n mid = mid + Math.imul(ah1, bl8) | 0;\n hi = hi + Math.imul(ah1, bh8) | 0;\n lo = lo + Math.imul(al0, bl9) | 0;\n mid = mid + Math.imul(al0, bh9) | 0;\n mid = mid + Math.imul(ah0, bl9) | 0;\n hi = hi + Math.imul(ah0, bh9) | 0;\n var w9 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w9 >>> 26) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = mid + Math.imul(ah9, bl1) | 0;\n hi = Math.imul(ah9, bh1);\n lo = lo + Math.imul(al8, bl2) | 0;\n mid = mid + Math.imul(al8, bh2) | 0;\n mid = mid + Math.imul(ah8, bl2) | 0;\n hi = hi + Math.imul(ah8, bh2) | 0;\n lo = lo + Math.imul(al7, bl3) | 0;\n mid = mid + Math.imul(al7, bh3) | 0;\n mid = mid + Math.imul(ah7, bl3) | 0;\n hi = hi + Math.imul(ah7, bh3) | 0;\n lo = lo + Math.imul(al6, bl4) | 0;\n mid = mid + Math.imul(al6, bh4) | 0;\n mid = mid + Math.imul(ah6, bl4) | 0;\n hi = hi + Math.imul(ah6, bh4) | 0;\n lo = lo + Math.imul(al5, bl5) | 0;\n mid = mid + Math.imul(al5, bh5) | 0;\n mid = mid + Math.imul(ah5, bl5) | 0;\n hi = hi + Math.imul(ah5, bh5) | 0;\n lo = lo + Math.imul(al4, bl6) | 0;\n mid = mid + Math.imul(al4, bh6) | 0;\n mid = mid + Math.imul(ah4, bl6) | 0;\n hi = hi + Math.imul(ah4, bh6) | 0;\n lo = lo + Math.imul(al3, bl7) | 0;\n mid = mid + Math.imul(al3, bh7) | 0;\n mid = mid + Math.imul(ah3, bl7) | 0;\n hi = hi + Math.imul(ah3, bh7) | 0;\n lo = lo + Math.imul(al2, bl8) | 0;\n mid = mid + Math.imul(al2, bh8) | 0;\n mid = mid + Math.imul(ah2, bl8) | 0;\n hi = hi + Math.imul(ah2, bh8) | 0;\n lo = lo + Math.imul(al1, bl9) | 0;\n mid = mid + Math.imul(al1, bh9) | 0;\n mid = mid + Math.imul(ah1, bl9) | 0;\n hi = hi + Math.imul(ah1, bh9) | 0;\n var w10 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w10 >>> 26) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = mid + Math.imul(ah9, bl2) | 0;\n hi = Math.imul(ah9, bh2);\n lo = lo + Math.imul(al8, bl3) | 0;\n mid = mid + Math.imul(al8, bh3) | 0;\n mid = mid + Math.imul(ah8, bl3) | 0;\n hi = hi + Math.imul(ah8, bh3) | 0;\n lo = lo + Math.imul(al7, bl4) | 0;\n mid = mid + Math.imul(al7, bh4) | 0;\n mid = mid + Math.imul(ah7, bl4) | 0;\n hi = hi + Math.imul(ah7, bh4) | 0;\n lo = lo + Math.imul(al6, bl5) | 0;\n mid = mid + Math.imul(al6, bh5) | 0;\n mid = mid + Math.imul(ah6, bl5) | 0;\n hi = hi + Math.imul(ah6, bh5) | 0;\n lo = lo + Math.imul(al5, bl6) | 0;\n mid = mid + Math.imul(al5, bh6) | 0;\n mid = mid + Math.imul(ah5, bl6) | 0;\n hi = hi + Math.imul(ah5, bh6) | 0;\n lo = lo + Math.imul(al4, bl7) | 0;\n mid = mid + Math.imul(al4, bh7) | 0;\n mid = mid + Math.imul(ah4, bl7) | 0;\n hi = hi + Math.imul(ah4, bh7) | 0;\n lo = lo + Math.imul(al3, bl8) | 0;\n mid = mid + Math.imul(al3, bh8) | 0;\n mid = mid + Math.imul(ah3, bl8) | 0;\n hi = hi + Math.imul(ah3, bh8) | 0;\n lo = lo + Math.imul(al2, bl9) | 0;\n mid = mid + Math.imul(al2, bh9) | 0;\n mid = mid + Math.imul(ah2, bl9) | 0;\n hi = hi + Math.imul(ah2, bh9) | 0;\n var w11 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w11 >>> 26) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = mid + Math.imul(ah9, bl3) | 0;\n hi = Math.imul(ah9, bh3);\n lo = lo + Math.imul(al8, bl4) | 0;\n mid = mid + Math.imul(al8, bh4) | 0;\n mid = mid + Math.imul(ah8, bl4) | 0;\n hi = hi + Math.imul(ah8, bh4) | 0;\n lo = lo + Math.imul(al7, bl5) | 0;\n mid = mid + Math.imul(al7, bh5) | 0;\n mid = mid + Math.imul(ah7, bl5) | 0;\n hi = hi + Math.imul(ah7, bh5) | 0;\n lo = lo + Math.imul(al6, bl6) | 0;\n mid = mid + Math.imul(al6, bh6) | 0;\n mid = mid + Math.imul(ah6, bl6) | 0;\n hi = hi + Math.imul(ah6, bh6) | 0;\n lo = lo + Math.imul(al5, bl7) | 0;\n mid = mid + Math.imul(al5, bh7) | 0;\n mid = mid + Math.imul(ah5, bl7) | 0;\n hi = hi + Math.imul(ah5, bh7) | 0;\n lo = lo + Math.imul(al4, bl8) | 0;\n mid = mid + Math.imul(al4, bh8) | 0;\n mid = mid + Math.imul(ah4, bl8) | 0;\n hi = hi + Math.imul(ah4, bh8) | 0;\n lo = lo + Math.imul(al3, bl9) | 0;\n mid = mid + Math.imul(al3, bh9) | 0;\n mid = mid + Math.imul(ah3, bl9) | 0;\n hi = hi + Math.imul(ah3, bh9) | 0;\n var w12 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w12 >>> 26) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = mid + Math.imul(ah9, bl4) | 0;\n hi = Math.imul(ah9, bh4);\n lo = lo + Math.imul(al8, bl5) | 0;\n mid = mid + Math.imul(al8, bh5) | 0;\n mid = mid + Math.imul(ah8, bl5) | 0;\n hi = hi + Math.imul(ah8, bh5) | 0;\n lo = lo + Math.imul(al7, bl6) | 0;\n mid = mid + Math.imul(al7, bh6) | 0;\n mid = mid + Math.imul(ah7, bl6) | 0;\n hi = hi + Math.imul(ah7, bh6) | 0;\n lo = lo + Math.imul(al6, bl7) | 0;\n mid = mid + Math.imul(al6, bh7) | 0;\n mid = mid + Math.imul(ah6, bl7) | 0;\n hi = hi + Math.imul(ah6, bh7) | 0;\n lo = lo + Math.imul(al5, bl8) | 0;\n mid = mid + Math.imul(al5, bh8) | 0;\n mid = mid + Math.imul(ah5, bl8) | 0;\n hi = hi + Math.imul(ah5, bh8) | 0;\n lo = lo + Math.imul(al4, bl9) | 0;\n mid = mid + Math.imul(al4, bh9) | 0;\n mid = mid + Math.imul(ah4, bl9) | 0;\n hi = hi + Math.imul(ah4, bh9) | 0;\n var w13 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w13 >>> 26) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = mid + Math.imul(ah9, bl5) | 0;\n hi = Math.imul(ah9, bh5);\n lo = lo + Math.imul(al8, bl6) | 0;\n mid = mid + Math.imul(al8, bh6) | 0;\n mid = mid + Math.imul(ah8, bl6) | 0;\n hi = hi + Math.imul(ah8, bh6) | 0;\n lo = lo + Math.imul(al7, bl7) | 0;\n mid = mid + Math.imul(al7, bh7) | 0;\n mid = mid + Math.imul(ah7, bl7) | 0;\n hi = hi + Math.imul(ah7, bh7) | 0;\n lo = lo + Math.imul(al6, bl8) | 0;\n mid = mid + Math.imul(al6, bh8) | 0;\n mid = mid + Math.imul(ah6, bl8) | 0;\n hi = hi + Math.imul(ah6, bh8) | 0;\n lo = lo + Math.imul(al5, bl9) | 0;\n mid = mid + Math.imul(al5, bh9) | 0;\n mid = mid + Math.imul(ah5, bl9) | 0;\n hi = hi + Math.imul(ah5, bh9) | 0;\n var w14 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w14 >>> 26) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = mid + Math.imul(ah9, bl6) | 0;\n hi = Math.imul(ah9, bh6);\n lo = lo + Math.imul(al8, bl7) | 0;\n mid = mid + Math.imul(al8, bh7) | 0;\n mid = mid + Math.imul(ah8, bl7) | 0;\n hi = hi + Math.imul(ah8, bh7) | 0;\n lo = lo + Math.imul(al7, bl8) | 0;\n mid = mid + Math.imul(al7, bh8) | 0;\n mid = mid + Math.imul(ah7, bl8) | 0;\n hi = hi + Math.imul(ah7, bh8) | 0;\n lo = lo + Math.imul(al6, bl9) | 0;\n mid = mid + Math.imul(al6, bh9) | 0;\n mid = mid + Math.imul(ah6, bl9) | 0;\n hi = hi + Math.imul(ah6, bh9) | 0;\n var w15 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w15 >>> 26) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = mid + Math.imul(ah9, bl7) | 0;\n hi = Math.imul(ah9, bh7);\n lo = lo + Math.imul(al8, bl8) | 0;\n mid = mid + Math.imul(al8, bh8) | 0;\n mid = mid + Math.imul(ah8, bl8) | 0;\n hi = hi + Math.imul(ah8, bh8) | 0;\n lo = lo + Math.imul(al7, bl9) | 0;\n mid = mid + Math.imul(al7, bh9) | 0;\n mid = mid + Math.imul(ah7, bl9) | 0;\n hi = hi + Math.imul(ah7, bh9) | 0;\n var w16 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w16 >>> 26) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = mid + Math.imul(ah9, bl8) | 0;\n hi = Math.imul(ah9, bh8);\n lo = lo + Math.imul(al8, bl9) | 0;\n mid = mid + Math.imul(al8, bh9) | 0;\n mid = mid + Math.imul(ah8, bl9) | 0;\n hi = hi + Math.imul(ah8, bh9) | 0;\n var w17 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w17 >>> 26) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = mid + Math.imul(ah9, bl9) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w18 >>> 26) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n function bigMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n ncarry = ncarry + (r / 0x4000000 | 0) | 0;\n lo = lo + rword | 0;\n rword = lo & 0x3ffffff;\n ncarry = ncarry + (lo >>> 26) | 0;\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n return out.strip();\n }\n function jumboMulTo(self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n BN.prototype.mulTo = function mulTo(num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM(x, y) {\n this.x = x;\n this.y = y;\n }\n FFTM.prototype.makeRBT = function makeRBT(N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin(x, l, N) {\n if (x === 0 || x === N - 1) return x;\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << l - i - 1;\n x >>= 1;\n }\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute(rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n FFTM.prototype.transform = function transform(rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n var rx = rtwdf_ * ro - itwdf_ * io;\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n FFTM.prototype.guessLen13b = function guessLen13b(n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n return 1 << i + 1 + odd;\n };\n FFTM.prototype.conjugate = function conjugate(rws, iws, N) {\n if (N <= 1) return;\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n t = iws[i];\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n FFTM.prototype.normalize13b = function normalize13b(ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 + Math.round(ws[2 * i] / N) + carry;\n ws[i] = w & 0x3ffffff;\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n return ws;\n };\n FFTM.prototype.convert13b = function convert13b(ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n rws[2 * i] = carry & 0x1fff;\n carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff;\n carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n FFTM.prototype.stub = function stub(N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n return ph;\n };\n FFTM.prototype.mulp = function mulp(x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n var rbt = this.makeRBT(N);\n var _ = this.stub(N);\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n var rmws = out.words;\n rmws.length = N;\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul(num) {\n return this.clone().mulTo(num, this);\n };\n BN.prototype.imuln = function imuln(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += w / 0x4000000 | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.muln = function muln(num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr() {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr() {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow(num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n res = res.mul(q);\n }\n }\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = 0x3ffffff >>> 26 - r << 26 - r;\n var i;\n if (r !== 0) {\n var carry = 0;\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = (this.words[i] | 0) - newCarry << r;\n this.words[i] = c | carry;\n carry = newCarry >>> 26 - r;\n }\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n this.length += s;\n }\n return this.strip();\n };\n BN.prototype.ishln = function ishln(bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn(bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - hint % 26) / 26;\n } else {\n h = 0;\n }\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n var maskedWords = extended;\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = carry << 26 - r | word >>> r;\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n return this.strip();\n };\n BN.prototype.ishrn = function ishrn(bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln(bits) {\n return this.clone().ishln(bits);\n };\n BN.prototype.ushln = function ushln(bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn(bits) {\n return this.clone().ishrn(bits);\n };\n BN.prototype.ushrn = function ushrn(bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn(bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n if (this.length <= s) {\n return this;\n }\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n if (r !== 0) {\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n this.words[this.length - 1] &= mask;\n }\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn(bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n BN.prototype._iaddn = function _iaddn(num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n this.words[0] -= num;\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n return this.strip();\n };\n BN.prototype.addn = function addn(num) {\n return this.clone().iaddn(num);\n };\n BN.prototype.subn = function subn(num) {\n return this.clone().isubn(num);\n };\n BN.prototype.iabs = function iabs() {\n this.negative = 0;\n return this;\n };\n BN.prototype.abs = function abs() {\n return this.clone().iabs();\n };\n BN.prototype._ishlnsubmul = function _ishlnsubmul(num, mul, shift) {\n var len = num.length + shift;\n var i;\n this._expand(len);\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - (right / 0x4000000 | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n return this.strip();\n };\n BN.prototype._wordDiv = function _wordDiv(num, mode) {\n var shift = this.length - num.length;\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 + (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min(qj / bhi | 0, 0x3ffffff);\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod(num, mode, positive) {\n assert(!num.isZero());\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n return {\n div: div,\n mod: mod\n };\n }\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n return {\n div: div,\n mod: res.mod\n };\n }\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div(num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod(num) {\n return this.divmod(num, 'mod', false).mod;\n };\n BN.prototype.umod = function umod(num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound(num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n BN.prototype.modn = function modn(num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn(num) {\n assert(num <= 0x3ffffff);\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = w / num | 0;\n carry = w % num;\n }\n return this.strip();\n };\n BN.prototype.divn = function divn(num) {\n return this.clone().idivn(num);\n };\n BN.prototype.egcd = function egcd(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var x = this;\n var y = p.clone();\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n var g = 0;\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n var yp = y.clone();\n var xp = x.clone();\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var a = this;\n var b = p.clone();\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n var x1 = new BN(1);\n var x2 = new BN(0);\n var delta = b.clone();\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n x1.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n x2.iushrn(1);\n }\n }\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n return res;\n };\n BN.prototype.gcd = function gcd(num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n a.isub(b);\n } while (true);\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm(num) {\n return this.egcd(num).a.umod(num);\n };\n BN.prototype.isEven = function isEven() {\n return (this.words[0] & 1) === 0;\n };\n BN.prototype.isOdd = function isOdd() {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln(num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn(bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.isZero = function isZero() {\n return this.length === 1 && this.words[0] === 0;\n };\n BN.prototype.cmpn = function cmpn(num) {\n var negative = num < 0;\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n this.strip();\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n assert(num <= 0x3ffffff, 'Number is too big');\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp(num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp(num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n BN.prototype.gtn = function gtn(num) {\n return this.cmpn(num) === 1;\n };\n BN.prototype.gt = function gt(num) {\n return this.cmp(num) === 1;\n };\n BN.prototype.gten = function gten(num) {\n return this.cmpn(num) >= 0;\n };\n BN.prototype.gte = function gte(num) {\n return this.cmp(num) >= 0;\n };\n BN.prototype.ltn = function ltn(num) {\n return this.cmpn(num) === -1;\n };\n BN.prototype.lt = function lt(num) {\n return this.cmp(num) === -1;\n };\n BN.prototype.lten = function lten(num) {\n return this.cmpn(num) <= 0;\n };\n BN.prototype.lte = function lte(num) {\n return this.cmp(num) <= 0;\n };\n BN.prototype.eqn = function eqn(num) {\n return this.cmpn(num) === 0;\n };\n BN.prototype.eq = function eq(num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red(num) {\n return new Red(num);\n };\n BN.prototype.toRed = function toRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n BN.prototype.fromRed = function fromRed() {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n BN.prototype._forceRed = function _forceRed(ctx) {\n this.red = ctx;\n return this;\n };\n BN.prototype.forceRed = function forceRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n BN.prototype.redAdd = function redAdd(num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n BN.prototype.redIAdd = function redIAdd(num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n BN.prototype.redSub = function redSub(num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n BN.prototype.redISub = function redISub(num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n BN.prototype.redShl = function redShl(num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n BN.prototype.redMul = function redMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n BN.prototype.redIMul = function redIMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n BN.prototype.redSqr = function redSqr() {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n BN.prototype.redISqr = function redISqr() {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt() {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n BN.prototype.redInvm = function redInvm() {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg() {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n BN.prototype.redPow = function redPow(num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime(name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n this.tmp = this._tmp();\n }\n MPrime.prototype._tmp = function _tmp() {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n MPrime.prototype.ireduce = function ireduce(num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n r.strip();\n }\n return r;\n };\n MPrime.prototype.split = function split(input, out) {\n input.iushrn(this.n, 0, out);\n };\n MPrime.prototype.imulK = function imulK(num) {\n return num.imul(this.k);\n };\n function K256() {\n MPrime.call(this, 'k256', 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n K256.prototype.split = function split(input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = (next & mask) << 4 | prev >>> 22;\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n K256.prototype.imulK = function imulK(num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + (lo / 0x4000000 | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n function P224() {\n MPrime.call(this, 'p224', 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n function P192() {\n MPrime.call(this, 'p192', 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n function P25519() {\n // 2 ^ 255 - 19\n MPrime.call(this, '25519', '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n P25519.prototype.imulK = function imulK(num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime(name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red(m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n Red.prototype._verify1 = function _verify1(a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n Red.prototype._verify2 = function _verify2(a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red, 'red works only with red numbers');\n };\n Red.prototype.imod = function imod(a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n Red.prototype.neg = function neg(a) {\n if (a.isZero()) {\n return a.clone();\n }\n return this.m.sub(a)._forceRed(this);\n };\n Red.prototype.add = function add(a, b) {\n this._verify2(a, b);\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.iadd = function iadd(a, b) {\n this._verify2(a, b);\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n Red.prototype.sub = function sub(a, b) {\n this._verify2(a, b);\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.isub = function isub(a, b) {\n this._verify2(a, b);\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n Red.prototype.shl = function shl(a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n Red.prototype.imul = function imul(a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n Red.prototype.mul = function mul(a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n Red.prototype.isqr = function isqr(a) {\n return this.imul(a, a.clone());\n };\n Red.prototype.sqr = function sqr(a) {\n return this.mul(a, a);\n };\n Red.prototype.sqrt = function sqrt(a) {\n if (a.isZero()) return a.clone();\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n return r;\n };\n Red.prototype.invm = function invm(a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n Red.prototype.pow = function pow(a, num) {\n if (num.isZero()) return new BN(1);\n if (num.cmpn(1) === 0) return a.clone();\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = word >> j & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n return res;\n };\n Red.prototype.convertTo = function convertTo(num) {\n var r = num.umod(this.m);\n return r === num ? r.clone() : r;\n };\n Red.prototype.convertFrom = function convertFrom(num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont(num) {\n return new Mont(num);\n };\n function Mont(m) {\n Red.call(this, m);\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - this.shift % 26;\n }\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n Mont.prototype.convertTo = function convertTo(num) {\n return this.imod(num.ushln(this.shift));\n };\n Mont.prototype.convertFrom = function convertFrom(num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n Mont.prototype.imul = function imul(a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.mul = function mul(a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.invm = function invm(a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);","'use strict';\n\nvar BN = require('bn.js');\nvar numberToBN = require('number-to-bn');\nvar zero = new BN(0);\nvar negative1 = new BN(-1);\n\n// complete ethereum unit map\nvar unitMap = {\n 'noether': '0',\n // eslint-disable-line\n 'wei': '1',\n // eslint-disable-line\n 'kwei': '1000',\n // eslint-disable-line\n 'Kwei': '1000',\n // eslint-disable-line\n 'babbage': '1000',\n // eslint-disable-line\n 'femtoether': '1000',\n // eslint-disable-line\n 'mwei': '1000000',\n // eslint-disable-line\n 'Mwei': '1000000',\n // eslint-disable-line\n 'lovelace': '1000000',\n // eslint-disable-line\n 'picoether': '1000000',\n // eslint-disable-line\n 'gwei': '1000000000',\n // eslint-disable-line\n 'Gwei': '1000000000',\n // eslint-disable-line\n 'shannon': '1000000000',\n // eslint-disable-line\n 'nanoether': '1000000000',\n // eslint-disable-line\n 'nano': '1000000000',\n // eslint-disable-line\n 'szabo': '1000000000000',\n // eslint-disable-line\n 'microether': '1000000000000',\n // eslint-disable-line\n 'micro': '1000000000000',\n // eslint-disable-line\n 'finney': '1000000000000000',\n // eslint-disable-line\n 'milliether': '1000000000000000',\n // eslint-disable-line\n 'milli': '1000000000000000',\n // eslint-disable-line\n 'ether': '1000000000000000000',\n // eslint-disable-line\n 'kether': '1000000000000000000000',\n // eslint-disable-line\n 'grand': '1000000000000000000000',\n // eslint-disable-line\n 'mether': '1000000000000000000000000',\n // eslint-disable-line\n 'gether': '1000000000000000000000000000',\n // eslint-disable-line\n 'tether': '1000000000000000000000000000000'\n};\n\n/**\n * Returns value of unit in Wei\n *\n * @method getValueOfUnit\n * @param {String} unit the unit to convert to, default ether\n * @returns {BigNumber} value of the unit (in Wei)\n * @throws error if the unit is not correct:w\n */\nfunction getValueOfUnit(unitInput) {\n var unit = unitInput ? unitInput.toLowerCase() : 'ether';\n var unitValue = unitMap[unit]; // eslint-disable-line\n\n if (typeof unitValue !== 'string') {\n throw new Error('[ethjs-unit] the unit provided ' + unitInput + ' doesn\\'t exists, please use the one of the following units ' + JSON.stringify(unitMap, null, 2));\n }\n return new BN(unitValue, 10);\n}\nfunction numberToString(arg) {\n if (typeof arg === 'string') {\n if (!arg.match(/^-?[0-9.]+$/)) {\n throw new Error('while converting number to string, invalid number value \\'' + arg + '\\', should be a number matching (^-?[0-9.]+).');\n }\n return arg;\n } else if (typeof arg === 'number') {\n return String(arg);\n } else if (typeof arg === 'object' && arg.toString && (arg.toTwos || arg.dividedToIntegerBy)) {\n if (arg.toPrecision) {\n return String(arg.toPrecision());\n } else {\n // eslint-disable-line\n return arg.toString(10);\n }\n }\n throw new Error('while converting number to string, invalid number value \\'' + arg + '\\' type ' + typeof arg + '.');\n}\nfunction fromWei(weiInput, unit, optionsInput) {\n var wei = numberToBN(weiInput); // eslint-disable-line\n var negative = wei.lt(zero); // eslint-disable-line\n var base = getValueOfUnit(unit);\n var baseLength = unitMap[unit].length - 1 || 1;\n var options = optionsInput || {};\n if (negative) {\n wei = wei.mul(negative1);\n }\n var fraction = wei.mod(base).toString(10); // eslint-disable-line\n\n while (fraction.length < baseLength) {\n fraction = '0' + fraction;\n }\n if (!options.pad) {\n fraction = fraction.match(/^([0-9]*[1-9]|0)(0*)/)[1];\n }\n var whole = wei.div(base).toString(10); // eslint-disable-line\n\n if (options.commify) {\n whole = whole.replace(/\\B(?=(\\d{3})+(?!\\d))/g, ',');\n }\n var value = '' + whole + (fraction == '0' ? '' : '.' + fraction); // eslint-disable-line\n\n if (negative) {\n value = '-' + value;\n }\n return value;\n}\nfunction toWei(etherInput, unit) {\n var ether = numberToString(etherInput); // eslint-disable-line\n var base = getValueOfUnit(unit);\n var baseLength = unitMap[unit].length - 1 || 1;\n\n // Is it negative?\n var negative = ether.substring(0, 1) === '-'; // eslint-disable-line\n if (negative) {\n ether = ether.substring(1);\n }\n if (ether === '.') {\n throw new Error('[ethjs-unit] while converting number ' + etherInput + ' to wei, invalid value');\n }\n\n // Split it into a whole and fractional part\n var comps = ether.split('.'); // eslint-disable-line\n if (comps.length > 2) {\n throw new Error('[ethjs-unit] while converting number ' + etherInput + ' to wei, too many decimal points');\n }\n var whole = comps[0],\n fraction = comps[1]; // eslint-disable-line\n\n if (!whole) {\n whole = '0';\n }\n if (!fraction) {\n fraction = '0';\n }\n if (fraction.length > baseLength) {\n throw new Error('[ethjs-unit] while converting number ' + etherInput + ' to wei, too many decimal places');\n }\n while (fraction.length < baseLength) {\n fraction += '0';\n }\n whole = new BN(whole);\n fraction = new BN(fraction);\n var wei = whole.mul(base).add(fraction); // eslint-disable-line\n\n if (negative) {\n wei = wei.mul(negative1);\n }\n return new BN(wei.toString(10), 10);\n}\nmodule.exports = {\n unitMap: unitMap,\n numberToString: numberToString,\n getValueOfUnit: getValueOfUnit,\n fromWei: fromWei,\n toWei: toWei\n};","\"use strict\";\n\n/* eslint-disable */\n// @ts-nocheck\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getUnitValue = exports.fromWei = exports.toWei = exports.toHex = exports.isBigNumber = exports.toBN = void 0;\n// Utilities from Web3.js library that need to be replaced\nconst bn_js_1 = __importDefault(require(\"bn.js\"));\nconst number_to_bn_1 = __importDefault(require(\"number-to-bn\"));\nconst ethjs_unit_1 = __importDefault(require(\"ethjs-unit\"));\n/**\n * Takes an input and transforms it into an BN\n *\n * @method toBN\n * @param {Number|String|BN} number, string, HEX string or BN\n * @return {BN} BN\n */\nvar toBN = function (number) {\n try {\n return number_to_bn_1.default.apply(null, arguments);\n } catch (e) {\n throw new Error(e + ' Given value: \"' + number + '\"');\n }\n};\nexports.toBN = toBN;\nfunction isBigNumber(object) {\n var _a, _b;\n return ((_a = object === null || object === void 0 ? void 0 : object.constructor) === null || _a === void 0 ? void 0 : _a.name) === 'BigNumber' || ((_b = object === null || object === void 0 ? void 0 : object.constructor) === null || _b === void 0 ? void 0 : _b.name) === 'BN';\n}\nexports.isBigNumber = isBigNumber;\n/**\n * Auto converts any given value into it's hex representation.\n *\n * And even stringifys objects before.\n *\n * @method toHex\n * @param {String|Number|BN|Object|Buffer} value\n * @param {Boolean} returnType\n * @return {String}\n */\nvar toHex = function (value, returnType) {\n /*jshint maxcomplexity: false */\n if (isAddress(value)) {\n return returnType ? 'address' : '0x' + value.toLowerCase().replace(/^0x/i, '');\n }\n if (typeof value === 'boolean') {\n return returnType ? 'bool' : value ? '0x01' : '0x00';\n }\n if (Buffer.isBuffer(value)) {\n return '0x' + value.toString('hex');\n }\n if (typeof value === 'object' && !!value && !isBigNumber(value) && !isBN(value)) {\n return returnType ? 'string' : utf8ToHex(JSON.stringify(value));\n }\n // if its a negative number, pass it through numberToHex\n if (typeof value === 'string') {\n if (value.indexOf('-0x') === 0 || value.indexOf('-0X') === 0) {\n return returnType ? 'int256' : numberToHex(value);\n } else if (value.indexOf('0x') === 0 || value.indexOf('0X') === 0) {\n return returnType ? 'bytes' : value;\n } else if (!isFinite(value)) {\n return returnType ? 'string' : utf8ToHex(value);\n }\n }\n return returnType ? value < 0 ? 'int256' : 'uint256' : numberToHex(value);\n};\nexports.toHex = toHex;\n/**\n * Converts value to it's hex representation\n *\n * @method numberToHex\n * @param {String|Number|BN} value\n * @return {String}\n */\nvar numberToHex = function (value) {\n if (value === null || value === undefined) {\n return value;\n }\n if (!isFinite(value) && !isHexStrict(value)) {\n throw new Error('Given input \"' + value + '\" is not a number.');\n }\n var number = (0, exports.toBN)(value);\n var result = number.toString(16);\n return number.lt(new bn_js_1.default(0)) ? '-0x' + result.slice(1) : '0x' + result;\n};\n/**\n * Checks if the given string is an address\n *\n * @method isAddress\n * @param {String} address the given HEX address\n * @return {Boolean}\n */\nvar isAddress = function (address) {\n // check if it has the basic requirements of an address\n if (!/^(0x)?[0-9a-f]{40}$/i.test(address)) {\n return false;\n // If it's ALL lowercase or ALL upppercase\n } else if (/^(0x|0X)?[0-9a-f]{40}$/.test(address) || /^(0x|0X)?[0-9A-F]{40}$/.test(address)) {\n return true;\n // Otherwise check each case\n } else {\n return checkAddressChecksum(address);\n }\n};\n// TODO TODO!!!\nvar checkAddressChecksum = function (address) {\n return true;\n};\n/**\n * Check if string is HEX, requires a 0x in front\n *\n * @method isHexStrict\n * @param {String} hex to be checked\n * @returns {Boolean}\n */\nvar isHexStrict = function (hex) {\n return (typeof hex === 'string' || typeof hex === 'number') && /^(-)?0x[0-9a-f]*$/i.test(hex);\n};\n/**\n * Takes a number of a unit and converts it to wei.\n *\n * Possible units are:\n * SI Short SI Full Effigy Other\n * - kwei femtoether babbage\n * - mwei picoether lovelace\n * - gwei nanoether shannon nano\n * - -- microether szabo micro\n * - -- microether szabo micro\n * - -- milliether finney milli\n * - ether -- --\n * - kether -- grand\n * - mether\n * - gether\n * - tether\n *\n * @method toWei\n * @param {Number|String|BN} number can be a number, number string or a HEX of a decimal\n * @param {String} unit the unit to convert from, default ether\n * @return {String|Object} When given a BN object it returns one as well, otherwise a number\n */\nvar toWei = function (number, unit) {\n unit = (0, exports.getUnitValue)(unit);\n if (!isBN(number) && !(typeof number === 'string')) {\n throw new Error('Please pass numbers as strings or BN objects to avoid precision errors.');\n }\n return isBN(number) ? ethjs_unit_1.default.toWei(number, unit) : ethjs_unit_1.default.toWei(number, unit).toString(10);\n};\nexports.toWei = toWei;\n/**\n * Takes a number of wei and converts it to any other ether unit.\n *\n * Possible units are:\n * SI Short SI Full Effigy Other\n * - kwei femtoether babbage\n * - mwei picoether lovelace\n * - gwei nanoether shannon nano\n * - -- microether szabo micro\n * - -- milliether finney milli\n * - ether -- --\n * - kether -- grand\n * - mether\n * - gether\n * - tether\n *\n * @method fromWei\n * @param {Number|String} number can be a number, number string or a HEX of a decimal\n * @param {String} unit the unit to convert to, default ether\n * @return {String|Object} When given a BN object it returns one as well, otherwise a number\n */\nvar fromWei = function (number, unit) {\n unit = (0, exports.getUnitValue)(unit);\n if (!isBN(number) && !(typeof number === 'string')) {\n throw new Error('Please pass numbers as strings or BN objects to avoid precision errors.');\n }\n return ethjs_unit_1.default.fromWei(number, unit).toString(10);\n};\nexports.fromWei = fromWei;\n/**\n * Returns true if object is BN, otherwise false\n *\n * @method isBN\n * @param {Object} object\n * @return {Boolean}\n */\nvar isBN = function (object) {\n return bn_js_1.default.isBN(object);\n};\n/**\n * Returns value of unit in Wei\n *\n * @method getUnitValue\n * @param {String} unit the unit to convert to, default ether\n * @returns {BN} value of the unit (in Wei)\n * @throws error if the unit is not correct:w\n */\nvar getUnitValue = function (unit) {\n unit = unit ? unit.toLowerCase() : 'ether';\n if (!ethjs_unit_1.default.unitMap[unit]) {\n throw new Error('This unit \"' + unit + '\" doesn\\'t exist, please use the one of the following units' + JSON.stringify(ethjs_unit_1.default.unitMap, null, 2));\n }\n return unit;\n};\nexports.getUnitValue = getUnitValue;\n","export const version = \"contracts/5.7.0\";\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { checkResultErrors, Indexed, Interface } from \"@ethersproject/abi\";\nimport { Provider } from \"@ethersproject/abstract-provider\";\nimport { Signer, VoidSigner } from \"@ethersproject/abstract-signer\";\nimport { getAddress, getContractAddress } from \"@ethersproject/address\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { arrayify, concat, hexlify, isBytes, isHexString } from \"@ethersproject/bytes\";\nimport { defineReadOnly, deepCopy, getStatic, resolveProperties, shallowCopy } from \"@ethersproject/properties\";\nimport { accessListify } from \"@ethersproject/transactions\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n;\n;\n///////////////////////////////\nconst allowedTransactionKeys = {\n chainId: true,\n data: true,\n from: true,\n gasLimit: true,\n gasPrice: true,\n nonce: true,\n to: true,\n value: true,\n type: true,\n accessList: true,\n maxFeePerGas: true,\n maxPriorityFeePerGas: true,\n customData: true,\n ccipReadEnabled: true\n};\nfunction resolveName(resolver, nameOrPromise) {\n return __awaiter(this, void 0, void 0, function* () {\n const name = yield nameOrPromise;\n if (typeof name !== \"string\") {\n logger.throwArgumentError(\"invalid address or ENS name\", \"name\", name);\n }\n // If it is already an address, just use it (after adding checksum)\n try {\n return getAddress(name);\n } catch (error) {}\n if (!resolver) {\n logger.throwError(\"a provider or signer is needed to resolve ENS names\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"resolveName\"\n });\n }\n const address = yield resolver.resolveName(name);\n if (address == null) {\n logger.throwArgumentError(\"resolver or addr is not configured for ENS name\", \"name\", name);\n }\n return address;\n });\n}\n// Recursively replaces ENS names with promises to resolve the name and resolves all properties\nfunction resolveAddresses(resolver, value, paramType) {\n return __awaiter(this, void 0, void 0, function* () {\n if (Array.isArray(paramType)) {\n return yield Promise.all(paramType.map((paramType, index) => {\n return resolveAddresses(resolver, Array.isArray(value) ? value[index] : value[paramType.name], paramType);\n }));\n }\n if (paramType.type === \"address\") {\n return yield resolveName(resolver, value);\n }\n if (paramType.type === \"tuple\") {\n return yield resolveAddresses(resolver, value, paramType.components);\n }\n if (paramType.baseType === \"array\") {\n if (!Array.isArray(value)) {\n return Promise.reject(logger.makeError(\"invalid value for array\", Logger.errors.INVALID_ARGUMENT, {\n argument: \"value\",\n value\n }));\n }\n return yield Promise.all(value.map(v => resolveAddresses(resolver, v, paramType.arrayChildren)));\n }\n return value;\n });\n}\nfunction populateTransaction(contract, fragment, args) {\n return __awaiter(this, void 0, void 0, function* () {\n // If an extra argument is given, it is overrides\n let overrides = {};\n if (args.length === fragment.inputs.length + 1 && typeof args[args.length - 1] === \"object\") {\n overrides = shallowCopy(args.pop());\n }\n // Make sure the parameter count matches\n logger.checkArgumentCount(args.length, fragment.inputs.length, \"passed to contract\");\n // Populate \"from\" override (allow promises)\n if (contract.signer) {\n if (overrides.from) {\n // Contracts with a Signer are from the Signer's frame-of-reference;\n // but we allow overriding \"from\" if it matches the signer\n overrides.from = resolveProperties({\n override: resolveName(contract.signer, overrides.from),\n signer: contract.signer.getAddress()\n }).then(check => __awaiter(this, void 0, void 0, function* () {\n if (getAddress(check.signer) !== check.override) {\n logger.throwError(\"Contract with a Signer cannot override from\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"overrides.from\"\n });\n }\n return check.override;\n }));\n } else {\n overrides.from = contract.signer.getAddress();\n }\n } else if (overrides.from) {\n overrides.from = resolveName(contract.provider, overrides.from);\n //} else {\n // Contracts without a signer can override \"from\", and if\n // unspecified the zero address is used\n //overrides.from = AddressZero;\n }\n // Wait for all dependencies to be resolved (prefer the signer over the provider)\n const resolved = yield resolveProperties({\n args: resolveAddresses(contract.signer || contract.provider, args, fragment.inputs),\n address: contract.resolvedAddress,\n overrides: resolveProperties(overrides) || {}\n });\n // The ABI coded transaction\n const data = contract.interface.encodeFunctionData(fragment, resolved.args);\n const tx = {\n data: data,\n to: resolved.address\n };\n // Resolved Overrides\n const ro = resolved.overrides;\n // Populate simple overrides\n if (ro.nonce != null) {\n tx.nonce = BigNumber.from(ro.nonce).toNumber();\n }\n if (ro.gasLimit != null) {\n tx.gasLimit = BigNumber.from(ro.gasLimit);\n }\n if (ro.gasPrice != null) {\n tx.gasPrice = BigNumber.from(ro.gasPrice);\n }\n if (ro.maxFeePerGas != null) {\n tx.maxFeePerGas = BigNumber.from(ro.maxFeePerGas);\n }\n if (ro.maxPriorityFeePerGas != null) {\n tx.maxPriorityFeePerGas = BigNumber.from(ro.maxPriorityFeePerGas);\n }\n if (ro.from != null) {\n tx.from = ro.from;\n }\n if (ro.type != null) {\n tx.type = ro.type;\n }\n if (ro.accessList != null) {\n tx.accessList = accessListify(ro.accessList);\n }\n // If there was no \"gasLimit\" override, but the ABI specifies a default, use it\n if (tx.gasLimit == null && fragment.gas != null) {\n // Compute the intrinsic gas cost for this transaction\n // @TODO: This is based on the yellow paper as of Petersburg; this is something\n // we may wish to parameterize in v6 as part of the Network object. Since this\n // is always a non-nil to address, we can ignore G_create, but may wish to add\n // similar logic to the ContractFactory.\n let intrinsic = 21000;\n const bytes = arrayify(data);\n for (let i = 0; i < bytes.length; i++) {\n intrinsic += 4;\n if (bytes[i]) {\n intrinsic += 64;\n }\n }\n tx.gasLimit = BigNumber.from(fragment.gas).add(intrinsic);\n }\n // Populate \"value\" override\n if (ro.value) {\n const roValue = BigNumber.from(ro.value);\n if (!roValue.isZero() && !fragment.payable) {\n logger.throwError(\"non-payable method cannot override value\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"overrides.value\",\n value: overrides.value\n });\n }\n tx.value = roValue;\n }\n if (ro.customData) {\n tx.customData = shallowCopy(ro.customData);\n }\n if (ro.ccipReadEnabled) {\n tx.ccipReadEnabled = !!ro.ccipReadEnabled;\n }\n // Remove the overrides\n delete overrides.nonce;\n delete overrides.gasLimit;\n delete overrides.gasPrice;\n delete overrides.from;\n delete overrides.value;\n delete overrides.type;\n delete overrides.accessList;\n delete overrides.maxFeePerGas;\n delete overrides.maxPriorityFeePerGas;\n delete overrides.customData;\n delete overrides.ccipReadEnabled;\n // Make sure there are no stray overrides, which may indicate a\n // typo or using an unsupported key.\n const leftovers = Object.keys(overrides).filter(key => overrides[key] != null);\n if (leftovers.length) {\n logger.throwError(`cannot override ${leftovers.map(l => JSON.stringify(l)).join(\",\")}`, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"overrides\",\n overrides: leftovers\n });\n }\n return tx;\n });\n}\nfunction buildPopulate(contract, fragment) {\n return function (...args) {\n return populateTransaction(contract, fragment, args);\n };\n}\nfunction buildEstimate(contract, fragment) {\n const signerOrProvider = contract.signer || contract.provider;\n return function (...args) {\n return __awaiter(this, void 0, void 0, function* () {\n if (!signerOrProvider) {\n logger.throwError(\"estimate require a provider or signer\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"estimateGas\"\n });\n }\n const tx = yield populateTransaction(contract, fragment, args);\n return yield signerOrProvider.estimateGas(tx);\n });\n };\n}\nfunction addContractWait(contract, tx) {\n const wait = tx.wait.bind(tx);\n tx.wait = confirmations => {\n return wait(confirmations).then(receipt => {\n receipt.events = receipt.logs.map(log => {\n let event = deepCopy(log);\n let parsed = null;\n try {\n parsed = contract.interface.parseLog(log);\n } catch (e) {}\n // Successfully parsed the event log; include it\n if (parsed) {\n event.args = parsed.args;\n event.decode = (data, topics) => {\n return contract.interface.decodeEventLog(parsed.eventFragment, data, topics);\n };\n event.event = parsed.name;\n event.eventSignature = parsed.signature;\n }\n // Useful operations\n event.removeListener = () => {\n return contract.provider;\n };\n event.getBlock = () => {\n return contract.provider.getBlock(receipt.blockHash);\n };\n event.getTransaction = () => {\n return contract.provider.getTransaction(receipt.transactionHash);\n };\n event.getTransactionReceipt = () => {\n return Promise.resolve(receipt);\n };\n return event;\n });\n return receipt;\n });\n };\n}\nfunction buildCall(contract, fragment, collapseSimple) {\n const signerOrProvider = contract.signer || contract.provider;\n return function (...args) {\n return __awaiter(this, void 0, void 0, function* () {\n // Extract the \"blockTag\" override if present\n let blockTag = undefined;\n if (args.length === fragment.inputs.length + 1 && typeof args[args.length - 1] === \"object\") {\n const overrides = shallowCopy(args.pop());\n if (overrides.blockTag != null) {\n blockTag = yield overrides.blockTag;\n }\n delete overrides.blockTag;\n args.push(overrides);\n }\n // If the contract was just deployed, wait until it is mined\n if (contract.deployTransaction != null) {\n yield contract._deployed(blockTag);\n }\n // Call a node and get the result\n const tx = yield populateTransaction(contract, fragment, args);\n const result = yield signerOrProvider.call(tx, blockTag);\n try {\n let value = contract.interface.decodeFunctionResult(fragment, result);\n if (collapseSimple && fragment.outputs.length === 1) {\n value = value[0];\n }\n return value;\n } catch (error) {\n if (error.code === Logger.errors.CALL_EXCEPTION) {\n error.address = contract.address;\n error.args = args;\n error.transaction = tx;\n }\n throw error;\n }\n });\n };\n}\nfunction buildSend(contract, fragment) {\n return function (...args) {\n return __awaiter(this, void 0, void 0, function* () {\n if (!contract.signer) {\n logger.throwError(\"sending a transaction requires a signer\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"sendTransaction\"\n });\n }\n // If the contract was just deployed, wait until it is mined\n if (contract.deployTransaction != null) {\n yield contract._deployed();\n }\n const txRequest = yield populateTransaction(contract, fragment, args);\n const tx = yield contract.signer.sendTransaction(txRequest);\n // Tweak the tx.wait so the receipt has extra properties\n addContractWait(contract, tx);\n return tx;\n });\n };\n}\nfunction buildDefault(contract, fragment, collapseSimple) {\n if (fragment.constant) {\n return buildCall(contract, fragment, collapseSimple);\n }\n return buildSend(contract, fragment);\n}\nfunction getEventTag(filter) {\n if (filter.address && (filter.topics == null || filter.topics.length === 0)) {\n return \"*\";\n }\n return (filter.address || \"*\") + \"@\" + (filter.topics ? filter.topics.map(topic => {\n if (Array.isArray(topic)) {\n return topic.join(\"|\");\n }\n return topic;\n }).join(\":\") : \"\");\n}\nclass RunningEvent {\n constructor(tag, filter) {\n defineReadOnly(this, \"tag\", tag);\n defineReadOnly(this, \"filter\", filter);\n this._listeners = [];\n }\n addListener(listener, once) {\n this._listeners.push({\n listener: listener,\n once: once\n });\n }\n removeListener(listener) {\n let done = false;\n this._listeners = this._listeners.filter(item => {\n if (done || item.listener !== listener) {\n return true;\n }\n done = true;\n return false;\n });\n }\n removeAllListeners() {\n this._listeners = [];\n }\n listeners() {\n return this._listeners.map(i => i.listener);\n }\n listenerCount() {\n return this._listeners.length;\n }\n run(args) {\n const listenerCount = this.listenerCount();\n this._listeners = this._listeners.filter(item => {\n const argsCopy = args.slice();\n // Call the callback in the next event loop\n setTimeout(() => {\n item.listener.apply(this, argsCopy);\n }, 0);\n // Reschedule it if it not \"once\"\n return !item.once;\n });\n return listenerCount;\n }\n prepareEvent(event) {}\n // Returns the array that will be applied to an emit\n getEmit(event) {\n return [event];\n }\n}\nclass ErrorRunningEvent extends RunningEvent {\n constructor() {\n super(\"error\", null);\n }\n}\n// @TODO Fragment should inherit Wildcard? and just override getEmit?\n// or have a common abstract super class, with enough constructor\n// options to configure both.\n// A Fragment Event will populate all the properties that Wildcard\n// will, and additionally dereference the arguments when emitting\nclass FragmentRunningEvent extends RunningEvent {\n constructor(address, contractInterface, fragment, topics) {\n const filter = {\n address: address\n };\n let topic = contractInterface.getEventTopic(fragment);\n if (topics) {\n if (topic !== topics[0]) {\n logger.throwArgumentError(\"topic mismatch\", \"topics\", topics);\n }\n filter.topics = topics.slice();\n } else {\n filter.topics = [topic];\n }\n super(getEventTag(filter), filter);\n defineReadOnly(this, \"address\", address);\n defineReadOnly(this, \"interface\", contractInterface);\n defineReadOnly(this, \"fragment\", fragment);\n }\n prepareEvent(event) {\n super.prepareEvent(event);\n event.event = this.fragment.name;\n event.eventSignature = this.fragment.format();\n event.decode = (data, topics) => {\n return this.interface.decodeEventLog(this.fragment, data, topics);\n };\n try {\n event.args = this.interface.decodeEventLog(this.fragment, event.data, event.topics);\n } catch (error) {\n event.args = null;\n event.decodeError = error;\n }\n }\n getEmit(event) {\n const errors = checkResultErrors(event.args);\n if (errors.length) {\n throw errors[0].error;\n }\n const args = (event.args || []).slice();\n args.push(event);\n return args;\n }\n}\n// A Wildcard Event will attempt to populate:\n// - event The name of the event name\n// - eventSignature The full signature of the event\n// - decode A function to decode data and topics\n// - args The decoded data and topics\nclass WildcardRunningEvent extends RunningEvent {\n constructor(address, contractInterface) {\n super(\"*\", {\n address: address\n });\n defineReadOnly(this, \"address\", address);\n defineReadOnly(this, \"interface\", contractInterface);\n }\n prepareEvent(event) {\n super.prepareEvent(event);\n try {\n const parsed = this.interface.parseLog(event);\n event.event = parsed.name;\n event.eventSignature = parsed.signature;\n event.decode = (data, topics) => {\n return this.interface.decodeEventLog(parsed.eventFragment, data, topics);\n };\n event.args = parsed.args;\n } catch (error) {\n // No matching event\n }\n }\n}\nexport class BaseContract {\n constructor(addressOrName, contractInterface, signerOrProvider) {\n // @TODO: Maybe still check the addressOrName looks like a valid address or name?\n //address = getAddress(address);\n defineReadOnly(this, \"interface\", getStatic(new.target, \"getInterface\")(contractInterface));\n if (signerOrProvider == null) {\n defineReadOnly(this, \"provider\", null);\n defineReadOnly(this, \"signer\", null);\n } else if (Signer.isSigner(signerOrProvider)) {\n defineReadOnly(this, \"provider\", signerOrProvider.provider || null);\n defineReadOnly(this, \"signer\", signerOrProvider);\n } else if (Provider.isProvider(signerOrProvider)) {\n defineReadOnly(this, \"provider\", signerOrProvider);\n defineReadOnly(this, \"signer\", null);\n } else {\n logger.throwArgumentError(\"invalid signer or provider\", \"signerOrProvider\", signerOrProvider);\n }\n defineReadOnly(this, \"callStatic\", {});\n defineReadOnly(this, \"estimateGas\", {});\n defineReadOnly(this, \"functions\", {});\n defineReadOnly(this, \"populateTransaction\", {});\n defineReadOnly(this, \"filters\", {});\n {\n const uniqueFilters = {};\n Object.keys(this.interface.events).forEach(eventSignature => {\n const event = this.interface.events[eventSignature];\n defineReadOnly(this.filters, eventSignature, (...args) => {\n return {\n address: this.address,\n topics: this.interface.encodeFilterTopics(event, args)\n };\n });\n if (!uniqueFilters[event.name]) {\n uniqueFilters[event.name] = [];\n }\n uniqueFilters[event.name].push(eventSignature);\n });\n Object.keys(uniqueFilters).forEach(name => {\n const filters = uniqueFilters[name];\n if (filters.length === 1) {\n defineReadOnly(this.filters, name, this.filters[filters[0]]);\n } else {\n logger.warn(`Duplicate definition of ${name} (${filters.join(\", \")})`);\n }\n });\n }\n defineReadOnly(this, \"_runningEvents\", {});\n defineReadOnly(this, \"_wrappedEmits\", {});\n if (addressOrName == null) {\n logger.throwArgumentError(\"invalid contract address or ENS name\", \"addressOrName\", addressOrName);\n }\n defineReadOnly(this, \"address\", addressOrName);\n if (this.provider) {\n defineReadOnly(this, \"resolvedAddress\", resolveName(this.provider, addressOrName));\n } else {\n try {\n defineReadOnly(this, \"resolvedAddress\", Promise.resolve(getAddress(addressOrName)));\n } catch (error) {\n // Without a provider, we cannot use ENS names\n logger.throwError(\"provider is required to use ENS name as contract address\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"new Contract\"\n });\n }\n }\n // Swallow bad ENS names to prevent Unhandled Exceptions\n this.resolvedAddress.catch(e => {});\n const uniqueNames = {};\n const uniqueSignatures = {};\n Object.keys(this.interface.functions).forEach(signature => {\n const fragment = this.interface.functions[signature];\n // Check that the signature is unique; if not the ABI generation has\n // not been cleaned or may be incorrectly generated\n if (uniqueSignatures[signature]) {\n logger.warn(`Duplicate ABI entry for ${JSON.stringify(signature)}`);\n return;\n }\n uniqueSignatures[signature] = true;\n // Track unique names; we only expose bare named functions if they\n // are ambiguous\n {\n const name = fragment.name;\n if (!uniqueNames[`%${name}`]) {\n uniqueNames[`%${name}`] = [];\n }\n uniqueNames[`%${name}`].push(signature);\n }\n if (this[signature] == null) {\n defineReadOnly(this, signature, buildDefault(this, fragment, true));\n }\n // We do not collapse simple calls on this bucket, which allows\n // frameworks to safely use this without introspection as well as\n // allows decoding error recovery.\n if (this.functions[signature] == null) {\n defineReadOnly(this.functions, signature, buildDefault(this, fragment, false));\n }\n if (this.callStatic[signature] == null) {\n defineReadOnly(this.callStatic, signature, buildCall(this, fragment, true));\n }\n if (this.populateTransaction[signature] == null) {\n defineReadOnly(this.populateTransaction, signature, buildPopulate(this, fragment));\n }\n if (this.estimateGas[signature] == null) {\n defineReadOnly(this.estimateGas, signature, buildEstimate(this, fragment));\n }\n });\n Object.keys(uniqueNames).forEach(name => {\n // Ambiguous names to not get attached as bare names\n const signatures = uniqueNames[name];\n if (signatures.length > 1) {\n return;\n }\n // Strip off the leading \"%\" used for prototype protection\n name = name.substring(1);\n const signature = signatures[0];\n // If overwriting a member property that is null, swallow the error\n try {\n if (this[name] == null) {\n defineReadOnly(this, name, this[signature]);\n }\n } catch (e) {}\n if (this.functions[name] == null) {\n defineReadOnly(this.functions, name, this.functions[signature]);\n }\n if (this.callStatic[name] == null) {\n defineReadOnly(this.callStatic, name, this.callStatic[signature]);\n }\n if (this.populateTransaction[name] == null) {\n defineReadOnly(this.populateTransaction, name, this.populateTransaction[signature]);\n }\n if (this.estimateGas[name] == null) {\n defineReadOnly(this.estimateGas, name, this.estimateGas[signature]);\n }\n });\n }\n static getContractAddress(transaction) {\n return getContractAddress(transaction);\n }\n static getInterface(contractInterface) {\n if (Interface.isInterface(contractInterface)) {\n return contractInterface;\n }\n return new Interface(contractInterface);\n }\n // @TODO: Allow timeout?\n deployed() {\n return this._deployed();\n }\n _deployed(blockTag) {\n if (!this._deployedPromise) {\n // If we were just deployed, we know the transaction we should occur in\n if (this.deployTransaction) {\n this._deployedPromise = this.deployTransaction.wait().then(() => {\n return this;\n });\n } else {\n // @TODO: Once we allow a timeout to be passed in, we will wait\n // up to that many blocks for getCode\n // Otherwise, poll for our code to be deployed\n this._deployedPromise = this.provider.getCode(this.address, blockTag).then(code => {\n if (code === \"0x\") {\n logger.throwError(\"contract not deployed\", Logger.errors.UNSUPPORTED_OPERATION, {\n contractAddress: this.address,\n operation: \"getDeployed\"\n });\n }\n return this;\n });\n }\n }\n return this._deployedPromise;\n }\n // @TODO:\n // estimateFallback(overrides?: TransactionRequest): Promise\n // @TODO:\n // estimateDeploy(bytecode: string, ...args): Promise\n fallback(overrides) {\n if (!this.signer) {\n logger.throwError(\"sending a transactions require a signer\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"sendTransaction(fallback)\"\n });\n }\n const tx = shallowCopy(overrides || {});\n [\"from\", \"to\"].forEach(function (key) {\n if (tx[key] == null) {\n return;\n }\n logger.throwError(\"cannot override \" + key, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: key\n });\n });\n tx.to = this.resolvedAddress;\n return this.deployed().then(() => {\n return this.signer.sendTransaction(tx);\n });\n }\n // Reconnect to a different signer or provider\n connect(signerOrProvider) {\n if (typeof signerOrProvider === \"string\") {\n signerOrProvider = new VoidSigner(signerOrProvider, this.provider);\n }\n const contract = new this.constructor(this.address, this.interface, signerOrProvider);\n if (this.deployTransaction) {\n defineReadOnly(contract, \"deployTransaction\", this.deployTransaction);\n }\n return contract;\n }\n // Re-attach to a different on-chain instance of this contract\n attach(addressOrName) {\n return new this.constructor(addressOrName, this.interface, this.signer || this.provider);\n }\n static isIndexed(value) {\n return Indexed.isIndexed(value);\n }\n _normalizeRunningEvent(runningEvent) {\n // Already have an instance of this event running; we can re-use it\n if (this._runningEvents[runningEvent.tag]) {\n return this._runningEvents[runningEvent.tag];\n }\n return runningEvent;\n }\n _getRunningEvent(eventName) {\n if (typeof eventName === \"string\") {\n // Listen for \"error\" events (if your contract has an error event, include\n // the full signature to bypass this special event keyword)\n if (eventName === \"error\") {\n return this._normalizeRunningEvent(new ErrorRunningEvent());\n }\n // Listen for any event that is registered\n if (eventName === \"event\") {\n return this._normalizeRunningEvent(new RunningEvent(\"event\", null));\n }\n // Listen for any event\n if (eventName === \"*\") {\n return this._normalizeRunningEvent(new WildcardRunningEvent(this.address, this.interface));\n }\n // Get the event Fragment (throws if ambiguous/unknown event)\n const fragment = this.interface.getEvent(eventName);\n return this._normalizeRunningEvent(new FragmentRunningEvent(this.address, this.interface, fragment));\n }\n // We have topics to filter by...\n if (eventName.topics && eventName.topics.length > 0) {\n // Is it a known topichash? (throws if no matching topichash)\n try {\n const topic = eventName.topics[0];\n if (typeof topic !== \"string\") {\n throw new Error(\"invalid topic\"); // @TODO: May happen for anonymous events\n }\n const fragment = this.interface.getEvent(topic);\n return this._normalizeRunningEvent(new FragmentRunningEvent(this.address, this.interface, fragment, eventName.topics));\n } catch (error) {}\n // Filter by the unknown topichash\n const filter = {\n address: this.address,\n topics: eventName.topics\n };\n return this._normalizeRunningEvent(new RunningEvent(getEventTag(filter), filter));\n }\n return this._normalizeRunningEvent(new WildcardRunningEvent(this.address, this.interface));\n }\n _checkRunningEvents(runningEvent) {\n if (runningEvent.listenerCount() === 0) {\n delete this._runningEvents[runningEvent.tag];\n // If we have a poller for this, remove it\n const emit = this._wrappedEmits[runningEvent.tag];\n if (emit && runningEvent.filter) {\n this.provider.off(runningEvent.filter, emit);\n delete this._wrappedEmits[runningEvent.tag];\n }\n }\n }\n // Subclasses can override this to gracefully recover\n // from parse errors if they wish\n _wrapEvent(runningEvent, log, listener) {\n const event = deepCopy(log);\n event.removeListener = () => {\n if (!listener) {\n return;\n }\n runningEvent.removeListener(listener);\n this._checkRunningEvents(runningEvent);\n };\n event.getBlock = () => {\n return this.provider.getBlock(log.blockHash);\n };\n event.getTransaction = () => {\n return this.provider.getTransaction(log.transactionHash);\n };\n event.getTransactionReceipt = () => {\n return this.provider.getTransactionReceipt(log.transactionHash);\n };\n // This may throw if the topics and data mismatch the signature\n runningEvent.prepareEvent(event);\n return event;\n }\n _addEventListener(runningEvent, listener, once) {\n if (!this.provider) {\n logger.throwError(\"events require a provider or a signer with a provider\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"once\"\n });\n }\n runningEvent.addListener(listener, once);\n // Track this running event and its listeners (may already be there; but no hard in updating)\n this._runningEvents[runningEvent.tag] = runningEvent;\n // If we are not polling the provider, start polling\n if (!this._wrappedEmits[runningEvent.tag]) {\n const wrappedEmit = log => {\n let event = this._wrapEvent(runningEvent, log, listener);\n // Try to emit the result for the parameterized event...\n if (event.decodeError == null) {\n try {\n const args = runningEvent.getEmit(event);\n this.emit(runningEvent.filter, ...args);\n } catch (error) {\n event.decodeError = error.error;\n }\n }\n // Always emit \"event\" for fragment-base events\n if (runningEvent.filter != null) {\n this.emit(\"event\", event);\n }\n // Emit \"error\" if there was an error\n if (event.decodeError != null) {\n this.emit(\"error\", event.decodeError, event);\n }\n };\n this._wrappedEmits[runningEvent.tag] = wrappedEmit;\n // Special events, like \"error\" do not have a filter\n if (runningEvent.filter != null) {\n this.provider.on(runningEvent.filter, wrappedEmit);\n }\n }\n }\n queryFilter(event, fromBlockOrBlockhash, toBlock) {\n const runningEvent = this._getRunningEvent(event);\n const filter = shallowCopy(runningEvent.filter);\n if (typeof fromBlockOrBlockhash === \"string\" && isHexString(fromBlockOrBlockhash, 32)) {\n if (toBlock != null) {\n logger.throwArgumentError(\"cannot specify toBlock with blockhash\", \"toBlock\", toBlock);\n }\n filter.blockHash = fromBlockOrBlockhash;\n } else {\n filter.fromBlock = fromBlockOrBlockhash != null ? fromBlockOrBlockhash : 0;\n filter.toBlock = toBlock != null ? toBlock : \"latest\";\n }\n return this.provider.getLogs(filter).then(logs => {\n return logs.map(log => this._wrapEvent(runningEvent, log, null));\n });\n }\n on(event, listener) {\n this._addEventListener(this._getRunningEvent(event), listener, false);\n return this;\n }\n once(event, listener) {\n this._addEventListener(this._getRunningEvent(event), listener, true);\n return this;\n }\n emit(eventName, ...args) {\n if (!this.provider) {\n return false;\n }\n const runningEvent = this._getRunningEvent(eventName);\n const result = runningEvent.run(args) > 0;\n // May have drained all the \"once\" events; check for living events\n this._checkRunningEvents(runningEvent);\n return result;\n }\n listenerCount(eventName) {\n if (!this.provider) {\n return 0;\n }\n if (eventName == null) {\n return Object.keys(this._runningEvents).reduce((accum, key) => {\n return accum + this._runningEvents[key].listenerCount();\n }, 0);\n }\n return this._getRunningEvent(eventName).listenerCount();\n }\n listeners(eventName) {\n if (!this.provider) {\n return [];\n }\n if (eventName == null) {\n const result = [];\n for (let tag in this._runningEvents) {\n this._runningEvents[tag].listeners().forEach(listener => {\n result.push(listener);\n });\n }\n return result;\n }\n return this._getRunningEvent(eventName).listeners();\n }\n removeAllListeners(eventName) {\n if (!this.provider) {\n return this;\n }\n if (eventName == null) {\n for (const tag in this._runningEvents) {\n const runningEvent = this._runningEvents[tag];\n runningEvent.removeAllListeners();\n this._checkRunningEvents(runningEvent);\n }\n return this;\n }\n // Delete any listeners\n const runningEvent = this._getRunningEvent(eventName);\n runningEvent.removeAllListeners();\n this._checkRunningEvents(runningEvent);\n return this;\n }\n off(eventName, listener) {\n if (!this.provider) {\n return this;\n }\n const runningEvent = this._getRunningEvent(eventName);\n runningEvent.removeListener(listener);\n this._checkRunningEvents(runningEvent);\n return this;\n }\n removeListener(eventName, listener) {\n return this.off(eventName, listener);\n }\n}\nexport class Contract extends BaseContract {}\nexport class ContractFactory {\n constructor(contractInterface, bytecode, signer) {\n let bytecodeHex = null;\n if (typeof bytecode === \"string\") {\n bytecodeHex = bytecode;\n } else if (isBytes(bytecode)) {\n bytecodeHex = hexlify(bytecode);\n } else if (bytecode && typeof bytecode.object === \"string\") {\n // Allow the bytecode object from the Solidity compiler\n bytecodeHex = bytecode.object;\n } else {\n // Crash in the next verification step\n bytecodeHex = \"!\";\n }\n // Make sure it is 0x prefixed\n if (bytecodeHex.substring(0, 2) !== \"0x\") {\n bytecodeHex = \"0x\" + bytecodeHex;\n }\n // Make sure the final result is valid bytecode\n if (!isHexString(bytecodeHex) || bytecodeHex.length % 2) {\n logger.throwArgumentError(\"invalid bytecode\", \"bytecode\", bytecode);\n }\n // If we have a signer, make sure it is valid\n if (signer && !Signer.isSigner(signer)) {\n logger.throwArgumentError(\"invalid signer\", \"signer\", signer);\n }\n defineReadOnly(this, \"bytecode\", bytecodeHex);\n defineReadOnly(this, \"interface\", getStatic(new.target, \"getInterface\")(contractInterface));\n defineReadOnly(this, \"signer\", signer || null);\n }\n // @TODO: Future; rename to populateTransaction?\n getDeployTransaction(...args) {\n let tx = {};\n // If we have 1 additional argument, we allow transaction overrides\n if (args.length === this.interface.deploy.inputs.length + 1 && typeof args[args.length - 1] === \"object\") {\n tx = shallowCopy(args.pop());\n for (const key in tx) {\n if (!allowedTransactionKeys[key]) {\n throw new Error(\"unknown transaction override \" + key);\n }\n }\n }\n // Do not allow these to be overridden in a deployment transaction\n [\"data\", \"from\", \"to\"].forEach(key => {\n if (tx[key] == null) {\n return;\n }\n logger.throwError(\"cannot override \" + key, Logger.errors.UNSUPPORTED_OPERATION, {\n operation: key\n });\n });\n if (tx.value) {\n const value = BigNumber.from(tx.value);\n if (!value.isZero() && !this.interface.deploy.payable) {\n logger.throwError(\"non-payable constructor cannot override value\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"overrides.value\",\n value: tx.value\n });\n }\n }\n // Make sure the call matches the constructor signature\n logger.checkArgumentCount(args.length, this.interface.deploy.inputs.length, \" in Contract constructor\");\n // Set the data to the bytecode + the encoded constructor arguments\n tx.data = hexlify(concat([this.bytecode, this.interface.encodeDeploy(args)]));\n return tx;\n }\n deploy(...args) {\n return __awaiter(this, void 0, void 0, function* () {\n let overrides = {};\n // If 1 extra parameter was passed in, it contains overrides\n if (args.length === this.interface.deploy.inputs.length + 1) {\n overrides = args.pop();\n }\n // Make sure the call matches the constructor signature\n logger.checkArgumentCount(args.length, this.interface.deploy.inputs.length, \" in Contract constructor\");\n // Resolve ENS names and promises in the arguments\n const params = yield resolveAddresses(this.signer, args, this.interface.deploy.inputs);\n params.push(overrides);\n // Get the deployment transaction (with optional overrides)\n const unsignedTx = this.getDeployTransaction(...params);\n // Send the deployment transaction\n const tx = yield this.signer.sendTransaction(unsignedTx);\n const address = getStatic(this.constructor, \"getContractAddress\")(tx);\n const contract = getStatic(this.constructor, \"getContract\")(address, this.interface, this.signer);\n // Add the modified wait that wraps events\n addContractWait(contract, tx);\n defineReadOnly(contract, \"deployTransaction\", tx);\n return contract;\n });\n }\n attach(address) {\n return this.constructor.getContract(address, this.interface, this.signer);\n }\n connect(signer) {\n return new this.constructor(this.interface, this.bytecode, signer);\n }\n static fromSolidity(compilerOutput, signer) {\n if (compilerOutput == null) {\n logger.throwError(\"missing compiler output\", Logger.errors.MISSING_ARGUMENT, {\n argument: \"compilerOutput\"\n });\n }\n if (typeof compilerOutput === \"string\") {\n compilerOutput = JSON.parse(compilerOutput);\n }\n const abi = compilerOutput.abi;\n let bytecode = null;\n if (compilerOutput.bytecode) {\n bytecode = compilerOutput.bytecode;\n } else if (compilerOutput.evm && compilerOutput.evm.bytecode) {\n bytecode = compilerOutput.evm.bytecode;\n }\n return new this(abi, bytecode, signer);\n }\n static getInterface(contractInterface) {\n return Contract.getInterface(contractInterface);\n }\n static getContractAddress(tx) {\n return getContractAddress(tx);\n }\n static getContract(address, contractInterface, signer) {\n return new Contract(address, contractInterface, signer);\n }\n}\n","\"use strict\";\n\nimport { arrayify, hexlify } from \"@ethersproject/bytes\";\nimport { computeHmac } from \"@ethersproject/sha2\";\nexport function pbkdf2(password, salt, iterations, keylen, hashAlgorithm) {\n password = arrayify(password);\n salt = arrayify(salt);\n let hLen;\n let l = 1;\n const DK = new Uint8Array(keylen);\n const block1 = new Uint8Array(salt.length + 4);\n block1.set(salt);\n //salt.copy(block1, 0, 0, salt.length)\n let r;\n let T;\n for (let i = 1; i <= l; i++) {\n //block1.writeUInt32BE(i, salt.length)\n block1[salt.length] = i >> 24 & 0xff;\n block1[salt.length + 1] = i >> 16 & 0xff;\n block1[salt.length + 2] = i >> 8 & 0xff;\n block1[salt.length + 3] = i & 0xff;\n //let U = createHmac(password).update(block1).digest();\n let U = arrayify(computeHmac(hashAlgorithm, password, block1));\n if (!hLen) {\n hLen = U.length;\n T = new Uint8Array(hLen);\n l = Math.ceil(keylen / hLen);\n r = keylen - (l - 1) * hLen;\n }\n //U.copy(T, 0, 0, hLen)\n T.set(U);\n for (let j = 1; j < iterations; j++) {\n //U = createHmac(password).update(U).digest();\n U = arrayify(computeHmac(hashAlgorithm, password, U));\n for (let k = 0; k < hLen; k++) T[k] ^= U[k];\n }\n const destPos = (i - 1) * hLen;\n const len = i === l ? r : hLen;\n //T.copy(DK, destPos, 0, len)\n DK.set(arrayify(T).slice(0, len), destPos);\n }\n return hexlify(DK);\n}\n","export { pbkdf2 } from \"./pbkdf2\";\n","export const version = \"wordlists/5.7.0\";\n","\"use strict\";\n\n// This gets overridden by rollup\nconst exportWordlist = false;\nimport { id } from \"@ethersproject/hash\";\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nexport const logger = new Logger(version);\nexport class Wordlist {\n constructor(locale) {\n logger.checkAbstract(new.target, Wordlist);\n defineReadOnly(this, \"locale\", locale);\n }\n // Subclasses may override this\n split(mnemonic) {\n return mnemonic.toLowerCase().split(/ +/g);\n }\n // Subclasses may override this\n join(words) {\n return words.join(\" \");\n }\n static check(wordlist) {\n const words = [];\n for (let i = 0; i < 2048; i++) {\n const word = wordlist.getWord(i);\n /* istanbul ignore if */\n if (i !== wordlist.getWordIndex(word)) {\n return \"0x\";\n }\n words.push(word);\n }\n return id(words.join(\"\\n\") + \"\\n\");\n }\n static register(lang, name) {\n if (!name) {\n name = lang.locale;\n }\n /* istanbul ignore if */\n if (exportWordlist) {\n try {\n const anyGlobal = window;\n if (anyGlobal._ethers && anyGlobal._ethers.wordlists) {\n if (!anyGlobal._ethers.wordlists[name]) {\n defineReadOnly(anyGlobal._ethers.wordlists, name, lang);\n }\n }\n } catch (error) {}\n }\n }\n}\n","\"use strict\";\n\nimport { Wordlist } from \"./wordlist\";\nconst words = \"AbandonAbilityAbleAboutAboveAbsentAbsorbAbstractAbsurdAbuseAccessAccidentAccountAccuseAchieveAcidAcousticAcquireAcrossActActionActorActressActualAdaptAddAddictAddressAdjustAdmitAdultAdvanceAdviceAerobicAffairAffordAfraidAgainAgeAgentAgreeAheadAimAirAirportAisleAlarmAlbumAlcoholAlertAlienAllAlleyAllowAlmostAloneAlphaAlreadyAlsoAlterAlwaysAmateurAmazingAmongAmountAmusedAnalystAnchorAncientAngerAngleAngryAnimalAnkleAnnounceAnnualAnotherAnswerAntennaAntiqueAnxietyAnyApartApologyAppearAppleApproveAprilArchArcticAreaArenaArgueArmArmedArmorArmyAroundArrangeArrestArriveArrowArtArtefactArtistArtworkAskAspectAssaultAssetAssistAssumeAsthmaAthleteAtomAttackAttendAttitudeAttractAuctionAuditAugustAuntAuthorAutoAutumnAverageAvocadoAvoidAwakeAwareAwayAwesomeAwfulAwkwardAxisBabyBachelorBaconBadgeBagBalanceBalconyBallBambooBananaBannerBarBarelyBargainBarrelBaseBasicBasketBattleBeachBeanBeautyBecauseBecomeBeefBeforeBeginBehaveBehindBelieveBelowBeltBenchBenefitBestBetrayBetterBetweenBeyondBicycleBidBikeBindBiologyBirdBirthBitterBlackBladeBlameBlanketBlastBleakBlessBlindBloodBlossomBlouseBlueBlurBlushBoardBoatBodyBoilBombBoneBonusBookBoostBorderBoringBorrowBossBottomBounceBoxBoyBracketBrainBrandBrassBraveBreadBreezeBrickBridgeBriefBrightBringBriskBroccoliBrokenBronzeBroomBrotherBrownBrushBubbleBuddyBudgetBuffaloBuildBulbBulkBulletBundleBunkerBurdenBurgerBurstBusBusinessBusyButterBuyerBuzzCabbageCabinCableCactusCageCakeCallCalmCameraCampCanCanalCancelCandyCannonCanoeCanvasCanyonCapableCapitalCaptainCarCarbonCardCargoCarpetCarryCartCaseCashCasinoCastleCasualCatCatalogCatchCategoryCattleCaughtCauseCautionCaveCeilingCeleryCementCensusCenturyCerealCertainChairChalkChampionChangeChaosChapterChargeChaseChatCheapCheckCheeseChefCherryChestChickenChiefChildChimneyChoiceChooseChronicChuckleChunkChurnCigarCinnamonCircleCitizenCityCivilClaimClapClarifyClawClayCleanClerkCleverClickClientCliffClimbClinicClipClockClogCloseClothCloudClownClubClumpClusterClutchCoachCoastCoconutCodeCoffeeCoilCoinCollectColorColumnCombineComeComfortComicCommonCompanyConcertConductConfirmCongressConnectConsiderControlConvinceCookCoolCopperCopyCoralCoreCornCorrectCostCottonCouchCountryCoupleCourseCousinCoverCoyoteCrackCradleCraftCramCraneCrashCraterCrawlCrazyCreamCreditCreekCrewCricketCrimeCrispCriticCropCrossCrouchCrowdCrucialCruelCruiseCrumbleCrunchCrushCryCrystalCubeCultureCupCupboardCuriousCurrentCurtainCurveCushionCustomCuteCycleDadDamageDampDanceDangerDaringDashDaughterDawnDayDealDebateDebrisDecadeDecemberDecideDeclineDecorateDecreaseDeerDefenseDefineDefyDegreeDelayDeliverDemandDemiseDenialDentistDenyDepartDependDepositDepthDeputyDeriveDescribeDesertDesignDeskDespairDestroyDetailDetectDevelopDeviceDevoteDiagramDialDiamondDiaryDiceDieselDietDifferDigitalDignityDilemmaDinnerDinosaurDirectDirtDisagreeDiscoverDiseaseDishDismissDisorderDisplayDistanceDivertDivideDivorceDizzyDoctorDocumentDogDollDolphinDomainDonateDonkeyDonorDoorDoseDoubleDoveDraftDragonDramaDrasticDrawDreamDressDriftDrillDrinkDripDriveDropDrumDryDuckDumbDuneDuringDustDutchDutyDwarfDynamicEagerEagleEarlyEarnEarthEasilyEastEasyEchoEcologyEconomyEdgeEditEducateEffortEggEightEitherElbowElderElectricElegantElementElephantElevatorEliteElseEmbarkEmbodyEmbraceEmergeEmotionEmployEmpowerEmptyEnableEnactEndEndlessEndorseEnemyEnergyEnforceEngageEngineEnhanceEnjoyEnlistEnoughEnrichEnrollEnsureEnterEntireEntryEnvelopeEpisodeEqualEquipEraEraseErodeErosionErrorEruptEscapeEssayEssenceEstateEternalEthicsEvidenceEvilEvokeEvolveExactExampleExcessExchangeExciteExcludeExcuseExecuteExerciseExhaustExhibitExileExistExitExoticExpandExpectExpireExplainExposeExpressExtendExtraEyeEyebrowFabricFaceFacultyFadeFaintFaithFallFalseFameFamilyFamousFanFancyFantasyFarmFashionFatFatalFatherFatigueFaultFavoriteFeatureFebruaryFederalFeeFeedFeelFemaleFenceFestivalFetchFeverFewFiberFictionFieldFigureFileFilmFilterFinalFindFineFingerFinishFireFirmFirstFiscalFishFitFitnessFixFlagFlameFlashFlatFlavorFleeFlightFlipFloatFlockFloorFlowerFluidFlushFlyFoamFocusFogFoilFoldFollowFoodFootForceForestForgetForkFortuneForumForwardFossilFosterFoundFoxFragileFrameFrequentFreshFriendFringeFrogFrontFrostFrownFrozenFruitFuelFunFunnyFurnaceFuryFutureGadgetGainGalaxyGalleryGameGapGarageGarbageGardenGarlicGarmentGasGaspGateGatherGaugeGazeGeneralGeniusGenreGentleGenuineGestureGhostGiantGiftGiggleGingerGiraffeGirlGiveGladGlanceGlareGlassGlideGlimpseGlobeGloomGloryGloveGlowGlueGoatGoddessGoldGoodGooseGorillaGospelGossipGovernGownGrabGraceGrainGrantGrapeGrassGravityGreatGreenGridGriefGritGroceryGroupGrowGruntGuardGuessGuideGuiltGuitarGunGymHabitHairHalfHammerHamsterHandHappyHarborHardHarshHarvestHatHaveHawkHazardHeadHealthHeartHeavyHedgehogHeightHelloHelmetHelpHenHeroHiddenHighHillHintHipHireHistoryHobbyHockeyHoldHoleHolidayHollowHomeHoneyHoodHopeHornHorrorHorseHospitalHostHotelHourHoverHubHugeHumanHumbleHumorHundredHungryHuntHurdleHurryHurtHusbandHybridIceIconIdeaIdentifyIdleIgnoreIllIllegalIllnessImageImitateImmenseImmuneImpactImposeImproveImpulseInchIncludeIncomeIncreaseIndexIndicateIndoorIndustryInfantInflictInformInhaleInheritInitialInjectInjuryInmateInnerInnocentInputInquiryInsaneInsectInsideInspireInstallIntactInterestIntoInvestInviteInvolveIronIslandIsolateIssueItemIvoryJacketJaguarJarJazzJealousJeansJellyJewelJobJoinJokeJourneyJoyJudgeJuiceJumpJungleJuniorJunkJustKangarooKeenKeepKetchupKeyKickKidKidneyKindKingdomKissKitKitchenKiteKittenKiwiKneeKnifeKnockKnowLabLabelLaborLadderLadyLakeLampLanguageLaptopLargeLaterLatinLaughLaundryLavaLawLawnLawsuitLayerLazyLeaderLeafLearnLeaveLectureLeftLegLegalLegendLeisureLemonLendLengthLensLeopardLessonLetterLevelLiarLibertyLibraryLicenseLifeLiftLightLikeLimbLimitLinkLionLiquidListLittleLiveLizardLoadLoanLobsterLocalLockLogicLonelyLongLoopLotteryLoudLoungeLoveLoyalLuckyLuggageLumberLunarLunchLuxuryLyricsMachineMadMagicMagnetMaidMailMainMajorMakeMammalManManageMandateMangoMansionManualMapleMarbleMarchMarginMarineMarketMarriageMaskMassMasterMatchMaterialMathMatrixMatterMaximumMazeMeadowMeanMeasureMeatMechanicMedalMediaMelodyMeltMemberMemoryMentionMenuMercyMergeMeritMerryMeshMessageMetalMethodMiddleMidnightMilkMillionMimicMindMinimumMinorMinuteMiracleMirrorMiseryMissMistakeMixMixedMixtureMobileModelModifyMomMomentMonitorMonkeyMonsterMonthMoonMoralMoreMorningMosquitoMotherMotionMotorMountainMouseMoveMovieMuchMuffinMuleMultiplyMuscleMuseumMushroomMusicMustMutualMyselfMysteryMythNaiveNameNapkinNarrowNastyNationNatureNearNeckNeedNegativeNeglectNeitherNephewNerveNestNetNetworkNeutralNeverNewsNextNiceNightNobleNoiseNomineeNoodleNormalNorthNoseNotableNoteNothingNoticeNovelNowNuclearNumberNurseNutOakObeyObjectObligeObscureObserveObtainObviousOccurOceanOctoberOdorOffOfferOfficeOftenOilOkayOldOliveOlympicOmitOnceOneOnionOnlineOnlyOpenOperaOpinionOpposeOptionOrangeOrbitOrchardOrderOrdinaryOrganOrientOriginalOrphanOstrichOtherOutdoorOuterOutputOutsideOvalOvenOverOwnOwnerOxygenOysterOzonePactPaddlePagePairPalacePalmPandaPanelPanicPantherPaperParadeParentParkParrotPartyPassPatchPathPatientPatrolPatternPausePavePaymentPeacePeanutPearPeasantPelicanPenPenaltyPencilPeoplePepperPerfectPermitPersonPetPhonePhotoPhrasePhysicalPianoPicnicPicturePiecePigPigeonPillPilotPinkPioneerPipePistolPitchPizzaPlacePlanetPlasticPlatePlayPleasePledgePluckPlugPlungePoemPoetPointPolarPolePolicePondPonyPoolPopularPortionPositionPossiblePostPotatoPotteryPovertyPowderPowerPracticePraisePredictPreferPreparePresentPrettyPreventPricePridePrimaryPrintPriorityPrisonPrivatePrizeProblemProcessProduceProfitProgramProjectPromoteProofPropertyProsperProtectProudProvidePublicPuddingPullPulpPulsePumpkinPunchPupilPuppyPurchasePurityPurposePursePushPutPuzzlePyramidQualityQuantumQuarterQuestionQuickQuitQuizQuoteRabbitRaccoonRaceRackRadarRadioRailRainRaiseRallyRampRanchRandomRangeRapidRareRateRatherRavenRawRazorReadyRealReasonRebelRebuildRecallReceiveRecipeRecordRecycleReduceReflectReformRefuseRegionRegretRegularRejectRelaxReleaseReliefRelyRemainRememberRemindRemoveRenderRenewRentReopenRepairRepeatReplaceReportRequireRescueResembleResistResourceResponseResultRetireRetreatReturnReunionRevealReviewRewardRhythmRibRibbonRiceRichRideRidgeRifleRightRigidRingRiotRippleRiskRitualRivalRiverRoadRoastRobotRobustRocketRomanceRoofRookieRoomRoseRotateRoughRoundRouteRoyalRubberRudeRugRuleRunRunwayRuralSadSaddleSadnessSafeSailSaladSalmonSalonSaltSaluteSameSampleSandSatisfySatoshiSauceSausageSaveSayScaleScanScareScatterSceneSchemeSchoolScienceScissorsScorpionScoutScrapScreenScriptScrubSeaSearchSeasonSeatSecondSecretSectionSecuritySeedSeekSegmentSelectSellSeminarSeniorSenseSentenceSeriesServiceSessionSettleSetupSevenShadowShaftShallowShareShedShellSheriffShieldShiftShineShipShiverShockShoeShootShopShortShoulderShoveShrimpShrugShuffleShySiblingSickSideSiegeSightSignSilentSilkSillySilverSimilarSimpleSinceSingSirenSisterSituateSixSizeSkateSketchSkiSkillSkinSkirtSkullSlabSlamSleepSlenderSliceSlideSlightSlimSloganSlotSlowSlushSmallSmartSmileSmokeSmoothSnackSnakeSnapSniffSnowSoapSoccerSocialSockSodaSoftSolarSoldierSolidSolutionSolveSomeoneSongSoonSorrySortSoulSoundSoupSourceSouthSpaceSpareSpatialSpawnSpeakSpecialSpeedSpellSpendSphereSpiceSpiderSpikeSpinSpiritSplitSpoilSponsorSpoonSportSpotSpraySpreadSpringSpySquareSqueezeSquirrelStableStadiumStaffStageStairsStampStandStartStateStaySteakSteelStemStepStereoStickStillStingStockStomachStoneStoolStoryStoveStrategyStreetStrikeStrongStruggleStudentStuffStumbleStyleSubjectSubmitSubwaySuccessSuchSuddenSufferSugarSuggestSuitSummerSunSunnySunsetSuperSupplySupremeSureSurfaceSurgeSurpriseSurroundSurveySuspectSustainSwallowSwampSwapSwarmSwearSweetSwiftSwimSwingSwitchSwordSymbolSymptomSyrupSystemTableTackleTagTailTalentTalkTankTapeTargetTaskTasteTattooTaxiTeachTeamTellTenTenantTennisTentTermTestTextThankThatThemeThenTheoryThereTheyThingThisThoughtThreeThriveThrowThumbThunderTicketTideTigerTiltTimberTimeTinyTipTiredTissueTitleToastTobaccoTodayToddlerToeTogetherToiletTokenTomatoTomorrowToneTongueTonightToolToothTopTopicToppleTorchTornadoTortoiseTossTotalTouristTowardTowerTownToyTrackTradeTrafficTragicTrainTransferTrapTrashTravelTrayTreatTreeTrendTrialTribeTrickTriggerTrimTripTrophyTroubleTruckTrueTrulyTrumpetTrustTruthTryTubeTuitionTumbleTunaTunnelTurkeyTurnTurtleTwelveTwentyTwiceTwinTwistTwoTypeTypicalUglyUmbrellaUnableUnawareUncleUncoverUnderUndoUnfairUnfoldUnhappyUniformUniqueUnitUniverseUnknownUnlockUntilUnusualUnveilUpdateUpgradeUpholdUponUpperUpsetUrbanUrgeUsageUseUsedUsefulUselessUsualUtilityVacantVacuumVagueValidValleyValveVanVanishVaporVariousVastVaultVehicleVelvetVendorVentureVenueVerbVerifyVersionVeryVesselVeteranViableVibrantViciousVictoryVideoViewVillageVintageViolinVirtualVirusVisaVisitVisualVitalVividVocalVoiceVoidVolcanoVolumeVoteVoyageWageWagonWaitWalkWallWalnutWantWarfareWarmWarriorWashWaspWasteWaterWaveWayWealthWeaponWearWeaselWeatherWebWeddingWeekendWeirdWelcomeWestWetWhaleWhatWheatWheelWhenWhereWhipWhisperWideWidthWifeWildWillWinWindowWineWingWinkWinnerWinterWireWisdomWiseWishWitnessWolfWomanWonderWoodWoolWordWorkWorldWorryWorthWrapWreckWrestleWristWriteWrongYardYearYellowYouYoungYouthZebraZeroZoneZoo\";\nlet wordlist = null;\nfunction loadWords(lang) {\n if (wordlist != null) {\n return;\n }\n wordlist = words.replace(/([A-Z])/g, \" $1\").toLowerCase().substring(1).split(\" \");\n // Verify the computed list matches the official list\n /* istanbul ignore if */\n if (Wordlist.check(lang) !== \"0x3c8acc1e7b08d8e76f9fda015ef48dc8c710a73cb7e0f77b2c18a9b5a7adde60\") {\n wordlist = null;\n throw new Error(\"BIP39 Wordlist for en (English) FAILED\");\n }\n}\nclass LangEn extends Wordlist {\n constructor() {\n super(\"en\");\n }\n getWord(index) {\n loadWords(this);\n return wordlist[index];\n }\n getWordIndex(word) {\n loadWords(this);\n return wordlist.indexOf(word);\n }\n}\nconst langEn = new LangEn();\nWordlist.register(langEn);\nexport { langEn };\n","\"use strict\";\n\nimport { langEn as en } from \"./lang-en\";\nexport const wordlists = {\n en: en\n};\n","\"use strict\";\n\n// Wordlists\n// See: https://github.com/bitcoin/bips/blob/master/bip-0039/bip-0039-wordlists.md\nimport { logger, Wordlist } from \"./wordlist\";\nimport { wordlists } from \"./wordlists\";\nexport { logger, Wordlist, wordlists };\n","export const version = \"hdnode/5.7.0\";\n","\"use strict\";\n\nimport { Base58 } from \"@ethersproject/basex\";\nimport { arrayify, concat, hexDataSlice, hexZeroPad, hexlify } from \"@ethersproject/bytes\";\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { toUtf8Bytes, UnicodeNormalizationForm } from \"@ethersproject/strings\";\nimport { pbkdf2 } from \"@ethersproject/pbkdf2\";\nimport { defineReadOnly } from \"@ethersproject/properties\";\nimport { SigningKey } from \"@ethersproject/signing-key\";\nimport { computeHmac, ripemd160, sha256, SupportedAlgorithm } from \"@ethersproject/sha2\";\nimport { computeAddress } from \"@ethersproject/transactions\";\nimport { wordlists } from \"@ethersproject/wordlists\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nconst N = BigNumber.from(\"0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141\");\n// \"Bitcoin seed\"\nconst MasterSecret = toUtf8Bytes(\"Bitcoin seed\");\nconst HardenedBit = 0x80000000;\n// Returns a byte with the MSB bits set\nfunction getUpperMask(bits) {\n return (1 << bits) - 1 << 8 - bits;\n}\n// Returns a byte with the LSB bits set\nfunction getLowerMask(bits) {\n return (1 << bits) - 1;\n}\nfunction bytes32(value) {\n return hexZeroPad(hexlify(value), 32);\n}\nfunction base58check(data) {\n return Base58.encode(concat([data, hexDataSlice(sha256(sha256(data)), 0, 4)]));\n}\nfunction getWordlist(wordlist) {\n if (wordlist == null) {\n return wordlists[\"en\"];\n }\n if (typeof wordlist === \"string\") {\n const words = wordlists[wordlist];\n if (words == null) {\n logger.throwArgumentError(\"unknown locale\", \"wordlist\", wordlist);\n }\n return words;\n }\n return wordlist;\n}\nconst _constructorGuard = {};\nexport const defaultPath = \"m/44'/60'/0'/0/0\";\n;\nexport class HDNode {\n /**\n * This constructor should not be called directly.\n *\n * Please use:\n * - fromMnemonic\n * - fromSeed\n */\n constructor(constructorGuard, privateKey, publicKey, parentFingerprint, chainCode, index, depth, mnemonicOrPath) {\n /* istanbul ignore if */\n if (constructorGuard !== _constructorGuard) {\n throw new Error(\"HDNode constructor cannot be called directly\");\n }\n if (privateKey) {\n const signingKey = new SigningKey(privateKey);\n defineReadOnly(this, \"privateKey\", signingKey.privateKey);\n defineReadOnly(this, \"publicKey\", signingKey.compressedPublicKey);\n } else {\n defineReadOnly(this, \"privateKey\", null);\n defineReadOnly(this, \"publicKey\", hexlify(publicKey));\n }\n defineReadOnly(this, \"parentFingerprint\", parentFingerprint);\n defineReadOnly(this, \"fingerprint\", hexDataSlice(ripemd160(sha256(this.publicKey)), 0, 4));\n defineReadOnly(this, \"address\", computeAddress(this.publicKey));\n defineReadOnly(this, \"chainCode\", chainCode);\n defineReadOnly(this, \"index\", index);\n defineReadOnly(this, \"depth\", depth);\n if (mnemonicOrPath == null) {\n // From a source that does not preserve the path (e.g. extended keys)\n defineReadOnly(this, \"mnemonic\", null);\n defineReadOnly(this, \"path\", null);\n } else if (typeof mnemonicOrPath === \"string\") {\n // From a source that does not preserve the mnemonic (e.g. neutered)\n defineReadOnly(this, \"mnemonic\", null);\n defineReadOnly(this, \"path\", mnemonicOrPath);\n } else {\n // From a fully qualified source\n defineReadOnly(this, \"mnemonic\", mnemonicOrPath);\n defineReadOnly(this, \"path\", mnemonicOrPath.path);\n }\n }\n get extendedKey() {\n // We only support the mainnet values for now, but if anyone needs\n // testnet values, let me know. I believe current sentiment is that\n // we should always use mainnet, and use BIP-44 to derive the network\n // - Mainnet: public=0x0488B21E, private=0x0488ADE4\n // - Testnet: public=0x043587CF, private=0x04358394\n if (this.depth >= 256) {\n throw new Error(\"Depth too large!\");\n }\n return base58check(concat([this.privateKey != null ? \"0x0488ADE4\" : \"0x0488B21E\", hexlify(this.depth), this.parentFingerprint, hexZeroPad(hexlify(this.index), 4), this.chainCode, this.privateKey != null ? concat([\"0x00\", this.privateKey]) : this.publicKey]));\n }\n neuter() {\n return new HDNode(_constructorGuard, null, this.publicKey, this.parentFingerprint, this.chainCode, this.index, this.depth, this.path);\n }\n _derive(index) {\n if (index > 0xffffffff) {\n throw new Error(\"invalid index - \" + String(index));\n }\n // Base path\n let path = this.path;\n if (path) {\n path += \"/\" + (index & ~HardenedBit);\n }\n const data = new Uint8Array(37);\n if (index & HardenedBit) {\n if (!this.privateKey) {\n throw new Error(\"cannot derive child of neutered node\");\n }\n // Data = 0x00 || ser_256(k_par)\n data.set(arrayify(this.privateKey), 1);\n // Hardened path\n if (path) {\n path += \"'\";\n }\n } else {\n // Data = ser_p(point(k_par))\n data.set(arrayify(this.publicKey));\n }\n // Data += ser_32(i)\n for (let i = 24; i >= 0; i -= 8) {\n data[33 + (i >> 3)] = index >> 24 - i & 0xff;\n }\n const I = arrayify(computeHmac(SupportedAlgorithm.sha512, this.chainCode, data));\n const IL = I.slice(0, 32);\n const IR = I.slice(32);\n // The private key\n let ki = null;\n // The public key\n let Ki = null;\n if (this.privateKey) {\n ki = bytes32(BigNumber.from(IL).add(this.privateKey).mod(N));\n } else {\n const ek = new SigningKey(hexlify(IL));\n Ki = ek._addPoint(this.publicKey);\n }\n let mnemonicOrPath = path;\n const srcMnemonic = this.mnemonic;\n if (srcMnemonic) {\n mnemonicOrPath = Object.freeze({\n phrase: srcMnemonic.phrase,\n path: path,\n locale: srcMnemonic.locale || \"en\"\n });\n }\n return new HDNode(_constructorGuard, ki, Ki, this.fingerprint, bytes32(IR), index, this.depth + 1, mnemonicOrPath);\n }\n derivePath(path) {\n const components = path.split(\"/\");\n if (components.length === 0 || components[0] === \"m\" && this.depth !== 0) {\n throw new Error(\"invalid path - \" + path);\n }\n if (components[0] === \"m\") {\n components.shift();\n }\n let result = this;\n for (let i = 0; i < components.length; i++) {\n const component = components[i];\n if (component.match(/^[0-9]+'$/)) {\n const index = parseInt(component.substring(0, component.length - 1));\n if (index >= HardenedBit) {\n throw new Error(\"invalid path index - \" + component);\n }\n result = result._derive(HardenedBit + index);\n } else if (component.match(/^[0-9]+$/)) {\n const index = parseInt(component);\n if (index >= HardenedBit) {\n throw new Error(\"invalid path index - \" + component);\n }\n result = result._derive(index);\n } else {\n throw new Error(\"invalid path component - \" + component);\n }\n }\n return result;\n }\n static _fromSeed(seed, mnemonic) {\n const seedArray = arrayify(seed);\n if (seedArray.length < 16 || seedArray.length > 64) {\n throw new Error(\"invalid seed\");\n }\n const I = arrayify(computeHmac(SupportedAlgorithm.sha512, MasterSecret, seedArray));\n return new HDNode(_constructorGuard, bytes32(I.slice(0, 32)), null, \"0x00000000\", bytes32(I.slice(32)), 0, 0, mnemonic);\n }\n static fromMnemonic(mnemonic, password, wordlist) {\n // If a locale name was passed in, find the associated wordlist\n wordlist = getWordlist(wordlist);\n // Normalize the case and spacing in the mnemonic (throws if the mnemonic is invalid)\n mnemonic = entropyToMnemonic(mnemonicToEntropy(mnemonic, wordlist), wordlist);\n return HDNode._fromSeed(mnemonicToSeed(mnemonic, password), {\n phrase: mnemonic,\n path: \"m\",\n locale: wordlist.locale\n });\n }\n static fromSeed(seed) {\n return HDNode._fromSeed(seed, null);\n }\n static fromExtendedKey(extendedKey) {\n const bytes = Base58.decode(extendedKey);\n if (bytes.length !== 82 || base58check(bytes.slice(0, 78)) !== extendedKey) {\n logger.throwArgumentError(\"invalid extended key\", \"extendedKey\", \"[REDACTED]\");\n }\n const depth = bytes[4];\n const parentFingerprint = hexlify(bytes.slice(5, 9));\n const index = parseInt(hexlify(bytes.slice(9, 13)).substring(2), 16);\n const chainCode = hexlify(bytes.slice(13, 45));\n const key = bytes.slice(45, 78);\n switch (hexlify(bytes.slice(0, 4))) {\n // Public Key\n case \"0x0488b21e\":\n case \"0x043587cf\":\n return new HDNode(_constructorGuard, null, hexlify(key), parentFingerprint, chainCode, index, depth, null);\n // Private Key\n case \"0x0488ade4\":\n case \"0x04358394 \":\n if (key[0] !== 0) {\n break;\n }\n return new HDNode(_constructorGuard, hexlify(key.slice(1)), null, parentFingerprint, chainCode, index, depth, null);\n }\n return logger.throwArgumentError(\"invalid extended key\", \"extendedKey\", \"[REDACTED]\");\n }\n}\nexport function mnemonicToSeed(mnemonic, password) {\n if (!password) {\n password = \"\";\n }\n const salt = toUtf8Bytes(\"mnemonic\" + password, UnicodeNormalizationForm.NFKD);\n return pbkdf2(toUtf8Bytes(mnemonic, UnicodeNormalizationForm.NFKD), salt, 2048, 64, \"sha512\");\n}\nexport function mnemonicToEntropy(mnemonic, wordlist) {\n wordlist = getWordlist(wordlist);\n logger.checkNormalize();\n const words = wordlist.split(mnemonic);\n if (words.length % 3 !== 0) {\n throw new Error(\"invalid mnemonic\");\n }\n const entropy = arrayify(new Uint8Array(Math.ceil(11 * words.length / 8)));\n let offset = 0;\n for (let i = 0; i < words.length; i++) {\n let index = wordlist.getWordIndex(words[i].normalize(\"NFKD\"));\n if (index === -1) {\n throw new Error(\"invalid mnemonic\");\n }\n for (let bit = 0; bit < 11; bit++) {\n if (index & 1 << 10 - bit) {\n entropy[offset >> 3] |= 1 << 7 - offset % 8;\n }\n offset++;\n }\n }\n const entropyBits = 32 * words.length / 3;\n const checksumBits = words.length / 3;\n const checksumMask = getUpperMask(checksumBits);\n const checksum = arrayify(sha256(entropy.slice(0, entropyBits / 8)))[0] & checksumMask;\n if (checksum !== (entropy[entropy.length - 1] & checksumMask)) {\n throw new Error(\"invalid checksum\");\n }\n return hexlify(entropy.slice(0, entropyBits / 8));\n}\nexport function entropyToMnemonic(entropy, wordlist) {\n wordlist = getWordlist(wordlist);\n entropy = arrayify(entropy);\n if (entropy.length % 4 !== 0 || entropy.length < 16 || entropy.length > 32) {\n throw new Error(\"invalid entropy\");\n }\n const indices = [0];\n let remainingBits = 11;\n for (let i = 0; i < entropy.length; i++) {\n // Consume the whole byte (with still more to go)\n if (remainingBits > 8) {\n indices[indices.length - 1] <<= 8;\n indices[indices.length - 1] |= entropy[i];\n remainingBits -= 8;\n // This byte will complete an 11-bit index\n } else {\n indices[indices.length - 1] <<= remainingBits;\n indices[indices.length - 1] |= entropy[i] >> 8 - remainingBits;\n // Start the next word\n indices.push(entropy[i] & getLowerMask(8 - remainingBits));\n remainingBits += 3;\n }\n }\n // Compute the checksum bits\n const checksumBits = entropy.length / 4;\n const checksum = arrayify(sha256(entropy))[0] & getUpperMask(checksumBits);\n // Shift the checksum into the word indices\n indices[indices.length - 1] <<= checksumBits;\n indices[indices.length - 1] |= checksum >> 8 - checksumBits;\n return wordlist.join(indices.map(index => wordlist.getWord(index)));\n}\nexport function isValidMnemonic(mnemonic, wordlist) {\n try {\n mnemonicToEntropy(mnemonic, wordlist);\n return true;\n } catch (error) {}\n return false;\n}\nexport function getAccountPath(index) {\n if (typeof index !== \"number\" || index < 0 || index >= HardenedBit || index % 1) {\n logger.throwArgumentError(\"invalid account index\", \"index\", index);\n }\n return `m/44'/60'/${index}'/0/0`;\n}\n","\"use strict\";\n\n(function (root) {\n function checkInt(value) {\n return parseInt(value) === value;\n }\n function checkInts(arrayish) {\n if (!checkInt(arrayish.length)) {\n return false;\n }\n for (var i = 0; i < arrayish.length; i++) {\n if (!checkInt(arrayish[i]) || arrayish[i] < 0 || arrayish[i] > 255) {\n return false;\n }\n }\n return true;\n }\n function coerceArray(arg, copy) {\n // ArrayBuffer view\n if (arg.buffer && ArrayBuffer.isView(arg) && arg.name === 'Uint8Array') {\n if (copy) {\n if (arg.slice) {\n arg = arg.slice();\n } else {\n arg = Array.prototype.slice.call(arg);\n }\n }\n return arg;\n }\n\n // It's an array; check it is a valid representation of a byte\n if (Array.isArray(arg)) {\n if (!checkInts(arg)) {\n throw new Error('Array contains invalid value: ' + arg);\n }\n return new Uint8Array(arg);\n }\n\n // Something else, but behaves like an array (maybe a Buffer? Arguments?)\n if (checkInt(arg.length) && checkInts(arg)) {\n return new Uint8Array(arg);\n }\n throw new Error('unsupported array-like object');\n }\n function createArray(length) {\n return new Uint8Array(length);\n }\n function copyArray(sourceArray, targetArray, targetStart, sourceStart, sourceEnd) {\n if (sourceStart != null || sourceEnd != null) {\n if (sourceArray.slice) {\n sourceArray = sourceArray.slice(sourceStart, sourceEnd);\n } else {\n sourceArray = Array.prototype.slice.call(sourceArray, sourceStart, sourceEnd);\n }\n }\n targetArray.set(sourceArray, targetStart);\n }\n var convertUtf8 = function () {\n function toBytes(text) {\n var result = [],\n i = 0;\n text = encodeURI(text);\n while (i < text.length) {\n var c = text.charCodeAt(i++);\n\n // if it is a % sign, encode the following 2 bytes as a hex value\n if (c === 37) {\n result.push(parseInt(text.substr(i, 2), 16));\n i += 2;\n\n // otherwise, just the actual byte\n } else {\n result.push(c);\n }\n }\n return coerceArray(result);\n }\n function fromBytes(bytes) {\n var result = [],\n i = 0;\n while (i < bytes.length) {\n var c = bytes[i];\n if (c < 128) {\n result.push(String.fromCharCode(c));\n i++;\n } else if (c > 191 && c < 224) {\n result.push(String.fromCharCode((c & 0x1f) << 6 | bytes[i + 1] & 0x3f));\n i += 2;\n } else {\n result.push(String.fromCharCode((c & 0x0f) << 12 | (bytes[i + 1] & 0x3f) << 6 | bytes[i + 2] & 0x3f));\n i += 3;\n }\n }\n return result.join('');\n }\n return {\n toBytes: toBytes,\n fromBytes: fromBytes\n };\n }();\n var convertHex = function () {\n function toBytes(text) {\n var result = [];\n for (var i = 0; i < text.length; i += 2) {\n result.push(parseInt(text.substr(i, 2), 16));\n }\n return result;\n }\n\n // http://ixti.net/development/javascript/2011/11/11/base64-encodedecode-of-utf8-in-browser-with-js.html\n var Hex = '0123456789abcdef';\n function fromBytes(bytes) {\n var result = [];\n for (var i = 0; i < bytes.length; i++) {\n var v = bytes[i];\n result.push(Hex[(v & 0xf0) >> 4] + Hex[v & 0x0f]);\n }\n return result.join('');\n }\n return {\n toBytes: toBytes,\n fromBytes: fromBytes\n };\n }();\n\n // Number of rounds by keysize\n var numberOfRounds = {\n 16: 10,\n 24: 12,\n 32: 14\n };\n\n // Round constant words\n var rcon = [0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91];\n\n // S-box and Inverse S-box (S is for Substitution)\n var S = [0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76, 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0, 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15, 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75, 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84, 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf, 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8, 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2, 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73, 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb, 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79, 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08, 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a, 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e, 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf, 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16];\n var Si = [0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb, 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb, 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e, 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25, 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92, 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84, 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06, 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b, 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73, 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e, 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b, 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4, 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f, 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef, 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61, 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d];\n\n // Transformations for encryption\n var T1 = [0xc66363a5, 0xf87c7c84, 0xee777799, 0xf67b7b8d, 0xfff2f20d, 0xd66b6bbd, 0xde6f6fb1, 0x91c5c554, 0x60303050, 0x02010103, 0xce6767a9, 0x562b2b7d, 0xe7fefe19, 0xb5d7d762, 0x4dababe6, 0xec76769a, 0x8fcaca45, 0x1f82829d, 0x89c9c940, 0xfa7d7d87, 0xeffafa15, 0xb25959eb, 0x8e4747c9, 0xfbf0f00b, 0x41adadec, 0xb3d4d467, 0x5fa2a2fd, 0x45afafea, 0x239c9cbf, 0x53a4a4f7, 0xe4727296, 0x9bc0c05b, 0x75b7b7c2, 0xe1fdfd1c, 0x3d9393ae, 0x4c26266a, 0x6c36365a, 0x7e3f3f41, 0xf5f7f702, 0x83cccc4f, 0x6834345c, 0x51a5a5f4, 0xd1e5e534, 0xf9f1f108, 0xe2717193, 0xabd8d873, 0x62313153, 0x2a15153f, 0x0804040c, 0x95c7c752, 0x46232365, 0x9dc3c35e, 0x30181828, 0x379696a1, 0x0a05050f, 0x2f9a9ab5, 0x0e070709, 0x24121236, 0x1b80809b, 0xdfe2e23d, 0xcdebeb26, 0x4e272769, 0x7fb2b2cd, 0xea75759f, 0x1209091b, 0x1d83839e, 0x582c2c74, 0x341a1a2e, 0x361b1b2d, 0xdc6e6eb2, 0xb45a5aee, 0x5ba0a0fb, 0xa45252f6, 0x763b3b4d, 0xb7d6d661, 0x7db3b3ce, 0x5229297b, 0xdde3e33e, 0x5e2f2f71, 0x13848497, 0xa65353f5, 0xb9d1d168, 0x00000000, 0xc1eded2c, 0x40202060, 0xe3fcfc1f, 0x79b1b1c8, 0xb65b5bed, 0xd46a6abe, 0x8dcbcb46, 0x67bebed9, 0x7239394b, 0x944a4ade, 0x984c4cd4, 0xb05858e8, 0x85cfcf4a, 0xbbd0d06b, 0xc5efef2a, 0x4faaaae5, 0xedfbfb16, 0x864343c5, 0x9a4d4dd7, 0x66333355, 0x11858594, 0x8a4545cf, 0xe9f9f910, 0x04020206, 0xfe7f7f81, 0xa05050f0, 0x783c3c44, 0x259f9fba, 0x4ba8a8e3, 0xa25151f3, 0x5da3a3fe, 0x804040c0, 0x058f8f8a, 0x3f9292ad, 0x219d9dbc, 0x70383848, 0xf1f5f504, 0x63bcbcdf, 0x77b6b6c1, 0xafdada75, 0x42212163, 0x20101030, 0xe5ffff1a, 0xfdf3f30e, 0xbfd2d26d, 0x81cdcd4c, 0x180c0c14, 0x26131335, 0xc3ecec2f, 0xbe5f5fe1, 0x359797a2, 0x884444cc, 0x2e171739, 0x93c4c457, 0x55a7a7f2, 0xfc7e7e82, 0x7a3d3d47, 0xc86464ac, 0xba5d5de7, 0x3219192b, 0xe6737395, 0xc06060a0, 0x19818198, 0x9e4f4fd1, 0xa3dcdc7f, 0x44222266, 0x542a2a7e, 0x3b9090ab, 0x0b888883, 0x8c4646ca, 0xc7eeee29, 0x6bb8b8d3, 0x2814143c, 0xa7dede79, 0xbc5e5ee2, 0x160b0b1d, 0xaddbdb76, 0xdbe0e03b, 0x64323256, 0x743a3a4e, 0x140a0a1e, 0x924949db, 0x0c06060a, 0x4824246c, 0xb85c5ce4, 0x9fc2c25d, 0xbdd3d36e, 0x43acacef, 0xc46262a6, 0x399191a8, 0x319595a4, 0xd3e4e437, 0xf279798b, 0xd5e7e732, 0x8bc8c843, 0x6e373759, 0xda6d6db7, 0x018d8d8c, 0xb1d5d564, 0x9c4e4ed2, 0x49a9a9e0, 0xd86c6cb4, 0xac5656fa, 0xf3f4f407, 0xcfeaea25, 0xca6565af, 0xf47a7a8e, 0x47aeaee9, 0x10080818, 0x6fbabad5, 0xf0787888, 0x4a25256f, 0x5c2e2e72, 0x381c1c24, 0x57a6a6f1, 0x73b4b4c7, 0x97c6c651, 0xcbe8e823, 0xa1dddd7c, 0xe874749c, 0x3e1f1f21, 0x964b4bdd, 0x61bdbddc, 0x0d8b8b86, 0x0f8a8a85, 0xe0707090, 0x7c3e3e42, 0x71b5b5c4, 0xcc6666aa, 0x904848d8, 0x06030305, 0xf7f6f601, 0x1c0e0e12, 0xc26161a3, 0x6a35355f, 0xae5757f9, 0x69b9b9d0, 0x17868691, 0x99c1c158, 0x3a1d1d27, 0x279e9eb9, 0xd9e1e138, 0xebf8f813, 0x2b9898b3, 0x22111133, 0xd26969bb, 0xa9d9d970, 0x078e8e89, 0x339494a7, 0x2d9b9bb6, 0x3c1e1e22, 0x15878792, 0xc9e9e920, 0x87cece49, 0xaa5555ff, 0x50282878, 0xa5dfdf7a, 0x038c8c8f, 0x59a1a1f8, 0x09898980, 0x1a0d0d17, 0x65bfbfda, 0xd7e6e631, 0x844242c6, 0xd06868b8, 0x824141c3, 0x299999b0, 0x5a2d2d77, 0x1e0f0f11, 0x7bb0b0cb, 0xa85454fc, 0x6dbbbbd6, 0x2c16163a];\n var T2 = [0xa5c66363, 0x84f87c7c, 0x99ee7777, 0x8df67b7b, 0x0dfff2f2, 0xbdd66b6b, 0xb1de6f6f, 0x5491c5c5, 0x50603030, 0x03020101, 0xa9ce6767, 0x7d562b2b, 0x19e7fefe, 0x62b5d7d7, 0xe64dabab, 0x9aec7676, 0x458fcaca, 0x9d1f8282, 0x4089c9c9, 0x87fa7d7d, 0x15effafa, 0xebb25959, 0xc98e4747, 0x0bfbf0f0, 0xec41adad, 0x67b3d4d4, 0xfd5fa2a2, 0xea45afaf, 0xbf239c9c, 0xf753a4a4, 0x96e47272, 0x5b9bc0c0, 0xc275b7b7, 0x1ce1fdfd, 0xae3d9393, 0x6a4c2626, 0x5a6c3636, 0x417e3f3f, 0x02f5f7f7, 0x4f83cccc, 0x5c683434, 0xf451a5a5, 0x34d1e5e5, 0x08f9f1f1, 0x93e27171, 0x73abd8d8, 0x53623131, 0x3f2a1515, 0x0c080404, 0x5295c7c7, 0x65462323, 0x5e9dc3c3, 0x28301818, 0xa1379696, 0x0f0a0505, 0xb52f9a9a, 0x090e0707, 0x36241212, 0x9b1b8080, 0x3ddfe2e2, 0x26cdebeb, 0x694e2727, 0xcd7fb2b2, 0x9fea7575, 0x1b120909, 0x9e1d8383, 0x74582c2c, 0x2e341a1a, 0x2d361b1b, 0xb2dc6e6e, 0xeeb45a5a, 0xfb5ba0a0, 0xf6a45252, 0x4d763b3b, 0x61b7d6d6, 0xce7db3b3, 0x7b522929, 0x3edde3e3, 0x715e2f2f, 0x97138484, 0xf5a65353, 0x68b9d1d1, 0x00000000, 0x2cc1eded, 0x60402020, 0x1fe3fcfc, 0xc879b1b1, 0xedb65b5b, 0xbed46a6a, 0x468dcbcb, 0xd967bebe, 0x4b723939, 0xde944a4a, 0xd4984c4c, 0xe8b05858, 0x4a85cfcf, 0x6bbbd0d0, 0x2ac5efef, 0xe54faaaa, 0x16edfbfb, 0xc5864343, 0xd79a4d4d, 0x55663333, 0x94118585, 0xcf8a4545, 0x10e9f9f9, 0x06040202, 0x81fe7f7f, 0xf0a05050, 0x44783c3c, 0xba259f9f, 0xe34ba8a8, 0xf3a25151, 0xfe5da3a3, 0xc0804040, 0x8a058f8f, 0xad3f9292, 0xbc219d9d, 0x48703838, 0x04f1f5f5, 0xdf63bcbc, 0xc177b6b6, 0x75afdada, 0x63422121, 0x30201010, 0x1ae5ffff, 0x0efdf3f3, 0x6dbfd2d2, 0x4c81cdcd, 0x14180c0c, 0x35261313, 0x2fc3ecec, 0xe1be5f5f, 0xa2359797, 0xcc884444, 0x392e1717, 0x5793c4c4, 0xf255a7a7, 0x82fc7e7e, 0x477a3d3d, 0xacc86464, 0xe7ba5d5d, 0x2b321919, 0x95e67373, 0xa0c06060, 0x98198181, 0xd19e4f4f, 0x7fa3dcdc, 0x66442222, 0x7e542a2a, 0xab3b9090, 0x830b8888, 0xca8c4646, 0x29c7eeee, 0xd36bb8b8, 0x3c281414, 0x79a7dede, 0xe2bc5e5e, 0x1d160b0b, 0x76addbdb, 0x3bdbe0e0, 0x56643232, 0x4e743a3a, 0x1e140a0a, 0xdb924949, 0x0a0c0606, 0x6c482424, 0xe4b85c5c, 0x5d9fc2c2, 0x6ebdd3d3, 0xef43acac, 0xa6c46262, 0xa8399191, 0xa4319595, 0x37d3e4e4, 0x8bf27979, 0x32d5e7e7, 0x438bc8c8, 0x596e3737, 0xb7da6d6d, 0x8c018d8d, 0x64b1d5d5, 0xd29c4e4e, 0xe049a9a9, 0xb4d86c6c, 0xfaac5656, 0x07f3f4f4, 0x25cfeaea, 0xafca6565, 0x8ef47a7a, 0xe947aeae, 0x18100808, 0xd56fbaba, 0x88f07878, 0x6f4a2525, 0x725c2e2e, 0x24381c1c, 0xf157a6a6, 0xc773b4b4, 0x5197c6c6, 0x23cbe8e8, 0x7ca1dddd, 0x9ce87474, 0x213e1f1f, 0xdd964b4b, 0xdc61bdbd, 0x860d8b8b, 0x850f8a8a, 0x90e07070, 0x427c3e3e, 0xc471b5b5, 0xaacc6666, 0xd8904848, 0x05060303, 0x01f7f6f6, 0x121c0e0e, 0xa3c26161, 0x5f6a3535, 0xf9ae5757, 0xd069b9b9, 0x91178686, 0x5899c1c1, 0x273a1d1d, 0xb9279e9e, 0x38d9e1e1, 0x13ebf8f8, 0xb32b9898, 0x33221111, 0xbbd26969, 0x70a9d9d9, 0x89078e8e, 0xa7339494, 0xb62d9b9b, 0x223c1e1e, 0x92158787, 0x20c9e9e9, 0x4987cece, 0xffaa5555, 0x78502828, 0x7aa5dfdf, 0x8f038c8c, 0xf859a1a1, 0x80098989, 0x171a0d0d, 0xda65bfbf, 0x31d7e6e6, 0xc6844242, 0xb8d06868, 0xc3824141, 0xb0299999, 0x775a2d2d, 0x111e0f0f, 0xcb7bb0b0, 0xfca85454, 0xd66dbbbb, 0x3a2c1616];\n var T3 = [0x63a5c663, 0x7c84f87c, 0x7799ee77, 0x7b8df67b, 0xf20dfff2, 0x6bbdd66b, 0x6fb1de6f, 0xc55491c5, 0x30506030, 0x01030201, 0x67a9ce67, 0x2b7d562b, 0xfe19e7fe, 0xd762b5d7, 0xabe64dab, 0x769aec76, 0xca458fca, 0x829d1f82, 0xc94089c9, 0x7d87fa7d, 0xfa15effa, 0x59ebb259, 0x47c98e47, 0xf00bfbf0, 0xadec41ad, 0xd467b3d4, 0xa2fd5fa2, 0xafea45af, 0x9cbf239c, 0xa4f753a4, 0x7296e472, 0xc05b9bc0, 0xb7c275b7, 0xfd1ce1fd, 0x93ae3d93, 0x266a4c26, 0x365a6c36, 0x3f417e3f, 0xf702f5f7, 0xcc4f83cc, 0x345c6834, 0xa5f451a5, 0xe534d1e5, 0xf108f9f1, 0x7193e271, 0xd873abd8, 0x31536231, 0x153f2a15, 0x040c0804, 0xc75295c7, 0x23654623, 0xc35e9dc3, 0x18283018, 0x96a13796, 0x050f0a05, 0x9ab52f9a, 0x07090e07, 0x12362412, 0x809b1b80, 0xe23ddfe2, 0xeb26cdeb, 0x27694e27, 0xb2cd7fb2, 0x759fea75, 0x091b1209, 0x839e1d83, 0x2c74582c, 0x1a2e341a, 0x1b2d361b, 0x6eb2dc6e, 0x5aeeb45a, 0xa0fb5ba0, 0x52f6a452, 0x3b4d763b, 0xd661b7d6, 0xb3ce7db3, 0x297b5229, 0xe33edde3, 0x2f715e2f, 0x84971384, 0x53f5a653, 0xd168b9d1, 0x00000000, 0xed2cc1ed, 0x20604020, 0xfc1fe3fc, 0xb1c879b1, 0x5bedb65b, 0x6abed46a, 0xcb468dcb, 0xbed967be, 0x394b7239, 0x4ade944a, 0x4cd4984c, 0x58e8b058, 0xcf4a85cf, 0xd06bbbd0, 0xef2ac5ef, 0xaae54faa, 0xfb16edfb, 0x43c58643, 0x4dd79a4d, 0x33556633, 0x85941185, 0x45cf8a45, 0xf910e9f9, 0x02060402, 0x7f81fe7f, 0x50f0a050, 0x3c44783c, 0x9fba259f, 0xa8e34ba8, 0x51f3a251, 0xa3fe5da3, 0x40c08040, 0x8f8a058f, 0x92ad3f92, 0x9dbc219d, 0x38487038, 0xf504f1f5, 0xbcdf63bc, 0xb6c177b6, 0xda75afda, 0x21634221, 0x10302010, 0xff1ae5ff, 0xf30efdf3, 0xd26dbfd2, 0xcd4c81cd, 0x0c14180c, 0x13352613, 0xec2fc3ec, 0x5fe1be5f, 0x97a23597, 0x44cc8844, 0x17392e17, 0xc45793c4, 0xa7f255a7, 0x7e82fc7e, 0x3d477a3d, 0x64acc864, 0x5de7ba5d, 0x192b3219, 0x7395e673, 0x60a0c060, 0x81981981, 0x4fd19e4f, 0xdc7fa3dc, 0x22664422, 0x2a7e542a, 0x90ab3b90, 0x88830b88, 0x46ca8c46, 0xee29c7ee, 0xb8d36bb8, 0x143c2814, 0xde79a7de, 0x5ee2bc5e, 0x0b1d160b, 0xdb76addb, 0xe03bdbe0, 0x32566432, 0x3a4e743a, 0x0a1e140a, 0x49db9249, 0x060a0c06, 0x246c4824, 0x5ce4b85c, 0xc25d9fc2, 0xd36ebdd3, 0xacef43ac, 0x62a6c462, 0x91a83991, 0x95a43195, 0xe437d3e4, 0x798bf279, 0xe732d5e7, 0xc8438bc8, 0x37596e37, 0x6db7da6d, 0x8d8c018d, 0xd564b1d5, 0x4ed29c4e, 0xa9e049a9, 0x6cb4d86c, 0x56faac56, 0xf407f3f4, 0xea25cfea, 0x65afca65, 0x7a8ef47a, 0xaee947ae, 0x08181008, 0xbad56fba, 0x7888f078, 0x256f4a25, 0x2e725c2e, 0x1c24381c, 0xa6f157a6, 0xb4c773b4, 0xc65197c6, 0xe823cbe8, 0xdd7ca1dd, 0x749ce874, 0x1f213e1f, 0x4bdd964b, 0xbddc61bd, 0x8b860d8b, 0x8a850f8a, 0x7090e070, 0x3e427c3e, 0xb5c471b5, 0x66aacc66, 0x48d89048, 0x03050603, 0xf601f7f6, 0x0e121c0e, 0x61a3c261, 0x355f6a35, 0x57f9ae57, 0xb9d069b9, 0x86911786, 0xc15899c1, 0x1d273a1d, 0x9eb9279e, 0xe138d9e1, 0xf813ebf8, 0x98b32b98, 0x11332211, 0x69bbd269, 0xd970a9d9, 0x8e89078e, 0x94a73394, 0x9bb62d9b, 0x1e223c1e, 0x87921587, 0xe920c9e9, 0xce4987ce, 0x55ffaa55, 0x28785028, 0xdf7aa5df, 0x8c8f038c, 0xa1f859a1, 0x89800989, 0x0d171a0d, 0xbfda65bf, 0xe631d7e6, 0x42c68442, 0x68b8d068, 0x41c38241, 0x99b02999, 0x2d775a2d, 0x0f111e0f, 0xb0cb7bb0, 0x54fca854, 0xbbd66dbb, 0x163a2c16];\n var T4 = [0x6363a5c6, 0x7c7c84f8, 0x777799ee, 0x7b7b8df6, 0xf2f20dff, 0x6b6bbdd6, 0x6f6fb1de, 0xc5c55491, 0x30305060, 0x01010302, 0x6767a9ce, 0x2b2b7d56, 0xfefe19e7, 0xd7d762b5, 0xababe64d, 0x76769aec, 0xcaca458f, 0x82829d1f, 0xc9c94089, 0x7d7d87fa, 0xfafa15ef, 0x5959ebb2, 0x4747c98e, 0xf0f00bfb, 0xadadec41, 0xd4d467b3, 0xa2a2fd5f, 0xafafea45, 0x9c9cbf23, 0xa4a4f753, 0x727296e4, 0xc0c05b9b, 0xb7b7c275, 0xfdfd1ce1, 0x9393ae3d, 0x26266a4c, 0x36365a6c, 0x3f3f417e, 0xf7f702f5, 0xcccc4f83, 0x34345c68, 0xa5a5f451, 0xe5e534d1, 0xf1f108f9, 0x717193e2, 0xd8d873ab, 0x31315362, 0x15153f2a, 0x04040c08, 0xc7c75295, 0x23236546, 0xc3c35e9d, 0x18182830, 0x9696a137, 0x05050f0a, 0x9a9ab52f, 0x0707090e, 0x12123624, 0x80809b1b, 0xe2e23ddf, 0xebeb26cd, 0x2727694e, 0xb2b2cd7f, 0x75759fea, 0x09091b12, 0x83839e1d, 0x2c2c7458, 0x1a1a2e34, 0x1b1b2d36, 0x6e6eb2dc, 0x5a5aeeb4, 0xa0a0fb5b, 0x5252f6a4, 0x3b3b4d76, 0xd6d661b7, 0xb3b3ce7d, 0x29297b52, 0xe3e33edd, 0x2f2f715e, 0x84849713, 0x5353f5a6, 0xd1d168b9, 0x00000000, 0xeded2cc1, 0x20206040, 0xfcfc1fe3, 0xb1b1c879, 0x5b5bedb6, 0x6a6abed4, 0xcbcb468d, 0xbebed967, 0x39394b72, 0x4a4ade94, 0x4c4cd498, 0x5858e8b0, 0xcfcf4a85, 0xd0d06bbb, 0xefef2ac5, 0xaaaae54f, 0xfbfb16ed, 0x4343c586, 0x4d4dd79a, 0x33335566, 0x85859411, 0x4545cf8a, 0xf9f910e9, 0x02020604, 0x7f7f81fe, 0x5050f0a0, 0x3c3c4478, 0x9f9fba25, 0xa8a8e34b, 0x5151f3a2, 0xa3a3fe5d, 0x4040c080, 0x8f8f8a05, 0x9292ad3f, 0x9d9dbc21, 0x38384870, 0xf5f504f1, 0xbcbcdf63, 0xb6b6c177, 0xdada75af, 0x21216342, 0x10103020, 0xffff1ae5, 0xf3f30efd, 0xd2d26dbf, 0xcdcd4c81, 0x0c0c1418, 0x13133526, 0xecec2fc3, 0x5f5fe1be, 0x9797a235, 0x4444cc88, 0x1717392e, 0xc4c45793, 0xa7a7f255, 0x7e7e82fc, 0x3d3d477a, 0x6464acc8, 0x5d5de7ba, 0x19192b32, 0x737395e6, 0x6060a0c0, 0x81819819, 0x4f4fd19e, 0xdcdc7fa3, 0x22226644, 0x2a2a7e54, 0x9090ab3b, 0x8888830b, 0x4646ca8c, 0xeeee29c7, 0xb8b8d36b, 0x14143c28, 0xdede79a7, 0x5e5ee2bc, 0x0b0b1d16, 0xdbdb76ad, 0xe0e03bdb, 0x32325664, 0x3a3a4e74, 0x0a0a1e14, 0x4949db92, 0x06060a0c, 0x24246c48, 0x5c5ce4b8, 0xc2c25d9f, 0xd3d36ebd, 0xacacef43, 0x6262a6c4, 0x9191a839, 0x9595a431, 0xe4e437d3, 0x79798bf2, 0xe7e732d5, 0xc8c8438b, 0x3737596e, 0x6d6db7da, 0x8d8d8c01, 0xd5d564b1, 0x4e4ed29c, 0xa9a9e049, 0x6c6cb4d8, 0x5656faac, 0xf4f407f3, 0xeaea25cf, 0x6565afca, 0x7a7a8ef4, 0xaeaee947, 0x08081810, 0xbabad56f, 0x787888f0, 0x25256f4a, 0x2e2e725c, 0x1c1c2438, 0xa6a6f157, 0xb4b4c773, 0xc6c65197, 0xe8e823cb, 0xdddd7ca1, 0x74749ce8, 0x1f1f213e, 0x4b4bdd96, 0xbdbddc61, 0x8b8b860d, 0x8a8a850f, 0x707090e0, 0x3e3e427c, 0xb5b5c471, 0x6666aacc, 0x4848d890, 0x03030506, 0xf6f601f7, 0x0e0e121c, 0x6161a3c2, 0x35355f6a, 0x5757f9ae, 0xb9b9d069, 0x86869117, 0xc1c15899, 0x1d1d273a, 0x9e9eb927, 0xe1e138d9, 0xf8f813eb, 0x9898b32b, 0x11113322, 0x6969bbd2, 0xd9d970a9, 0x8e8e8907, 0x9494a733, 0x9b9bb62d, 0x1e1e223c, 0x87879215, 0xe9e920c9, 0xcece4987, 0x5555ffaa, 0x28287850, 0xdfdf7aa5, 0x8c8c8f03, 0xa1a1f859, 0x89898009, 0x0d0d171a, 0xbfbfda65, 0xe6e631d7, 0x4242c684, 0x6868b8d0, 0x4141c382, 0x9999b029, 0x2d2d775a, 0x0f0f111e, 0xb0b0cb7b, 0x5454fca8, 0xbbbbd66d, 0x16163a2c];\n\n // Transformations for decryption\n var T5 = [0x51f4a750, 0x7e416553, 0x1a17a4c3, 0x3a275e96, 0x3bab6bcb, 0x1f9d45f1, 0xacfa58ab, 0x4be30393, 0x2030fa55, 0xad766df6, 0x88cc7691, 0xf5024c25, 0x4fe5d7fc, 0xc52acbd7, 0x26354480, 0xb562a38f, 0xdeb15a49, 0x25ba1b67, 0x45ea0e98, 0x5dfec0e1, 0xc32f7502, 0x814cf012, 0x8d4697a3, 0x6bd3f9c6, 0x038f5fe7, 0x15929c95, 0xbf6d7aeb, 0x955259da, 0xd4be832d, 0x587421d3, 0x49e06929, 0x8ec9c844, 0x75c2896a, 0xf48e7978, 0x99583e6b, 0x27b971dd, 0xbee14fb6, 0xf088ad17, 0xc920ac66, 0x7dce3ab4, 0x63df4a18, 0xe51a3182, 0x97513360, 0x62537f45, 0xb16477e0, 0xbb6bae84, 0xfe81a01c, 0xf9082b94, 0x70486858, 0x8f45fd19, 0x94de6c87, 0x527bf8b7, 0xab73d323, 0x724b02e2, 0xe31f8f57, 0x6655ab2a, 0xb2eb2807, 0x2fb5c203, 0x86c57b9a, 0xd33708a5, 0x302887f2, 0x23bfa5b2, 0x02036aba, 0xed16825c, 0x8acf1c2b, 0xa779b492, 0xf307f2f0, 0x4e69e2a1, 0x65daf4cd, 0x0605bed5, 0xd134621f, 0xc4a6fe8a, 0x342e539d, 0xa2f355a0, 0x058ae132, 0xa4f6eb75, 0x0b83ec39, 0x4060efaa, 0x5e719f06, 0xbd6e1051, 0x3e218af9, 0x96dd063d, 0xdd3e05ae, 0x4de6bd46, 0x91548db5, 0x71c45d05, 0x0406d46f, 0x605015ff, 0x1998fb24, 0xd6bde997, 0x894043cc, 0x67d99e77, 0xb0e842bd, 0x07898b88, 0xe7195b38, 0x79c8eedb, 0xa17c0a47, 0x7c420fe9, 0xf8841ec9, 0x00000000, 0x09808683, 0x322bed48, 0x1e1170ac, 0x6c5a724e, 0xfd0efffb, 0x0f853856, 0x3daed51e, 0x362d3927, 0x0a0fd964, 0x685ca621, 0x9b5b54d1, 0x24362e3a, 0x0c0a67b1, 0x9357e70f, 0xb4ee96d2, 0x1b9b919e, 0x80c0c54f, 0x61dc20a2, 0x5a774b69, 0x1c121a16, 0xe293ba0a, 0xc0a02ae5, 0x3c22e043, 0x121b171d, 0x0e090d0b, 0xf28bc7ad, 0x2db6a8b9, 0x141ea9c8, 0x57f11985, 0xaf75074c, 0xee99ddbb, 0xa37f60fd, 0xf701269f, 0x5c72f5bc, 0x44663bc5, 0x5bfb7e34, 0x8b432976, 0xcb23c6dc, 0xb6edfc68, 0xb8e4f163, 0xd731dcca, 0x42638510, 0x13972240, 0x84c61120, 0x854a247d, 0xd2bb3df8, 0xaef93211, 0xc729a16d, 0x1d9e2f4b, 0xdcb230f3, 0x0d8652ec, 0x77c1e3d0, 0x2bb3166c, 0xa970b999, 0x119448fa, 0x47e96422, 0xa8fc8cc4, 0xa0f03f1a, 0x567d2cd8, 0x223390ef, 0x87494ec7, 0xd938d1c1, 0x8ccaa2fe, 0x98d40b36, 0xa6f581cf, 0xa57ade28, 0xdab78e26, 0x3fadbfa4, 0x2c3a9de4, 0x5078920d, 0x6a5fcc9b, 0x547e4662, 0xf68d13c2, 0x90d8b8e8, 0x2e39f75e, 0x82c3aff5, 0x9f5d80be, 0x69d0937c, 0x6fd52da9, 0xcf2512b3, 0xc8ac993b, 0x10187da7, 0xe89c636e, 0xdb3bbb7b, 0xcd267809, 0x6e5918f4, 0xec9ab701, 0x834f9aa8, 0xe6956e65, 0xaaffe67e, 0x21bccf08, 0xef15e8e6, 0xbae79bd9, 0x4a6f36ce, 0xea9f09d4, 0x29b07cd6, 0x31a4b2af, 0x2a3f2331, 0xc6a59430, 0x35a266c0, 0x744ebc37, 0xfc82caa6, 0xe090d0b0, 0x33a7d815, 0xf104984a, 0x41ecdaf7, 0x7fcd500e, 0x1791f62f, 0x764dd68d, 0x43efb04d, 0xccaa4d54, 0xe49604df, 0x9ed1b5e3, 0x4c6a881b, 0xc12c1fb8, 0x4665517f, 0x9d5eea04, 0x018c355d, 0xfa877473, 0xfb0b412e, 0xb3671d5a, 0x92dbd252, 0xe9105633, 0x6dd64713, 0x9ad7618c, 0x37a10c7a, 0x59f8148e, 0xeb133c89, 0xcea927ee, 0xb761c935, 0xe11ce5ed, 0x7a47b13c, 0x9cd2df59, 0x55f2733f, 0x1814ce79, 0x73c737bf, 0x53f7cdea, 0x5ffdaa5b, 0xdf3d6f14, 0x7844db86, 0xcaaff381, 0xb968c43e, 0x3824342c, 0xc2a3405f, 0x161dc372, 0xbce2250c, 0x283c498b, 0xff0d9541, 0x39a80171, 0x080cb3de, 0xd8b4e49c, 0x6456c190, 0x7bcb8461, 0xd532b670, 0x486c5c74, 0xd0b85742];\n var T6 = [0x5051f4a7, 0x537e4165, 0xc31a17a4, 0x963a275e, 0xcb3bab6b, 0xf11f9d45, 0xabacfa58, 0x934be303, 0x552030fa, 0xf6ad766d, 0x9188cc76, 0x25f5024c, 0xfc4fe5d7, 0xd7c52acb, 0x80263544, 0x8fb562a3, 0x49deb15a, 0x6725ba1b, 0x9845ea0e, 0xe15dfec0, 0x02c32f75, 0x12814cf0, 0xa38d4697, 0xc66bd3f9, 0xe7038f5f, 0x9515929c, 0xebbf6d7a, 0xda955259, 0x2dd4be83, 0xd3587421, 0x2949e069, 0x448ec9c8, 0x6a75c289, 0x78f48e79, 0x6b99583e, 0xdd27b971, 0xb6bee14f, 0x17f088ad, 0x66c920ac, 0xb47dce3a, 0x1863df4a, 0x82e51a31, 0x60975133, 0x4562537f, 0xe0b16477, 0x84bb6bae, 0x1cfe81a0, 0x94f9082b, 0x58704868, 0x198f45fd, 0x8794de6c, 0xb7527bf8, 0x23ab73d3, 0xe2724b02, 0x57e31f8f, 0x2a6655ab, 0x07b2eb28, 0x032fb5c2, 0x9a86c57b, 0xa5d33708, 0xf2302887, 0xb223bfa5, 0xba02036a, 0x5ced1682, 0x2b8acf1c, 0x92a779b4, 0xf0f307f2, 0xa14e69e2, 0xcd65daf4, 0xd50605be, 0x1fd13462, 0x8ac4a6fe, 0x9d342e53, 0xa0a2f355, 0x32058ae1, 0x75a4f6eb, 0x390b83ec, 0xaa4060ef, 0x065e719f, 0x51bd6e10, 0xf93e218a, 0x3d96dd06, 0xaedd3e05, 0x464de6bd, 0xb591548d, 0x0571c45d, 0x6f0406d4, 0xff605015, 0x241998fb, 0x97d6bde9, 0xcc894043, 0x7767d99e, 0xbdb0e842, 0x8807898b, 0x38e7195b, 0xdb79c8ee, 0x47a17c0a, 0xe97c420f, 0xc9f8841e, 0x00000000, 0x83098086, 0x48322bed, 0xac1e1170, 0x4e6c5a72, 0xfbfd0eff, 0x560f8538, 0x1e3daed5, 0x27362d39, 0x640a0fd9, 0x21685ca6, 0xd19b5b54, 0x3a24362e, 0xb10c0a67, 0x0f9357e7, 0xd2b4ee96, 0x9e1b9b91, 0x4f80c0c5, 0xa261dc20, 0x695a774b, 0x161c121a, 0x0ae293ba, 0xe5c0a02a, 0x433c22e0, 0x1d121b17, 0x0b0e090d, 0xadf28bc7, 0xb92db6a8, 0xc8141ea9, 0x8557f119, 0x4caf7507, 0xbbee99dd, 0xfda37f60, 0x9ff70126, 0xbc5c72f5, 0xc544663b, 0x345bfb7e, 0x768b4329, 0xdccb23c6, 0x68b6edfc, 0x63b8e4f1, 0xcad731dc, 0x10426385, 0x40139722, 0x2084c611, 0x7d854a24, 0xf8d2bb3d, 0x11aef932, 0x6dc729a1, 0x4b1d9e2f, 0xf3dcb230, 0xec0d8652, 0xd077c1e3, 0x6c2bb316, 0x99a970b9, 0xfa119448, 0x2247e964, 0xc4a8fc8c, 0x1aa0f03f, 0xd8567d2c, 0xef223390, 0xc787494e, 0xc1d938d1, 0xfe8ccaa2, 0x3698d40b, 0xcfa6f581, 0x28a57ade, 0x26dab78e, 0xa43fadbf, 0xe42c3a9d, 0x0d507892, 0x9b6a5fcc, 0x62547e46, 0xc2f68d13, 0xe890d8b8, 0x5e2e39f7, 0xf582c3af, 0xbe9f5d80, 0x7c69d093, 0xa96fd52d, 0xb3cf2512, 0x3bc8ac99, 0xa710187d, 0x6ee89c63, 0x7bdb3bbb, 0x09cd2678, 0xf46e5918, 0x01ec9ab7, 0xa8834f9a, 0x65e6956e, 0x7eaaffe6, 0x0821bccf, 0xe6ef15e8, 0xd9bae79b, 0xce4a6f36, 0xd4ea9f09, 0xd629b07c, 0xaf31a4b2, 0x312a3f23, 0x30c6a594, 0xc035a266, 0x37744ebc, 0xa6fc82ca, 0xb0e090d0, 0x1533a7d8, 0x4af10498, 0xf741ecda, 0x0e7fcd50, 0x2f1791f6, 0x8d764dd6, 0x4d43efb0, 0x54ccaa4d, 0xdfe49604, 0xe39ed1b5, 0x1b4c6a88, 0xb8c12c1f, 0x7f466551, 0x049d5eea, 0x5d018c35, 0x73fa8774, 0x2efb0b41, 0x5ab3671d, 0x5292dbd2, 0x33e91056, 0x136dd647, 0x8c9ad761, 0x7a37a10c, 0x8e59f814, 0x89eb133c, 0xeecea927, 0x35b761c9, 0xede11ce5, 0x3c7a47b1, 0x599cd2df, 0x3f55f273, 0x791814ce, 0xbf73c737, 0xea53f7cd, 0x5b5ffdaa, 0x14df3d6f, 0x867844db, 0x81caaff3, 0x3eb968c4, 0x2c382434, 0x5fc2a340, 0x72161dc3, 0x0cbce225, 0x8b283c49, 0x41ff0d95, 0x7139a801, 0xde080cb3, 0x9cd8b4e4, 0x906456c1, 0x617bcb84, 0x70d532b6, 0x74486c5c, 0x42d0b857];\n var T7 = [0xa75051f4, 0x65537e41, 0xa4c31a17, 0x5e963a27, 0x6bcb3bab, 0x45f11f9d, 0x58abacfa, 0x03934be3, 0xfa552030, 0x6df6ad76, 0x769188cc, 0x4c25f502, 0xd7fc4fe5, 0xcbd7c52a, 0x44802635, 0xa38fb562, 0x5a49deb1, 0x1b6725ba, 0x0e9845ea, 0xc0e15dfe, 0x7502c32f, 0xf012814c, 0x97a38d46, 0xf9c66bd3, 0x5fe7038f, 0x9c951592, 0x7aebbf6d, 0x59da9552, 0x832dd4be, 0x21d35874, 0x692949e0, 0xc8448ec9, 0x896a75c2, 0x7978f48e, 0x3e6b9958, 0x71dd27b9, 0x4fb6bee1, 0xad17f088, 0xac66c920, 0x3ab47dce, 0x4a1863df, 0x3182e51a, 0x33609751, 0x7f456253, 0x77e0b164, 0xae84bb6b, 0xa01cfe81, 0x2b94f908, 0x68587048, 0xfd198f45, 0x6c8794de, 0xf8b7527b, 0xd323ab73, 0x02e2724b, 0x8f57e31f, 0xab2a6655, 0x2807b2eb, 0xc2032fb5, 0x7b9a86c5, 0x08a5d337, 0x87f23028, 0xa5b223bf, 0x6aba0203, 0x825ced16, 0x1c2b8acf, 0xb492a779, 0xf2f0f307, 0xe2a14e69, 0xf4cd65da, 0xbed50605, 0x621fd134, 0xfe8ac4a6, 0x539d342e, 0x55a0a2f3, 0xe132058a, 0xeb75a4f6, 0xec390b83, 0xefaa4060, 0x9f065e71, 0x1051bd6e, 0x8af93e21, 0x063d96dd, 0x05aedd3e, 0xbd464de6, 0x8db59154, 0x5d0571c4, 0xd46f0406, 0x15ff6050, 0xfb241998, 0xe997d6bd, 0x43cc8940, 0x9e7767d9, 0x42bdb0e8, 0x8b880789, 0x5b38e719, 0xeedb79c8, 0x0a47a17c, 0x0fe97c42, 0x1ec9f884, 0x00000000, 0x86830980, 0xed48322b, 0x70ac1e11, 0x724e6c5a, 0xfffbfd0e, 0x38560f85, 0xd51e3dae, 0x3927362d, 0xd9640a0f, 0xa621685c, 0x54d19b5b, 0x2e3a2436, 0x67b10c0a, 0xe70f9357, 0x96d2b4ee, 0x919e1b9b, 0xc54f80c0, 0x20a261dc, 0x4b695a77, 0x1a161c12, 0xba0ae293, 0x2ae5c0a0, 0xe0433c22, 0x171d121b, 0x0d0b0e09, 0xc7adf28b, 0xa8b92db6, 0xa9c8141e, 0x198557f1, 0x074caf75, 0xddbbee99, 0x60fda37f, 0x269ff701, 0xf5bc5c72, 0x3bc54466, 0x7e345bfb, 0x29768b43, 0xc6dccb23, 0xfc68b6ed, 0xf163b8e4, 0xdccad731, 0x85104263, 0x22401397, 0x112084c6, 0x247d854a, 0x3df8d2bb, 0x3211aef9, 0xa16dc729, 0x2f4b1d9e, 0x30f3dcb2, 0x52ec0d86, 0xe3d077c1, 0x166c2bb3, 0xb999a970, 0x48fa1194, 0x642247e9, 0x8cc4a8fc, 0x3f1aa0f0, 0x2cd8567d, 0x90ef2233, 0x4ec78749, 0xd1c1d938, 0xa2fe8cca, 0x0b3698d4, 0x81cfa6f5, 0xde28a57a, 0x8e26dab7, 0xbfa43fad, 0x9de42c3a, 0x920d5078, 0xcc9b6a5f, 0x4662547e, 0x13c2f68d, 0xb8e890d8, 0xf75e2e39, 0xaff582c3, 0x80be9f5d, 0x937c69d0, 0x2da96fd5, 0x12b3cf25, 0x993bc8ac, 0x7da71018, 0x636ee89c, 0xbb7bdb3b, 0x7809cd26, 0x18f46e59, 0xb701ec9a, 0x9aa8834f, 0x6e65e695, 0xe67eaaff, 0xcf0821bc, 0xe8e6ef15, 0x9bd9bae7, 0x36ce4a6f, 0x09d4ea9f, 0x7cd629b0, 0xb2af31a4, 0x23312a3f, 0x9430c6a5, 0x66c035a2, 0xbc37744e, 0xcaa6fc82, 0xd0b0e090, 0xd81533a7, 0x984af104, 0xdaf741ec, 0x500e7fcd, 0xf62f1791, 0xd68d764d, 0xb04d43ef, 0x4d54ccaa, 0x04dfe496, 0xb5e39ed1, 0x881b4c6a, 0x1fb8c12c, 0x517f4665, 0xea049d5e, 0x355d018c, 0x7473fa87, 0x412efb0b, 0x1d5ab367, 0xd25292db, 0x5633e910, 0x47136dd6, 0x618c9ad7, 0x0c7a37a1, 0x148e59f8, 0x3c89eb13, 0x27eecea9, 0xc935b761, 0xe5ede11c, 0xb13c7a47, 0xdf599cd2, 0x733f55f2, 0xce791814, 0x37bf73c7, 0xcdea53f7, 0xaa5b5ffd, 0x6f14df3d, 0xdb867844, 0xf381caaf, 0xc43eb968, 0x342c3824, 0x405fc2a3, 0xc372161d, 0x250cbce2, 0x498b283c, 0x9541ff0d, 0x017139a8, 0xb3de080c, 0xe49cd8b4, 0xc1906456, 0x84617bcb, 0xb670d532, 0x5c74486c, 0x5742d0b8];\n var T8 = [0xf4a75051, 0x4165537e, 0x17a4c31a, 0x275e963a, 0xab6bcb3b, 0x9d45f11f, 0xfa58abac, 0xe303934b, 0x30fa5520, 0x766df6ad, 0xcc769188, 0x024c25f5, 0xe5d7fc4f, 0x2acbd7c5, 0x35448026, 0x62a38fb5, 0xb15a49de, 0xba1b6725, 0xea0e9845, 0xfec0e15d, 0x2f7502c3, 0x4cf01281, 0x4697a38d, 0xd3f9c66b, 0x8f5fe703, 0x929c9515, 0x6d7aebbf, 0x5259da95, 0xbe832dd4, 0x7421d358, 0xe0692949, 0xc9c8448e, 0xc2896a75, 0x8e7978f4, 0x583e6b99, 0xb971dd27, 0xe14fb6be, 0x88ad17f0, 0x20ac66c9, 0xce3ab47d, 0xdf4a1863, 0x1a3182e5, 0x51336097, 0x537f4562, 0x6477e0b1, 0x6bae84bb, 0x81a01cfe, 0x082b94f9, 0x48685870, 0x45fd198f, 0xde6c8794, 0x7bf8b752, 0x73d323ab, 0x4b02e272, 0x1f8f57e3, 0x55ab2a66, 0xeb2807b2, 0xb5c2032f, 0xc57b9a86, 0x3708a5d3, 0x2887f230, 0xbfa5b223, 0x036aba02, 0x16825ced, 0xcf1c2b8a, 0x79b492a7, 0x07f2f0f3, 0x69e2a14e, 0xdaf4cd65, 0x05bed506, 0x34621fd1, 0xa6fe8ac4, 0x2e539d34, 0xf355a0a2, 0x8ae13205, 0xf6eb75a4, 0x83ec390b, 0x60efaa40, 0x719f065e, 0x6e1051bd, 0x218af93e, 0xdd063d96, 0x3e05aedd, 0xe6bd464d, 0x548db591, 0xc45d0571, 0x06d46f04, 0x5015ff60, 0x98fb2419, 0xbde997d6, 0x4043cc89, 0xd99e7767, 0xe842bdb0, 0x898b8807, 0x195b38e7, 0xc8eedb79, 0x7c0a47a1, 0x420fe97c, 0x841ec9f8, 0x00000000, 0x80868309, 0x2bed4832, 0x1170ac1e, 0x5a724e6c, 0x0efffbfd, 0x8538560f, 0xaed51e3d, 0x2d392736, 0x0fd9640a, 0x5ca62168, 0x5b54d19b, 0x362e3a24, 0x0a67b10c, 0x57e70f93, 0xee96d2b4, 0x9b919e1b, 0xc0c54f80, 0xdc20a261, 0x774b695a, 0x121a161c, 0x93ba0ae2, 0xa02ae5c0, 0x22e0433c, 0x1b171d12, 0x090d0b0e, 0x8bc7adf2, 0xb6a8b92d, 0x1ea9c814, 0xf1198557, 0x75074caf, 0x99ddbbee, 0x7f60fda3, 0x01269ff7, 0x72f5bc5c, 0x663bc544, 0xfb7e345b, 0x4329768b, 0x23c6dccb, 0xedfc68b6, 0xe4f163b8, 0x31dccad7, 0x63851042, 0x97224013, 0xc6112084, 0x4a247d85, 0xbb3df8d2, 0xf93211ae, 0x29a16dc7, 0x9e2f4b1d, 0xb230f3dc, 0x8652ec0d, 0xc1e3d077, 0xb3166c2b, 0x70b999a9, 0x9448fa11, 0xe9642247, 0xfc8cc4a8, 0xf03f1aa0, 0x7d2cd856, 0x3390ef22, 0x494ec787, 0x38d1c1d9, 0xcaa2fe8c, 0xd40b3698, 0xf581cfa6, 0x7ade28a5, 0xb78e26da, 0xadbfa43f, 0x3a9de42c, 0x78920d50, 0x5fcc9b6a, 0x7e466254, 0x8d13c2f6, 0xd8b8e890, 0x39f75e2e, 0xc3aff582, 0x5d80be9f, 0xd0937c69, 0xd52da96f, 0x2512b3cf, 0xac993bc8, 0x187da710, 0x9c636ee8, 0x3bbb7bdb, 0x267809cd, 0x5918f46e, 0x9ab701ec, 0x4f9aa883, 0x956e65e6, 0xffe67eaa, 0xbccf0821, 0x15e8e6ef, 0xe79bd9ba, 0x6f36ce4a, 0x9f09d4ea, 0xb07cd629, 0xa4b2af31, 0x3f23312a, 0xa59430c6, 0xa266c035, 0x4ebc3774, 0x82caa6fc, 0x90d0b0e0, 0xa7d81533, 0x04984af1, 0xecdaf741, 0xcd500e7f, 0x91f62f17, 0x4dd68d76, 0xefb04d43, 0xaa4d54cc, 0x9604dfe4, 0xd1b5e39e, 0x6a881b4c, 0x2c1fb8c1, 0x65517f46, 0x5eea049d, 0x8c355d01, 0x877473fa, 0x0b412efb, 0x671d5ab3, 0xdbd25292, 0x105633e9, 0xd647136d, 0xd7618c9a, 0xa10c7a37, 0xf8148e59, 0x133c89eb, 0xa927eece, 0x61c935b7, 0x1ce5ede1, 0x47b13c7a, 0xd2df599c, 0xf2733f55, 0x14ce7918, 0xc737bf73, 0xf7cdea53, 0xfdaa5b5f, 0x3d6f14df, 0x44db8678, 0xaff381ca, 0x68c43eb9, 0x24342c38, 0xa3405fc2, 0x1dc37216, 0xe2250cbc, 0x3c498b28, 0x0d9541ff, 0xa8017139, 0x0cb3de08, 0xb4e49cd8, 0x56c19064, 0xcb84617b, 0x32b670d5, 0x6c5c7448, 0xb85742d0];\n\n // Transformations for decryption key expansion\n var U1 = [0x00000000, 0x0e090d0b, 0x1c121a16, 0x121b171d, 0x3824342c, 0x362d3927, 0x24362e3a, 0x2a3f2331, 0x70486858, 0x7e416553, 0x6c5a724e, 0x62537f45, 0x486c5c74, 0x4665517f, 0x547e4662, 0x5a774b69, 0xe090d0b0, 0xee99ddbb, 0xfc82caa6, 0xf28bc7ad, 0xd8b4e49c, 0xd6bde997, 0xc4a6fe8a, 0xcaaff381, 0x90d8b8e8, 0x9ed1b5e3, 0x8ccaa2fe, 0x82c3aff5, 0xa8fc8cc4, 0xa6f581cf, 0xb4ee96d2, 0xbae79bd9, 0xdb3bbb7b, 0xd532b670, 0xc729a16d, 0xc920ac66, 0xe31f8f57, 0xed16825c, 0xff0d9541, 0xf104984a, 0xab73d323, 0xa57ade28, 0xb761c935, 0xb968c43e, 0x9357e70f, 0x9d5eea04, 0x8f45fd19, 0x814cf012, 0x3bab6bcb, 0x35a266c0, 0x27b971dd, 0x29b07cd6, 0x038f5fe7, 0x0d8652ec, 0x1f9d45f1, 0x119448fa, 0x4be30393, 0x45ea0e98, 0x57f11985, 0x59f8148e, 0x73c737bf, 0x7dce3ab4, 0x6fd52da9, 0x61dc20a2, 0xad766df6, 0xa37f60fd, 0xb16477e0, 0xbf6d7aeb, 0x955259da, 0x9b5b54d1, 0x894043cc, 0x87494ec7, 0xdd3e05ae, 0xd33708a5, 0xc12c1fb8, 0xcf2512b3, 0xe51a3182, 0xeb133c89, 0xf9082b94, 0xf701269f, 0x4de6bd46, 0x43efb04d, 0x51f4a750, 0x5ffdaa5b, 0x75c2896a, 0x7bcb8461, 0x69d0937c, 0x67d99e77, 0x3daed51e, 0x33a7d815, 0x21bccf08, 0x2fb5c203, 0x058ae132, 0x0b83ec39, 0x1998fb24, 0x1791f62f, 0x764dd68d, 0x7844db86, 0x6a5fcc9b, 0x6456c190, 0x4e69e2a1, 0x4060efaa, 0x527bf8b7, 0x5c72f5bc, 0x0605bed5, 0x080cb3de, 0x1a17a4c3, 0x141ea9c8, 0x3e218af9, 0x302887f2, 0x223390ef, 0x2c3a9de4, 0x96dd063d, 0x98d40b36, 0x8acf1c2b, 0x84c61120, 0xaef93211, 0xa0f03f1a, 0xb2eb2807, 0xbce2250c, 0xe6956e65, 0xe89c636e, 0xfa877473, 0xf48e7978, 0xdeb15a49, 0xd0b85742, 0xc2a3405f, 0xccaa4d54, 0x41ecdaf7, 0x4fe5d7fc, 0x5dfec0e1, 0x53f7cdea, 0x79c8eedb, 0x77c1e3d0, 0x65daf4cd, 0x6bd3f9c6, 0x31a4b2af, 0x3fadbfa4, 0x2db6a8b9, 0x23bfa5b2, 0x09808683, 0x07898b88, 0x15929c95, 0x1b9b919e, 0xa17c0a47, 0xaf75074c, 0xbd6e1051, 0xb3671d5a, 0x99583e6b, 0x97513360, 0x854a247d, 0x8b432976, 0xd134621f, 0xdf3d6f14, 0xcd267809, 0xc32f7502, 0xe9105633, 0xe7195b38, 0xf5024c25, 0xfb0b412e, 0x9ad7618c, 0x94de6c87, 0x86c57b9a, 0x88cc7691, 0xa2f355a0, 0xacfa58ab, 0xbee14fb6, 0xb0e842bd, 0xea9f09d4, 0xe49604df, 0xf68d13c2, 0xf8841ec9, 0xd2bb3df8, 0xdcb230f3, 0xcea927ee, 0xc0a02ae5, 0x7a47b13c, 0x744ebc37, 0x6655ab2a, 0x685ca621, 0x42638510, 0x4c6a881b, 0x5e719f06, 0x5078920d, 0x0a0fd964, 0x0406d46f, 0x161dc372, 0x1814ce79, 0x322bed48, 0x3c22e043, 0x2e39f75e, 0x2030fa55, 0xec9ab701, 0xe293ba0a, 0xf088ad17, 0xfe81a01c, 0xd4be832d, 0xdab78e26, 0xc8ac993b, 0xc6a59430, 0x9cd2df59, 0x92dbd252, 0x80c0c54f, 0x8ec9c844, 0xa4f6eb75, 0xaaffe67e, 0xb8e4f163, 0xb6edfc68, 0x0c0a67b1, 0x02036aba, 0x10187da7, 0x1e1170ac, 0x342e539d, 0x3a275e96, 0x283c498b, 0x26354480, 0x7c420fe9, 0x724b02e2, 0x605015ff, 0x6e5918f4, 0x44663bc5, 0x4a6f36ce, 0x587421d3, 0x567d2cd8, 0x37a10c7a, 0x39a80171, 0x2bb3166c, 0x25ba1b67, 0x0f853856, 0x018c355d, 0x13972240, 0x1d9e2f4b, 0x47e96422, 0x49e06929, 0x5bfb7e34, 0x55f2733f, 0x7fcd500e, 0x71c45d05, 0x63df4a18, 0x6dd64713, 0xd731dcca, 0xd938d1c1, 0xcb23c6dc, 0xc52acbd7, 0xef15e8e6, 0xe11ce5ed, 0xf307f2f0, 0xfd0efffb, 0xa779b492, 0xa970b999, 0xbb6bae84, 0xb562a38f, 0x9f5d80be, 0x91548db5, 0x834f9aa8, 0x8d4697a3];\n var U2 = [0x00000000, 0x0b0e090d, 0x161c121a, 0x1d121b17, 0x2c382434, 0x27362d39, 0x3a24362e, 0x312a3f23, 0x58704868, 0x537e4165, 0x4e6c5a72, 0x4562537f, 0x74486c5c, 0x7f466551, 0x62547e46, 0x695a774b, 0xb0e090d0, 0xbbee99dd, 0xa6fc82ca, 0xadf28bc7, 0x9cd8b4e4, 0x97d6bde9, 0x8ac4a6fe, 0x81caaff3, 0xe890d8b8, 0xe39ed1b5, 0xfe8ccaa2, 0xf582c3af, 0xc4a8fc8c, 0xcfa6f581, 0xd2b4ee96, 0xd9bae79b, 0x7bdb3bbb, 0x70d532b6, 0x6dc729a1, 0x66c920ac, 0x57e31f8f, 0x5ced1682, 0x41ff0d95, 0x4af10498, 0x23ab73d3, 0x28a57ade, 0x35b761c9, 0x3eb968c4, 0x0f9357e7, 0x049d5eea, 0x198f45fd, 0x12814cf0, 0xcb3bab6b, 0xc035a266, 0xdd27b971, 0xd629b07c, 0xe7038f5f, 0xec0d8652, 0xf11f9d45, 0xfa119448, 0x934be303, 0x9845ea0e, 0x8557f119, 0x8e59f814, 0xbf73c737, 0xb47dce3a, 0xa96fd52d, 0xa261dc20, 0xf6ad766d, 0xfda37f60, 0xe0b16477, 0xebbf6d7a, 0xda955259, 0xd19b5b54, 0xcc894043, 0xc787494e, 0xaedd3e05, 0xa5d33708, 0xb8c12c1f, 0xb3cf2512, 0x82e51a31, 0x89eb133c, 0x94f9082b, 0x9ff70126, 0x464de6bd, 0x4d43efb0, 0x5051f4a7, 0x5b5ffdaa, 0x6a75c289, 0x617bcb84, 0x7c69d093, 0x7767d99e, 0x1e3daed5, 0x1533a7d8, 0x0821bccf, 0x032fb5c2, 0x32058ae1, 0x390b83ec, 0x241998fb, 0x2f1791f6, 0x8d764dd6, 0x867844db, 0x9b6a5fcc, 0x906456c1, 0xa14e69e2, 0xaa4060ef, 0xb7527bf8, 0xbc5c72f5, 0xd50605be, 0xde080cb3, 0xc31a17a4, 0xc8141ea9, 0xf93e218a, 0xf2302887, 0xef223390, 0xe42c3a9d, 0x3d96dd06, 0x3698d40b, 0x2b8acf1c, 0x2084c611, 0x11aef932, 0x1aa0f03f, 0x07b2eb28, 0x0cbce225, 0x65e6956e, 0x6ee89c63, 0x73fa8774, 0x78f48e79, 0x49deb15a, 0x42d0b857, 0x5fc2a340, 0x54ccaa4d, 0xf741ecda, 0xfc4fe5d7, 0xe15dfec0, 0xea53f7cd, 0xdb79c8ee, 0xd077c1e3, 0xcd65daf4, 0xc66bd3f9, 0xaf31a4b2, 0xa43fadbf, 0xb92db6a8, 0xb223bfa5, 0x83098086, 0x8807898b, 0x9515929c, 0x9e1b9b91, 0x47a17c0a, 0x4caf7507, 0x51bd6e10, 0x5ab3671d, 0x6b99583e, 0x60975133, 0x7d854a24, 0x768b4329, 0x1fd13462, 0x14df3d6f, 0x09cd2678, 0x02c32f75, 0x33e91056, 0x38e7195b, 0x25f5024c, 0x2efb0b41, 0x8c9ad761, 0x8794de6c, 0x9a86c57b, 0x9188cc76, 0xa0a2f355, 0xabacfa58, 0xb6bee14f, 0xbdb0e842, 0xd4ea9f09, 0xdfe49604, 0xc2f68d13, 0xc9f8841e, 0xf8d2bb3d, 0xf3dcb230, 0xeecea927, 0xe5c0a02a, 0x3c7a47b1, 0x37744ebc, 0x2a6655ab, 0x21685ca6, 0x10426385, 0x1b4c6a88, 0x065e719f, 0x0d507892, 0x640a0fd9, 0x6f0406d4, 0x72161dc3, 0x791814ce, 0x48322bed, 0x433c22e0, 0x5e2e39f7, 0x552030fa, 0x01ec9ab7, 0x0ae293ba, 0x17f088ad, 0x1cfe81a0, 0x2dd4be83, 0x26dab78e, 0x3bc8ac99, 0x30c6a594, 0x599cd2df, 0x5292dbd2, 0x4f80c0c5, 0x448ec9c8, 0x75a4f6eb, 0x7eaaffe6, 0x63b8e4f1, 0x68b6edfc, 0xb10c0a67, 0xba02036a, 0xa710187d, 0xac1e1170, 0x9d342e53, 0x963a275e, 0x8b283c49, 0x80263544, 0xe97c420f, 0xe2724b02, 0xff605015, 0xf46e5918, 0xc544663b, 0xce4a6f36, 0xd3587421, 0xd8567d2c, 0x7a37a10c, 0x7139a801, 0x6c2bb316, 0x6725ba1b, 0x560f8538, 0x5d018c35, 0x40139722, 0x4b1d9e2f, 0x2247e964, 0x2949e069, 0x345bfb7e, 0x3f55f273, 0x0e7fcd50, 0x0571c45d, 0x1863df4a, 0x136dd647, 0xcad731dc, 0xc1d938d1, 0xdccb23c6, 0xd7c52acb, 0xe6ef15e8, 0xede11ce5, 0xf0f307f2, 0xfbfd0eff, 0x92a779b4, 0x99a970b9, 0x84bb6bae, 0x8fb562a3, 0xbe9f5d80, 0xb591548d, 0xa8834f9a, 0xa38d4697];\n var U3 = [0x00000000, 0x0d0b0e09, 0x1a161c12, 0x171d121b, 0x342c3824, 0x3927362d, 0x2e3a2436, 0x23312a3f, 0x68587048, 0x65537e41, 0x724e6c5a, 0x7f456253, 0x5c74486c, 0x517f4665, 0x4662547e, 0x4b695a77, 0xd0b0e090, 0xddbbee99, 0xcaa6fc82, 0xc7adf28b, 0xe49cd8b4, 0xe997d6bd, 0xfe8ac4a6, 0xf381caaf, 0xb8e890d8, 0xb5e39ed1, 0xa2fe8cca, 0xaff582c3, 0x8cc4a8fc, 0x81cfa6f5, 0x96d2b4ee, 0x9bd9bae7, 0xbb7bdb3b, 0xb670d532, 0xa16dc729, 0xac66c920, 0x8f57e31f, 0x825ced16, 0x9541ff0d, 0x984af104, 0xd323ab73, 0xde28a57a, 0xc935b761, 0xc43eb968, 0xe70f9357, 0xea049d5e, 0xfd198f45, 0xf012814c, 0x6bcb3bab, 0x66c035a2, 0x71dd27b9, 0x7cd629b0, 0x5fe7038f, 0x52ec0d86, 0x45f11f9d, 0x48fa1194, 0x03934be3, 0x0e9845ea, 0x198557f1, 0x148e59f8, 0x37bf73c7, 0x3ab47dce, 0x2da96fd5, 0x20a261dc, 0x6df6ad76, 0x60fda37f, 0x77e0b164, 0x7aebbf6d, 0x59da9552, 0x54d19b5b, 0x43cc8940, 0x4ec78749, 0x05aedd3e, 0x08a5d337, 0x1fb8c12c, 0x12b3cf25, 0x3182e51a, 0x3c89eb13, 0x2b94f908, 0x269ff701, 0xbd464de6, 0xb04d43ef, 0xa75051f4, 0xaa5b5ffd, 0x896a75c2, 0x84617bcb, 0x937c69d0, 0x9e7767d9, 0xd51e3dae, 0xd81533a7, 0xcf0821bc, 0xc2032fb5, 0xe132058a, 0xec390b83, 0xfb241998, 0xf62f1791, 0xd68d764d, 0xdb867844, 0xcc9b6a5f, 0xc1906456, 0xe2a14e69, 0xefaa4060, 0xf8b7527b, 0xf5bc5c72, 0xbed50605, 0xb3de080c, 0xa4c31a17, 0xa9c8141e, 0x8af93e21, 0x87f23028, 0x90ef2233, 0x9de42c3a, 0x063d96dd, 0x0b3698d4, 0x1c2b8acf, 0x112084c6, 0x3211aef9, 0x3f1aa0f0, 0x2807b2eb, 0x250cbce2, 0x6e65e695, 0x636ee89c, 0x7473fa87, 0x7978f48e, 0x5a49deb1, 0x5742d0b8, 0x405fc2a3, 0x4d54ccaa, 0xdaf741ec, 0xd7fc4fe5, 0xc0e15dfe, 0xcdea53f7, 0xeedb79c8, 0xe3d077c1, 0xf4cd65da, 0xf9c66bd3, 0xb2af31a4, 0xbfa43fad, 0xa8b92db6, 0xa5b223bf, 0x86830980, 0x8b880789, 0x9c951592, 0x919e1b9b, 0x0a47a17c, 0x074caf75, 0x1051bd6e, 0x1d5ab367, 0x3e6b9958, 0x33609751, 0x247d854a, 0x29768b43, 0x621fd134, 0x6f14df3d, 0x7809cd26, 0x7502c32f, 0x5633e910, 0x5b38e719, 0x4c25f502, 0x412efb0b, 0x618c9ad7, 0x6c8794de, 0x7b9a86c5, 0x769188cc, 0x55a0a2f3, 0x58abacfa, 0x4fb6bee1, 0x42bdb0e8, 0x09d4ea9f, 0x04dfe496, 0x13c2f68d, 0x1ec9f884, 0x3df8d2bb, 0x30f3dcb2, 0x27eecea9, 0x2ae5c0a0, 0xb13c7a47, 0xbc37744e, 0xab2a6655, 0xa621685c, 0x85104263, 0x881b4c6a, 0x9f065e71, 0x920d5078, 0xd9640a0f, 0xd46f0406, 0xc372161d, 0xce791814, 0xed48322b, 0xe0433c22, 0xf75e2e39, 0xfa552030, 0xb701ec9a, 0xba0ae293, 0xad17f088, 0xa01cfe81, 0x832dd4be, 0x8e26dab7, 0x993bc8ac, 0x9430c6a5, 0xdf599cd2, 0xd25292db, 0xc54f80c0, 0xc8448ec9, 0xeb75a4f6, 0xe67eaaff, 0xf163b8e4, 0xfc68b6ed, 0x67b10c0a, 0x6aba0203, 0x7da71018, 0x70ac1e11, 0x539d342e, 0x5e963a27, 0x498b283c, 0x44802635, 0x0fe97c42, 0x02e2724b, 0x15ff6050, 0x18f46e59, 0x3bc54466, 0x36ce4a6f, 0x21d35874, 0x2cd8567d, 0x0c7a37a1, 0x017139a8, 0x166c2bb3, 0x1b6725ba, 0x38560f85, 0x355d018c, 0x22401397, 0x2f4b1d9e, 0x642247e9, 0x692949e0, 0x7e345bfb, 0x733f55f2, 0x500e7fcd, 0x5d0571c4, 0x4a1863df, 0x47136dd6, 0xdccad731, 0xd1c1d938, 0xc6dccb23, 0xcbd7c52a, 0xe8e6ef15, 0xe5ede11c, 0xf2f0f307, 0xfffbfd0e, 0xb492a779, 0xb999a970, 0xae84bb6b, 0xa38fb562, 0x80be9f5d, 0x8db59154, 0x9aa8834f, 0x97a38d46];\n var U4 = [0x00000000, 0x090d0b0e, 0x121a161c, 0x1b171d12, 0x24342c38, 0x2d392736, 0x362e3a24, 0x3f23312a, 0x48685870, 0x4165537e, 0x5a724e6c, 0x537f4562, 0x6c5c7448, 0x65517f46, 0x7e466254, 0x774b695a, 0x90d0b0e0, 0x99ddbbee, 0x82caa6fc, 0x8bc7adf2, 0xb4e49cd8, 0xbde997d6, 0xa6fe8ac4, 0xaff381ca, 0xd8b8e890, 0xd1b5e39e, 0xcaa2fe8c, 0xc3aff582, 0xfc8cc4a8, 0xf581cfa6, 0xee96d2b4, 0xe79bd9ba, 0x3bbb7bdb, 0x32b670d5, 0x29a16dc7, 0x20ac66c9, 0x1f8f57e3, 0x16825ced, 0x0d9541ff, 0x04984af1, 0x73d323ab, 0x7ade28a5, 0x61c935b7, 0x68c43eb9, 0x57e70f93, 0x5eea049d, 0x45fd198f, 0x4cf01281, 0xab6bcb3b, 0xa266c035, 0xb971dd27, 0xb07cd629, 0x8f5fe703, 0x8652ec0d, 0x9d45f11f, 0x9448fa11, 0xe303934b, 0xea0e9845, 0xf1198557, 0xf8148e59, 0xc737bf73, 0xce3ab47d, 0xd52da96f, 0xdc20a261, 0x766df6ad, 0x7f60fda3, 0x6477e0b1, 0x6d7aebbf, 0x5259da95, 0x5b54d19b, 0x4043cc89, 0x494ec787, 0x3e05aedd, 0x3708a5d3, 0x2c1fb8c1, 0x2512b3cf, 0x1a3182e5, 0x133c89eb, 0x082b94f9, 0x01269ff7, 0xe6bd464d, 0xefb04d43, 0xf4a75051, 0xfdaa5b5f, 0xc2896a75, 0xcb84617b, 0xd0937c69, 0xd99e7767, 0xaed51e3d, 0xa7d81533, 0xbccf0821, 0xb5c2032f, 0x8ae13205, 0x83ec390b, 0x98fb2419, 0x91f62f17, 0x4dd68d76, 0x44db8678, 0x5fcc9b6a, 0x56c19064, 0x69e2a14e, 0x60efaa40, 0x7bf8b752, 0x72f5bc5c, 0x05bed506, 0x0cb3de08, 0x17a4c31a, 0x1ea9c814, 0x218af93e, 0x2887f230, 0x3390ef22, 0x3a9de42c, 0xdd063d96, 0xd40b3698, 0xcf1c2b8a, 0xc6112084, 0xf93211ae, 0xf03f1aa0, 0xeb2807b2, 0xe2250cbc, 0x956e65e6, 0x9c636ee8, 0x877473fa, 0x8e7978f4, 0xb15a49de, 0xb85742d0, 0xa3405fc2, 0xaa4d54cc, 0xecdaf741, 0xe5d7fc4f, 0xfec0e15d, 0xf7cdea53, 0xc8eedb79, 0xc1e3d077, 0xdaf4cd65, 0xd3f9c66b, 0xa4b2af31, 0xadbfa43f, 0xb6a8b92d, 0xbfa5b223, 0x80868309, 0x898b8807, 0x929c9515, 0x9b919e1b, 0x7c0a47a1, 0x75074caf, 0x6e1051bd, 0x671d5ab3, 0x583e6b99, 0x51336097, 0x4a247d85, 0x4329768b, 0x34621fd1, 0x3d6f14df, 0x267809cd, 0x2f7502c3, 0x105633e9, 0x195b38e7, 0x024c25f5, 0x0b412efb, 0xd7618c9a, 0xde6c8794, 0xc57b9a86, 0xcc769188, 0xf355a0a2, 0xfa58abac, 0xe14fb6be, 0xe842bdb0, 0x9f09d4ea, 0x9604dfe4, 0x8d13c2f6, 0x841ec9f8, 0xbb3df8d2, 0xb230f3dc, 0xa927eece, 0xa02ae5c0, 0x47b13c7a, 0x4ebc3774, 0x55ab2a66, 0x5ca62168, 0x63851042, 0x6a881b4c, 0x719f065e, 0x78920d50, 0x0fd9640a, 0x06d46f04, 0x1dc37216, 0x14ce7918, 0x2bed4832, 0x22e0433c, 0x39f75e2e, 0x30fa5520, 0x9ab701ec, 0x93ba0ae2, 0x88ad17f0, 0x81a01cfe, 0xbe832dd4, 0xb78e26da, 0xac993bc8, 0xa59430c6, 0xd2df599c, 0xdbd25292, 0xc0c54f80, 0xc9c8448e, 0xf6eb75a4, 0xffe67eaa, 0xe4f163b8, 0xedfc68b6, 0x0a67b10c, 0x036aba02, 0x187da710, 0x1170ac1e, 0x2e539d34, 0x275e963a, 0x3c498b28, 0x35448026, 0x420fe97c, 0x4b02e272, 0x5015ff60, 0x5918f46e, 0x663bc544, 0x6f36ce4a, 0x7421d358, 0x7d2cd856, 0xa10c7a37, 0xa8017139, 0xb3166c2b, 0xba1b6725, 0x8538560f, 0x8c355d01, 0x97224013, 0x9e2f4b1d, 0xe9642247, 0xe0692949, 0xfb7e345b, 0xf2733f55, 0xcd500e7f, 0xc45d0571, 0xdf4a1863, 0xd647136d, 0x31dccad7, 0x38d1c1d9, 0x23c6dccb, 0x2acbd7c5, 0x15e8e6ef, 0x1ce5ede1, 0x07f2f0f3, 0x0efffbfd, 0x79b492a7, 0x70b999a9, 0x6bae84bb, 0x62a38fb5, 0x5d80be9f, 0x548db591, 0x4f9aa883, 0x4697a38d];\n function convertToInt32(bytes) {\n var result = [];\n for (var i = 0; i < bytes.length; i += 4) {\n result.push(bytes[i] << 24 | bytes[i + 1] << 16 | bytes[i + 2] << 8 | bytes[i + 3]);\n }\n return result;\n }\n var AES = function (key) {\n if (!(this instanceof AES)) {\n throw Error('AES must be instanitated with `new`');\n }\n Object.defineProperty(this, 'key', {\n value: coerceArray(key, true)\n });\n this._prepare();\n };\n AES.prototype._prepare = function () {\n var rounds = numberOfRounds[this.key.length];\n if (rounds == null) {\n throw new Error('invalid key size (must be 16, 24 or 32 bytes)');\n }\n\n // encryption round keys\n this._Ke = [];\n\n // decryption round keys\n this._Kd = [];\n for (var i = 0; i <= rounds; i++) {\n this._Ke.push([0, 0, 0, 0]);\n this._Kd.push([0, 0, 0, 0]);\n }\n var roundKeyCount = (rounds + 1) * 4;\n var KC = this.key.length / 4;\n\n // convert the key into ints\n var tk = convertToInt32(this.key);\n\n // copy values into round key arrays\n var index;\n for (var i = 0; i < KC; i++) {\n index = i >> 2;\n this._Ke[index][i % 4] = tk[i];\n this._Kd[rounds - index][i % 4] = tk[i];\n }\n\n // key expansion (fips-197 section 5.2)\n var rconpointer = 0;\n var t = KC,\n tt;\n while (t < roundKeyCount) {\n tt = tk[KC - 1];\n tk[0] ^= S[tt >> 16 & 0xFF] << 24 ^ S[tt >> 8 & 0xFF] << 16 ^ S[tt & 0xFF] << 8 ^ S[tt >> 24 & 0xFF] ^ rcon[rconpointer] << 24;\n rconpointer += 1;\n\n // key expansion (for non-256 bit)\n if (KC != 8) {\n for (var i = 1; i < KC; i++) {\n tk[i] ^= tk[i - 1];\n }\n\n // key expansion for 256-bit keys is \"slightly different\" (fips-197)\n } else {\n for (var i = 1; i < KC / 2; i++) {\n tk[i] ^= tk[i - 1];\n }\n tt = tk[KC / 2 - 1];\n tk[KC / 2] ^= S[tt & 0xFF] ^ S[tt >> 8 & 0xFF] << 8 ^ S[tt >> 16 & 0xFF] << 16 ^ S[tt >> 24 & 0xFF] << 24;\n for (var i = KC / 2 + 1; i < KC; i++) {\n tk[i] ^= tk[i - 1];\n }\n }\n\n // copy values into round key arrays\n var i = 0,\n r,\n c;\n while (i < KC && t < roundKeyCount) {\n r = t >> 2;\n c = t % 4;\n this._Ke[r][c] = tk[i];\n this._Kd[rounds - r][c] = tk[i++];\n t++;\n }\n }\n\n // inverse-cipher-ify the decryption round key (fips-197 section 5.3)\n for (var r = 1; r < rounds; r++) {\n for (var c = 0; c < 4; c++) {\n tt = this._Kd[r][c];\n this._Kd[r][c] = U1[tt >> 24 & 0xFF] ^ U2[tt >> 16 & 0xFF] ^ U3[tt >> 8 & 0xFF] ^ U4[tt & 0xFF];\n }\n }\n };\n AES.prototype.encrypt = function (plaintext) {\n if (plaintext.length != 16) {\n throw new Error('invalid plaintext size (must be 16 bytes)');\n }\n var rounds = this._Ke.length - 1;\n var a = [0, 0, 0, 0];\n\n // convert plaintext to (ints ^ key)\n var t = convertToInt32(plaintext);\n for (var i = 0; i < 4; i++) {\n t[i] ^= this._Ke[0][i];\n }\n\n // apply round transforms\n for (var r = 1; r < rounds; r++) {\n for (var i = 0; i < 4; i++) {\n a[i] = T1[t[i] >> 24 & 0xff] ^ T2[t[(i + 1) % 4] >> 16 & 0xff] ^ T3[t[(i + 2) % 4] >> 8 & 0xff] ^ T4[t[(i + 3) % 4] & 0xff] ^ this._Ke[r][i];\n }\n t = a.slice();\n }\n\n // the last round is special\n var result = createArray(16),\n tt;\n for (var i = 0; i < 4; i++) {\n tt = this._Ke[rounds][i];\n result[4 * i] = (S[t[i] >> 24 & 0xff] ^ tt >> 24) & 0xff;\n result[4 * i + 1] = (S[t[(i + 1) % 4] >> 16 & 0xff] ^ tt >> 16) & 0xff;\n result[4 * i + 2] = (S[t[(i + 2) % 4] >> 8 & 0xff] ^ tt >> 8) & 0xff;\n result[4 * i + 3] = (S[t[(i + 3) % 4] & 0xff] ^ tt) & 0xff;\n }\n return result;\n };\n AES.prototype.decrypt = function (ciphertext) {\n if (ciphertext.length != 16) {\n throw new Error('invalid ciphertext size (must be 16 bytes)');\n }\n var rounds = this._Kd.length - 1;\n var a = [0, 0, 0, 0];\n\n // convert plaintext to (ints ^ key)\n var t = convertToInt32(ciphertext);\n for (var i = 0; i < 4; i++) {\n t[i] ^= this._Kd[0][i];\n }\n\n // apply round transforms\n for (var r = 1; r < rounds; r++) {\n for (var i = 0; i < 4; i++) {\n a[i] = T5[t[i] >> 24 & 0xff] ^ T6[t[(i + 3) % 4] >> 16 & 0xff] ^ T7[t[(i + 2) % 4] >> 8 & 0xff] ^ T8[t[(i + 1) % 4] & 0xff] ^ this._Kd[r][i];\n }\n t = a.slice();\n }\n\n // the last round is special\n var result = createArray(16),\n tt;\n for (var i = 0; i < 4; i++) {\n tt = this._Kd[rounds][i];\n result[4 * i] = (Si[t[i] >> 24 & 0xff] ^ tt >> 24) & 0xff;\n result[4 * i + 1] = (Si[t[(i + 3) % 4] >> 16 & 0xff] ^ tt >> 16) & 0xff;\n result[4 * i + 2] = (Si[t[(i + 2) % 4] >> 8 & 0xff] ^ tt >> 8) & 0xff;\n result[4 * i + 3] = (Si[t[(i + 1) % 4] & 0xff] ^ tt) & 0xff;\n }\n return result;\n };\n\n /**\n * Mode Of Operation - Electonic Codebook (ECB)\n */\n var ModeOfOperationECB = function (key) {\n if (!(this instanceof ModeOfOperationECB)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Electronic Code Block\";\n this.name = \"ecb\";\n this._aes = new AES(key);\n };\n ModeOfOperationECB.prototype.encrypt = function (plaintext) {\n plaintext = coerceArray(plaintext);\n if (plaintext.length % 16 !== 0) {\n throw new Error('invalid plaintext size (must be multiple of 16 bytes)');\n }\n var ciphertext = createArray(plaintext.length);\n var block = createArray(16);\n for (var i = 0; i < plaintext.length; i += 16) {\n copyArray(plaintext, block, 0, i, i + 16);\n block = this._aes.encrypt(block);\n copyArray(block, ciphertext, i);\n }\n return ciphertext;\n };\n ModeOfOperationECB.prototype.decrypt = function (ciphertext) {\n ciphertext = coerceArray(ciphertext);\n if (ciphertext.length % 16 !== 0) {\n throw new Error('invalid ciphertext size (must be multiple of 16 bytes)');\n }\n var plaintext = createArray(ciphertext.length);\n var block = createArray(16);\n for (var i = 0; i < ciphertext.length; i += 16) {\n copyArray(ciphertext, block, 0, i, i + 16);\n block = this._aes.decrypt(block);\n copyArray(block, plaintext, i);\n }\n return plaintext;\n };\n\n /**\n * Mode Of Operation - Cipher Block Chaining (CBC)\n */\n var ModeOfOperationCBC = function (key, iv) {\n if (!(this instanceof ModeOfOperationCBC)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Cipher Block Chaining\";\n this.name = \"cbc\";\n if (!iv) {\n iv = createArray(16);\n } else if (iv.length != 16) {\n throw new Error('invalid initialation vector size (must be 16 bytes)');\n }\n this._lastCipherblock = coerceArray(iv, true);\n this._aes = new AES(key);\n };\n ModeOfOperationCBC.prototype.encrypt = function (plaintext) {\n plaintext = coerceArray(plaintext);\n if (plaintext.length % 16 !== 0) {\n throw new Error('invalid plaintext size (must be multiple of 16 bytes)');\n }\n var ciphertext = createArray(plaintext.length);\n var block = createArray(16);\n for (var i = 0; i < plaintext.length; i += 16) {\n copyArray(plaintext, block, 0, i, i + 16);\n for (var j = 0; j < 16; j++) {\n block[j] ^= this._lastCipherblock[j];\n }\n this._lastCipherblock = this._aes.encrypt(block);\n copyArray(this._lastCipherblock, ciphertext, i);\n }\n return ciphertext;\n };\n ModeOfOperationCBC.prototype.decrypt = function (ciphertext) {\n ciphertext = coerceArray(ciphertext);\n if (ciphertext.length % 16 !== 0) {\n throw new Error('invalid ciphertext size (must be multiple of 16 bytes)');\n }\n var plaintext = createArray(ciphertext.length);\n var block = createArray(16);\n for (var i = 0; i < ciphertext.length; i += 16) {\n copyArray(ciphertext, block, 0, i, i + 16);\n block = this._aes.decrypt(block);\n for (var j = 0; j < 16; j++) {\n plaintext[i + j] = block[j] ^ this._lastCipherblock[j];\n }\n copyArray(ciphertext, this._lastCipherblock, 0, i, i + 16);\n }\n return plaintext;\n };\n\n /**\n * Mode Of Operation - Cipher Feedback (CFB)\n */\n var ModeOfOperationCFB = function (key, iv, segmentSize) {\n if (!(this instanceof ModeOfOperationCFB)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Cipher Feedback\";\n this.name = \"cfb\";\n if (!iv) {\n iv = createArray(16);\n } else if (iv.length != 16) {\n throw new Error('invalid initialation vector size (must be 16 size)');\n }\n if (!segmentSize) {\n segmentSize = 1;\n }\n this.segmentSize = segmentSize;\n this._shiftRegister = coerceArray(iv, true);\n this._aes = new AES(key);\n };\n ModeOfOperationCFB.prototype.encrypt = function (plaintext) {\n if (plaintext.length % this.segmentSize != 0) {\n throw new Error('invalid plaintext size (must be segmentSize bytes)');\n }\n var encrypted = coerceArray(plaintext, true);\n var xorSegment;\n for (var i = 0; i < encrypted.length; i += this.segmentSize) {\n xorSegment = this._aes.encrypt(this._shiftRegister);\n for (var j = 0; j < this.segmentSize; j++) {\n encrypted[i + j] ^= xorSegment[j];\n }\n\n // Shift the register\n copyArray(this._shiftRegister, this._shiftRegister, 0, this.segmentSize);\n copyArray(encrypted, this._shiftRegister, 16 - this.segmentSize, i, i + this.segmentSize);\n }\n return encrypted;\n };\n ModeOfOperationCFB.prototype.decrypt = function (ciphertext) {\n if (ciphertext.length % this.segmentSize != 0) {\n throw new Error('invalid ciphertext size (must be segmentSize bytes)');\n }\n var plaintext = coerceArray(ciphertext, true);\n var xorSegment;\n for (var i = 0; i < plaintext.length; i += this.segmentSize) {\n xorSegment = this._aes.encrypt(this._shiftRegister);\n for (var j = 0; j < this.segmentSize; j++) {\n plaintext[i + j] ^= xorSegment[j];\n }\n\n // Shift the register\n copyArray(this._shiftRegister, this._shiftRegister, 0, this.segmentSize);\n copyArray(ciphertext, this._shiftRegister, 16 - this.segmentSize, i, i + this.segmentSize);\n }\n return plaintext;\n };\n\n /**\n * Mode Of Operation - Output Feedback (OFB)\n */\n var ModeOfOperationOFB = function (key, iv) {\n if (!(this instanceof ModeOfOperationOFB)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Output Feedback\";\n this.name = \"ofb\";\n if (!iv) {\n iv = createArray(16);\n } else if (iv.length != 16) {\n throw new Error('invalid initialation vector size (must be 16 bytes)');\n }\n this._lastPrecipher = coerceArray(iv, true);\n this._lastPrecipherIndex = 16;\n this._aes = new AES(key);\n };\n ModeOfOperationOFB.prototype.encrypt = function (plaintext) {\n var encrypted = coerceArray(plaintext, true);\n for (var i = 0; i < encrypted.length; i++) {\n if (this._lastPrecipherIndex === 16) {\n this._lastPrecipher = this._aes.encrypt(this._lastPrecipher);\n this._lastPrecipherIndex = 0;\n }\n encrypted[i] ^= this._lastPrecipher[this._lastPrecipherIndex++];\n }\n return encrypted;\n };\n\n // Decryption is symetric\n ModeOfOperationOFB.prototype.decrypt = ModeOfOperationOFB.prototype.encrypt;\n\n /**\n * Counter object for CTR common mode of operation\n */\n var Counter = function (initialValue) {\n if (!(this instanceof Counter)) {\n throw Error('Counter must be instanitated with `new`');\n }\n\n // We allow 0, but anything false-ish uses the default 1\n if (initialValue !== 0 && !initialValue) {\n initialValue = 1;\n }\n if (typeof initialValue === 'number') {\n this._counter = createArray(16);\n this.setValue(initialValue);\n } else {\n this.setBytes(initialValue);\n }\n };\n Counter.prototype.setValue = function (value) {\n if (typeof value !== 'number' || parseInt(value) != value) {\n throw new Error('invalid counter value (must be an integer)');\n }\n for (var index = 15; index >= 0; --index) {\n this._counter[index] = value % 256;\n value = value >> 8;\n }\n };\n Counter.prototype.setBytes = function (bytes) {\n bytes = coerceArray(bytes, true);\n if (bytes.length != 16) {\n throw new Error('invalid counter bytes size (must be 16 bytes)');\n }\n this._counter = bytes;\n };\n Counter.prototype.increment = function () {\n for (var i = 15; i >= 0; i--) {\n if (this._counter[i] === 255) {\n this._counter[i] = 0;\n } else {\n this._counter[i]++;\n break;\n }\n }\n };\n\n /**\n * Mode Of Operation - Counter (CTR)\n */\n var ModeOfOperationCTR = function (key, counter) {\n if (!(this instanceof ModeOfOperationCTR)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Counter\";\n this.name = \"ctr\";\n if (!(counter instanceof Counter)) {\n counter = new Counter(counter);\n }\n this._counter = counter;\n this._remainingCounter = null;\n this._remainingCounterIndex = 16;\n this._aes = new AES(key);\n };\n ModeOfOperationCTR.prototype.encrypt = function (plaintext) {\n var encrypted = coerceArray(plaintext, true);\n for (var i = 0; i < encrypted.length; i++) {\n if (this._remainingCounterIndex === 16) {\n this._remainingCounter = this._aes.encrypt(this._counter._counter);\n this._remainingCounterIndex = 0;\n this._counter.increment();\n }\n encrypted[i] ^= this._remainingCounter[this._remainingCounterIndex++];\n }\n return encrypted;\n };\n\n // Decryption is symetric\n ModeOfOperationCTR.prototype.decrypt = ModeOfOperationCTR.prototype.encrypt;\n\n ///////////////////////\n // Padding\n\n // See:https://tools.ietf.org/html/rfc2315\n function pkcs7pad(data) {\n data = coerceArray(data, true);\n var padder = 16 - data.length % 16;\n var result = createArray(data.length + padder);\n copyArray(data, result);\n for (var i = data.length; i < result.length; i++) {\n result[i] = padder;\n }\n return result;\n }\n function pkcs7strip(data) {\n data = coerceArray(data, true);\n if (data.length < 16) {\n throw new Error('PKCS#7 invalid length');\n }\n var padder = data[data.length - 1];\n if (padder > 16) {\n throw new Error('PKCS#7 padding byte out of range');\n }\n var length = data.length - padder;\n for (var i = 0; i < padder; i++) {\n if (data[length + i] !== padder) {\n throw new Error('PKCS#7 invalid padding byte');\n }\n }\n var result = createArray(length);\n copyArray(data, result, 0, 0, length);\n return result;\n }\n\n ///////////////////////\n // Exporting\n\n // The block cipher\n var aesjs = {\n AES: AES,\n Counter: Counter,\n ModeOfOperation: {\n ecb: ModeOfOperationECB,\n cbc: ModeOfOperationCBC,\n cfb: ModeOfOperationCFB,\n ofb: ModeOfOperationOFB,\n ctr: ModeOfOperationCTR\n },\n utils: {\n hex: convertHex,\n utf8: convertUtf8\n },\n padding: {\n pkcs7: {\n pad: pkcs7pad,\n strip: pkcs7strip\n }\n },\n _arrayTest: {\n coerceArray: coerceArray,\n createArray: createArray,\n copyArray: copyArray\n }\n };\n\n // node.js\n if (typeof exports !== 'undefined') {\n module.exports = aesjs;\n\n // RequireJS/AMD\n // http://www.requirejs.org/docs/api.html\n // https://github.com/amdjs/amdjs-api/wiki/AMD\n } else if (typeof define === 'function' && define.amd) {\n define(aesjs);\n\n // Web Browsers\n } else {\n // If there was an existing library at \"aesjs\" make sure it's still available\n if (root.aesjs) {\n aesjs._aesjs = root.aesjs;\n }\n root.aesjs = aesjs;\n }\n})(this);","export const version = \"json-wallets/5.7.0\";\n","\"use strict\";\n\nimport { arrayify, hexlify } from \"@ethersproject/bytes\";\nimport { toUtf8Bytes, UnicodeNormalizationForm } from '@ethersproject/strings';\nexport function looseArrayify(hexString) {\n if (typeof hexString === 'string' && hexString.substring(0, 2) !== '0x') {\n hexString = '0x' + hexString;\n }\n return arrayify(hexString);\n}\nexport function zpad(value, length) {\n value = String(value);\n while (value.length < length) {\n value = '0' + value;\n }\n return value;\n}\nexport function getPassword(password) {\n if (typeof password === 'string') {\n return toUtf8Bytes(password, UnicodeNormalizationForm.NFKC);\n }\n return arrayify(password);\n}\nexport function searchPath(object, path) {\n let currentChild = object;\n const comps = path.toLowerCase().split('/');\n for (let i = 0; i < comps.length; i++) {\n // Search for a child object with a case-insensitive matching key\n let matchingChild = null;\n for (const key in currentChild) {\n if (key.toLowerCase() === comps[i]) {\n matchingChild = currentChild[key];\n break;\n }\n }\n // Didn't find one. :'(\n if (matchingChild === null) {\n return null;\n }\n // Now check this child...\n currentChild = matchingChild;\n }\n return currentChild;\n}\n// See: https://www.ietf.org/rfc/rfc4122.txt (Section 4.4)\nexport function uuidV4(randomBytes) {\n const bytes = arrayify(randomBytes);\n // Section: 4.1.3:\n // - time_hi_and_version[12:16] = 0b0100\n bytes[6] = bytes[6] & 0x0f | 0x40;\n // Section 4.4\n // - clock_seq_hi_and_reserved[6] = 0b0\n // - clock_seq_hi_and_reserved[7] = 0b1\n bytes[8] = bytes[8] & 0x3f | 0x80;\n const value = hexlify(bytes);\n return [value.substring(2, 10), value.substring(10, 14), value.substring(14, 18), value.substring(18, 22), value.substring(22, 34)].join(\"-\");\n}\n","\"use strict\";\n\nimport aes from \"aes-js\";\nimport { getAddress } from \"@ethersproject/address\";\nimport { arrayify } from \"@ethersproject/bytes\";\nimport { keccak256 } from \"@ethersproject/keccak256\";\nimport { pbkdf2 } from \"@ethersproject/pbkdf2\";\nimport { toUtf8Bytes } from \"@ethersproject/strings\";\nimport { Description } from \"@ethersproject/properties\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nimport { getPassword, looseArrayify, searchPath } from \"./utils\";\nexport class CrowdsaleAccount extends Description {\n isCrowdsaleAccount(value) {\n return !!(value && value._isCrowdsaleAccount);\n }\n}\n// See: https://github.com/ethereum/pyethsaletool\nexport function decrypt(json, password) {\n const data = JSON.parse(json);\n password = getPassword(password);\n // Ethereum Address\n const ethaddr = getAddress(searchPath(data, \"ethaddr\"));\n // Encrypted Seed\n const encseed = looseArrayify(searchPath(data, \"encseed\"));\n if (!encseed || encseed.length % 16 !== 0) {\n logger.throwArgumentError(\"invalid encseed\", \"json\", json);\n }\n const key = arrayify(pbkdf2(password, password, 2000, 32, \"sha256\")).slice(0, 16);\n const iv = encseed.slice(0, 16);\n const encryptedSeed = encseed.slice(16);\n // Decrypt the seed\n const aesCbc = new aes.ModeOfOperation.cbc(key, iv);\n const seed = aes.padding.pkcs7.strip(arrayify(aesCbc.decrypt(encryptedSeed)));\n // This wallet format is weird... Convert the binary encoded hex to a string.\n let seedHex = \"\";\n for (let i = 0; i < seed.length; i++) {\n seedHex += String.fromCharCode(seed[i]);\n }\n const seedHexBytes = toUtf8Bytes(seedHex);\n const privateKey = keccak256(seedHexBytes);\n return new CrowdsaleAccount({\n _isCrowdsaleAccount: true,\n address: ethaddr,\n privateKey: privateKey\n });\n}\n","\"use strict\";\n\nimport { getAddress } from \"@ethersproject/address\";\nexport function isCrowdsaleWallet(json) {\n let data = null;\n try {\n data = JSON.parse(json);\n } catch (error) {\n return false;\n }\n return data.encseed && data.ethaddr;\n}\nexport function isKeystoreWallet(json) {\n let data = null;\n try {\n data = JSON.parse(json);\n } catch (error) {\n return false;\n }\n if (!data.version || parseInt(data.version) !== data.version || parseInt(data.version) !== 3) {\n return false;\n }\n // @TODO: Put more checks to make sure it has kdf, iv and all that good stuff\n return true;\n}\n//export function isJsonWallet(json: string): boolean {\n// return (isSecretStorageWallet(json) || isCrowdsaleWallet(json));\n//}\nexport function getJsonWalletAddress(json) {\n if (isCrowdsaleWallet(json)) {\n try {\n return getAddress(JSON.parse(json).ethaddr);\n } catch (error) {\n return null;\n }\n }\n if (isKeystoreWallet(json)) {\n try {\n return getAddress(JSON.parse(json).address);\n } catch (error) {\n return null;\n }\n }\n return null;\n}\n","\"use strict\";\n\n(function (root) {\n const MAX_VALUE = 0x7fffffff;\n\n // The SHA256 and PBKDF2 implementation are from scrypt-async-js:\n // See: https://github.com/dchest/scrypt-async-js\n function SHA256(m) {\n const K = new Uint32Array([0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2]);\n let h0 = 0x6a09e667,\n h1 = 0xbb67ae85,\n h2 = 0x3c6ef372,\n h3 = 0xa54ff53a;\n let h4 = 0x510e527f,\n h5 = 0x9b05688c,\n h6 = 0x1f83d9ab,\n h7 = 0x5be0cd19;\n const w = new Uint32Array(64);\n function blocks(p) {\n let off = 0,\n len = p.length;\n while (len >= 64) {\n let a = h0,\n b = h1,\n c = h2,\n d = h3,\n e = h4,\n f = h5,\n g = h6,\n h = h7,\n u,\n i,\n j,\n t1,\n t2;\n for (i = 0; i < 16; i++) {\n j = off + i * 4;\n w[i] = (p[j] & 0xff) << 24 | (p[j + 1] & 0xff) << 16 | (p[j + 2] & 0xff) << 8 | p[j + 3] & 0xff;\n }\n for (i = 16; i < 64; i++) {\n u = w[i - 2];\n t1 = (u >>> 17 | u << 32 - 17) ^ (u >>> 19 | u << 32 - 19) ^ u >>> 10;\n u = w[i - 15];\n t2 = (u >>> 7 | u << 32 - 7) ^ (u >>> 18 | u << 32 - 18) ^ u >>> 3;\n w[i] = (t1 + w[i - 7] | 0) + (t2 + w[i - 16] | 0) | 0;\n }\n for (i = 0; i < 64; i++) {\n t1 = (((e >>> 6 | e << 32 - 6) ^ (e >>> 11 | e << 32 - 11) ^ (e >>> 25 | e << 32 - 25)) + (e & f ^ ~e & g) | 0) + (h + (K[i] + w[i] | 0) | 0) | 0;\n t2 = ((a >>> 2 | a << 32 - 2) ^ (a >>> 13 | a << 32 - 13) ^ (a >>> 22 | a << 32 - 22)) + (a & b ^ a & c ^ b & c) | 0;\n h = g;\n g = f;\n f = e;\n e = d + t1 | 0;\n d = c;\n c = b;\n b = a;\n a = t1 + t2 | 0;\n }\n h0 = h0 + a | 0;\n h1 = h1 + b | 0;\n h2 = h2 + c | 0;\n h3 = h3 + d | 0;\n h4 = h4 + e | 0;\n h5 = h5 + f | 0;\n h6 = h6 + g | 0;\n h7 = h7 + h | 0;\n off += 64;\n len -= 64;\n }\n }\n blocks(m);\n let i,\n bytesLeft = m.length % 64,\n bitLenHi = m.length / 0x20000000 | 0,\n bitLenLo = m.length << 3,\n numZeros = bytesLeft < 56 ? 56 : 120,\n p = m.slice(m.length - bytesLeft, m.length);\n p.push(0x80);\n for (i = bytesLeft + 1; i < numZeros; i++) {\n p.push(0);\n }\n p.push(bitLenHi >>> 24 & 0xff);\n p.push(bitLenHi >>> 16 & 0xff);\n p.push(bitLenHi >>> 8 & 0xff);\n p.push(bitLenHi >>> 0 & 0xff);\n p.push(bitLenLo >>> 24 & 0xff);\n p.push(bitLenLo >>> 16 & 0xff);\n p.push(bitLenLo >>> 8 & 0xff);\n p.push(bitLenLo >>> 0 & 0xff);\n blocks(p);\n return [h0 >>> 24 & 0xff, h0 >>> 16 & 0xff, h0 >>> 8 & 0xff, h0 >>> 0 & 0xff, h1 >>> 24 & 0xff, h1 >>> 16 & 0xff, h1 >>> 8 & 0xff, h1 >>> 0 & 0xff, h2 >>> 24 & 0xff, h2 >>> 16 & 0xff, h2 >>> 8 & 0xff, h2 >>> 0 & 0xff, h3 >>> 24 & 0xff, h3 >>> 16 & 0xff, h3 >>> 8 & 0xff, h3 >>> 0 & 0xff, h4 >>> 24 & 0xff, h4 >>> 16 & 0xff, h4 >>> 8 & 0xff, h4 >>> 0 & 0xff, h5 >>> 24 & 0xff, h5 >>> 16 & 0xff, h5 >>> 8 & 0xff, h5 >>> 0 & 0xff, h6 >>> 24 & 0xff, h6 >>> 16 & 0xff, h6 >>> 8 & 0xff, h6 >>> 0 & 0xff, h7 >>> 24 & 0xff, h7 >>> 16 & 0xff, h7 >>> 8 & 0xff, h7 >>> 0 & 0xff];\n }\n function PBKDF2_HMAC_SHA256_OneIter(password, salt, dkLen) {\n // compress password if it's longer than hash block length\n password = password.length <= 64 ? password : SHA256(password);\n const innerLen = 64 + salt.length + 4;\n const inner = new Array(innerLen);\n const outerKey = new Array(64);\n let i;\n let dk = [];\n\n // inner = (password ^ ipad) || salt || counter\n for (i = 0; i < 64; i++) {\n inner[i] = 0x36;\n }\n for (i = 0; i < password.length; i++) {\n inner[i] ^= password[i];\n }\n for (i = 0; i < salt.length; i++) {\n inner[64 + i] = salt[i];\n }\n for (i = innerLen - 4; i < innerLen; i++) {\n inner[i] = 0;\n }\n\n // outerKey = password ^ opad\n for (i = 0; i < 64; i++) outerKey[i] = 0x5c;\n for (i = 0; i < password.length; i++) outerKey[i] ^= password[i];\n\n // increments counter inside inner\n function incrementCounter() {\n for (let i = innerLen - 1; i >= innerLen - 4; i--) {\n inner[i]++;\n if (inner[i] <= 0xff) return;\n inner[i] = 0;\n }\n }\n\n // output blocks = SHA256(outerKey || SHA256(inner)) ...\n while (dkLen >= 32) {\n incrementCounter();\n dk = dk.concat(SHA256(outerKey.concat(SHA256(inner))));\n dkLen -= 32;\n }\n if (dkLen > 0) {\n incrementCounter();\n dk = dk.concat(SHA256(outerKey.concat(SHA256(inner))).slice(0, dkLen));\n }\n return dk;\n }\n\n // The following is an adaptation of scryptsy\n // See: https://www.npmjs.com/package/scryptsy\n function blockmix_salsa8(BY, Yi, r, x, _X) {\n let i;\n arraycopy(BY, (2 * r - 1) * 16, _X, 0, 16);\n for (i = 0; i < 2 * r; i++) {\n blockxor(BY, i * 16, _X, 16);\n salsa20_8(_X, x);\n arraycopy(_X, 0, BY, Yi + i * 16, 16);\n }\n for (i = 0; i < r; i++) {\n arraycopy(BY, Yi + i * 2 * 16, BY, i * 16, 16);\n }\n for (i = 0; i < r; i++) {\n arraycopy(BY, Yi + (i * 2 + 1) * 16, BY, (i + r) * 16, 16);\n }\n }\n function R(a, b) {\n return a << b | a >>> 32 - b;\n }\n function salsa20_8(B, x) {\n arraycopy(B, 0, x, 0, 16);\n for (let i = 8; i > 0; i -= 2) {\n x[4] ^= R(x[0] + x[12], 7);\n x[8] ^= R(x[4] + x[0], 9);\n x[12] ^= R(x[8] + x[4], 13);\n x[0] ^= R(x[12] + x[8], 18);\n x[9] ^= R(x[5] + x[1], 7);\n x[13] ^= R(x[9] + x[5], 9);\n x[1] ^= R(x[13] + x[9], 13);\n x[5] ^= R(x[1] + x[13], 18);\n x[14] ^= R(x[10] + x[6], 7);\n x[2] ^= R(x[14] + x[10], 9);\n x[6] ^= R(x[2] + x[14], 13);\n x[10] ^= R(x[6] + x[2], 18);\n x[3] ^= R(x[15] + x[11], 7);\n x[7] ^= R(x[3] + x[15], 9);\n x[11] ^= R(x[7] + x[3], 13);\n x[15] ^= R(x[11] + x[7], 18);\n x[1] ^= R(x[0] + x[3], 7);\n x[2] ^= R(x[1] + x[0], 9);\n x[3] ^= R(x[2] + x[1], 13);\n x[0] ^= R(x[3] + x[2], 18);\n x[6] ^= R(x[5] + x[4], 7);\n x[7] ^= R(x[6] + x[5], 9);\n x[4] ^= R(x[7] + x[6], 13);\n x[5] ^= R(x[4] + x[7], 18);\n x[11] ^= R(x[10] + x[9], 7);\n x[8] ^= R(x[11] + x[10], 9);\n x[9] ^= R(x[8] + x[11], 13);\n x[10] ^= R(x[9] + x[8], 18);\n x[12] ^= R(x[15] + x[14], 7);\n x[13] ^= R(x[12] + x[15], 9);\n x[14] ^= R(x[13] + x[12], 13);\n x[15] ^= R(x[14] + x[13], 18);\n }\n for (let i = 0; i < 16; ++i) {\n B[i] += x[i];\n }\n }\n\n // naive approach... going back to loop unrolling may yield additional performance\n function blockxor(S, Si, D, len) {\n for (let i = 0; i < len; i++) {\n D[i] ^= S[Si + i];\n }\n }\n function arraycopy(src, srcPos, dest, destPos, length) {\n while (length--) {\n dest[destPos++] = src[srcPos++];\n }\n }\n function checkBufferish(o) {\n if (!o || typeof o.length !== 'number') {\n return false;\n }\n for (let i = 0; i < o.length; i++) {\n const v = o[i];\n if (typeof v !== 'number' || v % 1 || v < 0 || v >= 256) {\n return false;\n }\n }\n return true;\n }\n function ensureInteger(value, name) {\n if (typeof value !== \"number\" || value % 1) {\n throw new Error('invalid ' + name);\n }\n return value;\n }\n\n // N = Cpu cost, r = Memory cost, p = parallelization cost\n // callback(error, progress, key)\n function _scrypt(password, salt, N, r, p, dkLen, callback) {\n N = ensureInteger(N, 'N');\n r = ensureInteger(r, 'r');\n p = ensureInteger(p, 'p');\n dkLen = ensureInteger(dkLen, 'dkLen');\n if (N === 0 || (N & N - 1) !== 0) {\n throw new Error('N must be power of 2');\n }\n if (N > MAX_VALUE / 128 / r) {\n throw new Error('N too large');\n }\n if (r > MAX_VALUE / 128 / p) {\n throw new Error('r too large');\n }\n if (!checkBufferish(password)) {\n throw new Error('password must be an array or buffer');\n }\n password = Array.prototype.slice.call(password);\n if (!checkBufferish(salt)) {\n throw new Error('salt must be an array or buffer');\n }\n salt = Array.prototype.slice.call(salt);\n let b = PBKDF2_HMAC_SHA256_OneIter(password, salt, p * 128 * r);\n const B = new Uint32Array(p * 32 * r);\n for (let i = 0; i < B.length; i++) {\n const j = i * 4;\n B[i] = (b[j + 3] & 0xff) << 24 | (b[j + 2] & 0xff) << 16 | (b[j + 1] & 0xff) << 8 | (b[j + 0] & 0xff) << 0;\n }\n const XY = new Uint32Array(64 * r);\n const V = new Uint32Array(32 * r * N);\n const Yi = 32 * r;\n\n // scratch space\n const x = new Uint32Array(16); // salsa20_8\n const _X = new Uint32Array(16); // blockmix_salsa8\n\n const totalOps = p * N * 2;\n let currentOp = 0;\n let lastPercent10 = null;\n\n // Set this to true to abandon the scrypt on the next step\n let stop = false;\n\n // State information\n let state = 0;\n let i0 = 0,\n i1;\n let Bi;\n\n // How many blockmix_salsa8 can we do per step?\n const limit = callback ? parseInt(1000 / r) : 0xffffffff;\n\n // Trick from scrypt-async; if there is a setImmediate shim in place, use it\n const nextTick = typeof setImmediate !== 'undefined' ? setImmediate : setTimeout;\n\n // This is really all I changed; making scryptsy a state machine so we occasionally\n // stop and give other evnts on the evnt loop a chance to run. ~RicMoo\n const incrementalSMix = function () {\n if (stop) {\n return callback(new Error('cancelled'), currentOp / totalOps);\n }\n let steps;\n switch (state) {\n case 0:\n // for (var i = 0; i < p; i++)...\n Bi = i0 * 32 * r;\n arraycopy(B, Bi, XY, 0, Yi); // ROMix - 1\n\n state = 1; // Move to ROMix 2\n i1 = 0;\n\n // Fall through\n\n case 1:\n // Run up to 1000 steps of the first inner smix loop\n steps = N - i1;\n if (steps > limit) {\n steps = limit;\n }\n for (let i = 0; i < steps; i++) {\n // ROMix - 2\n arraycopy(XY, 0, V, (i1 + i) * Yi, Yi); // ROMix - 3\n blockmix_salsa8(XY, Yi, r, x, _X); // ROMix - 4\n }\n\n // for (var i = 0; i < N; i++)\n i1 += steps;\n currentOp += steps;\n if (callback) {\n // Call the callback with the progress (optionally stopping us)\n const percent10 = parseInt(1000 * currentOp / totalOps);\n if (percent10 !== lastPercent10) {\n stop = callback(null, currentOp / totalOps);\n if (stop) {\n break;\n }\n lastPercent10 = percent10;\n }\n }\n if (i1 < N) {\n break;\n }\n i1 = 0; // Move to ROMix 6\n state = 2;\n\n // Fall through\n\n case 2:\n // Run up to 1000 steps of the second inner smix loop\n steps = N - i1;\n if (steps > limit) {\n steps = limit;\n }\n for (let i = 0; i < steps; i++) {\n // ROMix - 6\n const offset = (2 * r - 1) * 16; // ROMix - 7\n const j = XY[offset] & N - 1;\n blockxor(V, j * Yi, XY, Yi); // ROMix - 8 (inner)\n blockmix_salsa8(XY, Yi, r, x, _X); // ROMix - 9 (outer)\n }\n\n // for (var i = 0; i < N; i++)...\n i1 += steps;\n currentOp += steps;\n\n // Call the callback with the progress (optionally stopping us)\n if (callback) {\n const percent10 = parseInt(1000 * currentOp / totalOps);\n if (percent10 !== lastPercent10) {\n stop = callback(null, currentOp / totalOps);\n if (stop) {\n break;\n }\n lastPercent10 = percent10;\n }\n }\n if (i1 < N) {\n break;\n }\n arraycopy(XY, 0, B, Bi, Yi); // ROMix - 10\n\n // for (var i = 0; i < p; i++)...\n i0++;\n if (i0 < p) {\n state = 0;\n break;\n }\n b = [];\n for (let i = 0; i < B.length; i++) {\n b.push(B[i] >> 0 & 0xff);\n b.push(B[i] >> 8 & 0xff);\n b.push(B[i] >> 16 & 0xff);\n b.push(B[i] >> 24 & 0xff);\n }\n const derivedKey = PBKDF2_HMAC_SHA256_OneIter(password, b, dkLen);\n\n // Send the result to the callback\n if (callback) {\n callback(null, 1.0, derivedKey);\n }\n\n // Done; don't break (which would reschedule)\n return derivedKey;\n }\n\n // Schedule the next steps\n if (callback) {\n nextTick(incrementalSMix);\n }\n };\n\n // Run the smix state machine until completion\n if (!callback) {\n while (true) {\n const derivedKey = incrementalSMix();\n if (derivedKey != undefined) {\n return derivedKey;\n }\n }\n }\n\n // Bootstrap the async incremental smix\n incrementalSMix();\n }\n const lib = {\n scrypt: function (password, salt, N, r, p, dkLen, progressCallback) {\n return new Promise(function (resolve, reject) {\n let lastProgress = 0;\n if (progressCallback) {\n progressCallback(0);\n }\n _scrypt(password, salt, N, r, p, dkLen, function (error, progress, key) {\n if (error) {\n reject(error);\n } else if (key) {\n if (progressCallback && lastProgress !== 1) {\n progressCallback(1);\n }\n resolve(new Uint8Array(key));\n } else if (progressCallback && progress !== lastProgress) {\n lastProgress = progress;\n return progressCallback(progress);\n }\n });\n });\n },\n syncScrypt: function (password, salt, N, r, p, dkLen) {\n return new Uint8Array(_scrypt(password, salt, N, r, p, dkLen));\n }\n };\n\n // node.js\n if (typeof exports !== 'undefined') {\n module.exports = lib;\n\n // RequireJS/AMD\n // http://www.requirejs.org/docs/api.html\n // https://github.com/amdjs/amdjs-api/wiki/AMD\n } else if (typeof define === 'function' && define.amd) {\n define(lib);\n\n // Web Browsers\n } else if (root) {\n // If there was an existing library \"scrypt\", make sure it is still available\n if (root.scrypt) {\n root._scrypt = root.scrypt;\n }\n root.scrypt = lib;\n }\n})(this);","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport aes from \"aes-js\";\nimport scrypt from \"scrypt-js\";\nimport { getAddress } from \"@ethersproject/address\";\nimport { arrayify, concat, hexlify } from \"@ethersproject/bytes\";\nimport { defaultPath, entropyToMnemonic, HDNode, mnemonicToEntropy } from \"@ethersproject/hdnode\";\nimport { keccak256 } from \"@ethersproject/keccak256\";\nimport { pbkdf2 as _pbkdf2 } from \"@ethersproject/pbkdf2\";\nimport { randomBytes } from \"@ethersproject/random\";\nimport { Description } from \"@ethersproject/properties\";\nimport { computeAddress } from \"@ethersproject/transactions\";\nimport { getPassword, looseArrayify, searchPath, uuidV4, zpad } from \"./utils\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n// Exported Types\nfunction hasMnemonic(value) {\n return value != null && value.mnemonic && value.mnemonic.phrase;\n}\nexport class KeystoreAccount extends Description {\n isKeystoreAccount(value) {\n return !!(value && value._isKeystoreAccount);\n }\n}\nfunction _decrypt(data, key, ciphertext) {\n const cipher = searchPath(data, \"crypto/cipher\");\n if (cipher === \"aes-128-ctr\") {\n const iv = looseArrayify(searchPath(data, \"crypto/cipherparams/iv\"));\n const counter = new aes.Counter(iv);\n const aesCtr = new aes.ModeOfOperation.ctr(key, counter);\n return arrayify(aesCtr.decrypt(ciphertext));\n }\n return null;\n}\nfunction _getAccount(data, key) {\n const ciphertext = looseArrayify(searchPath(data, \"crypto/ciphertext\"));\n const computedMAC = hexlify(keccak256(concat([key.slice(16, 32), ciphertext]))).substring(2);\n if (computedMAC !== searchPath(data, \"crypto/mac\").toLowerCase()) {\n throw new Error(\"invalid password\");\n }\n const privateKey = _decrypt(data, key.slice(0, 16), ciphertext);\n if (!privateKey) {\n logger.throwError(\"unsupported cipher\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"decrypt\"\n });\n }\n const mnemonicKey = key.slice(32, 64);\n const address = computeAddress(privateKey);\n if (data.address) {\n let check = data.address.toLowerCase();\n if (check.substring(0, 2) !== \"0x\") {\n check = \"0x\" + check;\n }\n if (getAddress(check) !== address) {\n throw new Error(\"address mismatch\");\n }\n }\n const account = {\n _isKeystoreAccount: true,\n address: address,\n privateKey: hexlify(privateKey)\n };\n // Version 0.1 x-ethers metadata must contain an encrypted mnemonic phrase\n if (searchPath(data, \"x-ethers/version\") === \"0.1\") {\n const mnemonicCiphertext = looseArrayify(searchPath(data, \"x-ethers/mnemonicCiphertext\"));\n const mnemonicIv = looseArrayify(searchPath(data, \"x-ethers/mnemonicCounter\"));\n const mnemonicCounter = new aes.Counter(mnemonicIv);\n const mnemonicAesCtr = new aes.ModeOfOperation.ctr(mnemonicKey, mnemonicCounter);\n const path = searchPath(data, \"x-ethers/path\") || defaultPath;\n const locale = searchPath(data, \"x-ethers/locale\") || \"en\";\n const entropy = arrayify(mnemonicAesCtr.decrypt(mnemonicCiphertext));\n try {\n const mnemonic = entropyToMnemonic(entropy, locale);\n const node = HDNode.fromMnemonic(mnemonic, null, locale).derivePath(path);\n if (node.privateKey != account.privateKey) {\n throw new Error(\"mnemonic mismatch\");\n }\n account.mnemonic = node.mnemonic;\n } catch (error) {\n // If we don't have the locale wordlist installed to\n // read this mnemonic, just bail and don't set the\n // mnemonic\n if (error.code !== Logger.errors.INVALID_ARGUMENT || error.argument !== \"wordlist\") {\n throw error;\n }\n }\n }\n return new KeystoreAccount(account);\n}\nfunction pbkdf2Sync(passwordBytes, salt, count, dkLen, prfFunc) {\n return arrayify(_pbkdf2(passwordBytes, salt, count, dkLen, prfFunc));\n}\nfunction pbkdf2(passwordBytes, salt, count, dkLen, prfFunc) {\n return Promise.resolve(pbkdf2Sync(passwordBytes, salt, count, dkLen, prfFunc));\n}\nfunction _computeKdfKey(data, password, pbkdf2Func, scryptFunc, progressCallback) {\n const passwordBytes = getPassword(password);\n const kdf = searchPath(data, \"crypto/kdf\");\n if (kdf && typeof kdf === \"string\") {\n const throwError = function (name, value) {\n return logger.throwArgumentError(\"invalid key-derivation function parameters\", name, value);\n };\n if (kdf.toLowerCase() === \"scrypt\") {\n const salt = looseArrayify(searchPath(data, \"crypto/kdfparams/salt\"));\n const N = parseInt(searchPath(data, \"crypto/kdfparams/n\"));\n const r = parseInt(searchPath(data, \"crypto/kdfparams/r\"));\n const p = parseInt(searchPath(data, \"crypto/kdfparams/p\"));\n // Check for all required parameters\n if (!N || !r || !p) {\n throwError(\"kdf\", kdf);\n }\n // Make sure N is a power of 2\n if ((N & N - 1) !== 0) {\n throwError(\"N\", N);\n }\n const dkLen = parseInt(searchPath(data, \"crypto/kdfparams/dklen\"));\n if (dkLen !== 32) {\n throwError(\"dklen\", dkLen);\n }\n return scryptFunc(passwordBytes, salt, N, r, p, 64, progressCallback);\n } else if (kdf.toLowerCase() === \"pbkdf2\") {\n const salt = looseArrayify(searchPath(data, \"crypto/kdfparams/salt\"));\n let prfFunc = null;\n const prf = searchPath(data, \"crypto/kdfparams/prf\");\n if (prf === \"hmac-sha256\") {\n prfFunc = \"sha256\";\n } else if (prf === \"hmac-sha512\") {\n prfFunc = \"sha512\";\n } else {\n throwError(\"prf\", prf);\n }\n const count = parseInt(searchPath(data, \"crypto/kdfparams/c\"));\n const dkLen = parseInt(searchPath(data, \"crypto/kdfparams/dklen\"));\n if (dkLen !== 32) {\n throwError(\"dklen\", dkLen);\n }\n return pbkdf2Func(passwordBytes, salt, count, dkLen, prfFunc);\n }\n }\n return logger.throwArgumentError(\"unsupported key-derivation function\", \"kdf\", kdf);\n}\nexport function decryptSync(json, password) {\n const data = JSON.parse(json);\n const key = _computeKdfKey(data, password, pbkdf2Sync, scrypt.syncScrypt);\n return _getAccount(data, key);\n}\nexport function decrypt(json, password, progressCallback) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = JSON.parse(json);\n const key = yield _computeKdfKey(data, password, pbkdf2, scrypt.scrypt, progressCallback);\n return _getAccount(data, key);\n });\n}\nexport function encrypt(account, password, options, progressCallback) {\n try {\n // Check the address matches the private key\n if (getAddress(account.address) !== computeAddress(account.privateKey)) {\n throw new Error(\"address/privateKey mismatch\");\n }\n // Check the mnemonic (if any) matches the private key\n if (hasMnemonic(account)) {\n const mnemonic = account.mnemonic;\n const node = HDNode.fromMnemonic(mnemonic.phrase, null, mnemonic.locale).derivePath(mnemonic.path || defaultPath);\n if (node.privateKey != account.privateKey) {\n throw new Error(\"mnemonic mismatch\");\n }\n }\n } catch (e) {\n return Promise.reject(e);\n }\n // The options are optional, so adjust the call as needed\n if (typeof options === \"function\" && !progressCallback) {\n progressCallback = options;\n options = {};\n }\n if (!options) {\n options = {};\n }\n const privateKey = arrayify(account.privateKey);\n const passwordBytes = getPassword(password);\n let entropy = null;\n let path = null;\n let locale = null;\n if (hasMnemonic(account)) {\n const srcMnemonic = account.mnemonic;\n entropy = arrayify(mnemonicToEntropy(srcMnemonic.phrase, srcMnemonic.locale || \"en\"));\n path = srcMnemonic.path || defaultPath;\n locale = srcMnemonic.locale || \"en\";\n }\n let client = options.client;\n if (!client) {\n client = \"ethers.js\";\n }\n // Check/generate the salt\n let salt = null;\n if (options.salt) {\n salt = arrayify(options.salt);\n } else {\n salt = randomBytes(32);\n ;\n }\n // Override initialization vector\n let iv = null;\n if (options.iv) {\n iv = arrayify(options.iv);\n if (iv.length !== 16) {\n throw new Error(\"invalid iv\");\n }\n } else {\n iv = randomBytes(16);\n }\n // Override the uuid\n let uuidRandom = null;\n if (options.uuid) {\n uuidRandom = arrayify(options.uuid);\n if (uuidRandom.length !== 16) {\n throw new Error(\"invalid uuid\");\n }\n } else {\n uuidRandom = randomBytes(16);\n }\n // Override the scrypt password-based key derivation function parameters\n let N = 1 << 17,\n r = 8,\n p = 1;\n if (options.scrypt) {\n if (options.scrypt.N) {\n N = options.scrypt.N;\n }\n if (options.scrypt.r) {\n r = options.scrypt.r;\n }\n if (options.scrypt.p) {\n p = options.scrypt.p;\n }\n }\n // We take 64 bytes:\n // - 32 bytes As normal for the Web3 secret storage (derivedKey, macPrefix)\n // - 32 bytes AES key to encrypt mnemonic with (required here to be Ethers Wallet)\n return scrypt.scrypt(passwordBytes, salt, N, r, p, 64, progressCallback).then(key => {\n key = arrayify(key);\n // This will be used to encrypt the wallet (as per Web3 secret storage)\n const derivedKey = key.slice(0, 16);\n const macPrefix = key.slice(16, 32);\n // This will be used to encrypt the mnemonic phrase (if any)\n const mnemonicKey = key.slice(32, 64);\n // Encrypt the private key\n const counter = new aes.Counter(iv);\n const aesCtr = new aes.ModeOfOperation.ctr(derivedKey, counter);\n const ciphertext = arrayify(aesCtr.encrypt(privateKey));\n // Compute the message authentication code, used to check the password\n const mac = keccak256(concat([macPrefix, ciphertext]));\n // See: https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition\n const data = {\n address: account.address.substring(2).toLowerCase(),\n id: uuidV4(uuidRandom),\n version: 3,\n crypto: {\n cipher: \"aes-128-ctr\",\n cipherparams: {\n iv: hexlify(iv).substring(2)\n },\n ciphertext: hexlify(ciphertext).substring(2),\n kdf: \"scrypt\",\n kdfparams: {\n salt: hexlify(salt).substring(2),\n n: N,\n dklen: 32,\n p: p,\n r: r\n },\n mac: mac.substring(2)\n }\n };\n // If we have a mnemonic, encrypt it into the JSON wallet\n if (entropy) {\n const mnemonicIv = randomBytes(16);\n const mnemonicCounter = new aes.Counter(mnemonicIv);\n const mnemonicAesCtr = new aes.ModeOfOperation.ctr(mnemonicKey, mnemonicCounter);\n const mnemonicCiphertext = arrayify(mnemonicAesCtr.encrypt(entropy));\n const now = new Date();\n const timestamp = now.getUTCFullYear() + \"-\" + zpad(now.getUTCMonth() + 1, 2) + \"-\" + zpad(now.getUTCDate(), 2) + \"T\" + zpad(now.getUTCHours(), 2) + \"-\" + zpad(now.getUTCMinutes(), 2) + \"-\" + zpad(now.getUTCSeconds(), 2) + \".0Z\";\n data[\"x-ethers\"] = {\n client: client,\n gethFilename: \"UTC--\" + timestamp + \"--\" + data.address,\n mnemonicCounter: hexlify(mnemonicIv).substring(2),\n mnemonicCiphertext: hexlify(mnemonicCiphertext).substring(2),\n path: path,\n locale: locale,\n version: \"0.1\"\n };\n }\n return JSON.stringify(data);\n });\n}\n","\"use strict\";\n\nimport { decrypt as decryptCrowdsale } from \"./crowdsale\";\nimport { getJsonWalletAddress, isCrowdsaleWallet, isKeystoreWallet } from \"./inspect\";\nimport { decrypt as decryptKeystore, decryptSync as decryptKeystoreSync, encrypt as encryptKeystore } from \"./keystore\";\nfunction decryptJsonWallet(json, password, progressCallback) {\n if (isCrowdsaleWallet(json)) {\n if (progressCallback) {\n progressCallback(0);\n }\n const account = decryptCrowdsale(json, password);\n if (progressCallback) {\n progressCallback(1);\n }\n return Promise.resolve(account);\n }\n if (isKeystoreWallet(json)) {\n return decryptKeystore(json, password, progressCallback);\n }\n return Promise.reject(new Error(\"invalid JSON wallet\"));\n}\nfunction decryptJsonWalletSync(json, password) {\n if (isCrowdsaleWallet(json)) {\n return decryptCrowdsale(json, password);\n }\n if (isKeystoreWallet(json)) {\n return decryptKeystoreSync(json, password);\n }\n throw new Error(\"invalid JSON wallet\");\n}\nexport { decryptCrowdsale, decryptKeystore, decryptKeystoreSync, encryptKeystore, isCrowdsaleWallet, isKeystoreWallet, getJsonWalletAddress, decryptJsonWallet, decryptJsonWalletSync };\n","export const version = \"wallet/5.7.0\";\n","\"use strict\";\n\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { getAddress } from \"@ethersproject/address\";\nimport { Provider } from \"@ethersproject/abstract-provider\";\nimport { Signer } from \"@ethersproject/abstract-signer\";\nimport { arrayify, concat, hexDataSlice, isHexString, joinSignature } from \"@ethersproject/bytes\";\nimport { hashMessage, _TypedDataEncoder } from \"@ethersproject/hash\";\nimport { defaultPath, HDNode, entropyToMnemonic } from \"@ethersproject/hdnode\";\nimport { keccak256 } from \"@ethersproject/keccak256\";\nimport { defineReadOnly, resolveProperties } from \"@ethersproject/properties\";\nimport { randomBytes } from \"@ethersproject/random\";\nimport { SigningKey } from \"@ethersproject/signing-key\";\nimport { decryptJsonWallet, decryptJsonWalletSync, encryptKeystore } from \"@ethersproject/json-wallets\";\nimport { computeAddress, recoverAddress, serialize } from \"@ethersproject/transactions\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nfunction isAccount(value) {\n return value != null && isHexString(value.privateKey, 32) && value.address != null;\n}\nfunction hasMnemonic(value) {\n const mnemonic = value.mnemonic;\n return mnemonic && mnemonic.phrase;\n}\nexport class Wallet extends Signer {\n constructor(privateKey, provider) {\n super();\n if (isAccount(privateKey)) {\n const signingKey = new SigningKey(privateKey.privateKey);\n defineReadOnly(this, \"_signingKey\", () => signingKey);\n defineReadOnly(this, \"address\", computeAddress(this.publicKey));\n if (this.address !== getAddress(privateKey.address)) {\n logger.throwArgumentError(\"privateKey/address mismatch\", \"privateKey\", \"[REDACTED]\");\n }\n if (hasMnemonic(privateKey)) {\n const srcMnemonic = privateKey.mnemonic;\n defineReadOnly(this, \"_mnemonic\", () => ({\n phrase: srcMnemonic.phrase,\n path: srcMnemonic.path || defaultPath,\n locale: srcMnemonic.locale || \"en\"\n }));\n const mnemonic = this.mnemonic;\n const node = HDNode.fromMnemonic(mnemonic.phrase, null, mnemonic.locale).derivePath(mnemonic.path);\n if (computeAddress(node.privateKey) !== this.address) {\n logger.throwArgumentError(\"mnemonic/address mismatch\", \"privateKey\", \"[REDACTED]\");\n }\n } else {\n defineReadOnly(this, \"_mnemonic\", () => null);\n }\n } else {\n if (SigningKey.isSigningKey(privateKey)) {\n /* istanbul ignore if */\n if (privateKey.curve !== \"secp256k1\") {\n logger.throwArgumentError(\"unsupported curve; must be secp256k1\", \"privateKey\", \"[REDACTED]\");\n }\n defineReadOnly(this, \"_signingKey\", () => privateKey);\n } else {\n // A lot of common tools do not prefix private keys with a 0x (see: #1166)\n if (typeof privateKey === \"string\") {\n if (privateKey.match(/^[0-9a-f]*$/i) && privateKey.length === 64) {\n privateKey = \"0x\" + privateKey;\n }\n }\n const signingKey = new SigningKey(privateKey);\n defineReadOnly(this, \"_signingKey\", () => signingKey);\n }\n defineReadOnly(this, \"_mnemonic\", () => null);\n defineReadOnly(this, \"address\", computeAddress(this.publicKey));\n }\n /* istanbul ignore if */\n if (provider && !Provider.isProvider(provider)) {\n logger.throwArgumentError(\"invalid provider\", \"provider\", provider);\n }\n defineReadOnly(this, \"provider\", provider || null);\n }\n get mnemonic() {\n return this._mnemonic();\n }\n get privateKey() {\n return this._signingKey().privateKey;\n }\n get publicKey() {\n return this._signingKey().publicKey;\n }\n getAddress() {\n return Promise.resolve(this.address);\n }\n connect(provider) {\n return new Wallet(this, provider);\n }\n signTransaction(transaction) {\n return resolveProperties(transaction).then(tx => {\n if (tx.from != null) {\n if (getAddress(tx.from) !== this.address) {\n logger.throwArgumentError(\"transaction from address mismatch\", \"transaction.from\", transaction.from);\n }\n delete tx.from;\n }\n const signature = this._signingKey().signDigest(keccak256(serialize(tx)));\n return serialize(tx, signature);\n });\n }\n signMessage(message) {\n return __awaiter(this, void 0, void 0, function* () {\n return joinSignature(this._signingKey().signDigest(hashMessage(message)));\n });\n }\n _signTypedData(domain, types, value) {\n return __awaiter(this, void 0, void 0, function* () {\n // Populate any ENS names\n const populated = yield _TypedDataEncoder.resolveNames(domain, types, value, name => {\n if (this.provider == null) {\n logger.throwError(\"cannot resolve ENS names without a provider\", Logger.errors.UNSUPPORTED_OPERATION, {\n operation: \"resolveName\",\n value: name\n });\n }\n return this.provider.resolveName(name);\n });\n return joinSignature(this._signingKey().signDigest(_TypedDataEncoder.hash(populated.domain, types, populated.value)));\n });\n }\n encrypt(password, options, progressCallback) {\n if (typeof options === \"function\" && !progressCallback) {\n progressCallback = options;\n options = {};\n }\n if (progressCallback && typeof progressCallback !== \"function\") {\n throw new Error(\"invalid callback\");\n }\n if (!options) {\n options = {};\n }\n return encryptKeystore(this, password, options, progressCallback);\n }\n /**\n * Static methods to create Wallet instances.\n */\n static createRandom(options) {\n let entropy = randomBytes(16);\n if (!options) {\n options = {};\n }\n if (options.extraEntropy) {\n entropy = arrayify(hexDataSlice(keccak256(concat([entropy, options.extraEntropy])), 0, 16));\n }\n const mnemonic = entropyToMnemonic(entropy, options.locale);\n return Wallet.fromMnemonic(mnemonic, options.path, options.locale);\n }\n static fromEncryptedJson(json, password, progressCallback) {\n return decryptJsonWallet(json, password, progressCallback).then(account => {\n return new Wallet(account);\n });\n }\n static fromEncryptedJsonSync(json, password) {\n return new Wallet(decryptJsonWalletSync(json, password));\n }\n static fromMnemonic(mnemonic, path, wordlist) {\n if (!path) {\n path = defaultPath;\n }\n return new Wallet(HDNode.fromMnemonic(mnemonic, null, wordlist).derivePath(path));\n }\n}\nexport function verifyMessage(message, signature) {\n return recoverAddress(hashMessage(message), signature);\n}\nexport function verifyTypedData(domain, types, value, signature) {\n return recoverAddress(_TypedDataEncoder.hash(domain, types, value), signature);\n}\n","export const version = \"solidity/5.7.0\";\n","\"use strict\";\n\nimport { BigNumber } from \"@ethersproject/bignumber\";\nimport { arrayify, concat, hexlify, zeroPad } from \"@ethersproject/bytes\";\nimport { keccak256 as hashKeccak256 } from \"@ethersproject/keccak256\";\nimport { sha256 as hashSha256 } from \"@ethersproject/sha2\";\nimport { toUtf8Bytes } from \"@ethersproject/strings\";\nconst regexBytes = new RegExp(\"^bytes([0-9]+)$\");\nconst regexNumber = new RegExp(\"^(u?int)([0-9]*)$\");\nconst regexArray = new RegExp(\"^(.*)\\\\[([0-9]*)\\\\]$\");\nconst Zeros = \"0000000000000000000000000000000000000000000000000000000000000000\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nfunction _pack(type, value, isArray) {\n switch (type) {\n case \"address\":\n if (isArray) {\n return zeroPad(value, 32);\n }\n return arrayify(value);\n case \"string\":\n return toUtf8Bytes(value);\n case \"bytes\":\n return arrayify(value);\n case \"bool\":\n value = value ? \"0x01\" : \"0x00\";\n if (isArray) {\n return zeroPad(value, 32);\n }\n return arrayify(value);\n }\n let match = type.match(regexNumber);\n if (match) {\n //let signed = (match[1] === \"int\")\n let size = parseInt(match[2] || \"256\");\n if (match[2] && String(size) !== match[2] || size % 8 !== 0 || size === 0 || size > 256) {\n logger.throwArgumentError(\"invalid number type\", \"type\", type);\n }\n if (isArray) {\n size = 256;\n }\n value = BigNumber.from(value).toTwos(size);\n return zeroPad(value, size / 8);\n }\n match = type.match(regexBytes);\n if (match) {\n const size = parseInt(match[1]);\n if (String(size) !== match[1] || size === 0 || size > 32) {\n logger.throwArgumentError(\"invalid bytes type\", \"type\", type);\n }\n if (arrayify(value).byteLength !== size) {\n logger.throwArgumentError(`invalid value for ${type}`, \"value\", value);\n }\n if (isArray) {\n return arrayify((value + Zeros).substring(0, 66));\n }\n return value;\n }\n match = type.match(regexArray);\n if (match && Array.isArray(value)) {\n const baseType = match[1];\n const count = parseInt(match[2] || String(value.length));\n if (count != value.length) {\n logger.throwArgumentError(`invalid array length for ${type}`, \"value\", value);\n }\n const result = [];\n value.forEach(function (value) {\n result.push(_pack(baseType, value, true));\n });\n return concat(result);\n }\n return logger.throwArgumentError(\"invalid type\", \"type\", type);\n}\n// @TODO: Array Enum\nexport function pack(types, values) {\n if (types.length != values.length) {\n logger.throwArgumentError(\"wrong number of values; expected ${ types.length }\", \"values\", values);\n }\n const tight = [];\n types.forEach(function (type, index) {\n tight.push(_pack(type, values[index]));\n });\n return hexlify(concat(tight));\n}\nexport function keccak256(types, values) {\n return hashKeccak256(pack(types, values));\n}\nexport function sha256(types, values) {\n return hashSha256(pack(types, values));\n}\n","export const version = \"units/5.7.0\";\n","\"use strict\";\n\nimport { formatFixed, parseFixed } from \"@ethersproject/bignumber\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\nconst names = [\"wei\", \"kwei\", \"mwei\", \"gwei\", \"szabo\", \"finney\", \"ether\"];\n// Some environments have issues with RegEx that contain back-tracking, so we cannot\n// use them.\nexport function commify(value) {\n const comps = String(value).split(\".\");\n if (comps.length > 2 || !comps[0].match(/^-?[0-9]*$/) || comps[1] && !comps[1].match(/^[0-9]*$/) || value === \".\" || value === \"-.\") {\n logger.throwArgumentError(\"invalid value\", \"value\", value);\n }\n // Make sure we have at least one whole digit (0 if none)\n let whole = comps[0];\n let negative = \"\";\n if (whole.substring(0, 1) === \"-\") {\n negative = \"-\";\n whole = whole.substring(1);\n }\n // Make sure we have at least 1 whole digit with no leading zeros\n while (whole.substring(0, 1) === \"0\") {\n whole = whole.substring(1);\n }\n if (whole === \"\") {\n whole = \"0\";\n }\n let suffix = \"\";\n if (comps.length === 2) {\n suffix = \".\" + (comps[1] || \"0\");\n }\n while (suffix.length > 2 && suffix[suffix.length - 1] === \"0\") {\n suffix = suffix.substring(0, suffix.length - 1);\n }\n const formatted = [];\n while (whole.length) {\n if (whole.length <= 3) {\n formatted.unshift(whole);\n break;\n } else {\n const index = whole.length - 3;\n formatted.unshift(whole.substring(index));\n whole = whole.substring(0, index);\n }\n }\n return negative + formatted.join(\",\") + suffix;\n}\nexport function formatUnits(value, unitName) {\n if (typeof unitName === \"string\") {\n const index = names.indexOf(unitName);\n if (index !== -1) {\n unitName = 3 * index;\n }\n }\n return formatFixed(value, unitName != null ? unitName : 18);\n}\nexport function parseUnits(value, unitName) {\n if (typeof value !== \"string\") {\n logger.throwArgumentError(\"value must be a string\", \"value\", value);\n }\n if (typeof unitName === \"string\") {\n const index = names.indexOf(unitName);\n if (index !== -1) {\n unitName = 3 * index;\n }\n }\n return parseFixed(value, unitName != null ? unitName : 18);\n}\nexport function formatEther(wei) {\n return formatUnits(wei, 18);\n}\nexport function parseEther(ether) {\n return parseUnits(ether, 18);\n}\n","\"use strict\";\n\nimport { AbiCoder, checkResultErrors, ConstructorFragment, defaultAbiCoder, ErrorFragment, EventFragment, FormatTypes, Fragment, FunctionFragment, Indexed, Interface, LogDescription, ParamType, TransactionDescription } from \"@ethersproject/abi\";\nimport { getAddress, getCreate2Address, getContractAddress, getIcapAddress, isAddress } from \"@ethersproject/address\";\nimport * as base64 from \"@ethersproject/base64\";\nimport { Base58 as base58 } from \"@ethersproject/basex\";\nimport { arrayify, concat, hexConcat, hexDataSlice, hexDataLength, hexlify, hexStripZeros, hexValue, hexZeroPad, isBytes, isBytesLike, isHexString, joinSignature, zeroPad, splitSignature, stripZeros } from \"@ethersproject/bytes\";\nimport { _TypedDataEncoder, dnsEncode, hashMessage, id, isValidName, namehash } from \"@ethersproject/hash\";\nimport { defaultPath, entropyToMnemonic, getAccountPath, HDNode, isValidMnemonic, mnemonicToEntropy, mnemonicToSeed } from \"@ethersproject/hdnode\";\nimport { getJsonWalletAddress } from \"@ethersproject/json-wallets\";\nimport { keccak256 } from \"@ethersproject/keccak256\";\nimport { Logger } from \"@ethersproject/logger\";\nimport { computeHmac, ripemd160, sha256, sha512 } from \"@ethersproject/sha2\";\nimport { keccak256 as solidityKeccak256, pack as solidityPack, sha256 as soliditySha256 } from \"@ethersproject/solidity\";\nimport { randomBytes, shuffled } from \"@ethersproject/random\";\nimport { checkProperties, deepCopy, defineReadOnly, getStatic, resolveProperties, shallowCopy } from \"@ethersproject/properties\";\nimport * as RLP from \"@ethersproject/rlp\";\nimport { computePublicKey, recoverPublicKey, SigningKey } from \"@ethersproject/signing-key\";\nimport { formatBytes32String, nameprep, parseBytes32String, _toEscapedUtf8String, toUtf8Bytes, toUtf8CodePoints, toUtf8String, Utf8ErrorFuncs } from \"@ethersproject/strings\";\nimport { accessListify, computeAddress, parse as parseTransaction, recoverAddress, serialize as serializeTransaction, TransactionTypes } from \"@ethersproject/transactions\";\nimport { commify, formatEther, parseEther, formatUnits, parseUnits } from \"@ethersproject/units\";\nimport { verifyMessage, verifyTypedData } from \"@ethersproject/wallet\";\nimport { _fetchData, fetchJson, poll } from \"@ethersproject/web\";\n////////////////////////\n// Enums\nimport { SupportedAlgorithm } from \"@ethersproject/sha2\";\nimport { UnicodeNormalizationForm, Utf8ErrorReason } from \"@ethersproject/strings\";\n////////////////////////\n// Exports\nexport { AbiCoder, defaultAbiCoder, Fragment, ConstructorFragment, ErrorFragment, EventFragment, FunctionFragment, ParamType, FormatTypes, checkResultErrors, Logger, RLP, _fetchData, fetchJson, poll, checkProperties, deepCopy, defineReadOnly, getStatic, resolveProperties, shallowCopy, arrayify, concat, stripZeros, zeroPad, isBytes, isBytesLike, defaultPath, HDNode, SigningKey, Interface, LogDescription, TransactionDescription, base58, base64, hexlify, isHexString, hexConcat, hexStripZeros, hexValue, hexZeroPad, hexDataLength, hexDataSlice, nameprep, _toEscapedUtf8String, toUtf8Bytes, toUtf8CodePoints, toUtf8String, Utf8ErrorFuncs, formatBytes32String, parseBytes32String, dnsEncode, hashMessage, namehash, isValidName, id, _TypedDataEncoder, getAddress, getIcapAddress, getContractAddress, getCreate2Address, isAddress, formatEther, parseEther, formatUnits, parseUnits, commify, computeHmac, keccak256, ripemd160, sha256, sha512, randomBytes, shuffled, solidityPack, solidityKeccak256, soliditySha256, splitSignature, joinSignature, accessListify, parseTransaction, serializeTransaction, TransactionTypes, getJsonWalletAddress, computeAddress, recoverAddress, computePublicKey, recoverPublicKey, verifyMessage, verifyTypedData, getAccountPath, mnemonicToEntropy, entropyToMnemonic, isValidMnemonic, mnemonicToSeed,\n////////////////////////\n// Enums\nSupportedAlgorithm, UnicodeNormalizationForm, Utf8ErrorReason, Indexed };\n","export const version = \"ethers/5.7.2\";\n","\"use strict\";\n\nimport { BaseContract, Contract, ContractFactory } from \"@ethersproject/contracts\";\nimport { BigNumber, FixedNumber } from \"@ethersproject/bignumber\";\nimport { Signer, VoidSigner } from \"@ethersproject/abstract-signer\";\nimport { Wallet } from \"@ethersproject/wallet\";\nimport * as constants from \"@ethersproject/constants\";\nimport * as providers from \"@ethersproject/providers\";\nimport { getDefaultProvider } from \"@ethersproject/providers\";\nimport { Wordlist, wordlists } from \"@ethersproject/wordlists\";\nimport * as utils from \"./utils\";\nimport { ErrorCode as errors, Logger } from \"@ethersproject/logger\";\n////////////////////////\n// Compile-Time Constants\n// This is generated by \"npm run dist\"\nimport { version } from \"./_version\";\nconst logger = new Logger(version);\n////////////////////////\n// Exports\nexport { Signer, Wallet, VoidSigner, getDefaultProvider, providers, BaseContract, Contract, ContractFactory, BigNumber, FixedNumber, constants, errors, logger, utils, wordlists,\n////////////////////////\n// Compile-Time Constants\nversion, Wordlist };\n","\"use strict\";\n\n// To modify this file, you must update ./misc/admin/lib/cmds/update-exports.js\nimport * as ethers from \"./ethers\";\ntry {\n const anyGlobal = window;\n if (anyGlobal._ethers == null) {\n anyGlobal._ethers = ethers;\n }\n} catch (error) {}\nexport { ethers };\nexport { Signer, Wallet, VoidSigner, getDefaultProvider, providers, BaseContract, Contract, ContractFactory, BigNumber, FixedNumber, constants, errors, logger, utils, wordlists,\n////////////////////////\n// Compile-Time Constants\nversion, Wordlist } from \"./ethers\";\n","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\n} : function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\nvar __setModuleDefault = this && this.__setModuleDefault || (Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.formatBytes32String = exports.Utf8ErrorFuncs = exports.toUtf8String = exports.toUtf8CodePoints = exports.toUtf8Bytes = exports._toEscapedUtf8String = exports.nameprep = exports.hexDataSlice = exports.hexDataLength = exports.hexZeroPad = exports.hexValue = exports.hexStripZeros = exports.hexConcat = exports.isHexString = exports.hexlify = exports.base64 = exports.base58 = exports.TransactionDescription = exports.LogDescription = exports.Interface = exports.SigningKey = exports.HDNode = exports.defaultPath = exports.isBytesLike = exports.isBytes = exports.zeroPad = exports.stripZeros = exports.concat = exports.arrayify = exports.shallowCopy = exports.resolveProperties = exports.getStatic = exports.defineReadOnly = exports.deepCopy = exports.checkProperties = exports.poll = exports.fetchJson = exports._fetchData = exports.RLP = exports.Logger = exports.checkResultErrors = exports.FormatTypes = exports.ParamType = exports.FunctionFragment = exports.EventFragment = exports.ErrorFragment = exports.ConstructorFragment = exports.Fragment = exports.defaultAbiCoder = exports.AbiCoder = void 0;\nexports.Indexed = exports.Utf8ErrorReason = exports.UnicodeNormalizationForm = exports.SupportedAlgorithm = exports.mnemonicToSeed = exports.isValidMnemonic = exports.entropyToMnemonic = exports.mnemonicToEntropy = exports.getAccountPath = exports.verifyTypedData = exports.verifyMessage = exports.recoverPublicKey = exports.computePublicKey = exports.recoverAddress = exports.computeAddress = exports.getJsonWalletAddress = exports.TransactionTypes = exports.serializeTransaction = exports.parseTransaction = exports.accessListify = exports.joinSignature = exports.splitSignature = exports.soliditySha256 = exports.solidityKeccak256 = exports.solidityPack = exports.shuffled = exports.randomBytes = exports.sha512 = exports.sha256 = exports.ripemd160 = exports.keccak256 = exports.computeHmac = exports.commify = exports.parseUnits = exports.formatUnits = exports.parseEther = exports.formatEther = exports.isAddress = exports.getCreate2Address = exports.getContractAddress = exports.getIcapAddress = exports.getAddress = exports._TypedDataEncoder = exports.id = exports.isValidName = exports.namehash = exports.hashMessage = exports.dnsEncode = exports.parseBytes32String = void 0;\nvar abi_1 = require(\"@ethersproject/abi\");\nObject.defineProperty(exports, \"AbiCoder\", {\n enumerable: true,\n get: function () {\n return abi_1.AbiCoder;\n }\n});\nObject.defineProperty(exports, \"checkResultErrors\", {\n enumerable: true,\n get: function () {\n return abi_1.checkResultErrors;\n }\n});\nObject.defineProperty(exports, \"ConstructorFragment\", {\n enumerable: true,\n get: function () {\n return abi_1.ConstructorFragment;\n }\n});\nObject.defineProperty(exports, \"defaultAbiCoder\", {\n enumerable: true,\n get: function () {\n return abi_1.defaultAbiCoder;\n }\n});\nObject.defineProperty(exports, \"ErrorFragment\", {\n enumerable: true,\n get: function () {\n return abi_1.ErrorFragment;\n }\n});\nObject.defineProperty(exports, \"EventFragment\", {\n enumerable: true,\n get: function () {\n return abi_1.EventFragment;\n }\n});\nObject.defineProperty(exports, \"FormatTypes\", {\n enumerable: true,\n get: function () {\n return abi_1.FormatTypes;\n }\n});\nObject.defineProperty(exports, \"Fragment\", {\n enumerable: true,\n get: function () {\n return abi_1.Fragment;\n }\n});\nObject.defineProperty(exports, \"FunctionFragment\", {\n enumerable: true,\n get: function () {\n return abi_1.FunctionFragment;\n }\n});\nObject.defineProperty(exports, \"Indexed\", {\n enumerable: true,\n get: function () {\n return abi_1.Indexed;\n }\n});\nObject.defineProperty(exports, \"Interface\", {\n enumerable: true,\n get: function () {\n return abi_1.Interface;\n }\n});\nObject.defineProperty(exports, \"LogDescription\", {\n enumerable: true,\n get: function () {\n return abi_1.LogDescription;\n }\n});\nObject.defineProperty(exports, \"ParamType\", {\n enumerable: true,\n get: function () {\n return abi_1.ParamType;\n }\n});\nObject.defineProperty(exports, \"TransactionDescription\", {\n enumerable: true,\n get: function () {\n return abi_1.TransactionDescription;\n }\n});\nvar address_1 = require(\"@ethersproject/address\");\nObject.defineProperty(exports, \"getAddress\", {\n enumerable: true,\n get: function () {\n return address_1.getAddress;\n }\n});\nObject.defineProperty(exports, \"getCreate2Address\", {\n enumerable: true,\n get: function () {\n return address_1.getCreate2Address;\n }\n});\nObject.defineProperty(exports, \"getContractAddress\", {\n enumerable: true,\n get: function () {\n return address_1.getContractAddress;\n }\n});\nObject.defineProperty(exports, \"getIcapAddress\", {\n enumerable: true,\n get: function () {\n return address_1.getIcapAddress;\n }\n});\nObject.defineProperty(exports, \"isAddress\", {\n enumerable: true,\n get: function () {\n return address_1.isAddress;\n }\n});\nvar base64 = __importStar(require(\"@ethersproject/base64\"));\nexports.base64 = base64;\nvar basex_1 = require(\"@ethersproject/basex\");\nObject.defineProperty(exports, \"base58\", {\n enumerable: true,\n get: function () {\n return basex_1.Base58;\n }\n});\nvar bytes_1 = require(\"@ethersproject/bytes\");\nObject.defineProperty(exports, \"arrayify\", {\n enumerable: true,\n get: function () {\n return bytes_1.arrayify;\n }\n});\nObject.defineProperty(exports, \"concat\", {\n enumerable: true,\n get: function () {\n return bytes_1.concat;\n }\n});\nObject.defineProperty(exports, \"hexConcat\", {\n enumerable: true,\n get: function () {\n return bytes_1.hexConcat;\n }\n});\nObject.defineProperty(exports, \"hexDataSlice\", {\n enumerable: true,\n get: function () {\n return bytes_1.hexDataSlice;\n }\n});\nObject.defineProperty(exports, \"hexDataLength\", {\n enumerable: true,\n get: function () {\n return bytes_1.hexDataLength;\n }\n});\nObject.defineProperty(exports, \"hexlify\", {\n enumerable: true,\n get: function () {\n return bytes_1.hexlify;\n }\n});\nObject.defineProperty(exports, \"hexStripZeros\", {\n enumerable: true,\n get: function () {\n return bytes_1.hexStripZeros;\n }\n});\nObject.defineProperty(exports, \"hexValue\", {\n enumerable: true,\n get: function () {\n return bytes_1.hexValue;\n }\n});\nObject.defineProperty(exports, \"hexZeroPad\", {\n enumerable: true,\n get: function () {\n return bytes_1.hexZeroPad;\n }\n});\nObject.defineProperty(exports, \"isBytes\", {\n enumerable: true,\n get: function () {\n return bytes_1.isBytes;\n }\n});\nObject.defineProperty(exports, \"isBytesLike\", {\n enumerable: true,\n get: function () {\n return bytes_1.isBytesLike;\n }\n});\nObject.defineProperty(exports, \"isHexString\", {\n enumerable: true,\n get: function () {\n return bytes_1.isHexString;\n }\n});\nObject.defineProperty(exports, \"joinSignature\", {\n enumerable: true,\n get: function () {\n return bytes_1.joinSignature;\n }\n});\nObject.defineProperty(exports, \"zeroPad\", {\n enumerable: true,\n get: function () {\n return bytes_1.zeroPad;\n }\n});\nObject.defineProperty(exports, \"splitSignature\", {\n enumerable: true,\n get: function () {\n return bytes_1.splitSignature;\n }\n});\nObject.defineProperty(exports, \"stripZeros\", {\n enumerable: true,\n get: function () {\n return bytes_1.stripZeros;\n }\n});\nvar hash_1 = require(\"@ethersproject/hash\");\nObject.defineProperty(exports, \"_TypedDataEncoder\", {\n enumerable: true,\n get: function () {\n return hash_1._TypedDataEncoder;\n }\n});\nObject.defineProperty(exports, \"dnsEncode\", {\n enumerable: true,\n get: function () {\n return hash_1.dnsEncode;\n }\n});\nObject.defineProperty(exports, \"hashMessage\", {\n enumerable: true,\n get: function () {\n return hash_1.hashMessage;\n }\n});\nObject.defineProperty(exports, \"id\", {\n enumerable: true,\n get: function () {\n return hash_1.id;\n }\n});\nObject.defineProperty(exports, \"isValidName\", {\n enumerable: true,\n get: function () {\n return hash_1.isValidName;\n }\n});\nObject.defineProperty(exports, \"namehash\", {\n enumerable: true,\n get: function () {\n return hash_1.namehash;\n }\n});\nvar hdnode_1 = require(\"@ethersproject/hdnode\");\nObject.defineProperty(exports, \"defaultPath\", {\n enumerable: true,\n get: function () {\n return hdnode_1.defaultPath;\n }\n});\nObject.defineProperty(exports, \"entropyToMnemonic\", {\n enumerable: true,\n get: function () {\n return hdnode_1.entropyToMnemonic;\n }\n});\nObject.defineProperty(exports, \"getAccountPath\", {\n enumerable: true,\n get: function () {\n return hdnode_1.getAccountPath;\n }\n});\nObject.defineProperty(exports, \"HDNode\", {\n enumerable: true,\n get: function () {\n return hdnode_1.HDNode;\n }\n});\nObject.defineProperty(exports, \"isValidMnemonic\", {\n enumerable: true,\n get: function () {\n return hdnode_1.isValidMnemonic;\n }\n});\nObject.defineProperty(exports, \"mnemonicToEntropy\", {\n enumerable: true,\n get: function () {\n return hdnode_1.mnemonicToEntropy;\n }\n});\nObject.defineProperty(exports, \"mnemonicToSeed\", {\n enumerable: true,\n get: function () {\n return hdnode_1.mnemonicToSeed;\n }\n});\nvar json_wallets_1 = require(\"@ethersproject/json-wallets\");\nObject.defineProperty(exports, \"getJsonWalletAddress\", {\n enumerable: true,\n get: function () {\n return json_wallets_1.getJsonWalletAddress;\n }\n});\nvar keccak256_1 = require(\"@ethersproject/keccak256\");\nObject.defineProperty(exports, \"keccak256\", {\n enumerable: true,\n get: function () {\n return keccak256_1.keccak256;\n }\n});\nvar logger_1 = require(\"@ethersproject/logger\");\nObject.defineProperty(exports, \"Logger\", {\n enumerable: true,\n get: function () {\n return logger_1.Logger;\n }\n});\nvar sha2_1 = require(\"@ethersproject/sha2\");\nObject.defineProperty(exports, \"computeHmac\", {\n enumerable: true,\n get: function () {\n return sha2_1.computeHmac;\n }\n});\nObject.defineProperty(exports, \"ripemd160\", {\n enumerable: true,\n get: function () {\n return sha2_1.ripemd160;\n }\n});\nObject.defineProperty(exports, \"sha256\", {\n enumerable: true,\n get: function () {\n return sha2_1.sha256;\n }\n});\nObject.defineProperty(exports, \"sha512\", {\n enumerable: true,\n get: function () {\n return sha2_1.sha512;\n }\n});\nvar solidity_1 = require(\"@ethersproject/solidity\");\nObject.defineProperty(exports, \"solidityKeccak256\", {\n enumerable: true,\n get: function () {\n return solidity_1.keccak256;\n }\n});\nObject.defineProperty(exports, \"solidityPack\", {\n enumerable: true,\n get: function () {\n return solidity_1.pack;\n }\n});\nObject.defineProperty(exports, \"soliditySha256\", {\n enumerable: true,\n get: function () {\n return solidity_1.sha256;\n }\n});\nvar random_1 = require(\"@ethersproject/random\");\nObject.defineProperty(exports, \"randomBytes\", {\n enumerable: true,\n get: function () {\n return random_1.randomBytes;\n }\n});\nObject.defineProperty(exports, \"shuffled\", {\n enumerable: true,\n get: function () {\n return random_1.shuffled;\n }\n});\nvar properties_1 = require(\"@ethersproject/properties\");\nObject.defineProperty(exports, \"checkProperties\", {\n enumerable: true,\n get: function () {\n return properties_1.checkProperties;\n }\n});\nObject.defineProperty(exports, \"deepCopy\", {\n enumerable: true,\n get: function () {\n return properties_1.deepCopy;\n }\n});\nObject.defineProperty(exports, \"defineReadOnly\", {\n enumerable: true,\n get: function () {\n return properties_1.defineReadOnly;\n }\n});\nObject.defineProperty(exports, \"getStatic\", {\n enumerable: true,\n get: function () {\n return properties_1.getStatic;\n }\n});\nObject.defineProperty(exports, \"resolveProperties\", {\n enumerable: true,\n get: function () {\n return properties_1.resolveProperties;\n }\n});\nObject.defineProperty(exports, \"shallowCopy\", {\n enumerable: true,\n get: function () {\n return properties_1.shallowCopy;\n }\n});\nvar RLP = __importStar(require(\"@ethersproject/rlp\"));\nexports.RLP = RLP;\nvar signing_key_1 = require(\"@ethersproject/signing-key\");\nObject.defineProperty(exports, \"computePublicKey\", {\n enumerable: true,\n get: function () {\n return signing_key_1.computePublicKey;\n }\n});\nObject.defineProperty(exports, \"recoverPublicKey\", {\n enumerable: true,\n get: function () {\n return signing_key_1.recoverPublicKey;\n }\n});\nObject.defineProperty(exports, \"SigningKey\", {\n enumerable: true,\n get: function () {\n return signing_key_1.SigningKey;\n }\n});\nvar strings_1 = require(\"@ethersproject/strings\");\nObject.defineProperty(exports, \"formatBytes32String\", {\n enumerable: true,\n get: function () {\n return strings_1.formatBytes32String;\n }\n});\nObject.defineProperty(exports, \"nameprep\", {\n enumerable: true,\n get: function () {\n return strings_1.nameprep;\n }\n});\nObject.defineProperty(exports, \"parseBytes32String\", {\n enumerable: true,\n get: function () {\n return strings_1.parseBytes32String;\n }\n});\nObject.defineProperty(exports, \"_toEscapedUtf8String\", {\n enumerable: true,\n get: function () {\n return strings_1._toEscapedUtf8String;\n }\n});\nObject.defineProperty(exports, \"toUtf8Bytes\", {\n enumerable: true,\n get: function () {\n return strings_1.toUtf8Bytes;\n }\n});\nObject.defineProperty(exports, \"toUtf8CodePoints\", {\n enumerable: true,\n get: function () {\n return strings_1.toUtf8CodePoints;\n }\n});\nObject.defineProperty(exports, \"toUtf8String\", {\n enumerable: true,\n get: function () {\n return strings_1.toUtf8String;\n }\n});\nObject.defineProperty(exports, \"Utf8ErrorFuncs\", {\n enumerable: true,\n get: function () {\n return strings_1.Utf8ErrorFuncs;\n }\n});\nvar transactions_1 = require(\"@ethersproject/transactions\");\nObject.defineProperty(exports, \"accessListify\", {\n enumerable: true,\n get: function () {\n return transactions_1.accessListify;\n }\n});\nObject.defineProperty(exports, \"computeAddress\", {\n enumerable: true,\n get: function () {\n return transactions_1.computeAddress;\n }\n});\nObject.defineProperty(exports, \"parseTransaction\", {\n enumerable: true,\n get: function () {\n return transactions_1.parse;\n }\n});\nObject.defineProperty(exports, \"recoverAddress\", {\n enumerable: true,\n get: function () {\n return transactions_1.recoverAddress;\n }\n});\nObject.defineProperty(exports, \"serializeTransaction\", {\n enumerable: true,\n get: function () {\n return transactions_1.serialize;\n }\n});\nObject.defineProperty(exports, \"TransactionTypes\", {\n enumerable: true,\n get: function () {\n return transactions_1.TransactionTypes;\n }\n});\nvar units_1 = require(\"@ethersproject/units\");\nObject.defineProperty(exports, \"commify\", {\n enumerable: true,\n get: function () {\n return units_1.commify;\n }\n});\nObject.defineProperty(exports, \"formatEther\", {\n enumerable: true,\n get: function () {\n return units_1.formatEther;\n }\n});\nObject.defineProperty(exports, \"parseEther\", {\n enumerable: true,\n get: function () {\n return units_1.parseEther;\n }\n});\nObject.defineProperty(exports, \"formatUnits\", {\n enumerable: true,\n get: function () {\n return units_1.formatUnits;\n }\n});\nObject.defineProperty(exports, \"parseUnits\", {\n enumerable: true,\n get: function () {\n return units_1.parseUnits;\n }\n});\nvar wallet_1 = require(\"@ethersproject/wallet\");\nObject.defineProperty(exports, \"verifyMessage\", {\n enumerable: true,\n get: function () {\n return wallet_1.verifyMessage;\n }\n});\nObject.defineProperty(exports, \"verifyTypedData\", {\n enumerable: true,\n get: function () {\n return wallet_1.verifyTypedData;\n }\n});\nvar web_1 = require(\"@ethersproject/web\");\nObject.defineProperty(exports, \"_fetchData\", {\n enumerable: true,\n get: function () {\n return web_1._fetchData;\n }\n});\nObject.defineProperty(exports, \"fetchJson\", {\n enumerable: true,\n get: function () {\n return web_1.fetchJson;\n }\n});\nObject.defineProperty(exports, \"poll\", {\n enumerable: true,\n get: function () {\n return web_1.poll;\n }\n});\n////////////////////////\n// Enums\nvar sha2_2 = require(\"@ethersproject/sha2\");\nObject.defineProperty(exports, \"SupportedAlgorithm\", {\n enumerable: true,\n get: function () {\n return sha2_2.SupportedAlgorithm;\n }\n});\nvar strings_2 = require(\"@ethersproject/strings\");\nObject.defineProperty(exports, \"UnicodeNormalizationForm\", {\n enumerable: true,\n get: function () {\n return strings_2.UnicodeNormalizationForm;\n }\n});\nObject.defineProperty(exports, \"Utf8ErrorReason\", {\n enumerable: true,\n get: function () {\n return strings_2.Utf8ErrorReason;\n }\n});\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.appendSlashTrim = exports.wrapWeb3JsProvider = exports.validateRelayUrl = exports.averageBN = exports.adjustRelayRequestForPingResponse = exports.adjustGasCostParameterUp = exports.pickRandomElementFromArray = exports.waitForSuccess = exports.shuffle = exports.getERC165InterfaceID = exports.getRelayRequestID = exports.toNumber = exports.packRelayUrlForRegistrar = exports.splitRelayUrlForRegistrar = exports.formatTokenAmount = exports.removeNullValues = exports.signedTransactionToHash = exports.getDataAndSignature = exports.boolString = exports.getLatestEventData = exports.isSecondEventLater = exports.eventsComparator = exports.randomInRange = exports.ether = exports.sleep = exports.isSameAddress = exports.parseHexString = exports.getEcRecoverMeta = exports.calculateCalldataBytesZeroNonzero = exports.correctV = exports.getEip712Signature = exports.getDefaultMethodSuffix = exports.decodeRevertReason = exports.errorAsBoolean = exports.address2topic = exports.addresses2topics = exports.event2topic = exports.signatureRSV2Hex = exports.padTo64 = exports.removeHexPrefix = void 0;\nconst bn_js_1 = __importDefault(require(\"bn.js\"));\nconst chalk_1 = __importDefault(require(\"chalk\"));\nconst providers_1 = require(\"@ethersproject/providers\");\nconst abi_1 = require(\"@ethersproject/abi\");\nconst rlp_1 = require(\"rlp\");\nconst tx_1 = require(\"@ethereumjs/tx\");\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst Web3JSUtils_1 = require(\"./web3js/Web3JSUtils\");\nconst ethers_1 = require(\"ethers\");\nconst utils_1 = require(\"ethers/lib/utils\");\nfunction removeHexPrefix(hex) {\n if (hex == null || typeof hex.replace !== 'function') {\n throw new Error('Cannot remove hex prefix');\n }\n return hex.replace(/^0x/, '');\n}\nexports.removeHexPrefix = removeHexPrefix;\nconst zeroPad = '0000000000000000000000000000000000000000000000000000000000000000';\nfunction padTo64(hex) {\n if (hex.length < 64) {\n hex = (zeroPad + hex).slice(-64);\n }\n return hex;\n}\nexports.padTo64 = padTo64;\nfunction signatureRSV2Hex(r, s, v) {\n return '0x' + padTo64(r.toString('hex')) + padTo64(s.toString('hex')) + v.toString(16).padStart(2, '0');\n}\nexports.signatureRSV2Hex = signatureRSV2Hex;\nfunction event2topic(contract, names) {\n // for testing: don't crash on mockup..\n // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions\n if (!contract.filters) {\n return names;\n }\n return names.map(name => {\n return contract.filters[name]().topics[0];\n });\n}\nexports.event2topic = event2topic;\nfunction addresses2topics(addresses) {\n return addresses.map(address2topic);\n}\nexports.addresses2topics = addresses2topics;\nfunction address2topic(address) {\n return '0x' + '0'.repeat(24) + address.toLowerCase().slice(2);\n}\nexports.address2topic = address2topic;\n// This conversion is needed since WS provider returns error as false instead of null/undefined in (error,result)\nfunction errorAsBoolean(err) {\n return err;\n}\nexports.errorAsBoolean = errorAsBoolean;\n// extract revert reason from a revert bytes array.\nfunction decodeRevertReason(revertBytes, throwOnError = false) {\n if (revertBytes == null) {\n return null;\n }\n if (!revertBytes.startsWith('0x08c379a0')) {\n if (revertBytes.includes('without a reason string') || revertBytes.includes('FWD: insufficient gas')) {\n revertBytes = 'Check Relay Worker balance - potentially Out Of Gas' + revertBytes;\n }\n if (throwOnError) {\n throw new Error('invalid revert bytes: ' + revertBytes);\n }\n return revertBytes;\n }\n return new abi_1.AbiCoder().decode(['string'], '0x' + revertBytes.slice(10))[0];\n}\nexports.decodeRevertReason = decodeRevertReason;\nasync function getDefaultMethodSuffix(provider) {\n const nodeInfo = await provider.send('web3_clientVersion', []);\n // ganache-cli\n if (nodeInfo.toLowerCase().includes('testrpc')) return '';\n // hardhat\n if (nodeInfo.toLowerCase().includes('hardhat')) return '_v4';\n // all other networks\n return '_v4';\n}\nexports.getDefaultMethodSuffix = getDefaultMethodSuffix;\nasync function getEip712Signature(provider, typedRequestData, methodSuffix = null, jsonStringifyRequest = false) {\n const senderAddress = typedRequestData.message.from;\n let dataToSign;\n if (jsonStringifyRequest) {\n dataToSign = JSON.stringify(typedRequestData);\n } else {\n dataToSign = typedRequestData;\n }\n methodSuffix = methodSuffix !== null && methodSuffix !== void 0 ? methodSuffix : await getDefaultMethodSuffix(provider);\n const paramBlock = {\n method: `eth_signTypedData${methodSuffix}`,\n params: [senderAddress, dataToSign],\n jsonrpc: '2.0',\n id: Date.now()\n };\n return await provider.send(paramBlock.method, paramBlock.params);\n}\nexports.getEip712Signature = getEip712Signature;\nfunction correctV(result) {\n const buffer = (0, ethereumjs_util_1.toBuffer)(result);\n const last = buffer.length - 1;\n const oldV = buffer[last];\n if (oldV < 2) {\n buffer[last] += 27;\n console.warn(`signature V adjusted from ${oldV} to ${buffer[last]}`);\n }\n return (0, ethereumjs_util_1.bufferToHex)(buffer);\n}\nexports.correctV = correctV;\n/**\n * @param calldata the hex string of data to be sent to the blockchain\n * @returns { calldataZeroBytes, calldataNonzeroBytes } - number of zero and nonzero bytes in the given calldata input\n */\nfunction calculateCalldataBytesZeroNonzero(calldata) {\n const calldataBuf = Buffer.from(calldata.replace('0x', ''), 'hex');\n let calldataZeroBytes = 0;\n let calldataNonzeroBytes = 0;\n calldataBuf.forEach(ch => {\n ch === 0 ? calldataZeroBytes++ : calldataNonzeroBytes++;\n });\n return {\n calldataZeroBytes,\n calldataNonzeroBytes\n };\n}\nexports.calculateCalldataBytesZeroNonzero = calculateCalldataBytesZeroNonzero;\nfunction getEcRecoverMeta(message, signature) {\n if (typeof signature === 'string') {\n const r = parseHexString(signature.substr(2, 65));\n const s = parseHexString(signature.substr(66, 65));\n const v = parseHexString(signature.substr(130, 2));\n signature = {\n v: v,\n r: r,\n s: s\n };\n }\n const bufSigned = (0, ethereumjs_util_1.hashPersonalMessage)(Buffer.from(message));\n const recoveredPubKey = (0, ethereumjs_util_1.ecrecover)(bufSigned, signature.v[0], Buffer.from(signature.r), Buffer.from(signature.s));\n return (0, ethereumjs_util_1.bufferToHex)((0, ethereumjs_util_1.pubToAddress)(recoveredPubKey));\n}\nexports.getEcRecoverMeta = getEcRecoverMeta;\nfunction parseHexString(str) {\n const result = [];\n while (str.length >= 2) {\n result.push(parseInt(str.substring(0, 2), 16));\n str = str.substring(2, str.length);\n }\n return result;\n}\nexports.parseHexString = parseHexString;\nfunction isSameAddress(address1, address2) {\n return address1.toLowerCase() === address2.toLowerCase();\n}\nexports.isSameAddress = isSameAddress;\nasync function sleep(ms) {\n return await new Promise(resolve => setTimeout(resolve, ms));\n}\nexports.sleep = sleep;\nfunction ether(n) {\n return new bn_js_1.default((0, Web3JSUtils_1.toWei)(n, 'ether'));\n}\nexports.ether = ether;\nfunction randomInRange(min, max) {\n return Math.floor(Math.random() * (max - min) + min);\n}\nexports.randomInRange = randomInRange;\nfunction eventsComparator(a, b) {\n if (a.blockNumber === b.blockNumber) {\n return b.transactionIndex - a.transactionIndex;\n }\n return b.blockNumber - a.blockNumber;\n}\nexports.eventsComparator = eventsComparator;\nfunction isSecondEventLater(a, b) {\n return eventsComparator(a, b) > 0;\n}\nexports.isSecondEventLater = isSecondEventLater;\nfunction getLatestEventData(events) {\n if (events.length === 0) {\n return;\n }\n const eventDataSorted = events.sort(eventsComparator);\n return eventDataSorted[0];\n}\nexports.getLatestEventData = getLatestEventData;\nfunction boolString(bool) {\n return bool ? chalk_1.default.green('good'.padEnd(14)) : chalk_1.default.red('wrong'.padEnd(14));\n}\nexports.boolString = boolString;\nfunction getDataAndSignature(tx, chainId) {\n if (tx.to == null) {\n throw new Error('tx.to must be defined');\n }\n if (tx.s == null || tx.r == null || tx.v == null) {\n throw new Error('tx signature must be defined');\n }\n const input = [(0, ethereumjs_util_1.bnToUnpaddedBuffer)(tx.nonce)];\n if (!tx.supports(tx_1.Capability.EIP1559FeeMarket)) {\n input.push((0, ethereumjs_util_1.bnToUnpaddedBuffer)(tx.gasPrice));\n } else {\n input.push((0, ethereumjs_util_1.bnToUnpaddedBuffer)(tx.maxPriorityFeePerGas), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(tx.maxFeePerGas));\n }\n input.push((0, ethereumjs_util_1.bnToUnpaddedBuffer)(tx.gasLimit), tx.to.toBuffer(), (0, ethereumjs_util_1.bnToUnpaddedBuffer)(tx.value), tx.data, (0, ethereumjs_util_1.toBuffer)(chainId), (0, ethereumjs_util_1.unpadBuffer)((0, ethereumjs_util_1.toBuffer)(0)), (0, ethereumjs_util_1.unpadBuffer)((0, ethereumjs_util_1.toBuffer)(0)));\n let vInt = tx.v.toNumber();\n if (vInt > 28) {\n vInt -= chainId * 2 + 8;\n }\n const data = `0x${(0, rlp_1.encode)(input).toString('hex')}`;\n const signature = signatureRSV2Hex(tx.r, tx.s, vInt);\n return {\n data,\n signature\n };\n}\nexports.getDataAndSignature = getDataAndSignature;\nfunction signedTransactionToHash(signedTransaction, transactionOptions) {\n return (0, ethereumjs_util_1.bufferToHex)(tx_1.TransactionFactory.fromSerializedData((0, ethereumjs_util_1.toBuffer)(signedTransaction), transactionOptions).hash());\n}\nexports.signedTransactionToHash = signedTransactionToHash;\n/**\n * remove properties with null (or undefined) value\n * (does NOT handle inner arrays)\n * @param obj - object to clean\n * @param recursive - descend into inner objects\n */\nfunction removeNullValues(obj, recursive = false) {\n const c = {};\n Object.assign(c, obj);\n for (const k of Object.keys(c)) {\n if (c[k] == null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete c[k];\n } else if (recursive) {\n let val = c[k];\n if (typeof val === 'object' && !Array.isArray(val) && !bn_js_1.default.isBN(val)) {\n val = removeNullValues(val, recursive);\n }\n c[k] = val;\n }\n }\n return c;\n}\nexports.removeNullValues = removeNullValues;\nfunction formatTokenAmount(balance, decimals, tokenAddress, tokenSymbol) {\n let shiftedBalance;\n const tokenDecimals = (0, Web3JSUtils_1.toBN)(decimals.toString());\n if (tokenDecimals.eqn(18)) {\n shiftedBalance = balance;\n } else if (tokenDecimals.ltn(18)) {\n const shift = (0, Web3JSUtils_1.toBN)(18).sub(tokenDecimals);\n shiftedBalance = balance.mul((0, Web3JSUtils_1.toBN)(10).pow(shift));\n } else {\n const shift = tokenDecimals.subn(18);\n shiftedBalance = balance.div((0, Web3JSUtils_1.toBN)(10).pow(shift));\n }\n let shortTokenAddress = '';\n if (tokenAddress != null) {\n shortTokenAddress = `(${tokenAddress.substring(0, 6)}...${tokenAddress.substring(39)})`;\n }\n return `${(0, Web3JSUtils_1.fromWei)(shiftedBalance)} ${tokenSymbol} ${shortTokenAddress}`;\n}\nexports.formatTokenAmount = formatTokenAmount;\nfunction splitRelayUrlForRegistrar(url, partsCount = 3) {\n var _a, _b;\n const maxLength = 32 * partsCount;\n if (url.length > maxLength) {\n throw new Error(`The URL does not fit to the RelayRegistrar. Please shorten it to less than ${maxLength} characters. The provided URL is: ${url}`);\n }\n const parts = (_a = url.match(/.{1,32}/g)) !== null && _a !== void 0 ? _a : [];\n const result = [];\n for (let i = 0; i < partsCount; i++) {\n result.push(`0x${Buffer.from((_b = parts[i]) !== null && _b !== void 0 ? _b : '').toString('hex').padEnd(64, '0')}`);\n }\n return result;\n}\nexports.splitRelayUrlForRegistrar = splitRelayUrlForRegistrar;\nfunction packRelayUrlForRegistrar(parts) {\n return Buffer.from(parts.join('').replace(/0x/g, '').replace(/(00)+$/g, ''), 'hex').toString();\n}\nexports.packRelayUrlForRegistrar = packRelayUrlForRegistrar;\nfunction toNumber(numberish) {\n switch (typeof numberish) {\n case 'string':\n return parseFloat(numberish);\n case 'number':\n return numberish;\n case 'bigint':\n return Number(numberish);\n case 'object':\n if ((0, Web3JSUtils_1.isBigNumber)(numberish)) {\n // @ts-ignore\n return numberish.toNumber();\n }\n throw new Error(`unsupported object of type ${numberish.constructor.name}`);\n default:\n throw new Error(`unsupported type ${typeof numberish}`);\n }\n}\nexports.toNumber = toNumber;\nfunction getRelayRequestID(relayRequest, signature) {\n const types = ['address', 'uint256', 'bytes'];\n const parameters = [relayRequest.request.from, relayRequest.request.nonce, signature];\n const abiCoder = new ethers_1.ethers.utils.AbiCoder();\n const hash = (0, utils_1.keccak256)(abiCoder.encode(types, parameters));\n const rawRelayRequestId = removeHexPrefix(hash).padStart(64, '0');\n const prefixSize = 8;\n const prefixedRelayRequestId = rawRelayRequestId.replace(new RegExp(`^.{${prefixSize}}`), '0'.repeat(prefixSize));\n return `0x${prefixedRelayRequestId}`;\n}\nexports.getRelayRequestID = getRelayRequestID;\nfunction getERC165InterfaceID(abi) {\n let interfaceId = abi.filter(it => it.type === 'function' && it.name != null).map(it => {\n const iface = new abi_1.Interface([it]);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return iface.getSighash(it.name);\n }).filter(it => it !== '0x01ffc9a7') // remove the IERC165 method itself\n .map(x => parseInt(x, 16)).reduce((x, y) => x ^ y);\n interfaceId = interfaceId > 0 ? interfaceId : 0xFFFFFFFF + interfaceId + 1;\n return '0x' + interfaceId.toString(16).padStart(8, '0');\n}\nexports.getERC165InterfaceID = getERC165InterfaceID;\nfunction shuffle(array) {\n let currentIndex = array.length;\n let randomIndex;\n // While there remain elements to shuffle.\n while (currentIndex !== 0) {\n // Pick a remaining element.\n randomIndex = Math.floor(Math.random() * currentIndex);\n currentIndex--;\n // And swap it with the current element.\n [array[currentIndex], array[randomIndex]] = [array[randomIndex], array[currentIndex]];\n }\n return array;\n}\nexports.shuffle = shuffle;\n/**\n * Wait for an array of promises.\n * After the first successful result, wait for \"graceTime\" period when the rest of the promises can still resolve.\n * Select a \"winner\" at random one of those successfully resolved promises.\n * @param promises - all promises we try to resolve\n * @param errorKeys - keys used to map errors to promises\n * @param graceTime - how long to wait after first successful result, in milliseconds\n * @param random - Math.random-equivalent function (use for testing)\n * @returns - filled {@link WaitForSuccessResults} information\n */\nasync function waitForSuccess(promises, errorKeys, graceTime) {\n if (promises.length !== errorKeys.length) {\n throw new Error('Invalid errorKeys length');\n }\n for (let i = 0; i < errorKeys.length; i++) {\n const indexOfKey = errorKeys.indexOf(errorKeys[i]);\n if (indexOfKey !== i) {\n throw new Error('waitForSuccess: duplicate relay URL keys, aborting');\n }\n }\n return await new Promise(resolve => {\n const ret = {\n errors: new Map(),\n results: []\n };\n function complete() {\n resolve(ret);\n }\n for (let i = 0; i < promises.length; i++) {\n promises[i].then(result => {\n ret.results.push(result);\n if (ret.results.length === 1) {\n setTimeout(complete, graceTime);\n }\n }).catch(err => {\n ret.errors.set(errorKeys[i], err);\n }).finally(() => {\n if (ret.results.length + ret.errors.size === promises.length) {\n complete();\n }\n });\n }\n });\n}\nexports.waitForSuccess = waitForSuccess;\nfunction pickRandomElementFromArray(arrayIn, random = Math.random) {\n return arrayIn[Math.floor(random() * arrayIn.length)];\n}\nexports.pickRandomElementFromArray = pickRandomElementFromArray;\n/**\n * @return newValue - the best value to use as a gas parameter:\n * the one RelayProvider used if it is above RelayServer minimum, the minimum otherwise\n * @return deltaPercent - the difference between input and result, in percents\n */\nfunction adjustGasCostParameterUp(clientInput, pingResponseMinimum) {\n if (clientInput >= pingResponseMinimum) {\n return {\n newValue: clientInput,\n deltaPercent: 0\n };\n }\n const deltaPercent = Math.round((pingResponseMinimum - clientInput) * 100 / clientInput);\n return {\n newValue: pingResponseMinimum,\n deltaPercent\n };\n}\nexports.adjustGasCostParameterUp = adjustGasCostParameterUp;\n/**\n * The RelayServer may respond with a {@link PingResponse} with a response that will require adjusting some parameters.\n * @return - a {@link RelayRequest} with parameters that should satisfy the RelayServer,\n * or null if the required gas fees are different more than the {@link gasPriceFactorPercent}.\n */\nfunction adjustRelayRequestForPingResponse(feesIn, relayInfo) {\n const maxPriorityFeePerGas = adjustGasCostParameterUp(parseInt(feesIn.maxPriorityFeePerGas), parseInt(relayInfo.pingResponse.minMaxPriorityFeePerGas));\n const maxFeePerGas = adjustGasCostParameterUp(parseInt(feesIn.maxFeePerGas), parseInt(relayInfo.pingResponse.minMaxFeePerGas));\n const updatedGasFees = {\n maxPriorityFeePerGas: (0, Web3JSUtils_1.toHex)(maxPriorityFeePerGas.newValue),\n maxFeePerGas: (0, Web3JSUtils_1.toHex)(maxFeePerGas.newValue)\n };\n const maxDeltaPercent = Math.max(maxFeePerGas.deltaPercent, maxPriorityFeePerGas.deltaPercent);\n return {\n relayInfo,\n maxDeltaPercent,\n updatedGasFees\n };\n}\nexports.adjustRelayRequestForPingResponse = adjustRelayRequestForPingResponse;\nfunction averageBN(array) {\n const sum = array.reduce((a, v) => a.add(v));\n return sum.divn(array.length);\n}\nexports.averageBN = averageBN;\nfunction validateRelayUrl(relayUrl) {\n let url;\n try {\n url = new URL(relayUrl);\n } catch (error) {\n return false;\n }\n return url.protocol === 'http:' || url.protocol === 'https:';\n}\nexports.validateRelayUrl = validateRelayUrl;\nfunction wrapWeb3JsProvider(provider) {\n if (typeof provider === 'object' && typeof provider.getSigner !== 'function') {\n return new providers_1.Web3Provider(provider);\n }\n return provider;\n}\nexports.wrapWeb3JsProvider = wrapWeb3JsProvider;\nfunction appendSlashTrim(urlInput) {\n urlInput = urlInput.trim();\n if (urlInput[urlInput.length - 1] !== '/') {\n urlInput += '/';\n }\n return urlInput;\n}\nexports.appendSlashTrim = appendSlashTrim;\n","[{ \"inputs\": [{ \"internalType\": \"bytes4\", \"name\": \"interfaceId\", \"type\": \"bytes4\" }], \"name\": \"supportsInterface\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getGasAndDataLimits\", \"outputs\": [{ \"components\": [{ \"internalType\": \"uint256\", \"name\": \"acceptanceBudget\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"preRelayedCallGasLimit\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"postRelayedCallGasLimit\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"calldataSizeLimit\", \"type\": \"uint256\" }], \"internalType\": \"struct IPaymaster.GasAndDataLimits\", \"name\": \"limits\", \"type\": \"tuple\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getTrustedForwarder\", \"outputs\": [{ \"internalType\": \"address\", \"name\": \"trustedForwarder\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getRelayHub\", \"outputs\": [{ \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"components\": [{ \"components\": [{ \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"value\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"nonce\", \"type\": \"uint256\" }, { \"internalType\": \"bytes\", \"name\": \"data\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"validUntilTime\", \"type\": \"uint256\" }], \"internalType\": \"struct IForwarder.ForwardRequest\", \"name\": \"request\", \"type\": \"tuple\" }, { \"components\": [{ \"internalType\": \"uint256\", \"name\": \"maxFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"maxPriorityFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"transactionCalldataGasUsed\", \"type\": \"uint256\" }, { \"internalType\": \"address\", \"name\": \"relayWorker\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"paymaster\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"forwarder\", \"type\": \"address\" }, { \"internalType\": \"bytes\", \"name\": \"paymasterData\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"clientId\", \"type\": \"uint256\" }], \"internalType\": \"struct GsnTypes.RelayData\", \"name\": \"relayData\", \"type\": \"tuple\" }], \"internalType\": \"struct GsnTypes.RelayRequest\", \"name\": \"relayRequest\", \"type\": \"tuple\" }, { \"internalType\": \"bytes\", \"name\": \"signature\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"approvalData\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"maxPossibleGas\", \"type\": \"uint256\" }], \"name\": \"preRelayedCall\", \"outputs\": [{ \"internalType\": \"bytes\", \"name\": \"context\", \"type\": \"bytes\" }, { \"internalType\": \"bool\", \"name\": \"rejectOnRecipientRevert\", \"type\": \"bool\" }], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"bytes\", \"name\": \"context\", \"type\": \"bytes\" }, { \"internalType\": \"bool\", \"name\": \"success\", \"type\": \"bool\" }, { \"internalType\": \"uint256\", \"name\": \"gasUseWithoutPost\", \"type\": \"uint256\" }, { \"components\": [{ \"internalType\": \"uint256\", \"name\": \"maxFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"maxPriorityFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"transactionCalldataGasUsed\", \"type\": \"uint256\" }, { \"internalType\": \"address\", \"name\": \"relayWorker\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"paymaster\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"forwarder\", \"type\": \"address\" }, { \"internalType\": \"bytes\", \"name\": \"paymasterData\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"clientId\", \"type\": \"uint256\" }], \"internalType\": \"struct GsnTypes.RelayData\", \"name\": \"relayData\", \"type\": \"tuple\" }], \"name\": \"postRelayedCall\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"versionPaymaster\", \"outputs\": [{ \"internalType\": \"string\", \"name\": \"\", \"type\": \"string\" }], \"stateMutability\": \"view\", \"type\": \"function\" }]\n","[{ \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"balance\", \"type\": \"uint256\" }], \"name\": \"AbandonedRelayManagerBalanceEscheated\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"paymaster\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"Deposited\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"deprecationTime\", \"type\": \"uint256\" }], \"name\": \"HubDeprecated\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"components\": [{ \"internalType\": \"uint256\", \"name\": \"maxWorkerCount\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gasReserve\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"postOverhead\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gasOverhead\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"minimumUnstakeDelay\", \"type\": \"uint256\" }, { \"internalType\": \"address\", \"name\": \"devAddress\", \"type\": \"address\" }, { \"internalType\": \"uint8\", \"name\": \"devFee\", \"type\": \"uint8\" }, { \"internalType\": \"uint80\", \"name\": \"baseRelayFee\", \"type\": \"uint80\" }, { \"internalType\": \"uint16\", \"name\": \"pctRelayFee\", \"type\": \"uint16\" }], \"indexed\": false, \"internalType\": \"struct IRelayHub.RelayHubConfig\", \"name\": \"config\", \"type\": \"tuple\" }], \"name\": \"RelayHubConfigured\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"address[]\", \"name\": \"newRelayWorkers\", \"type\": \"address[]\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"workersCount\", \"type\": \"uint256\" }], \"name\": \"RelayWorkersAdded\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": false, \"internalType\": \"address\", \"name\": \"token\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"minimumStake\", \"type\": \"uint256\" }], \"name\": \"StakingTokenDataChanged\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"paymaster\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"bytes32\", \"name\": \"relayRequestID\", \"type\": \"bytes32\" }, { \"indexed\": false, \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"address\", \"name\": \"relayWorker\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"bytes4\", \"name\": \"selector\", \"type\": \"bytes4\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"innerGasUsed\", \"type\": \"uint256\" }, { \"indexed\": false, \"internalType\": \"bytes\", \"name\": \"reason\", \"type\": \"bytes\" }], \"name\": \"TransactionRejectedByPaymaster\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayWorker\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"bytes32\", \"name\": \"relayRequestID\", \"type\": \"bytes32\" }, { \"indexed\": false, \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"address\", \"name\": \"paymaster\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"bytes4\", \"name\": \"selector\", \"type\": \"bytes4\" }, { \"indexed\": false, \"internalType\": \"enum IRelayHub.RelayCallStatus\", \"name\": \"status\", \"type\": \"uint8\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"charge\", \"type\": \"uint256\" }], \"name\": \"TransactionRelayed\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": false, \"internalType\": \"enum IRelayHub.RelayCallStatus\", \"name\": \"status\", \"type\": \"uint8\" }, { \"indexed\": false, \"internalType\": \"bytes\", \"name\": \"returnValue\", \"type\": \"bytes\" }], \"name\": \"TransactionResult\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"account\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"dest\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"Withdrawn\", \"type\": \"event\" }, { \"inputs\": [{ \"internalType\": \"bytes4\", \"name\": \"interfaceId\", \"type\": \"bytes4\" }], \"name\": \"supportsInterface\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address[]\", \"name\": \"newRelayWorkers\", \"type\": \"address[]\" }], \"name\": \"addRelayWorkers\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"onRelayServerRegistered\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"target\", \"type\": \"address\" }], \"name\": \"depositFor\", \"outputs\": [], \"stateMutability\": \"payable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address payable\", \"name\": \"dest\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"withdraw\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address payable[]\", \"name\": \"dest\", \"type\": \"address[]\" }, { \"internalType\": \"uint256[]\", \"name\": \"amount\", \"type\": \"uint256[]\" }], \"name\": \"withdrawMultiple\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"string\", \"name\": \"domainSeparatorName\", \"type\": \"string\" }, { \"internalType\": \"uint256\", \"name\": \"maxAcceptanceBudget\", \"type\": \"uint256\" }, { \"components\": [{ \"components\": [{ \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"value\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"nonce\", \"type\": \"uint256\" }, { \"internalType\": \"bytes\", \"name\": \"data\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"validUntilTime\", \"type\": \"uint256\" }], \"internalType\": \"struct IForwarder.ForwardRequest\", \"name\": \"request\", \"type\": \"tuple\" }, { \"components\": [{ \"internalType\": \"uint256\", \"name\": \"maxFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"maxPriorityFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"transactionCalldataGasUsed\", \"type\": \"uint256\" }, { \"internalType\": \"address\", \"name\": \"relayWorker\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"paymaster\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"forwarder\", \"type\": \"address\" }, { \"internalType\": \"bytes\", \"name\": \"paymasterData\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"clientId\", \"type\": \"uint256\" }], \"internalType\": \"struct GsnTypes.RelayData\", \"name\": \"relayData\", \"type\": \"tuple\" }], \"internalType\": \"struct GsnTypes.RelayRequest\", \"name\": \"relayRequest\", \"type\": \"tuple\" }, { \"internalType\": \"bytes\", \"name\": \"signature\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"approvalData\", \"type\": \"bytes\" }], \"name\": \"relayCall\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"paymasterAccepted\", \"type\": \"bool\" }, { \"internalType\": \"uint256\", \"name\": \"charge\", \"type\": \"uint256\" }, { \"internalType\": \"enum IRelayHub.RelayCallStatus\", \"name\": \"status\", \"type\": \"uint8\" }, { \"internalType\": \"bytes\", \"name\": \"returnValue\", \"type\": \"bytes\" }], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayWorker\", \"type\": \"address\" }, { \"internalType\": \"address payable\", \"name\": \"beneficiary\", \"type\": \"address\" }], \"name\": \"penalize\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"components\": [{ \"internalType\": \"uint256\", \"name\": \"maxWorkerCount\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gasReserve\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"postOverhead\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gasOverhead\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"minimumUnstakeDelay\", \"type\": \"uint256\" }, { \"internalType\": \"address\", \"name\": \"devAddress\", \"type\": \"address\" }, { \"internalType\": \"uint8\", \"name\": \"devFee\", \"type\": \"uint8\" }, { \"internalType\": \"uint80\", \"name\": \"baseRelayFee\", \"type\": \"uint80\" }, { \"internalType\": \"uint16\", \"name\": \"pctRelayFee\", \"type\": \"uint16\" }], \"internalType\": \"struct IRelayHub.RelayHubConfig\", \"name\": \"_config\", \"type\": \"tuple\" }], \"name\": \"setConfiguration\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"contract IERC20[]\", \"name\": \"token\", \"type\": \"address[]\" }, { \"internalType\": \"uint256[]\", \"name\": \"minimumStake\", \"type\": \"uint256[]\" }], \"name\": \"setMinimumStakes\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"uint256\", \"name\": \"_deprecationTime\", \"type\": \"uint256\" }], \"name\": \"deprecateHub\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"escheatAbandonedRelayBalance\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"uint256\", \"name\": \"gasUsed\", \"type\": \"uint256\" }, { \"components\": [{ \"internalType\": \"uint256\", \"name\": \"maxFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"maxPriorityFeePerGas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"transactionCalldataGasUsed\", \"type\": \"uint256\" }, { \"internalType\": \"address\", \"name\": \"relayWorker\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"paymaster\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"forwarder\", \"type\": \"address\" }, { \"internalType\": \"bytes\", \"name\": \"paymasterData\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"clientId\", \"type\": \"uint256\" }], \"internalType\": \"struct GsnTypes.RelayData\", \"name\": \"relayData\", \"type\": \"tuple\" }], \"name\": \"calculateCharge\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"uint256\", \"name\": \"charge\", \"type\": \"uint256\" }], \"name\": \"calculateDevCharge\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getConfiguration\", \"outputs\": [{ \"components\": [{ \"internalType\": \"uint256\", \"name\": \"maxWorkerCount\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gasReserve\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"postOverhead\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gasOverhead\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"minimumUnstakeDelay\", \"type\": \"uint256\" }, { \"internalType\": \"address\", \"name\": \"devAddress\", \"type\": \"address\" }, { \"internalType\": \"uint8\", \"name\": \"devFee\", \"type\": \"uint8\" }, { \"internalType\": \"uint80\", \"name\": \"baseRelayFee\", \"type\": \"uint80\" }, { \"internalType\": \"uint16\", \"name\": \"pctRelayFee\", \"type\": \"uint16\" }], \"internalType\": \"struct IRelayHub.RelayHubConfig\", \"name\": \"config\", \"type\": \"tuple\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"contract IERC20\", \"name\": \"token\", \"type\": \"address\" }], \"name\": \"getMinimumStakePerToken\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"worker\", \"type\": \"address\" }], \"name\": \"getWorkerManager\", \"outputs\": [{ \"internalType\": \"address\", \"name\": \"\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"manager\", \"type\": \"address\" }], \"name\": \"getWorkerCount\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"target\", \"type\": \"address\" }], \"name\": \"balanceOf\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getStakeManager\", \"outputs\": [{ \"internalType\": \"contract IStakeManager\", \"name\": \"\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getPenalizer\", \"outputs\": [{ \"internalType\": \"address\", \"name\": \"\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getRelayRegistrar\", \"outputs\": [{ \"internalType\": \"address\", \"name\": \"\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getBatchGateway\", \"outputs\": [{ \"internalType\": \"address\", \"name\": \"\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"verifyRelayManagerStaked\", \"outputs\": [], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"isRelayEscheatable\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"isDeprecated\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getDeprecationTime\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getCreationBlock\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"versionHub\", \"outputs\": [{ \"internalType\": \"string\", \"name\": \"\", \"type\": \"string\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"aggregateGasleft\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }]\n","[{ \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"bytes32\", \"name\": \"domainSeparator\", \"type\": \"bytes32\" }, { \"indexed\": false, \"internalType\": \"bytes\", \"name\": \"domainValue\", \"type\": \"bytes\" }], \"name\": \"DomainRegistered\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"bytes32\", \"name\": \"typeHash\", \"type\": \"bytes32\" }, { \"indexed\": false, \"internalType\": \"string\", \"name\": \"typeStr\", \"type\": \"string\" }], \"name\": \"RequestTypeRegistered\", \"type\": \"event\" }, { \"inputs\": [{ \"internalType\": \"bytes4\", \"name\": \"interfaceId\", \"type\": \"bytes4\" }], \"name\": \"supportsInterface\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }], \"name\": \"getNonce\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"components\": [{ \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"value\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"nonce\", \"type\": \"uint256\" }, { \"internalType\": \"bytes\", \"name\": \"data\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"validUntilTime\", \"type\": \"uint256\" }], \"internalType\": \"struct IForwarder.ForwardRequest\", \"name\": \"forwardRequest\", \"type\": \"tuple\" }, { \"internalType\": \"bytes32\", \"name\": \"domainSeparator\", \"type\": \"bytes32\" }, { \"internalType\": \"bytes32\", \"name\": \"requestTypeHash\", \"type\": \"bytes32\" }, { \"internalType\": \"bytes\", \"name\": \"suffixData\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"signature\", \"type\": \"bytes\" }], \"name\": \"verify\", \"outputs\": [], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"components\": [{ \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"value\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"gas\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"nonce\", \"type\": \"uint256\" }, { \"internalType\": \"bytes\", \"name\": \"data\", \"type\": \"bytes\" }, { \"internalType\": \"uint256\", \"name\": \"validUntilTime\", \"type\": \"uint256\" }], \"internalType\": \"struct IForwarder.ForwardRequest\", \"name\": \"forwardRequest\", \"type\": \"tuple\" }, { \"internalType\": \"bytes32\", \"name\": \"domainSeparator\", \"type\": \"bytes32\" }, { \"internalType\": \"bytes32\", \"name\": \"requestTypeHash\", \"type\": \"bytes32\" }, { \"internalType\": \"bytes\", \"name\": \"suffixData\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"signature\", \"type\": \"bytes\" }], \"name\": \"execute\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"success\", \"type\": \"bool\" }, { \"internalType\": \"bytes\", \"name\": \"ret\", \"type\": \"bytes\" }], \"stateMutability\": \"payable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"string\", \"name\": \"typeName\", \"type\": \"string\" }, { \"internalType\": \"string\", \"name\": \"typeSuffix\", \"type\": \"string\" }], \"name\": \"registerRequestType\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"string\", \"name\": \"name\", \"type\": \"string\" }, { \"internalType\": \"string\", \"name\": \"version\", \"type\": \"string\" }], \"name\": \"registerDomainSeparator\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }]\n","[{ \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"contract IERC20\", \"name\": \"token\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"AbandonedRelayManagerStakeEscheated\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"burnAddress\", \"type\": \"address\" }], \"name\": \"BurnAddressSet\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"devAddress\", \"type\": \"address\" }], \"name\": \"DevAddressSet\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }], \"name\": \"HubAuthorized\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"removalTime\", \"type\": \"uint256\" }], \"name\": \"HubUnauthorized\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }], \"name\": \"OwnerSet\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"abandonedTime\", \"type\": \"uint256\" }], \"name\": \"RelayServerAbandoned\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"keepaliveTime\", \"type\": \"uint256\" }], \"name\": \"RelayServerKeepalive\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"contract IERC20\", \"name\": \"token\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"stake\", \"type\": \"uint256\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"unstakeDelay\", \"type\": \"uint256\" }], \"name\": \"StakeAdded\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"beneficiary\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"contract IERC20\", \"name\": \"token\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"reward\", \"type\": \"uint256\" }], \"name\": \"StakePenalized\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"withdrawTime\", \"type\": \"uint256\" }], \"name\": \"StakeUnlocked\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"contract IERC20\", \"name\": \"token\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"StakeWithdrawn\", \"type\": \"event\" }, { \"inputs\": [{ \"internalType\": \"bytes4\", \"name\": \"interfaceId\", \"type\": \"bytes4\" }], \"name\": \"supportsInterface\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }], \"name\": \"setRelayManagerOwner\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"contract IERC20\", \"name\": \"token\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"unstakeDelay\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"stakeForRelayManager\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"unlockStake\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"withdrawStake\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }], \"name\": \"authorizeHubByOwner\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }], \"name\": \"authorizeHubByManager\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }], \"name\": \"unauthorizeHubByOwner\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }], \"name\": \"unauthorizeHubByManager\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"beneficiary\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"penalizeRelayManager\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"markRelayAbandoned\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"escheatAbandonedRelayStake\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"updateRelayKeepaliveTime\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"isRelayEscheatable\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"getStakeInfo\", \"outputs\": [{ \"components\": [{ \"internalType\": \"uint256\", \"name\": \"stake\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"unstakeDelay\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"withdrawTime\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"abandonedTime\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"keepaliveTime\", \"type\": \"uint256\" }, { \"internalType\": \"contract IERC20\", \"name\": \"token\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }], \"internalType\": \"struct IStakeManager.StakeInfo\", \"name\": \"stakeInfo\", \"type\": \"tuple\" }, { \"internalType\": \"bool\", \"name\": \"isSenderAuthorizedHub\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getMaxUnstakeDelay\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"_burnAddress\", \"type\": \"address\" }], \"name\": \"setBurnAddress\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getBurnAddress\", \"outputs\": [{ \"internalType\": \"address\", \"name\": \"\", \"type\": \"address\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"_burnAddress\", \"type\": \"address\" }], \"name\": \"setDevAddress\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getAbandonedRelayServerConfig\", \"outputs\": [{ \"components\": [{ \"internalType\": \"address\", \"name\": \"devAddress\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"abandonmentDelay\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"escheatmentDelay\", \"type\": \"uint256\" }], \"internalType\": \"struct IStakeManager.AbandonedRelayServerConfig\", \"name\": \"\", \"type\": \"tuple\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getCreationBlock\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"versionSM\", \"outputs\": [{ \"internalType\": \"string\", \"name\": \"\", \"type\": \"string\" }], \"stateMutability\": \"view\", \"type\": \"function\" }]\n","[{ \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"sender\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"bytes32\", \"name\": \"commitHash\", \"type\": \"bytes32\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"readyBlockNumber\", \"type\": \"uint256\" }], \"name\": \"CommitAdded\", \"type\": \"event\" }, { \"inputs\": [{ \"internalType\": \"bytes4\", \"name\": \"interfaceId\", \"type\": \"bytes4\" }], \"name\": \"supportsInterface\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"bytes32\", \"name\": \"commitHash\", \"type\": \"bytes32\" }], \"name\": \"commit\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"bytes\", \"name\": \"unsignedTx1\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"signature1\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"unsignedTx2\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"signature2\", \"type\": \"bytes\" }, { \"internalType\": \"contract IRelayHub\", \"name\": \"hub\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"randomValue\", \"type\": \"uint256\" }], \"name\": \"penalizeRepeatedNonce\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"bytes\", \"name\": \"unsignedTx\", \"type\": \"bytes\" }, { \"internalType\": \"bytes\", \"name\": \"signature\", \"type\": \"bytes\" }, { \"internalType\": \"contract IRelayHub\", \"name\": \"hub\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"randomValue\", \"type\": \"uint256\" }], \"name\": \"penalizeIllegalTransaction\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"versionPenalizer\", \"outputs\": [{ \"internalType\": \"string\", \"name\": \"\", \"type\": \"string\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getPenalizeBlockDelay\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getPenalizeBlockExpiration\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }]\n","[{ \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"bytes32[3]\", \"name\": \"relayUrl\", \"type\": \"bytes32[3]\" }], \"name\": \"RelayServerRegistered\", \"type\": \"event\" }, { \"inputs\": [{ \"internalType\": \"bytes4\", \"name\": \"interfaceId\", \"type\": \"bytes4\" }], \"name\": \"supportsInterface\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }, { \"internalType\": \"bytes32[3]\", \"name\": \"url\", \"type\": \"bytes32[3]\" }], \"name\": \"registerRelayServer\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getCreationBlock\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"getRelayRegistrationMaxAge\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"name\": \"setRelayRegistrationMaxAge\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"name\": \"getRelayInfo\", \"outputs\": [{ \"components\": [{ \"internalType\": \"uint32\", \"name\": \"lastSeenBlockNumber\", \"type\": \"uint32\" }, { \"internalType\": \"uint40\", \"name\": \"lastSeenTimestamp\", \"type\": \"uint40\" }, { \"internalType\": \"uint32\", \"name\": \"firstSeenBlockNumber\", \"type\": \"uint32\" }, { \"internalType\": \"uint40\", \"name\": \"firstSeenTimestamp\", \"type\": \"uint40\" }, { \"internalType\": \"bytes32[3]\", \"name\": \"urlParts\", \"type\": \"bytes32[3]\" }, { \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"internalType\": \"struct IRelayRegistrar.RelayInfo\", \"name\": \"info\", \"type\": \"tuple\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }], \"name\": \"readRelayInfos\", \"outputs\": [{ \"components\": [{ \"internalType\": \"uint32\", \"name\": \"lastSeenBlockNumber\", \"type\": \"uint32\" }, { \"internalType\": \"uint40\", \"name\": \"lastSeenTimestamp\", \"type\": \"uint40\" }, { \"internalType\": \"uint32\", \"name\": \"firstSeenBlockNumber\", \"type\": \"uint32\" }, { \"internalType\": \"uint40\", \"name\": \"firstSeenTimestamp\", \"type\": \"uint40\" }, { \"internalType\": \"bytes32[3]\", \"name\": \"urlParts\", \"type\": \"bytes32[3]\" }, { \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"internalType\": \"struct IRelayRegistrar.RelayInfo[]\", \"name\": \"info\", \"type\": \"tuple[]\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"relayHub\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"oldestBlockNumber\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"oldestBlockTimestamp\", \"type\": \"uint256\" }, { \"internalType\": \"uint256\", \"name\": \"maxCount\", \"type\": \"uint256\" }], \"name\": \"readRelayInfosInRange\", \"outputs\": [{ \"components\": [{ \"internalType\": \"uint32\", \"name\": \"lastSeenBlockNumber\", \"type\": \"uint32\" }, { \"internalType\": \"uint40\", \"name\": \"lastSeenTimestamp\", \"type\": \"uint40\" }, { \"internalType\": \"uint32\", \"name\": \"firstSeenBlockNumber\", \"type\": \"uint32\" }, { \"internalType\": \"uint40\", \"name\": \"firstSeenTimestamp\", \"type\": \"uint40\" }, { \"internalType\": \"bytes32[3]\", \"name\": \"urlParts\", \"type\": \"bytes32[3]\" }, { \"internalType\": \"address\", \"name\": \"relayManager\", \"type\": \"address\" }], \"internalType\": \"struct IRelayRegistrar.RelayInfo[]\", \"name\": \"info\", \"type\": \"tuple[]\" }], \"stateMutability\": \"view\", \"type\": \"function\" }]\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RelayCallStatusCodes = exports.erc165Interfaces = exports.constants = void 0;\nconst bn_js_1 = __importDefault(require(\"bn.js\"));\nconst IPaymaster_json_1 = __importDefault(require(\"./interfaces/IPaymaster.json\"));\nconst IRelayHub_json_1 = __importDefault(require(\"./interfaces/IRelayHub.json\"));\nconst IForwarder_json_1 = __importDefault(require(\"./interfaces/IForwarder.json\"));\nconst IStakeManager_json_1 = __importDefault(require(\"./interfaces/IStakeManager.json\"));\nconst IPenalizer_json_1 = __importDefault(require(\"./interfaces/IPenalizer.json\"));\nconst IRelayRegistrar_json_1 = __importDefault(require(\"./interfaces/IRelayRegistrar.json\"));\nconst Utils_1 = require(\"./Utils\");\nconst Web3JSUtils_1 = require(\"./web3js/Web3JSUtils\");\nconst dayInSec = 24 * 60 * 60;\nconst weekInSec = dayInSec * 7;\nconst yearInSec = dayInSec * 365;\nconst oneEther = (0, Web3JSUtils_1.toBN)(1e18);\nexports.constants = {\n dayInSec,\n weekInSec,\n yearInSec,\n oneEther,\n ZERO_ADDRESS: '0x0000000000000000000000000000000000000000',\n // OpenZeppelin's ERC-20 implementation bans transfer to zero address\n BURN_ADDRESS: '0xFFfFfFffFFfffFFfFFfFFFFFffFFFffffFfFFFfF',\n // in order to avoid error on insufficient balance for gas, send dry-run call from zero address\n DRY_RUN_ADDRESS: '0x0000000000000000000000000000000000000000',\n DRY_RUN_KEY: 'DRY-RUN',\n ZERO_BYTES32: '0x0000000000000000000000000000000000000000000000000000000000000000',\n MAX_UINT256: new bn_js_1.default('2').pow(new bn_js_1.default('256')).sub(new bn_js_1.default('1')),\n MAX_UINT96: new bn_js_1.default('2').pow(new bn_js_1.default('96')).sub(new bn_js_1.default('1')),\n MAX_INT256: new bn_js_1.default('2').pow(new bn_js_1.default('255')).sub(new bn_js_1.default('1')),\n MIN_INT256: new bn_js_1.default('2').pow(new bn_js_1.default('255')).mul(new bn_js_1.default('-1')),\n ARBITRUM_ARBSYS: '0x0000000000000000000000000000000000000064'\n};\nexports.erc165Interfaces = {\n forwarder: (0, Utils_1.getERC165InterfaceID)(IForwarder_json_1.default),\n paymaster: (0, Utils_1.getERC165InterfaceID)(IPaymaster_json_1.default),\n penalizer: (0, Utils_1.getERC165InterfaceID)(IPenalizer_json_1.default),\n relayRegistrar: (0, Utils_1.getERC165InterfaceID)(IRelayRegistrar_json_1.default),\n relayHub: (0, Utils_1.getERC165InterfaceID)(IRelayHub_json_1.default),\n stakeManager: (0, Utils_1.getERC165InterfaceID)(IStakeManager_json_1.default)\n};\nexports.RelayCallStatusCodes = {\n OK: new bn_js_1.default('0'),\n RelayedCallFailed: new bn_js_1.default('1'),\n RejectedByPreRelayed: new bn_js_1.default('2'),\n RejectedByForwarder: new bn_js_1.default('3'),\n RejectedByRecipientRevert: new bn_js_1.default('4'),\n PostRelayedFailed: new bn_js_1.default('5'),\n PaymasterBalanceChanged: new bn_js_1.default('6')\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AmountRequired = void 0;\nconst Utils_1 = require(\"./Utils\");\nconst Constants_1 = require(\"./Constants\");\nconst Web3JSUtils_1 = require(\"./web3js/Web3JSUtils\");\nconst ether = {\n tokenAddress: Constants_1.constants.ZERO_ADDRESS,\n tokenName: 'Ether',\n tokenSymbol: 'ETH',\n tokenDecimals: (0, Web3JSUtils_1.toBN)(18)\n};\nclass AmountRequired {\n constructor(name, requiredValue, requiredTokenAddress, logger, listener, tokenMetadata = ether) {\n this._currentValue = (0, Web3JSUtils_1.toBN)(0);\n this._requiredValue = (0, Web3JSUtils_1.toBN)(0);\n this._currentTokenAddress = Constants_1.constants.ZERO_ADDRESS;\n this.logger = logger;\n this._name = name;\n this._tokenMetadata = tokenMetadata;\n this._requiredValue = requiredValue;\n this._listener = listener;\n }\n get currentValue() {\n return this._currentValue;\n }\n set currentValue(newValue) {\n const didChange = !this._currentValue.eq(newValue);\n const wasSatisfied = this.isSatisfied;\n this._currentValue = newValue;\n if (didChange) {\n this._onChange(wasSatisfied);\n }\n }\n get currentTokenAddress() {\n return this._currentTokenAddress;\n }\n set currentTokenAddress(newValue) {\n const didChange = !(0, Utils_1.isSameAddress)(this._currentTokenAddress, newValue);\n const wasSatisfied = this.isSatisfied;\n this._currentTokenAddress = newValue;\n if (didChange) {\n this._onChange(wasSatisfied);\n }\n }\n get requiredValue() {\n return this._requiredValue;\n }\n set requiredValue(newValue) {\n const didChange = !this._requiredValue.eq(newValue);\n const wasSatisfied = this.isSatisfied;\n this._requiredValue = newValue;\n if (didChange) {\n this._onChange(wasSatisfied);\n }\n }\n _onChange(wasSatisfied) {\n let changeString;\n if (wasSatisfied === this.isSatisfied) {\n changeString = `still${this.isSatisfied ? '' : ' not'}`;\n } else if (this.isSatisfied) {\n changeString = 'now';\n } else {\n changeString = 'no longer';\n }\n const message = `${this._name} requirement is ${changeString} satisfied\\n${this.description}`;\n this.logger.warn(message);\n if (this._listener != null) {\n this._listener();\n }\n }\n get isSatisfied() {\n const correctTokenSatisfied = (0, Utils_1.isSameAddress)(this._tokenMetadata.tokenAddress, this._currentTokenAddress);\n const valueSatisfied = this._currentValue.gte(this._requiredValue);\n return correctTokenSatisfied && valueSatisfied;\n }\n get description() {\n const status = (0, Utils_1.boolString)(this.isSatisfied);\n const actual = (0, Utils_1.formatTokenAmount)(this._currentValue, this._tokenMetadata.tokenDecimals, this._tokenMetadata.tokenAddress, this._tokenMetadata.tokenSymbol);\n const required = (0, Utils_1.formatTokenAmount)(this._requiredValue, this._tokenMetadata.tokenDecimals, this._tokenMetadata.tokenAddress, this._tokenMetadata.tokenSymbol);\n return `${this._name.padEnd(14)} | ${status.padEnd(14)} | actual: ${actual.padStart(16)} | required: ${required.padStart(16)}`;\n }\n}\nexports.AmountRequired = AmountRequired;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","[{ \"inputs\": [{ \"internalType\": \"address\", \"name\": \"forwarder\", \"type\": \"address\" }], \"name\": \"isTrustedForwarder\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"view\", \"type\": \"function\" }]\n","[{ \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"spender\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"value\", \"type\": \"uint256\" }], \"name\": \"Approval\", \"type\": \"event\" }, { \"anonymous\": false, \"inputs\": [{ \"indexed\": true, \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"indexed\": true, \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"indexed\": false, \"internalType\": \"uint256\", \"name\": \"value\", \"type\": \"uint256\" }], \"name\": \"Transfer\", \"type\": \"event\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"owner\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"spender\", \"type\": \"address\" }], \"name\": \"allowance\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"spender\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"approve\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"account\", \"type\": \"address\" }], \"name\": \"balanceOf\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"decimals\", \"outputs\": [{ \"internalType\": \"uint8\", \"name\": \"\", \"type\": \"uint8\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"name\", \"outputs\": [{ \"internalType\": \"string\", \"name\": \"\", \"type\": \"string\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"symbol\", \"outputs\": [{ \"internalType\": \"string\", \"name\": \"\", \"type\": \"string\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"totalSupply\", \"outputs\": [{ \"internalType\": \"uint256\", \"name\": \"\", \"type\": \"uint256\" }], \"stateMutability\": \"view\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"transfer\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"address\", \"name\": \"from\", \"type\": \"address\" }, { \"internalType\": \"address\", \"name\": \"to\", \"type\": \"address\" }, { \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"transferFrom\", \"outputs\": [{ \"internalType\": \"bool\", \"name\": \"\", \"type\": \"bool\" }], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }, { \"inputs\": [], \"name\": \"deposit\", \"outputs\": [], \"stateMutability\": \"payable\", \"type\": \"function\" }, { \"inputs\": [{ \"internalType\": \"uint256\", \"name\": \"amount\", \"type\": \"uint256\" }], \"name\": \"withdraw\", \"outputs\": [], \"stateMutability\": \"nonpayable\", \"type\": \"function\" }]\n","// Note: this is the semver.org version of the spec that it implements\n// Not necessarily the package version of this code.\nconst SEMVER_SPEC_VERSION = '2.0.0';\nconst MAX_LENGTH = 256;\nconst MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || /* istanbul ignore next */9007199254740991;\n\n// Max safe segment length for coercion.\nconst MAX_SAFE_COMPONENT_LENGTH = 16;\n\n// Max safe length for a build identifier. The max length minus 6 characters for\n// the shortest version with a build 0.0.0+BUILD.\nconst MAX_SAFE_BUILD_LENGTH = MAX_LENGTH - 6;\nconst RELEASE_TYPES = ['major', 'premajor', 'minor', 'preminor', 'patch', 'prepatch', 'prerelease'];\nmodule.exports = {\n MAX_LENGTH,\n MAX_SAFE_COMPONENT_LENGTH,\n MAX_SAFE_BUILD_LENGTH,\n MAX_SAFE_INTEGER,\n RELEASE_TYPES,\n SEMVER_SPEC_VERSION,\n FLAG_INCLUDE_PRERELEASE: 0b001,\n FLAG_LOOSE: 0b010\n};","const debug = typeof process === 'object' && process.env && process.env.NODE_DEBUG && /\\bsemver\\b/i.test(process.env.NODE_DEBUG) ? (...args) => console.error('SEMVER', ...args) : () => {};\nmodule.exports = debug;","const {\n MAX_SAFE_COMPONENT_LENGTH,\n MAX_SAFE_BUILD_LENGTH,\n MAX_LENGTH\n} = require('./constants');\nconst debug = require('./debug');\nexports = module.exports = {};\n\n// The actual regexps go on exports.re\nconst re = exports.re = [];\nconst safeRe = exports.safeRe = [];\nconst src = exports.src = [];\nconst t = exports.t = {};\nlet R = 0;\nconst LETTERDASHNUMBER = '[a-zA-Z0-9-]';\n\n// Replace some greedy regex tokens to prevent regex dos issues. These regex are\n// used internally via the safeRe object since all inputs in this library get\n// normalized first to trim and collapse all extra whitespace. The original\n// regexes are exported for userland consumption and lower level usage. A\n// future breaking change could export the safer regex only with a note that\n// all input should have extra whitespace removed.\nconst safeRegexReplacements = [['\\\\s', 1], ['\\\\d', MAX_LENGTH], [LETTERDASHNUMBER, MAX_SAFE_BUILD_LENGTH]];\nconst makeSafeRegex = value => {\n for (const [token, max] of safeRegexReplacements) {\n value = value.split(`${token}*`).join(`${token}{0,${max}}`).split(`${token}+`).join(`${token}{1,${max}}`);\n }\n return value;\n};\nconst createToken = (name, value, isGlobal) => {\n const safe = makeSafeRegex(value);\n const index = R++;\n debug(name, index, value);\n t[name] = index;\n src[index] = value;\n re[index] = new RegExp(value, isGlobal ? 'g' : undefined);\n safeRe[index] = new RegExp(safe, isGlobal ? 'g' : undefined);\n};\n\n// The following Regular Expressions can be used for tokenizing,\n// validating, and parsing SemVer version strings.\n\n// ## Numeric Identifier\n// A single `0`, or a non-zero digit followed by zero or more digits.\n\ncreateToken('NUMERICIDENTIFIER', '0|[1-9]\\\\d*');\ncreateToken('NUMERICIDENTIFIERLOOSE', '\\\\d+');\n\n// ## Non-numeric Identifier\n// Zero or more digits, followed by a letter or hyphen, and then zero or\n// more letters, digits, or hyphens.\n\ncreateToken('NONNUMERICIDENTIFIER', `\\\\d*[a-zA-Z-]${LETTERDASHNUMBER}*`);\n\n// ## Main Version\n// Three dot-separated numeric identifiers.\n\ncreateToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\\\.` + `(${src[t.NUMERICIDENTIFIER]})\\\\.` + `(${src[t.NUMERICIDENTIFIER]})`);\ncreateToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\\\.` + `(${src[t.NUMERICIDENTIFIERLOOSE]})\\\\.` + `(${src[t.NUMERICIDENTIFIERLOOSE]})`);\n\n// ## Pre-release Version Identifier\n// A numeric identifier, or a non-numeric identifier.\n\ncreateToken('PRERELEASEIDENTIFIER', `(?:${src[t.NUMERICIDENTIFIER]}|${src[t.NONNUMERICIDENTIFIER]})`);\ncreateToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NUMERICIDENTIFIERLOOSE]}|${src[t.NONNUMERICIDENTIFIER]})`);\n\n// ## Pre-release Version\n// Hyphen, followed by one or more dot-separated pre-release version\n// identifiers.\n\ncreateToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER]}(?:\\\\.${src[t.PRERELEASEIDENTIFIER]})*))`);\ncreateToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE]}(?:\\\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`);\n\n// ## Build Metadata Identifier\n// Any combination of digits, letters, or hyphens.\n\ncreateToken('BUILDIDENTIFIER', `${LETTERDASHNUMBER}+`);\n\n// ## Build Metadata\n// Plus sign, followed by one or more period-separated build metadata\n// identifiers.\n\ncreateToken('BUILD', `(?:\\\\+(${src[t.BUILDIDENTIFIER]}(?:\\\\.${src[t.BUILDIDENTIFIER]})*))`);\n\n// ## Full Version String\n// A main version, followed optionally by a pre-release version and\n// build metadata.\n\n// Note that the only major, minor, patch, and pre-release sections of\n// the version string are capturing groups. The build metadata is not a\n// capturing group, because it should not ever be used in version\n// comparison.\n\ncreateToken('FULLPLAIN', `v?${src[t.MAINVERSION]}${src[t.PRERELEASE]}?${src[t.BUILD]}?`);\ncreateToken('FULL', `^${src[t.FULLPLAIN]}$`);\n\n// like full, but allows v1.2.3 and =1.2.3, which people do sometimes.\n// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty\n// common in the npm registry.\ncreateToken('LOOSEPLAIN', `[v=\\\\s]*${src[t.MAINVERSIONLOOSE]}${src[t.PRERELEASELOOSE]}?${src[t.BUILD]}?`);\ncreateToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`);\ncreateToken('GTLT', '((?:<|>)?=?)');\n\n// Something like \"2.*\" or \"1.2.x\".\n// Note that \"x.x\" is a valid xRange identifer, meaning \"any version\"\n// Only the first item is strictly required.\ncreateToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\\\*`);\ncreateToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\\\*`);\ncreateToken('XRANGEPLAIN', `[v=\\\\s]*(${src[t.XRANGEIDENTIFIER]})` + `(?:\\\\.(${src[t.XRANGEIDENTIFIER]})` + `(?:\\\\.(${src[t.XRANGEIDENTIFIER]})` + `(?:${src[t.PRERELEASE]})?${src[t.BUILD]}?` + `)?)?`);\ncreateToken('XRANGEPLAINLOOSE', `[v=\\\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` + `(?:\\\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + `(?:\\\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + `(?:${src[t.PRERELEASELOOSE]})?${src[t.BUILD]}?` + `)?)?`);\ncreateToken('XRANGE', `^${src[t.GTLT]}\\\\s*${src[t.XRANGEPLAIN]}$`);\ncreateToken('XRANGELOOSE', `^${src[t.GTLT]}\\\\s*${src[t.XRANGEPLAINLOOSE]}$`);\n\n// Coercion.\n// Extract anything that could conceivably be a part of a valid semver\ncreateToken('COERCEPLAIN', `${'(^|[^\\\\d])' + '(\\\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` + `(?:\\\\.(\\\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` + `(?:\\\\.(\\\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?`);\ncreateToken('COERCE', `${src[t.COERCEPLAIN]}(?:$|[^\\\\d])`);\ncreateToken('COERCEFULL', src[t.COERCEPLAIN] + `(?:${src[t.PRERELEASE]})?` + `(?:${src[t.BUILD]})?` + `(?:$|[^\\\\d])`);\ncreateToken('COERCERTL', src[t.COERCE], true);\ncreateToken('COERCERTLFULL', src[t.COERCEFULL], true);\n\n// Tilde ranges.\n// Meaning is \"reasonably at or greater than\"\ncreateToken('LONETILDE', '(?:~>?)');\ncreateToken('TILDETRIM', `(\\\\s*)${src[t.LONETILDE]}\\\\s+`, true);\nexports.tildeTrimReplace = '$1~';\ncreateToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`);\ncreateToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`);\n\n// Caret ranges.\n// Meaning is \"at least and backwards compatible with\"\ncreateToken('LONECARET', '(?:\\\\^)');\ncreateToken('CARETTRIM', `(\\\\s*)${src[t.LONECARET]}\\\\s+`, true);\nexports.caretTrimReplace = '$1^';\ncreateToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`);\ncreateToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`);\n\n// A simple gt/lt/eq thing, or just \"\" to indicate \"any version\"\ncreateToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\\\s*(${src[t.LOOSEPLAIN]})$|^$`);\ncreateToken('COMPARATOR', `^${src[t.GTLT]}\\\\s*(${src[t.FULLPLAIN]})$|^$`);\n\n// An expression to strip any whitespace between the gtlt and the thing\n// it modifies, so that `> 1.2.3` ==> `>1.2.3`\ncreateToken('COMPARATORTRIM', `(\\\\s*)${src[t.GTLT]}\\\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true);\nexports.comparatorTrimReplace = '$1$2$3';\n\n// Something like `1.2.3 - 1.2.4`\n// Note that these all use the loose form, because they'll be\n// checked against either the strict or loose comparator form\n// later.\ncreateToken('HYPHENRANGE', `^\\\\s*(${src[t.XRANGEPLAIN]})` + `\\\\s+-\\\\s+` + `(${src[t.XRANGEPLAIN]})` + `\\\\s*$`);\ncreateToken('HYPHENRANGELOOSE', `^\\\\s*(${src[t.XRANGEPLAINLOOSE]})` + `\\\\s+-\\\\s+` + `(${src[t.XRANGEPLAINLOOSE]})` + `\\\\s*$`);\n\n// Star ranges basically just allow anything at all.\ncreateToken('STAR', '(<|>)?=?\\\\s*\\\\*');\n// >=0.0.0 is like a star\ncreateToken('GTE0', '^\\\\s*>=\\\\s*0\\\\.0\\\\.0\\\\s*$');\ncreateToken('GTE0PRE', '^\\\\s*>=\\\\s*0\\\\.0\\\\.0-0\\\\s*$');","// parse out just the options we care about\nconst looseOption = Object.freeze({\n loose: true\n});\nconst emptyOpts = Object.freeze({});\nconst parseOptions = options => {\n if (!options) {\n return emptyOpts;\n }\n if (typeof options !== 'object') {\n return looseOption;\n }\n return options;\n};\nmodule.exports = parseOptions;","const numeric = /^[0-9]+$/;\nconst compareIdentifiers = (a, b) => {\n const anum = numeric.test(a);\n const bnum = numeric.test(b);\n if (anum && bnum) {\n a = +a;\n b = +b;\n }\n return a === b ? 0 : anum && !bnum ? -1 : bnum && !anum ? 1 : a < b ? -1 : 1;\n};\nconst rcompareIdentifiers = (a, b) => compareIdentifiers(b, a);\nmodule.exports = {\n compareIdentifiers,\n rcompareIdentifiers\n};","const debug = require('../internal/debug');\nconst {\n MAX_LENGTH,\n MAX_SAFE_INTEGER\n} = require('../internal/constants');\nconst {\n safeRe: re,\n t\n} = require('../internal/re');\nconst parseOptions = require('../internal/parse-options');\nconst {\n compareIdentifiers\n} = require('../internal/identifiers');\nclass SemVer {\n constructor(version, options) {\n options = parseOptions(options);\n if (version instanceof SemVer) {\n if (version.loose === !!options.loose && version.includePrerelease === !!options.includePrerelease) {\n return version;\n } else {\n version = version.version;\n }\n } else if (typeof version !== 'string') {\n throw new TypeError(`Invalid version. Must be a string. Got type \"${typeof version}\".`);\n }\n if (version.length > MAX_LENGTH) {\n throw new TypeError(`version is longer than ${MAX_LENGTH} characters`);\n }\n debug('SemVer', version, options);\n this.options = options;\n this.loose = !!options.loose;\n // this isn't actually relevant for versions, but keep it so that we\n // don't run into trouble passing this.options around.\n this.includePrerelease = !!options.includePrerelease;\n const m = version.trim().match(options.loose ? re[t.LOOSE] : re[t.FULL]);\n if (!m) {\n throw new TypeError(`Invalid Version: ${version}`);\n }\n this.raw = version;\n\n // these are actually numbers\n this.major = +m[1];\n this.minor = +m[2];\n this.patch = +m[3];\n if (this.major > MAX_SAFE_INTEGER || this.major < 0) {\n throw new TypeError('Invalid major version');\n }\n if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) {\n throw new TypeError('Invalid minor version');\n }\n if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) {\n throw new TypeError('Invalid patch version');\n }\n\n // numberify any prerelease numeric ids\n if (!m[4]) {\n this.prerelease = [];\n } else {\n this.prerelease = m[4].split('.').map(id => {\n if (/^[0-9]+$/.test(id)) {\n const num = +id;\n if (num >= 0 && num < MAX_SAFE_INTEGER) {\n return num;\n }\n }\n return id;\n });\n }\n this.build = m[5] ? m[5].split('.') : [];\n this.format();\n }\n format() {\n this.version = `${this.major}.${this.minor}.${this.patch}`;\n if (this.prerelease.length) {\n this.version += `-${this.prerelease.join('.')}`;\n }\n return this.version;\n }\n toString() {\n return this.version;\n }\n compare(other) {\n debug('SemVer.compare', this.version, this.options, other);\n if (!(other instanceof SemVer)) {\n if (typeof other === 'string' && other === this.version) {\n return 0;\n }\n other = new SemVer(other, this.options);\n }\n if (other.version === this.version) {\n return 0;\n }\n return this.compareMain(other) || this.comparePre(other);\n }\n compareMain(other) {\n if (!(other instanceof SemVer)) {\n other = new SemVer(other, this.options);\n }\n return compareIdentifiers(this.major, other.major) || compareIdentifiers(this.minor, other.minor) || compareIdentifiers(this.patch, other.patch);\n }\n comparePre(other) {\n if (!(other instanceof SemVer)) {\n other = new SemVer(other, this.options);\n }\n\n // NOT having a prerelease is > having one\n if (this.prerelease.length && !other.prerelease.length) {\n return -1;\n } else if (!this.prerelease.length && other.prerelease.length) {\n return 1;\n } else if (!this.prerelease.length && !other.prerelease.length) {\n return 0;\n }\n let i = 0;\n do {\n const a = this.prerelease[i];\n const b = other.prerelease[i];\n debug('prerelease compare', i, a, b);\n if (a === undefined && b === undefined) {\n return 0;\n } else if (b === undefined) {\n return 1;\n } else if (a === undefined) {\n return -1;\n } else if (a === b) {\n continue;\n } else {\n return compareIdentifiers(a, b);\n }\n } while (++i);\n }\n compareBuild(other) {\n if (!(other instanceof SemVer)) {\n other = new SemVer(other, this.options);\n }\n let i = 0;\n do {\n const a = this.build[i];\n const b = other.build[i];\n debug('build compare', i, a, b);\n if (a === undefined && b === undefined) {\n return 0;\n } else if (b === undefined) {\n return 1;\n } else if (a === undefined) {\n return -1;\n } else if (a === b) {\n continue;\n } else {\n return compareIdentifiers(a, b);\n }\n } while (++i);\n }\n\n // preminor will bump the version up to the next minor release, and immediately\n // down to pre-release. premajor and prepatch work the same way.\n inc(release, identifier, identifierBase) {\n switch (release) {\n case 'premajor':\n this.prerelease.length = 0;\n this.patch = 0;\n this.minor = 0;\n this.major++;\n this.inc('pre', identifier, identifierBase);\n break;\n case 'preminor':\n this.prerelease.length = 0;\n this.patch = 0;\n this.minor++;\n this.inc('pre', identifier, identifierBase);\n break;\n case 'prepatch':\n // If this is already a prerelease, it will bump to the next version\n // drop any prereleases that might already exist, since they are not\n // relevant at this point.\n this.prerelease.length = 0;\n this.inc('patch', identifier, identifierBase);\n this.inc('pre', identifier, identifierBase);\n break;\n // If the input is a non-prerelease version, this acts the same as\n // prepatch.\n case 'prerelease':\n if (this.prerelease.length === 0) {\n this.inc('patch', identifier, identifierBase);\n }\n this.inc('pre', identifier, identifierBase);\n break;\n case 'major':\n // If this is a pre-major version, bump up to the same major version.\n // Otherwise increment major.\n // 1.0.0-5 bumps to 1.0.0\n // 1.1.0 bumps to 2.0.0\n if (this.minor !== 0 || this.patch !== 0 || this.prerelease.length === 0) {\n this.major++;\n }\n this.minor = 0;\n this.patch = 0;\n this.prerelease = [];\n break;\n case 'minor':\n // If this is a pre-minor version, bump up to the same minor version.\n // Otherwise increment minor.\n // 1.2.0-5 bumps to 1.2.0\n // 1.2.1 bumps to 1.3.0\n if (this.patch !== 0 || this.prerelease.length === 0) {\n this.minor++;\n }\n this.patch = 0;\n this.prerelease = [];\n break;\n case 'patch':\n // If this is not a pre-release version, it will increment the patch.\n // If it is a pre-release it will bump up to the same patch version.\n // 1.2.0-5 patches to 1.2.0\n // 1.2.0 patches to 1.2.1\n if (this.prerelease.length === 0) {\n this.patch++;\n }\n this.prerelease = [];\n break;\n // This probably shouldn't be used publicly.\n // 1.0.0 'pre' would become 1.0.0-0 which is the wrong direction.\n case 'pre':\n {\n const base = Number(identifierBase) ? 1 : 0;\n if (!identifier && identifierBase === false) {\n throw new Error('invalid increment argument: identifier is empty');\n }\n if (this.prerelease.length === 0) {\n this.prerelease = [base];\n } else {\n let i = this.prerelease.length;\n while (--i >= 0) {\n if (typeof this.prerelease[i] === 'number') {\n this.prerelease[i]++;\n i = -2;\n }\n }\n if (i === -1) {\n // didn't increment anything\n if (identifier === this.prerelease.join('.') && identifierBase === false) {\n throw new Error('invalid increment argument: identifier already exists');\n }\n this.prerelease.push(base);\n }\n }\n if (identifier) {\n // 1.2.0-beta.1 bumps to 1.2.0-beta.2,\n // 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0\n let prerelease = [identifier, base];\n if (identifierBase === false) {\n prerelease = [identifier];\n }\n if (compareIdentifiers(this.prerelease[0], identifier) === 0) {\n if (isNaN(this.prerelease[1])) {\n this.prerelease = prerelease;\n }\n } else {\n this.prerelease = prerelease;\n }\n }\n break;\n }\n default:\n throw new Error(`invalid increment argument: ${release}`);\n }\n this.raw = this.format();\n if (this.build.length) {\n this.raw += `+${this.build.join('.')}`;\n }\n return this;\n }\n}\nmodule.exports = SemVer;","const SemVer = require('../classes/semver');\nconst parse = (version, options, throwErrors = false) => {\n if (version instanceof SemVer) {\n return version;\n }\n try {\n return new SemVer(version, options);\n } catch (er) {\n if (!throwErrors) {\n return null;\n }\n throw er;\n }\n};\nmodule.exports = parse;","const parse = require('./parse');\nconst valid = (version, options) => {\n const v = parse(version, options);\n return v ? v.version : null;\n};\nmodule.exports = valid;","const parse = require('./parse');\nconst clean = (version, options) => {\n const s = parse(version.trim().replace(/^[=v]+/, ''), options);\n return s ? s.version : null;\n};\nmodule.exports = clean;","const SemVer = require('../classes/semver');\nconst inc = (version, release, options, identifier, identifierBase) => {\n if (typeof options === 'string') {\n identifierBase = identifier;\n identifier = options;\n options = undefined;\n }\n try {\n return new SemVer(version instanceof SemVer ? version.version : version, options).inc(release, identifier, identifierBase).version;\n } catch (er) {\n return null;\n }\n};\nmodule.exports = inc;","const parse = require('./parse.js');\nconst diff = (version1, version2) => {\n const v1 = parse(version1, null, true);\n const v2 = parse(version2, null, true);\n const comparison = v1.compare(v2);\n if (comparison === 0) {\n return null;\n }\n const v1Higher = comparison > 0;\n const highVersion = v1Higher ? v1 : v2;\n const lowVersion = v1Higher ? v2 : v1;\n const highHasPre = !!highVersion.prerelease.length;\n const lowHasPre = !!lowVersion.prerelease.length;\n if (lowHasPre && !highHasPre) {\n // Going from prerelease -> no prerelease requires some special casing\n\n // If the low version has only a major, then it will always be a major\n // Some examples:\n // 1.0.0-1 -> 1.0.0\n // 1.0.0-1 -> 1.1.1\n // 1.0.0-1 -> 2.0.0\n if (!lowVersion.patch && !lowVersion.minor) {\n return 'major';\n }\n\n // Otherwise it can be determined by checking the high version\n\n if (highVersion.patch) {\n // anything higher than a patch bump would result in the wrong version\n return 'patch';\n }\n if (highVersion.minor) {\n // anything higher than a minor bump would result in the wrong version\n return 'minor';\n }\n\n // bumping major/minor/patch all have same result\n return 'major';\n }\n\n // add the `pre` prefix if we are going to a prerelease version\n const prefix = highHasPre ? 'pre' : '';\n if (v1.major !== v2.major) {\n return prefix + 'major';\n }\n if (v1.minor !== v2.minor) {\n return prefix + 'minor';\n }\n if (v1.patch !== v2.patch) {\n return prefix + 'patch';\n }\n\n // high and low are preleases\n return 'prerelease';\n};\nmodule.exports = diff;","const SemVer = require('../classes/semver');\nconst major = (a, loose) => new SemVer(a, loose).major;\nmodule.exports = major;","const SemVer = require('../classes/semver');\nconst minor = (a, loose) => new SemVer(a, loose).minor;\nmodule.exports = minor;","const SemVer = require('../classes/semver');\nconst patch = (a, loose) => new SemVer(a, loose).patch;\nmodule.exports = patch;","const parse = require('./parse');\nconst prerelease = (version, options) => {\n const parsed = parse(version, options);\n return parsed && parsed.prerelease.length ? parsed.prerelease : null;\n};\nmodule.exports = prerelease;","const SemVer = require('../classes/semver');\nconst compare = (a, b, loose) => new SemVer(a, loose).compare(new SemVer(b, loose));\nmodule.exports = compare;","const compare = require('./compare');\nconst rcompare = (a, b, loose) => compare(b, a, loose);\nmodule.exports = rcompare;","const compare = require('./compare');\nconst compareLoose = (a, b) => compare(a, b, true);\nmodule.exports = compareLoose;","const SemVer = require('../classes/semver');\nconst compareBuild = (a, b, loose) => {\n const versionA = new SemVer(a, loose);\n const versionB = new SemVer(b, loose);\n return versionA.compare(versionB) || versionA.compareBuild(versionB);\n};\nmodule.exports = compareBuild;","const compareBuild = require('./compare-build');\nconst sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose));\nmodule.exports = sort;","const compareBuild = require('./compare-build');\nconst rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose));\nmodule.exports = rsort;","const compare = require('./compare');\nconst gt = (a, b, loose) => compare(a, b, loose) > 0;\nmodule.exports = gt;","const compare = require('./compare');\nconst lt = (a, b, loose) => compare(a, b, loose) < 0;\nmodule.exports = lt;","const compare = require('./compare');\nconst eq = (a, b, loose) => compare(a, b, loose) === 0;\nmodule.exports = eq;","const compare = require('./compare');\nconst neq = (a, b, loose) => compare(a, b, loose) !== 0;\nmodule.exports = neq;","const compare = require('./compare');\nconst gte = (a, b, loose) => compare(a, b, loose) >= 0;\nmodule.exports = gte;","const compare = require('./compare');\nconst lte = (a, b, loose) => compare(a, b, loose) <= 0;\nmodule.exports = lte;","const eq = require('./eq');\nconst neq = require('./neq');\nconst gt = require('./gt');\nconst gte = require('./gte');\nconst lt = require('./lt');\nconst lte = require('./lte');\nconst cmp = (a, op, b, loose) => {\n switch (op) {\n case '===':\n if (typeof a === 'object') {\n a = a.version;\n }\n if (typeof b === 'object') {\n b = b.version;\n }\n return a === b;\n case '!==':\n if (typeof a === 'object') {\n a = a.version;\n }\n if (typeof b === 'object') {\n b = b.version;\n }\n return a !== b;\n case '':\n case '=':\n case '==':\n return eq(a, b, loose);\n case '!=':\n return neq(a, b, loose);\n case '>':\n return gt(a, b, loose);\n case '>=':\n return gte(a, b, loose);\n case '<':\n return lt(a, b, loose);\n case '<=':\n return lte(a, b, loose);\n default:\n throw new TypeError(`Invalid operator: ${op}`);\n }\n};\nmodule.exports = cmp;","const SemVer = require('../classes/semver');\nconst parse = require('./parse');\nconst {\n safeRe: re,\n t\n} = require('../internal/re');\nconst coerce = (version, options) => {\n if (version instanceof SemVer) {\n return version;\n }\n if (typeof version === 'number') {\n version = String(version);\n }\n if (typeof version !== 'string') {\n return null;\n }\n options = options || {};\n let match = null;\n if (!options.rtl) {\n match = version.match(options.includePrerelease ? re[t.COERCEFULL] : re[t.COERCE]);\n } else {\n // Find the right-most coercible string that does not share\n // a terminus with a more left-ward coercible string.\n // Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4'\n // With includePrerelease option set, '1.2.3.4-rc' wants to coerce '2.3.4-rc', not '2.3.4'\n //\n // Walk through the string checking with a /g regexp\n // Manually set the index so as to pick up overlapping matches.\n // Stop when we get a match that ends at the string end, since no\n // coercible string can be more right-ward without the same terminus.\n const coerceRtlRegex = options.includePrerelease ? re[t.COERCERTLFULL] : re[t.COERCERTL];\n let next;\n while ((next = coerceRtlRegex.exec(version)) && (!match || match.index + match[0].length !== version.length)) {\n if (!match || next.index + next[0].length !== match.index + match[0].length) {\n match = next;\n }\n coerceRtlRegex.lastIndex = next.index + next[1].length + next[2].length;\n }\n // leave it in a clean state\n coerceRtlRegex.lastIndex = -1;\n }\n if (match === null) {\n return null;\n }\n const major = match[2];\n const minor = match[3] || '0';\n const patch = match[4] || '0';\n const prerelease = options.includePrerelease && match[5] ? `-${match[5]}` : '';\n const build = options.includePrerelease && match[6] ? `+${match[6]}` : '';\n return parse(`${major}.${minor}.${patch}${prerelease}${build}`, options);\n};\nmodule.exports = coerce;","class LRUCache {\n constructor() {\n this.max = 1000;\n this.map = new Map();\n }\n get(key) {\n const value = this.map.get(key);\n if (value === undefined) {\n return undefined;\n } else {\n // Remove the key from the map and add it to the end\n this.map.delete(key);\n this.map.set(key, value);\n return value;\n }\n }\n delete(key) {\n return this.map.delete(key);\n }\n set(key, value) {\n const deleted = this.delete(key);\n if (!deleted && value !== undefined) {\n // If cache is full, delete the least recently used item\n if (this.map.size >= this.max) {\n const firstKey = this.map.keys().next().value;\n this.delete(firstKey);\n }\n this.map.set(key, value);\n }\n return this;\n }\n}\nmodule.exports = LRUCache;","const SPACE_CHARACTERS = /\\s+/g;\n\n// hoisted class for cyclic dependency\nclass Range {\n constructor(range, options) {\n options = parseOptions(options);\n if (range instanceof Range) {\n if (range.loose === !!options.loose && range.includePrerelease === !!options.includePrerelease) {\n return range;\n } else {\n return new Range(range.raw, options);\n }\n }\n if (range instanceof Comparator) {\n // just put it in the set and return\n this.raw = range.value;\n this.set = [[range]];\n this.formatted = undefined;\n return this;\n }\n this.options = options;\n this.loose = !!options.loose;\n this.includePrerelease = !!options.includePrerelease;\n\n // First reduce all whitespace as much as possible so we do not have to rely\n // on potentially slow regexes like \\s*. This is then stored and used for\n // future error messages as well.\n this.raw = range.trim().replace(SPACE_CHARACTERS, ' ');\n\n // First, split on ||\n this.set = this.raw.split('||')\n // map the range to a 2d array of comparators\n .map(r => this.parseRange(r.trim()))\n // throw out any comparator lists that are empty\n // this generally means that it was not a valid range, which is allowed\n // in loose mode, but will still throw if the WHOLE range is invalid.\n .filter(c => c.length);\n if (!this.set.length) {\n throw new TypeError(`Invalid SemVer Range: ${this.raw}`);\n }\n\n // if we have any that are not the null set, throw out null sets.\n if (this.set.length > 1) {\n // keep the first one, in case they're all null sets\n const first = this.set[0];\n this.set = this.set.filter(c => !isNullSet(c[0]));\n if (this.set.length === 0) {\n this.set = [first];\n } else if (this.set.length > 1) {\n // if we have any that are *, then the range is just *\n for (const c of this.set) {\n if (c.length === 1 && isAny(c[0])) {\n this.set = [c];\n break;\n }\n }\n }\n }\n this.formatted = undefined;\n }\n get range() {\n if (this.formatted === undefined) {\n this.formatted = '';\n for (let i = 0; i < this.set.length; i++) {\n if (i > 0) {\n this.formatted += '||';\n }\n const comps = this.set[i];\n for (let k = 0; k < comps.length; k++) {\n if (k > 0) {\n this.formatted += ' ';\n }\n this.formatted += comps[k].toString().trim();\n }\n }\n }\n return this.formatted;\n }\n format() {\n return this.range;\n }\n toString() {\n return this.range;\n }\n parseRange(range) {\n // memoize range parsing for performance.\n // this is a very hot path, and fully deterministic.\n const memoOpts = (this.options.includePrerelease && FLAG_INCLUDE_PRERELEASE) | (this.options.loose && FLAG_LOOSE);\n const memoKey = memoOpts + ':' + range;\n const cached = cache.get(memoKey);\n if (cached) {\n return cached;\n }\n const loose = this.options.loose;\n // `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`\n const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE];\n range = range.replace(hr, hyphenReplace(this.options.includePrerelease));\n debug('hyphen replace', range);\n\n // `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5`\n range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace);\n debug('comparator trim', range);\n\n // `~ 1.2.3` => `~1.2.3`\n range = range.replace(re[t.TILDETRIM], tildeTrimReplace);\n debug('tilde trim', range);\n\n // `^ 1.2.3` => `^1.2.3`\n range = range.replace(re[t.CARETTRIM], caretTrimReplace);\n debug('caret trim', range);\n\n // At this point, the range is completely trimmed and\n // ready to be split into comparators.\n\n let rangeList = range.split(' ').map(comp => parseComparator(comp, this.options)).join(' ').split(/\\s+/)\n // >=0.0.0 is equivalent to *\n .map(comp => replaceGTE0(comp, this.options));\n if (loose) {\n // in loose mode, throw out any that are not valid comparators\n rangeList = rangeList.filter(comp => {\n debug('loose invalid filter', comp, this.options);\n return !!comp.match(re[t.COMPARATORLOOSE]);\n });\n }\n debug('range list', rangeList);\n\n // if any comparators are the null set, then replace with JUST null set\n // if more than one comparator, remove any * comparators\n // also, don't include the same comparator more than once\n const rangeMap = new Map();\n const comparators = rangeList.map(comp => new Comparator(comp, this.options));\n for (const comp of comparators) {\n if (isNullSet(comp)) {\n return [comp];\n }\n rangeMap.set(comp.value, comp);\n }\n if (rangeMap.size > 1 && rangeMap.has('')) {\n rangeMap.delete('');\n }\n const result = [...rangeMap.values()];\n cache.set(memoKey, result);\n return result;\n }\n intersects(range, options) {\n if (!(range instanceof Range)) {\n throw new TypeError('a Range is required');\n }\n return this.set.some(thisComparators => {\n return isSatisfiable(thisComparators, options) && range.set.some(rangeComparators => {\n return isSatisfiable(rangeComparators, options) && thisComparators.every(thisComparator => {\n return rangeComparators.every(rangeComparator => {\n return thisComparator.intersects(rangeComparator, options);\n });\n });\n });\n });\n }\n\n // if ANY of the sets match ALL of its comparators, then pass\n test(version) {\n if (!version) {\n return false;\n }\n if (typeof version === 'string') {\n try {\n version = new SemVer(version, this.options);\n } catch (er) {\n return false;\n }\n }\n for (let i = 0; i < this.set.length; i++) {\n if (testSet(this.set[i], version, this.options)) {\n return true;\n }\n }\n return false;\n }\n}\nmodule.exports = Range;\nconst LRU = require('../internal/lrucache');\nconst cache = new LRU();\nconst parseOptions = require('../internal/parse-options');\nconst Comparator = require('./comparator');\nconst debug = require('../internal/debug');\nconst SemVer = require('./semver');\nconst {\n safeRe: re,\n t,\n comparatorTrimReplace,\n tildeTrimReplace,\n caretTrimReplace\n} = require('../internal/re');\nconst {\n FLAG_INCLUDE_PRERELEASE,\n FLAG_LOOSE\n} = require('../internal/constants');\nconst isNullSet = c => c.value === '<0.0.0-0';\nconst isAny = c => c.value === '';\n\n// take a set of comparators and determine whether there\n// exists a version which can satisfy it\nconst isSatisfiable = (comparators, options) => {\n let result = true;\n const remainingComparators = comparators.slice();\n let testComparator = remainingComparators.pop();\n while (result && remainingComparators.length) {\n result = remainingComparators.every(otherComparator => {\n return testComparator.intersects(otherComparator, options);\n });\n testComparator = remainingComparators.pop();\n }\n return result;\n};\n\n// comprised of xranges, tildes, stars, and gtlt's at this point.\n// already replaced the hyphen ranges\n// turn into a set of JUST comparators.\nconst parseComparator = (comp, options) => {\n debug('comp', comp, options);\n comp = replaceCarets(comp, options);\n debug('caret', comp);\n comp = replaceTildes(comp, options);\n debug('tildes', comp);\n comp = replaceXRanges(comp, options);\n debug('xrange', comp);\n comp = replaceStars(comp, options);\n debug('stars', comp);\n return comp;\n};\nconst isX = id => !id || id.toLowerCase() === 'x' || id === '*';\n\n// ~, ~> --> * (any, kinda silly)\n// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0\n// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0\n// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0-0\n// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0-0\n// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0-0\n// ~0.0.1 --> >=0.0.1 <0.1.0-0\nconst replaceTildes = (comp, options) => {\n return comp.trim().split(/\\s+/).map(c => replaceTilde(c, options)).join(' ');\n};\nconst replaceTilde = (comp, options) => {\n const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE];\n return comp.replace(r, (_, M, m, p, pr) => {\n debug('tilde', comp, _, M, m, p, pr);\n let ret;\n if (isX(M)) {\n ret = '';\n } else if (isX(m)) {\n ret = `>=${M}.0.0 <${+M + 1}.0.0-0`;\n } else if (isX(p)) {\n // ~1.2 == >=1.2.0 <1.3.0-0\n ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`;\n } else if (pr) {\n debug('replaceTilde pr', pr);\n ret = `>=${M}.${m}.${p}-${pr} <${M}.${+m + 1}.0-0`;\n } else {\n // ~1.2.3 == >=1.2.3 <1.3.0-0\n ret = `>=${M}.${m}.${p} <${M}.${+m + 1}.0-0`;\n }\n debug('tilde return', ret);\n return ret;\n });\n};\n\n// ^ --> * (any, kinda silly)\n// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0-0\n// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0-0\n// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0-0\n// ^1.2.3 --> >=1.2.3 <2.0.0-0\n// ^1.2.0 --> >=1.2.0 <2.0.0-0\n// ^0.0.1 --> >=0.0.1 <0.0.2-0\n// ^0.1.0 --> >=0.1.0 <0.2.0-0\nconst replaceCarets = (comp, options) => {\n return comp.trim().split(/\\s+/).map(c => replaceCaret(c, options)).join(' ');\n};\nconst replaceCaret = (comp, options) => {\n debug('caret', comp, options);\n const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET];\n const z = options.includePrerelease ? '-0' : '';\n return comp.replace(r, (_, M, m, p, pr) => {\n debug('caret', comp, _, M, m, p, pr);\n let ret;\n if (isX(M)) {\n ret = '';\n } else if (isX(m)) {\n ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0`;\n } else if (isX(p)) {\n if (M === '0') {\n ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0`;\n } else {\n ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`;\n }\n } else if (pr) {\n debug('replaceCaret pr', pr);\n if (M === '0') {\n if (m === '0') {\n ret = `>=${M}.${m}.${p}-${pr} <${M}.${m}.${+p + 1}-0`;\n } else {\n ret = `>=${M}.${m}.${p}-${pr} <${M}.${+m + 1}.0-0`;\n }\n } else {\n ret = `>=${M}.${m}.${p}-${pr} <${+M + 1}.0.0-0`;\n }\n } else {\n debug('no pr');\n if (M === '0') {\n if (m === '0') {\n ret = `>=${M}.${m}.${p}${z} <${M}.${m}.${+p + 1}-0`;\n } else {\n ret = `>=${M}.${m}.${p}${z} <${M}.${+m + 1}.0-0`;\n }\n } else {\n ret = `>=${M}.${m}.${p} <${+M + 1}.0.0-0`;\n }\n }\n debug('caret return', ret);\n return ret;\n });\n};\nconst replaceXRanges = (comp, options) => {\n debug('replaceXRanges', comp, options);\n return comp.split(/\\s+/).map(c => replaceXRange(c, options)).join(' ');\n};\nconst replaceXRange = (comp, options) => {\n comp = comp.trim();\n const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE];\n return comp.replace(r, (ret, gtlt, M, m, p, pr) => {\n debug('xRange', comp, ret, gtlt, M, m, p, pr);\n const xM = isX(M);\n const xm = xM || isX(m);\n const xp = xm || isX(p);\n const anyX = xp;\n if (gtlt === '=' && anyX) {\n gtlt = '';\n }\n\n // if we're including prereleases in the match, then we need\n // to fix this to -0, the lowest possible prerelease value\n pr = options.includePrerelease ? '-0' : '';\n if (xM) {\n if (gtlt === '>' || gtlt === '<') {\n // nothing is allowed\n ret = '<0.0.0-0';\n } else {\n // nothing is forbidden\n ret = '*';\n }\n } else if (gtlt && anyX) {\n // we know patch is an x, because we have any x at all.\n // replace X with 0\n if (xm) {\n m = 0;\n }\n p = 0;\n if (gtlt === '>') {\n // >1 => >=2.0.0\n // >1.2 => >=1.3.0\n gtlt = '>=';\n if (xm) {\n M = +M + 1;\n m = 0;\n p = 0;\n } else {\n m = +m + 1;\n p = 0;\n }\n } else if (gtlt === '<=') {\n // <=0.7.x is actually <0.8.0, since any 0.7.x should\n // pass. Similarly, <=7.x is actually <8.0.0, etc.\n gtlt = '<';\n if (xm) {\n M = +M + 1;\n } else {\n m = +m + 1;\n }\n }\n if (gtlt === '<') {\n pr = '-0';\n }\n ret = `${gtlt + M}.${m}.${p}${pr}`;\n } else if (xm) {\n ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0`;\n } else if (xp) {\n ret = `>=${M}.${m}.0${pr} <${M}.${+m + 1}.0-0`;\n }\n debug('xRange return', ret);\n return ret;\n });\n};\n\n// Because * is AND-ed with everything else in the comparator,\n// and '' means \"any version\", just remove the *s entirely.\nconst replaceStars = (comp, options) => {\n debug('replaceStars', comp, options);\n // Looseness is ignored here. star is always as loose as it gets!\n return comp.trim().replace(re[t.STAR], '');\n};\nconst replaceGTE0 = (comp, options) => {\n debug('replaceGTE0', comp, options);\n return comp.trim().replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], '');\n};\n\n// This function is passed to string.replace(re[t.HYPHENRANGE])\n// M, m, patch, prerelease, build\n// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5\n// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do\n// 1.2 - 3.4 => >=1.2.0 <3.5.0-0\n// TODO build?\nconst hyphenReplace = incPr => ($0, from, fM, fm, fp, fpr, fb, to, tM, tm, tp, tpr) => {\n if (isX(fM)) {\n from = '';\n } else if (isX(fm)) {\n from = `>=${fM}.0.0${incPr ? '-0' : ''}`;\n } else if (isX(fp)) {\n from = `>=${fM}.${fm}.0${incPr ? '-0' : ''}`;\n } else if (fpr) {\n from = `>=${from}`;\n } else {\n from = `>=${from}${incPr ? '-0' : ''}`;\n }\n if (isX(tM)) {\n to = '';\n } else if (isX(tm)) {\n to = `<${+tM + 1}.0.0-0`;\n } else if (isX(tp)) {\n to = `<${tM}.${+tm + 1}.0-0`;\n } else if (tpr) {\n to = `<=${tM}.${tm}.${tp}-${tpr}`;\n } else if (incPr) {\n to = `<${tM}.${tm}.${+tp + 1}-0`;\n } else {\n to = `<=${to}`;\n }\n return `${from} ${to}`.trim();\n};\nconst testSet = (set, version, options) => {\n for (let i = 0; i < set.length; i++) {\n if (!set[i].test(version)) {\n return false;\n }\n }\n if (version.prerelease.length && !options.includePrerelease) {\n // Find the set of versions that are allowed to have prereleases\n // For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0\n // That should allow `1.2.3-pr.2` to pass.\n // However, `1.2.4-alpha.notready` should NOT be allowed,\n // even though it's within the range set by the comparators.\n for (let i = 0; i < set.length; i++) {\n debug(set[i].semver);\n if (set[i].semver === Comparator.ANY) {\n continue;\n }\n if (set[i].semver.prerelease.length > 0) {\n const allowed = set[i].semver;\n if (allowed.major === version.major && allowed.minor === version.minor && allowed.patch === version.patch) {\n return true;\n }\n }\n }\n\n // Version has a -pre, but it's not one of the ones we like.\n return false;\n }\n return true;\n};","const ANY = Symbol('SemVer ANY');\n// hoisted class for cyclic dependency\nclass Comparator {\n static get ANY() {\n return ANY;\n }\n constructor(comp, options) {\n options = parseOptions(options);\n if (comp instanceof Comparator) {\n if (comp.loose === !!options.loose) {\n return comp;\n } else {\n comp = comp.value;\n }\n }\n comp = comp.trim().split(/\\s+/).join(' ');\n debug('comparator', comp, options);\n this.options = options;\n this.loose = !!options.loose;\n this.parse(comp);\n if (this.semver === ANY) {\n this.value = '';\n } else {\n this.value = this.operator + this.semver.version;\n }\n debug('comp', this);\n }\n parse(comp) {\n const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR];\n const m = comp.match(r);\n if (!m) {\n throw new TypeError(`Invalid comparator: ${comp}`);\n }\n this.operator = m[1] !== undefined ? m[1] : '';\n if (this.operator === '=') {\n this.operator = '';\n }\n\n // if it literally is just '>' or '' then allow anything.\n if (!m[2]) {\n this.semver = ANY;\n } else {\n this.semver = new SemVer(m[2], this.options.loose);\n }\n }\n toString() {\n return this.value;\n }\n test(version) {\n debug('Comparator.test', version, this.options.loose);\n if (this.semver === ANY || version === ANY) {\n return true;\n }\n if (typeof version === 'string') {\n try {\n version = new SemVer(version, this.options);\n } catch (er) {\n return false;\n }\n }\n return cmp(version, this.operator, this.semver, this.options);\n }\n intersects(comp, options) {\n if (!(comp instanceof Comparator)) {\n throw new TypeError('a Comparator is required');\n }\n if (this.operator === '') {\n if (this.value === '') {\n return true;\n }\n return new Range(comp.value, options).test(this.value);\n } else if (comp.operator === '') {\n if (comp.value === '') {\n return true;\n }\n return new Range(this.value, options).test(comp.semver);\n }\n options = parseOptions(options);\n\n // Special cases where nothing can possibly be lower\n if (options.includePrerelease && (this.value === '<0.0.0-0' || comp.value === '<0.0.0-0')) {\n return false;\n }\n if (!options.includePrerelease && (this.value.startsWith('<0.0.0') || comp.value.startsWith('<0.0.0'))) {\n return false;\n }\n\n // Same direction increasing (> or >=)\n if (this.operator.startsWith('>') && comp.operator.startsWith('>')) {\n return true;\n }\n // Same direction decreasing (< or <=)\n if (this.operator.startsWith('<') && comp.operator.startsWith('<')) {\n return true;\n }\n // same SemVer and both sides are inclusive (<= or >=)\n if (this.semver.version === comp.semver.version && this.operator.includes('=') && comp.operator.includes('=')) {\n return true;\n }\n // opposite directions less than\n if (cmp(this.semver, '<', comp.semver, options) && this.operator.startsWith('>') && comp.operator.startsWith('<')) {\n return true;\n }\n // opposite directions greater than\n if (cmp(this.semver, '>', comp.semver, options) && this.operator.startsWith('<') && comp.operator.startsWith('>')) {\n return true;\n }\n return false;\n }\n}\nmodule.exports = Comparator;\nconst parseOptions = require('../internal/parse-options');\nconst {\n safeRe: re,\n t\n} = require('../internal/re');\nconst cmp = require('../functions/cmp');\nconst debug = require('../internal/debug');\nconst SemVer = require('./semver');\nconst Range = require('./range');","const Range = require('../classes/range');\nconst satisfies = (version, range, options) => {\n try {\n range = new Range(range, options);\n } catch (er) {\n return false;\n }\n return range.test(version);\n};\nmodule.exports = satisfies;","const Range = require('../classes/range');\n\n// Mostly just for testing and legacy API reasons\nconst toComparators = (range, options) => new Range(range, options).set.map(comp => comp.map(c => c.value).join(' ').trim().split(' '));\nmodule.exports = toComparators;","const SemVer = require('../classes/semver');\nconst Range = require('../classes/range');\nconst maxSatisfying = (versions, range, options) => {\n let max = null;\n let maxSV = null;\n let rangeObj = null;\n try {\n rangeObj = new Range(range, options);\n } catch (er) {\n return null;\n }\n versions.forEach(v => {\n if (rangeObj.test(v)) {\n // satisfies(v, range, options)\n if (!max || maxSV.compare(v) === -1) {\n // compare(max, v, true)\n max = v;\n maxSV = new SemVer(max, options);\n }\n }\n });\n return max;\n};\nmodule.exports = maxSatisfying;","const SemVer = require('../classes/semver');\nconst Range = require('../classes/range');\nconst minSatisfying = (versions, range, options) => {\n let min = null;\n let minSV = null;\n let rangeObj = null;\n try {\n rangeObj = new Range(range, options);\n } catch (er) {\n return null;\n }\n versions.forEach(v => {\n if (rangeObj.test(v)) {\n // satisfies(v, range, options)\n if (!min || minSV.compare(v) === 1) {\n // compare(min, v, true)\n min = v;\n minSV = new SemVer(min, options);\n }\n }\n });\n return min;\n};\nmodule.exports = minSatisfying;","const SemVer = require('../classes/semver');\nconst Range = require('../classes/range');\nconst gt = require('../functions/gt');\nconst minVersion = (range, loose) => {\n range = new Range(range, loose);\n let minver = new SemVer('0.0.0');\n if (range.test(minver)) {\n return minver;\n }\n minver = new SemVer('0.0.0-0');\n if (range.test(minver)) {\n return minver;\n }\n minver = null;\n for (let i = 0; i < range.set.length; ++i) {\n const comparators = range.set[i];\n let setMin = null;\n comparators.forEach(comparator => {\n // Clone to avoid manipulating the comparator's semver object.\n const compver = new SemVer(comparator.semver.version);\n switch (comparator.operator) {\n case '>':\n if (compver.prerelease.length === 0) {\n compver.patch++;\n } else {\n compver.prerelease.push(0);\n }\n compver.raw = compver.format();\n /* fallthrough */\n case '':\n case '>=':\n if (!setMin || gt(compver, setMin)) {\n setMin = compver;\n }\n break;\n case '<':\n case '<=':\n /* Ignore maximum versions */\n break;\n /* istanbul ignore next */\n default:\n throw new Error(`Unexpected operation: ${comparator.operator}`);\n }\n });\n if (setMin && (!minver || gt(minver, setMin))) {\n minver = setMin;\n }\n }\n if (minver && range.test(minver)) {\n return minver;\n }\n return null;\n};\nmodule.exports = minVersion;","const Range = require('../classes/range');\nconst validRange = (range, options) => {\n try {\n // Return '*' instead of '' so that truthiness works.\n // This will throw if it's invalid anyway\n return new Range(range, options).range || '*';\n } catch (er) {\n return null;\n }\n};\nmodule.exports = validRange;","const SemVer = require('../classes/semver');\nconst Comparator = require('../classes/comparator');\nconst {\n ANY\n} = Comparator;\nconst Range = require('../classes/range');\nconst satisfies = require('../functions/satisfies');\nconst gt = require('../functions/gt');\nconst lt = require('../functions/lt');\nconst lte = require('../functions/lte');\nconst gte = require('../functions/gte');\nconst outside = (version, range, hilo, options) => {\n version = new SemVer(version, options);\n range = new Range(range, options);\n let gtfn, ltefn, ltfn, comp, ecomp;\n switch (hilo) {\n case '>':\n gtfn = gt;\n ltefn = lte;\n ltfn = lt;\n comp = '>';\n ecomp = '>=';\n break;\n case '<':\n gtfn = lt;\n ltefn = gte;\n ltfn = gt;\n comp = '<';\n ecomp = '<=';\n break;\n default:\n throw new TypeError('Must provide a hilo val of \"<\" or \">\"');\n }\n\n // If it satisfies the range it is not outside\n if (satisfies(version, range, options)) {\n return false;\n }\n\n // From now on, variable terms are as if we're in \"gtr\" mode.\n // but note that everything is flipped for the \"ltr\" function.\n\n for (let i = 0; i < range.set.length; ++i) {\n const comparators = range.set[i];\n let high = null;\n let low = null;\n comparators.forEach(comparator => {\n if (comparator.semver === ANY) {\n comparator = new Comparator('>=0.0.0');\n }\n high = high || comparator;\n low = low || comparator;\n if (gtfn(comparator.semver, high.semver, options)) {\n high = comparator;\n } else if (ltfn(comparator.semver, low.semver, options)) {\n low = comparator;\n }\n });\n\n // If the edge version comparator has a operator then our version\n // isn't outside it\n if (high.operator === comp || high.operator === ecomp) {\n return false;\n }\n\n // If the lowest version comparator has an operator and our version\n // is less than it then it isn't higher than the range\n if ((!low.operator || low.operator === comp) && ltefn(version, low.semver)) {\n return false;\n } else if (low.operator === ecomp && ltfn(version, low.semver)) {\n return false;\n }\n }\n return true;\n};\nmodule.exports = outside;","// Determine if version is greater than all the versions possible in the range.\nconst outside = require('./outside');\nconst gtr = (version, range, options) => outside(version, range, '>', options);\nmodule.exports = gtr;","const outside = require('./outside');\n// Determine if version is less than all the versions possible in the range\nconst ltr = (version, range, options) => outside(version, range, '<', options);\nmodule.exports = ltr;","const Range = require('../classes/range');\nconst intersects = (r1, r2, options) => {\n r1 = new Range(r1, options);\n r2 = new Range(r2, options);\n return r1.intersects(r2, options);\n};\nmodule.exports = intersects;","// given a set of versions and a range, create a \"simplified\" range\n// that includes the same versions that the original range does\n// If the original range is shorter than the simplified one, return that.\nconst satisfies = require('../functions/satisfies.js');\nconst compare = require('../functions/compare.js');\nmodule.exports = (versions, range, options) => {\n const set = [];\n let first = null;\n let prev = null;\n const v = versions.sort((a, b) => compare(a, b, options));\n for (const version of v) {\n const included = satisfies(version, range, options);\n if (included) {\n prev = version;\n if (!first) {\n first = version;\n }\n } else {\n if (prev) {\n set.push([first, prev]);\n }\n prev = null;\n first = null;\n }\n }\n if (first) {\n set.push([first, null]);\n }\n const ranges = [];\n for (const [min, max] of set) {\n if (min === max) {\n ranges.push(min);\n } else if (!max && min === v[0]) {\n ranges.push('*');\n } else if (!max) {\n ranges.push(`>=${min}`);\n } else if (min === v[0]) {\n ranges.push(`<=${max}`);\n } else {\n ranges.push(`${min} - ${max}`);\n }\n }\n const simplified = ranges.join(' || ');\n const original = typeof range.raw === 'string' ? range.raw : String(range);\n return simplified.length < original.length ? simplified : range;\n};","const Range = require('../classes/range.js');\nconst Comparator = require('../classes/comparator.js');\nconst {\n ANY\n} = Comparator;\nconst satisfies = require('../functions/satisfies.js');\nconst compare = require('../functions/compare.js');\n\n// Complex range `r1 || r2 || ...` is a subset of `R1 || R2 || ...` iff:\n// - Every simple range `r1, r2, ...` is a null set, OR\n// - Every simple range `r1, r2, ...` which is not a null set is a subset of\n// some `R1, R2, ...`\n//\n// Simple range `c1 c2 ...` is a subset of simple range `C1 C2 ...` iff:\n// - If c is only the ANY comparator\n// - If C is only the ANY comparator, return true\n// - Else if in prerelease mode, return false\n// - else replace c with `[>=0.0.0]`\n// - If C is only the ANY comparator\n// - if in prerelease mode, return true\n// - else replace C with `[>=0.0.0]`\n// - Let EQ be the set of = comparators in c\n// - If EQ is more than one, return true (null set)\n// - Let GT be the highest > or >= comparator in c\n// - Let LT be the lowest < or <= comparator in c\n// - If GT and LT, and GT.semver > LT.semver, return true (null set)\n// - If any C is a = range, and GT or LT are set, return false\n// - If EQ\n// - If GT, and EQ does not satisfy GT, return true (null set)\n// - If LT, and EQ does not satisfy LT, return true (null set)\n// - If EQ satisfies every C, return true\n// - Else return false\n// - If GT\n// - If GT.semver is lower than any > or >= comp in C, return false\n// - If GT is >=, and GT.semver does not satisfy every C, return false\n// - If GT.semver has a prerelease, and not in prerelease mode\n// - If no C has a prerelease and the GT.semver tuple, return false\n// - If LT\n// - If LT.semver is greater than any < or <= comp in C, return false\n// - If LT is <=, and LT.semver does not satisfy every C, return false\n// - If GT.semver has a prerelease, and not in prerelease mode\n// - If no C has a prerelease and the LT.semver tuple, return false\n// - Else return true\n\nconst subset = (sub, dom, options = {}) => {\n if (sub === dom) {\n return true;\n }\n sub = new Range(sub, options);\n dom = new Range(dom, options);\n let sawNonNull = false;\n OUTER: for (const simpleSub of sub.set) {\n for (const simpleDom of dom.set) {\n const isSub = simpleSubset(simpleSub, simpleDom, options);\n sawNonNull = sawNonNull || isSub !== null;\n if (isSub) {\n continue OUTER;\n }\n }\n // the null set is a subset of everything, but null simple ranges in\n // a complex range should be ignored. so if we saw a non-null range,\n // then we know this isn't a subset, but if EVERY simple range was null,\n // then it is a subset.\n if (sawNonNull) {\n return false;\n }\n }\n return true;\n};\nconst minimumVersionWithPreRelease = [new Comparator('>=0.0.0-0')];\nconst minimumVersion = [new Comparator('>=0.0.0')];\nconst simpleSubset = (sub, dom, options) => {\n if (sub === dom) {\n return true;\n }\n if (sub.length === 1 && sub[0].semver === ANY) {\n if (dom.length === 1 && dom[0].semver === ANY) {\n return true;\n } else if (options.includePrerelease) {\n sub = minimumVersionWithPreRelease;\n } else {\n sub = minimumVersion;\n }\n }\n if (dom.length === 1 && dom[0].semver === ANY) {\n if (options.includePrerelease) {\n return true;\n } else {\n dom = minimumVersion;\n }\n }\n const eqSet = new Set();\n let gt, lt;\n for (const c of sub) {\n if (c.operator === '>' || c.operator === '>=') {\n gt = higherGT(gt, c, options);\n } else if (c.operator === '<' || c.operator === '<=') {\n lt = lowerLT(lt, c, options);\n } else {\n eqSet.add(c.semver);\n }\n }\n if (eqSet.size > 1) {\n return null;\n }\n let gtltComp;\n if (gt && lt) {\n gtltComp = compare(gt.semver, lt.semver, options);\n if (gtltComp > 0) {\n return null;\n } else if (gtltComp === 0 && (gt.operator !== '>=' || lt.operator !== '<=')) {\n return null;\n }\n }\n\n // will iterate one or zero times\n for (const eq of eqSet) {\n if (gt && !satisfies(eq, String(gt), options)) {\n return null;\n }\n if (lt && !satisfies(eq, String(lt), options)) {\n return null;\n }\n for (const c of dom) {\n if (!satisfies(eq, String(c), options)) {\n return false;\n }\n }\n return true;\n }\n let higher, lower;\n let hasDomLT, hasDomGT;\n // if the subset has a prerelease, we need a comparator in the superset\n // with the same tuple and a prerelease, or it's not a subset\n let needDomLTPre = lt && !options.includePrerelease && lt.semver.prerelease.length ? lt.semver : false;\n let needDomGTPre = gt && !options.includePrerelease && gt.semver.prerelease.length ? gt.semver : false;\n // exception: <1.2.3-0 is the same as <1.2.3\n if (needDomLTPre && needDomLTPre.prerelease.length === 1 && lt.operator === '<' && needDomLTPre.prerelease[0] === 0) {\n needDomLTPre = false;\n }\n for (const c of dom) {\n hasDomGT = hasDomGT || c.operator === '>' || c.operator === '>=';\n hasDomLT = hasDomLT || c.operator === '<' || c.operator === '<=';\n if (gt) {\n if (needDomGTPre) {\n if (c.semver.prerelease && c.semver.prerelease.length && c.semver.major === needDomGTPre.major && c.semver.minor === needDomGTPre.minor && c.semver.patch === needDomGTPre.patch) {\n needDomGTPre = false;\n }\n }\n if (c.operator === '>' || c.operator === '>=') {\n higher = higherGT(gt, c, options);\n if (higher === c && higher !== gt) {\n return false;\n }\n } else if (gt.operator === '>=' && !satisfies(gt.semver, String(c), options)) {\n return false;\n }\n }\n if (lt) {\n if (needDomLTPre) {\n if (c.semver.prerelease && c.semver.prerelease.length && c.semver.major === needDomLTPre.major && c.semver.minor === needDomLTPre.minor && c.semver.patch === needDomLTPre.patch) {\n needDomLTPre = false;\n }\n }\n if (c.operator === '<' || c.operator === '<=') {\n lower = lowerLT(lt, c, options);\n if (lower === c && lower !== lt) {\n return false;\n }\n } else if (lt.operator === '<=' && !satisfies(lt.semver, String(c), options)) {\n return false;\n }\n }\n if (!c.operator && (lt || gt) && gtltComp !== 0) {\n return false;\n }\n }\n\n // if there was a < or >, and nothing in the dom, then must be false\n // UNLESS it was limited by another range in the other direction.\n // Eg, >1.0.0 <1.0.1 is still a subset of <2.0.0\n if (gt && hasDomLT && !lt && gtltComp !== 0) {\n return false;\n }\n if (lt && hasDomGT && !gt && gtltComp !== 0) {\n return false;\n }\n\n // we needed a prerelease range in a specific tuple, but didn't get one\n // then this isn't a subset. eg >=1.2.3-pre is not a subset of >=1.0.0,\n // because it includes prereleases in the 1.2.3 tuple\n if (needDomGTPre || needDomLTPre) {\n return false;\n }\n return true;\n};\n\n// >=1.2.3 is lower than >1.2.3\nconst higherGT = (a, b, options) => {\n if (!a) {\n return b;\n }\n const comp = compare(a.semver, b.semver, options);\n return comp > 0 ? a : comp < 0 ? b : b.operator === '>' && a.operator === '>=' ? b : a;\n};\n\n// <=1.2.3 is higher than <1.2.3\nconst lowerLT = (a, b, options) => {\n if (!a) {\n return b;\n }\n const comp = compare(a.semver, b.semver, options);\n return comp < 0 ? a : comp > 0 ? b : b.operator === '<' && a.operator === '<=' ? b : a;\n};\nmodule.exports = subset;","// just pre-load all the stuff that index.js lazily exports\nconst internalRe = require('./internal/re');\nconst constants = require('./internal/constants');\nconst SemVer = require('./classes/semver');\nconst identifiers = require('./internal/identifiers');\nconst parse = require('./functions/parse');\nconst valid = require('./functions/valid');\nconst clean = require('./functions/clean');\nconst inc = require('./functions/inc');\nconst diff = require('./functions/diff');\nconst major = require('./functions/major');\nconst minor = require('./functions/minor');\nconst patch = require('./functions/patch');\nconst prerelease = require('./functions/prerelease');\nconst compare = require('./functions/compare');\nconst rcompare = require('./functions/rcompare');\nconst compareLoose = require('./functions/compare-loose');\nconst compareBuild = require('./functions/compare-build');\nconst sort = require('./functions/sort');\nconst rsort = require('./functions/rsort');\nconst gt = require('./functions/gt');\nconst lt = require('./functions/lt');\nconst eq = require('./functions/eq');\nconst neq = require('./functions/neq');\nconst gte = require('./functions/gte');\nconst lte = require('./functions/lte');\nconst cmp = require('./functions/cmp');\nconst coerce = require('./functions/coerce');\nconst Comparator = require('./classes/comparator');\nconst Range = require('./classes/range');\nconst satisfies = require('./functions/satisfies');\nconst toComparators = require('./ranges/to-comparators');\nconst maxSatisfying = require('./ranges/max-satisfying');\nconst minSatisfying = require('./ranges/min-satisfying');\nconst minVersion = require('./ranges/min-version');\nconst validRange = require('./ranges/valid');\nconst outside = require('./ranges/outside');\nconst gtr = require('./ranges/gtr');\nconst ltr = require('./ranges/ltr');\nconst intersects = require('./ranges/intersects');\nconst simplifyRange = require('./ranges/simplify');\nconst subset = require('./ranges/subset');\nmodule.exports = {\n parse,\n valid,\n clean,\n inc,\n diff,\n major,\n minor,\n patch,\n prerelease,\n compare,\n rcompare,\n compareLoose,\n compareBuild,\n sort,\n rsort,\n gt,\n lt,\n eq,\n neq,\n gte,\n lte,\n cmp,\n coerce,\n Comparator,\n Range,\n satisfies,\n toComparators,\n maxSatisfying,\n minSatisfying,\n minVersion,\n validRange,\n outside,\n gtr,\n ltr,\n intersects,\n simplifyRange,\n subset,\n SemVer,\n re: internalRe.re,\n src: internalRe.src,\n tokens: internalRe.t,\n SEMVER_SPEC_VERSION: constants.SEMVER_SPEC_VERSION,\n RELEASE_TYPES: constants.RELEASE_TYPES,\n compareIdentifiers: identifiers.compareIdentifiers,\n rcompareIdentifiers: identifiers.rcompareIdentifiers\n};","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.VersionsManager = void 0;\nconst semver_1 = __importDefault(require(\"semver\"));\nclass VersionsManager {\n /**\n * @param componentVersion - a semver of a component that uses the VersionsManager\n * @param requiredVersionRange - a semver that has to be satisfied by the\n */\n constructor(componentVersion, requiredVersionRange) {\n if (semver_1.default.valid(componentVersion) == null) {\n throw new Error('Component version is not valid');\n }\n if (requiredVersionRange == null) {\n const ver = new semver_1.default.SemVer(componentVersion);\n ver.patch = 0;\n requiredVersionRange = '^' + ver.format();\n }\n this.requiredVersionRange = requiredVersionRange;\n }\n /**\n * @param version - the version of a dependency to compare against\n * @return true if {@param version} satisfies the {@link requiredVersionRange}\n */\n isRequiredVersionSatisfied(version) {\n // prevent crash with some early paymasters (which are otherwise perfectly valid)\n version = version.replace('_', '-');\n return semver_1.default.satisfies(version, this.requiredVersionRange, {\n includePrerelease: true\n });\n }\n}\nexports.VersionsManager = VersionsManager;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.replaceErrors = void 0;\nfunction replaceErrors(key, value) {\n if (value instanceof Map) {\n return {\n dataType: 'Map',\n value: Array.from(value.entries())\n };\n } else if (value instanceof Error) {\n const error = {};\n // remove \"circular referenced\" objects we don't really want to log...\n Object.getOwnPropertyNames(value).filter(e => !['request', 'response'].includes(e)).forEach(function (key) {\n error[key] =\n // @ts-ignore\n value[key];\n });\n return error;\n }\n return value;\n}\nexports.replaceErrors = replaceErrors;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.TruffleContract = exports.Contract = void 0;\nconst ethers_1 = require(\"ethers\");\nconst Web3JSUtils_1 = require(\"./web3js/Web3JSUtils\");\nfunction getComponent(key, components) {\n // @ts-ignore\n const component = components[key];\n if (component != null) {\n return component;\n }\n return components.find(it => it.name === key);\n}\nfunction retypeItem(abiOutput, ret) {\n if (abiOutput.type == null) {\n return ret;\n }\n if (abiOutput.type.includes('int')) {\n return (0, Web3JSUtils_1.toBN)(ret.toString());\n } else if (abiOutput.type === 'tuple[]') {\n return ret.map(item => retypeItem(Object.assign(Object.assign({}, abiOutput), {\n type: 'tuple'\n }), item));\n } else if (abiOutput.type.includes('tuple') && abiOutput.components != null) {\n const keys = Object.keys(ret);\n const newRet = {};\n for (let i = 0; i < keys.length; i++) {\n const component = getComponent(keys[i], abiOutput.components);\n if (component == null) {\n newRet[keys[i]] = ret[keys[i]];\n continue;\n }\n newRet[keys[i]] = retypeItem(component, ret[keys[i]]);\n }\n return newRet;\n } else {\n return ret;\n }\n}\n// restore TF type: uint are returned as string in web3, and as BN in TF.\nfunction retype(outputs, ret) {\n if ((outputs === null || outputs === void 0 ? void 0 : outputs.length) === 1) {\n return retypeItem(outputs[0], ret);\n } else {\n const response = {};\n outputs === null || outputs === void 0 ? void 0 : outputs.forEach((value, index) => {\n response[index] = retypeItem(value, ret[index]);\n });\n return response;\n }\n}\nclass Contract {\n constructor(contractName, abi) {\n this.contractName = contractName;\n this.abi = abi;\n }\n createContract(address, signer) {\n const ethersContract = new ethers_1.Contract(address, this.abi);\n return ethersContract.connect(signer !== null && signer !== void 0 ? signer : this.provider);\n }\n // return a contract instance at the given address.\n // UNLIKE TF, we don't do any on-chain check if the contract exist.\n // the application is assumed to call some view function (e.g. version) that implicitly verifies a contract\n // is deployed at that address (and has that view function)\n async at(address) {\n // TODO: this is done to force cache the 'from' address to avoid Ethers making a call to 'eth_accounts' every time\n const signerFromAddress = await this.signer.getAddress();\n const addressAwareSigner = this.provider.getSigner(signerFromAddress);\n const contract = this.createContract(address, addressAwareSigner);\n const obj = {\n address,\n contract,\n async getPastEvents(name, options) {\n // @ts-ignore\n return contract.getPastEvents(name, options).map(e => Object.assign(Object.assign({}, e), {\n args: e.returnValues // TODO: web3 uses strings, Truffle uses BN for numbers\n }));\n }\n };\n this.abi.forEach(m => {\n var _a, _b, _c;\n const methodName = (_a = m.name) !== null && _a !== void 0 ? _a : '';\n const nArgs = (_c = (_b = m.inputs) === null || _b === void 0 ? void 0 : _b.length) !== null && _c !== void 0 ? _c : 0;\n const isViewFunction = m.stateMutability === 'view' || m.stateMutability === 'pure';\n obj[methodName] = async function () {\n let args = Array.from(arguments);\n let options = {};\n if (args.length === nArgs + 1 && typeof args[args.length - 1] === 'object') {\n options = args[args.length - 1];\n args = args.slice(0, args.length - 1);\n }\n // TODO: this substitution seems redundant - try removing it!\n let methodCall;\n if (!isViewFunction) {\n methodCall = contract.functions[methodName];\n return methodCall(...args, options);\n } else {\n methodCall = contract.callStatic[methodName];\n return methodCall(...args, options).then(res => {\n return retype(m.outputs, res);\n });\n }\n // console.log('===calling', methodName, args)\n // return await methodCall.call(options)\n // .catch((e: Error) => {\n // console.log('===ex1', e)\n // throw e\n // })\n };\n });\n return obj;\n }\n setProvider(provider, _) {\n this.provider = provider;\n this.signer = provider.getSigner();\n }\n}\nexports.Contract = Contract;\nfunction TruffleContract({\n contractName,\n abi\n}) {\n return new Contract(contractName, abi);\n}\nexports.TruffleContract = TruffleContract;\n","{\n \"name\": \"@opengsn/common\",\n \"version\": \"3.0.0-beta.6\",\n \"license\": \"Apache-2.0\",\n \"main\": \"dist/index.js\",\n \"scripts\": {\n \"tsc\": \"tsc\",\n \"watch-tsc\": \"tsc -w --preserveWatchOutput\",\n \"lint\": \"eslint -f unix .\",\n \"lint-fix\": \"yarn lint --fix\",\n \"rm-dist\": \"rm -rf tsconfig.tsbuildinfo dist\"\n },\n \"files\": [\n \"dist/*\",\n \"README.md\"\n ],\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"dependencies\": {\n \"@ethereumjs/common\": \"^2.6.5\",\n \"@ethereumjs/tx\": \"^3.2.0\",\n \"@ethersproject/abi\": \"^5.7.0\",\n \"@ethersproject/bignumber\": \"^5.7.0\",\n \"@ethersproject/networks\": \"^5.7.1\",\n \"@ethersproject/providers\": \"^5.7.2\",\n \"@metamask/eth-sig-util\": \"^4.0.1\",\n \"@opengsn/contracts\": \"^3.0.0-beta.6\",\n \"@types/bn.js\": \"^5.1.0\",\n \"@types/semver\": \"^7.3.4\",\n \"axios\": \"^0.21.1\",\n \"bn.js\": \"^5.2.0\",\n \"chalk\": \"^4.1.2\",\n \"ethereumjs-util\": \"^7.1.0\",\n \"ethers\": \"^5.7.2\",\n \"ethjs-unit\": \"^0.1.6\",\n \"number-to-bn\": \"^1.7.0\",\n \"ow\": \"^0.28.1\",\n \"rlp\": \"^2.2.6\",\n \"semver\": \"^7.3.2\"\n },\n \"gitHead\": \"e02767b4741a0ef1ec105548c4ce6c0c92c23b2b\"\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.gsnRequiredVersion = exports.gsnRuntimeVersion = void 0;\nexports.gsnRuntimeVersion = require('../package.json').version;\nexports.gsnRequiredVersion = '^3.0.0-beta.3';\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.allStakeManagerEvents = exports.OwnerSet = exports.StakeWithdrawn = exports.StakeUnlocked = exports.StakePenalized = exports.StakeAdded = exports.HubUnauthorized = exports.HubAuthorized = exports.isInfoFromEvent = exports.ActiveManagerEvents = exports.Deposited = exports.TransactionRelayed = exports.TransactionRejectedByPaymaster = exports.RelayWorkersAdded = exports.RelayServerRegistered = exports.CommitAdded = void 0;\n/** IPenalizer.sol */\nexports.CommitAdded = 'CommitAdded';\n/** IRelayHub.sol */\nexports.RelayServerRegistered = 'RelayServerRegistered';\nexports.RelayWorkersAdded = 'RelayWorkersAdded';\nexports.TransactionRejectedByPaymaster = 'TransactionRejectedByPaymaster';\nexports.TransactionRelayed = 'TransactionRelayed';\nexports.Deposited = 'Deposited';\n/**\n * Emitting any of these events is handled by GSN clients as a sign of activity by a RelayServer.\n */\nexports.ActiveManagerEvents = [exports.RelayWorkersAdded, exports.TransactionRelayed, exports.TransactionRejectedByPaymaster];\nfunction isInfoFromEvent(info) {\n return 'relayManager' in info;\n}\nexports.isInfoFromEvent = isInfoFromEvent;\n/** IStakeManager.sol */\nexports.HubAuthorized = 'HubAuthorized';\nexports.HubUnauthorized = 'HubUnauthorized';\nexports.StakeAdded = 'StakeAdded';\nexports.StakePenalized = 'StakePenalized';\nexports.StakeUnlocked = 'StakeUnlocked';\nexports.StakeWithdrawn = 'StakeWithdrawn';\nexports.OwnerSet = 'OwnerSet';\nexports.allStakeManagerEvents = [exports.StakeAdded, exports.HubAuthorized, exports.HubUnauthorized, exports.StakeUnlocked, exports.StakeWithdrawn, exports.StakePenalized];\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.TransactionType = void 0;\nvar TransactionType;\n(function (TransactionType) {\n TransactionType[TransactionType[\"LEGACY\"] = 0] = \"LEGACY\";\n TransactionType[TransactionType[\"TYPE_TWO\"] = 2] = \"TYPE_TWO\";\n})(TransactionType = exports.TransactionType || (exports.TransactionType = {}));\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.MainnetCalldataGasEstimation = void 0;\nconst Utils_1 = require(\"../Utils\");\n/**\n * On the Ethereum Mainnet, the transaction cost is currently determined by the EIP-2028.\n * In case different coefficients are used later or in different chains, the values are read from the Environment.\n * @param calldata\n * @param environment\n * @constructor\n */\nconst MainnetCalldataGasEstimation = async (calldata, environment) => {\n const {\n calldataZeroBytes,\n calldataNonzeroBytes\n } = (0, Utils_1.calculateCalldataBytesZeroNonzero)(calldata);\n return environment.mintxgascost + calldataZeroBytes * environment.gtxdatazero + calldataNonzeroBytes * environment.gtxdatanonzero;\n};\nexports.MainnetCalldataGasEstimation = MainnetCalldataGasEstimation;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AsyncZeroAddressCalldataGasEstimation = void 0;\nconst Constants_1 = require(\"../Constants\");\n/**\n * In most L2s, the cost of the transaction is dynamic and depends on L1 gas price.\n * This function tries to extract calldata cost by requesting an estimate but setting target to zero address.\n * As our result must be above the Relay Server's estimate, it makes sense to add some slack to the estimate.\n * @param calldata\n * @param environment\n * @param calldataEstimationSlackFactor\n * @param provider\n * @constructor\n */\nconst AsyncZeroAddressCalldataGasEstimation = async (calldata, environment, calldataEstimationSlackFactor, provider) => {\n const estimateGasCallToZero = await provider.estimateGas({\n to: Constants_1.constants.ZERO_ADDRESS,\n data: calldata\n });\n return parseInt(estimateGasCallToZero.toString()) * calldataEstimationSlackFactor;\n};\nexports.AsyncZeroAddressCalldataGasEstimation = AsyncZeroAddressCalldataGasEstimation;\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getRawTxOptions = exports.ContractInteractor = exports.asRelayCallAbi = void 0;\nconst bn_js_1 = __importDefault(require(\"bn.js\"));\nconst ethers_1 = require(\"ethers\");\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst IPaymaster_json_1 = __importDefault(require(\"./interfaces/IPaymaster.json\"));\nconst IRelayHub_json_1 = __importDefault(require(\"./interfaces/IRelayHub.json\"));\nconst IForwarder_json_1 = __importDefault(require(\"./interfaces/IForwarder.json\"));\nconst IStakeManager_json_1 = __importDefault(require(\"./interfaces/IStakeManager.json\"));\nconst IPenalizer_json_1 = __importDefault(require(\"./interfaces/IPenalizer.json\"));\nconst IERC2771Recipient_json_1 = __importDefault(require(\"./interfaces/IERC2771Recipient.json\"));\nconst IRelayRegistrar_json_1 = __importDefault(require(\"./interfaces/IRelayRegistrar.json\"));\nconst IERC20Token_json_1 = __importDefault(require(\"./interfaces/IERC20Token.json\"));\nconst VersionsManager_1 = require(\"./VersionsManager\");\nconst ErrorReplacerJSON_1 = require(\"./ErrorReplacerJSON\");\nconst Utils_1 = require(\"./Utils\");\nconst LightTruffleContract_1 = require(\"./LightTruffleContract\");\nconst Version_1 = require(\"./Version\");\nconst common_1 = __importDefault(require(\"@ethereumjs/common\"));\nconst GSNContractsDataTypes_1 = require(\"./types/GSNContractsDataTypes\");\nconst Utils_js_1 = require(\"./Utils.js\");\nconst TransactionType_1 = require(\"./types/TransactionType\");\nconst Constants_1 = require(\"./Constants\");\nconst MainnetCalldataGasEstimation_1 = require(\"./environments/MainnetCalldataGasEstimation\");\nconst AsyncZeroAddressCalldataGasEstimation_1 = require(\"./environments/AsyncZeroAddressCalldataGasEstimation\");\nconst Web3JSUtils_1 = require(\"./web3js/Web3JSUtils\");\nconst abi_1 = require(\"@ethersproject/abi\");\nfunction asRelayCallAbi(r) {\n return {\n domainSeparatorName: r.metadata.domainSeparatorName,\n relayRequest: r.relayRequest,\n signature: r.metadata.signature,\n approvalData: r.metadata.approvalData,\n maxAcceptanceBudget: r.metadata.maxAcceptanceBudget\n };\n}\nexports.asRelayCallAbi = asRelayCallAbi;\nclass ContractInteractor {\n constructor({\n maxPageSize,\n maxPageCount,\n provider,\n versionManager,\n logger,\n environment,\n calldataEstimationSlackFactor,\n domainSeparatorName,\n deployment = {}\n }) {\n this.transactionType = TransactionType_1.TransactionType.LEGACY;\n this.maxPageSize = maxPageSize;\n this.maxPageCount = maxPageCount !== null && maxPageCount !== void 0 ? maxPageCount : Number.MAX_SAFE_INTEGER;\n this.logger = logger;\n this.versionManager = versionManager !== null && versionManager !== void 0 ? versionManager : new VersionsManager_1.VersionsManager(Version_1.gsnRuntimeVersion, Version_1.gsnRequiredVersion);\n this.deployment = deployment;\n this.provider = provider;\n this.calldataEstimationSlackFactor = calldataEstimationSlackFactor !== null && calldataEstimationSlackFactor !== void 0 ? calldataEstimationSlackFactor : 1;\n this.lastBlockNumber = 0;\n this.environment = environment;\n this.calculateCalldataGasUsed = this.environment.useEstimateGasForCalldataCost ? AsyncZeroAddressCalldataGasEstimation_1.AsyncZeroAddressCalldataGasEstimation : MainnetCalldataGasEstimation_1.MainnetCalldataGasEstimation;\n this.domainSeparatorName = domainSeparatorName !== null && domainSeparatorName !== void 0 ? domainSeparatorName : '';\n this.IPaymasterContract = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IPaymaster',\n abi: IPaymaster_json_1.default\n });\n this.IRelayHubContract = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IRelayHub',\n abi: IRelayHub_json_1.default\n });\n this.IForwarderContract = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IForwarder',\n abi: IForwarder_json_1.default\n });\n this.IStakeManager = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IStakeManager',\n abi: IStakeManager_json_1.default\n });\n this.IPenalizer = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IPenalizer',\n abi: IPenalizer_json_1.default\n });\n this.IERC2771Recipient = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IERC2771Recipient',\n abi: IERC2771Recipient_json_1.default\n });\n this.IRelayRegistrar = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IRelayRegistrar',\n abi: IRelayRegistrar_json_1.default\n });\n this.IERC20Token = (0, LightTruffleContract_1.TruffleContract)({\n contractName: 'IERC20Token',\n abi: IERC20Token_json_1.default\n });\n this.IStakeManager.setProvider(this.provider, undefined);\n this.IRelayHubContract.setProvider(this.provider, undefined);\n this.IPaymasterContract.setProvider(this.provider, undefined);\n this.IForwarderContract.setProvider(this.provider, undefined);\n this.IPenalizer.setProvider(this.provider, undefined);\n this.IERC2771Recipient.setProvider(this.provider, undefined);\n this.IRelayRegistrar.setProvider(this.provider, undefined);\n this.IERC20Token.setProvider(this.provider, undefined);\n }\n async init() {\n const initStartTimestamp = Date.now();\n this.logger.debug('interactor init start');\n if (this.rawTxOptions != null) {\n throw new Error('init was already called');\n }\n const block = await this.provider.getBlock('latest').catch(e => {\n throw new Error(`getBlock('latest') failed: ${e.message}\\nCheck your internet/ethereum node connection`);\n });\n if ((block === null || block === void 0 ? void 0 : block.baseFeePerGas) != null) {\n this.logger.info('Network supports Type 2 Transactions (EIP-1559). Checking RPC node \\'eth_feeHistory\\' method');\n try {\n await this.getFeeHistory('0x1', 'latest', [0.5]);\n this.transactionType = TransactionType_1.TransactionType.TYPE_TWO;\n this.logger.debug('RPC node supports \\'eth_feeHistory\\'. Initializing to Type 2 Transactions.');\n } catch (e) {\n this.logger.warn('Call to \\'eth_feeHistory\\' failed. Falling back to Legacy Transaction Type.');\n this.transactionType = TransactionType_1.TransactionType.LEGACY;\n }\n }\n await this._resolveDeployment();\n await this._initializeContracts();\n await this._validateCompatibility();\n await this._initializeNetworkParams();\n if (this.relayHubInstance != null) {\n this.relayHubConfiguration = await this.relayHubInstance.getConfiguration();\n }\n this.logger.debug(`client init finished in ${Date.now() - initStartTimestamp} ms`);\n return this;\n }\n async _initializeNetworkParams() {\n this.network = await this.provider.getNetwork();\n this.chainId = parseInt(this.network.chainId.toString());\n this.networkId = await this.provider.send('net_version', []);\n if (this.networkId == null) {\n throw new Error('Failed to query \"net_version\" from the RPC endpoint');\n }\n this.rawTxOptions = getRawTxOptions(this.chainId, this.networkId, 'private');\n }\n async _resolveDeployment() {\n if (this.deployment.paymasterAddress != null && this.deployment.relayHubAddress != null) {\n this.logger.warn('Already resolved!');\n return;\n }\n if (this.deployment.paymasterAddress != null) {\n await this._resolveDeploymentFromPaymaster(this.deployment.paymasterAddress);\n } else if (this.deployment.relayHubAddress != null) {\n if (!(await this.isContractDeployed(this.deployment.relayHubAddress))) {\n throw new Error(`RelayHub: no contract at address ${this.deployment.relayHubAddress}`);\n }\n // TODO: this branch shouldn't exist as it's only used by the Server and can lead to broken Client configuration\n await this._resolveDeploymentFromRelayHub(this.deployment.relayHubAddress);\n } else {\n this.logger.info(`Contract interactor cannot resolve a full deployment from the following input: ${JSON.stringify(this.deployment)}`);\n }\n }\n async _resolveDeploymentFromPaymaster(paymasterAddress) {\n this.paymasterInstance = await this._createPaymaster(paymasterAddress);\n const [relayHubAddress, forwarderAddress, paymasterVersion] = await Promise.all([this.paymasterInstance.getRelayHub().catch(e => {\n throw new Error(`Not a paymaster contract: ${e.message}`);\n }), this.paymasterInstance.getTrustedForwarder().catch(e => {\n throw new Error(`paymaster has no trustedForwarder(): ${e.message}`);\n }), this.paymasterInstance.versionPaymaster().catch(e => {\n throw new Error(`Not a paymaster contract: ${e.message}`);\n }).then(version => {\n this._validateVersion(version, 'Paymaster');\n return version;\n })]);\n this.deployment.relayHubAddress = relayHubAddress;\n this.deployment.forwarderAddress = forwarderAddress;\n this.paymasterVersion = paymasterVersion;\n await this._resolveDeploymentFromRelayHub(relayHubAddress);\n }\n async _resolveDeploymentFromRelayHub(relayHubAddress) {\n this.relayHubInstance = await this._createRelayHub(relayHubAddress);\n const [stakeManagerAddress, penalizerAddress, relayRegistrarAddress] = await Promise.all([this._hubStakeManagerAddress(), this._hubPenalizerAddress(), this._hubRelayRegistrarAddress()]);\n this.deployment.relayHubAddress = relayHubAddress;\n this.deployment.stakeManagerAddress = stakeManagerAddress;\n this.deployment.penalizerAddress = penalizerAddress;\n this.deployment.relayRegistrarAddress = relayRegistrarAddress;\n }\n async _validateCompatibility() {\n if (this.deployment == null || this.relayHubInstance == null) {\n return;\n }\n const hub = this.relayHubInstance;\n const version = await hub.versionHub();\n this._validateVersion(version, 'RelayHub');\n }\n _validateVersion(version, contractName) {\n const versionSatisfied = this.versionManager.isRequiredVersionSatisfied(version);\n if (!versionSatisfied) {\n throw new Error(`Provided ${contractName} version(${version}) does not satisfy the requirement(${this.versionManager.requiredVersionRange})`);\n }\n }\n async _validateERC165InterfacesRelay() {\n this.logger.debug(`ERC-165 interface IDs: ${JSON.stringify(Constants_1.erc165Interfaces)}`);\n const pnPromise = this._trySupportsInterface('Penalizer', this.penalizerInstance, Constants_1.erc165Interfaces.penalizer);\n const rrPromise = this._trySupportsInterface('RelayRegistrar', this.relayRegistrar, Constants_1.erc165Interfaces.relayRegistrar);\n const rhPromise = this._trySupportsInterface('RelayHub', this.relayHubInstance, Constants_1.erc165Interfaces.relayHub);\n const smPromise = this._trySupportsInterface('StakeManager', this.stakeManagerInstance, Constants_1.erc165Interfaces.stakeManager);\n const [pn, rr, rh, sm] = await Promise.all([pnPromise, rrPromise, rhPromise, smPromise]);\n const all = pn && rr && rh && sm;\n if (!all) {\n throw new Error(`ERC-165 interface check failed. PN: ${pn} RR: ${rr} RH: ${rh} SM: ${sm}`);\n }\n }\n async _validateERC165InterfacesClient(allowNoPaymaster = false) {\n this.logger.debug(`ERC-165 interface IDs: ${JSON.stringify(Constants_1.erc165Interfaces)}`);\n const fwPromise = this._trySupportsInterface('Forwarder', this.forwarderInstance, Constants_1.erc165Interfaces.forwarder);\n let pmPromise;\n if (allowNoPaymaster && (0, Utils_1.isSameAddress)(this.paymasterInstance.address, Constants_1.constants.ZERO_ADDRESS)) {\n this.logger.debug('skipping ERC-165 check for paymaster: address is not set');\n pmPromise = Promise.resolve(true);\n } else {\n pmPromise = this._trySupportsInterface('Paymaster', this.paymasterInstance, Constants_1.erc165Interfaces.paymaster);\n }\n const [fw, pm] = await Promise.all([fwPromise, pmPromise]);\n const all = fw && pm;\n if (!all) {\n throw new Error(`ERC-165 interface check failed. FW: ${fw} PM: ${pm}`);\n }\n }\n async _trySupportsInterface(contractName, contractInstance, interfaceId) {\n if (contractInstance == null) {\n throw new Error(`ERC-165 interface check failed. ${contractName} instance is not initialized`);\n }\n try {\n return await contractInstance.supportsInterface(interfaceId);\n } catch (e) {\n const isContractDeployed = await this.isContractDeployed(contractInstance.address);\n throw new Error(`Failed call to ${contractName} supportsInterface at address: ${contractInstance.address} (isContractDeployed: ${isContractDeployed}) with error: ${e.message}`);\n }\n }\n async _initializeContracts() {\n // TODO: do we need all this \"differential\" deployment ?\n // any sense NOT to initialize some components, or NOT to read them all from the PM and then RH ?\n if (this.relayHubInstance == null && this.deployment.relayHubAddress != null) {\n this.relayHubInstance = await this._createRelayHub(this.deployment.relayHubAddress);\n }\n if (this.relayRegistrar == null && this.deployment.relayRegistrarAddress != null) {\n this.relayRegistrar = await this._createRelayRegistrar(this.deployment.relayRegistrarAddress);\n }\n if (this.paymasterInstance == null && this.deployment.paymasterAddress != null) {\n this.paymasterInstance = await this._createPaymaster(this.deployment.paymasterAddress);\n }\n if (this.deployment.forwarderAddress != null) {\n this.forwarderInstance = await this._createForwarder(this.deployment.forwarderAddress);\n }\n if (this.deployment.stakeManagerAddress != null) {\n this.stakeManagerInstance = await this._createStakeManager(this.deployment.stakeManagerAddress);\n }\n if (this.deployment.penalizerAddress != null) {\n this.penalizerInstance = await this._createPenalizer(this.deployment.penalizerAddress);\n }\n if (this.deployment.managerStakeTokenAddress != null) {\n this.erc20Token = await this._createERC20(this.deployment.managerStakeTokenAddress);\n }\n }\n // must use these options when creating Transaction object\n getRawTxOptions() {\n if (this.rawTxOptions == null) {\n throw new Error('_init not called');\n }\n return this.rawTxOptions;\n }\n async _createRecipient(address) {\n if (this.erc2771RecipientInstance != null && this.erc2771RecipientInstance.address.toLowerCase() === address.toLowerCase()) {\n return this.erc2771RecipientInstance;\n }\n this.erc2771RecipientInstance = await this.IERC2771Recipient.at(address);\n return this.erc2771RecipientInstance;\n }\n async _createPaymaster(address) {\n return await this.IPaymasterContract.at(address);\n }\n async _createRelayHub(address) {\n return await this.IRelayHubContract.at(address);\n }\n async _createForwarder(address) {\n return await this.IForwarderContract.at(address);\n }\n async _createStakeManager(address) {\n return await this.IStakeManager.at(address);\n }\n async _createPenalizer(address) {\n return await this.IPenalizer.at(address);\n }\n async _createRelayRegistrar(address) {\n return await this.IRelayRegistrar.at(address);\n }\n async _createERC20(address) {\n return await this.IERC20Token.at(address);\n }\n /**\n * Queries the balance of the token and displays it in a human-readable format, taking 'decimals' into account.\n * Note: does not round up the fraction and truncates it.\n */\n async getTokenBalanceFormatted(address) {\n const balance = await this.erc20Token.balanceOf(address);\n return await this.formatTokenAmount(balance);\n }\n async formatTokenAmount(balance) {\n const {\n tokenSymbol,\n tokenDecimals,\n tokenAddress\n } = await this.getErc20TokenMetadata();\n return (0, Utils_1.formatTokenAmount)(balance, tokenDecimals, tokenAddress, tokenSymbol);\n }\n async getErc20TokenMetadata() {\n let tokenName;\n try {\n tokenName = await this.erc20Token.name();\n } catch (_) {\n tokenName = `ERC-20 token ${this.erc20Token.address}`;\n }\n let tokenSymbol;\n try {\n tokenSymbol = await this.erc20Token.symbol();\n } catch (_) {\n tokenSymbol = `ERC-20 token ${this.erc20Token.address}`;\n }\n let tokenDecimals;\n try {\n tokenDecimals = await this.erc20Token.decimals();\n } catch (_) {\n tokenDecimals = (0, Web3JSUtils_1.toBN)(0);\n }\n const tokenAddress = this.erc20Token.address;\n return {\n tokenName,\n tokenSymbol,\n tokenAddress,\n tokenDecimals\n };\n }\n async isTrustedForwarder(recipientAddress, forwarder) {\n const recipient = await this._createRecipient(recipientAddress);\n return await recipient.isTrustedForwarder(forwarder);\n }\n async getSenderNonce(sender, forwarderAddress) {\n const forwarder = await this._createForwarder(forwarderAddress);\n const nonce = await forwarder.getNonce(sender);\n return nonce.toString();\n }\n async getBlockGasLimit() {\n const latestBlock = await this.provider.getBlock('latest');\n if (latestBlock == null) {\n throw new Error('Failed to query \"getBlock\", crashing.');\n }\n return parseInt(latestBlock.gasLimit.toString());\n }\n _fixGasFees(relayRequest) {\n if (this.transactionType === TransactionType_1.TransactionType.LEGACY) {\n return {\n gasPrice: (0, Web3JSUtils_1.toHex)(relayRequest.relayData.maxFeePerGas)\n };\n } else {\n return {\n maxFeePerGas: (0, Web3JSUtils_1.toHex)(relayRequest.relayData.maxFeePerGas),\n maxPriorityFeePerGas: (0, Web3JSUtils_1.toHex)(relayRequest.relayData.maxPriorityFeePerGas)\n };\n }\n }\n /**\n * make a view call to relayCall(), just like the way it will be called by the relayer.\n * returns:\n * - paymasterAccepted - true if accepted\n * - reverted - true if relayCall was reverted.\n * - returnValue - if either reverted or paymaster NOT accepted, then this is the reason string.\n */\n async validateRelayCall(relayCallABIData, viewCallGasLimit, isDryRun) {\n var _a;\n if (viewCallGasLimit == null || relayCallABIData.relayRequest.relayData.maxFeePerGas == null || relayCallABIData.relayRequest.relayData.maxPriorityFeePerGas == null) {\n throw new Error('validateRelayCall: invalid input');\n }\n const relayHub = this.relayHubInstance;\n const from = isDryRun ? Constants_1.constants.DRY_RUN_ADDRESS : relayCallABIData.relayRequest.relayData.relayWorker;\n try {\n const encodedRelayCall = this.encodeABI(relayCallABIData);\n const res = await new Promise((resolve, reject) => {\n const gasFees = this._fixGasFees(relayCallABIData.relayRequest);\n const rpcPayload = [Object.assign({\n from,\n to: relayHub.address,\n gas: (0, Web3JSUtils_1.toHex)(viewCallGasLimit),\n data: encodedRelayCall\n }, gasFees), 'latest'];\n this.logger.debug(`Sending in view mode: \\n${JSON.stringify(rpcPayload)}\\n encoded data: \\n${JSON.stringify(relayCallABIData)}`);\n // TODO: this does not seem right....\n const unifiedResErrHandlerFromWeb3Times = (res, err) => {\n if ((res === null || res === void 0 ? void 0 : res.error) != null) {\n err = res.error;\n }\n const revertMsg = this._decodeRevertFromResponse(err, res);\n if (revertMsg != null) {\n reject(new Error(revertMsg));\n } else if ((0, Utils_1.errorAsBoolean)(err)) {\n reject(err);\n } else if ((res === null || res === void 0 ? void 0 : res.result) == null) {\n reject(new Error('RPC call returned no error and no result'));\n } else {\n resolve(res.result);\n }\n };\n this.provider.send('eth_call', rpcPayload).then(res => {\n resolve(res);\n }).catch(err => {\n // TODO: this function is not very necessary\n unifiedResErrHandlerFromWeb3Times(undefined, err);\n });\n });\n this.logger.debug('relayCall res=' + res);\n const decoded = new abi_1.AbiCoder().decode(['bool', 'uint256', 'uint256', 'bytes'], res);\n const paymasterAccepted = decoded[0];\n const relayCallStatus = parseInt(decoded[2]);\n let returnValue = decoded[3];\n const recipientReverted = Constants_1.RelayCallStatusCodes.RelayedCallFailed.eqn(relayCallStatus);\n if (!paymasterAccepted || recipientReverted) {\n returnValue = (_a = this._decodeRevertFromResponse({}, {\n result: returnValue\n })) !== null && _a !== void 0 ? _a : returnValue;\n }\n return {\n returnValue: returnValue,\n paymasterAccepted,\n recipientReverted,\n relayHubReverted: false\n };\n } catch (e) {\n const message = e instanceof Error ? e.message : JSON.stringify(e, ErrorReplacerJSON_1.replaceErrors);\n return {\n paymasterAccepted: false,\n recipientReverted: false,\n relayHubReverted: true,\n returnValue: `view call to 'relayCall' reverted in client: ${message}`\n };\n }\n }\n /**\n * decode revert from rpc response.\n * called from the callback of the provider \"eth_call\" call.\n * check if response is revert, and extract revert reason from it.\n * support kovan, geth, ganache error formats..\n * @param err - provider err value\n * @param res - provider res value\n */\n // decode revert from rpc response.\n //\n _decodeRevertFromResponse(err, res) {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;\n let matchGanache = (_b = (_a = err === null || err === void 0 ? void 0 : err.data) === null || _a === void 0 ? void 0 : _a.message) === null || _b === void 0 ? void 0 : _b.toString().match(/: revert(?:ed)? (.*)/);\n if (matchGanache == null) {\n matchGanache = (_d = (_c = res === null || res === void 0 ? void 0 : res.error) === null || _c === void 0 ? void 0 : _c.message) === null || _d === void 0 ? void 0 : _d.toString().match(/: revert(?:ed)? (.*)/);\n }\n if (matchGanache == null) {\n // TODO: investigate other RPC nodes with Ethers.js!\n // ethers.js with hardhat\n matchGanache = (_f = (_e = err === null || err === void 0 ? void 0 : err.error) === null || _e === void 0 ? void 0 : _e.message) === null || _f === void 0 ? void 0 : _f.toString().match(/: revert(?:ed)? (.*)/);\n }\n if (matchGanache == null) {\n // Infura and Alchemy revert message format\n matchGanache = (_g = err === null || err === void 0 ? void 0 : err.message) === null || _g === void 0 ? void 0 : _g.toString().match(/ revert(?:ed):? (.*)/);\n }\n if (matchGanache == null) {\n matchGanache = (_h = err === null || err === void 0 ? void 0 : err.message) === null || _h === void 0 ? void 0 : _h.toString().match(/reverted:(.*)/);\n }\n if (matchGanache != null) {\n // also cleaning up Hardhat Node's verbose revert errors\n return matchGanache[1].replace('with reason string ', '').replace(/^'|'$/g, '');\n }\n const errorData = (_j = err === null || err === void 0 ? void 0 : err.data) !== null && _j !== void 0 ? _j : (_k = res === null || res === void 0 ? void 0 : res.error) === null || _k === void 0 ? void 0 : _k.data;\n const m = errorData === null || errorData === void 0 ? void 0 : errorData.toString().match(/(0x08c379a0\\S*)/);\n if (m != null) {\n return (0, Utils_1.decodeRevertReason)(m[1]);\n }\n const result = (_l = res === null || res === void 0 ? void 0 : res.result) !== null && _l !== void 0 ? _l : '';\n if (result.startsWith('0x08c379a0')) {\n return (0, Utils_1.decodeRevertReason)(result);\n }\n return null;\n }\n encodeABI(_) {\n const iface = new abi_1.Interface(this.relayHubInstance.contract.interface.fragments);\n return iface.encodeFunctionData('relayCall', [_.domainSeparatorName, _.maxAcceptanceBudget, _.relayRequest, _.signature, _.approvalData]);\n }\n async getPastEventsForHub(extraTopics, options, names = GSNContractsDataTypes_1.ActiveManagerEvents) {\n return await this._getPastEventsPaginated(this.relayHubInstance.contract, names, extraTopics, options);\n }\n async getPastEventsForRegistrar(extraTopics, options, names = [GSNContractsDataTypes_1.RelayServerRegistered]) {\n return await this._getPastEventsPaginated(this.relayRegistrar.contract, names, extraTopics, options);\n }\n async getPastEventsForStakeManager(names, extraTopics, options) {\n const stakeManager = await this.stakeManagerInstance;\n return await this._getPastEventsPaginated(stakeManager.contract, names, extraTopics, options);\n }\n async getPastEventsForPenalizer(names, extraTopics, options) {\n return await this._getPastEventsPaginated(this.penalizerInstance.contract, names, extraTopics, options);\n }\n getLogsPagesForRange(fromBlock = 1, toBlock) {\n // save 'getBlockNumber' roundtrip for a known max value\n if (this.maxPageSize === Number.MAX_SAFE_INTEGER) {\n return {\n rangeSize: 1,\n pagesForRange: 1\n };\n }\n // noinspection SuspiciousTypeOfGuard - known false positive\n if (typeof fromBlock !== 'number' || typeof toBlock !== 'number') {\n throw new Error(`ContractInteractor:getLogsPagesForRange: [${fromBlock.toString()}..${toBlock === null || toBlock === void 0 ? void 0 : toBlock.toString()}]: only numbers supported when using pagination`);\n }\n const rangeSize = toBlock - fromBlock + 1;\n const pagesForRange = Math.max(Math.ceil(rangeSize / this.maxPageSize), 1);\n if (pagesForRange > 1) {\n this.logger.info(`Splitting request for ${rangeSize} blocks into ${pagesForRange} smaller paginated requests!`);\n }\n return {\n rangeSize,\n pagesForRange\n };\n }\n splitRange(fromBlock, toBlock, parts) {\n if (parts === 1) {\n return [{\n fromBlock,\n toBlock\n }];\n }\n // noinspection SuspiciousTypeOfGuard - known false positive\n if (typeof fromBlock !== 'number' || typeof toBlock !== 'number') {\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n throw new Error(`ContractInteractor:splitRange: only number supported for block range when using pagination, ${fromBlock} ${toBlock} ${parts}`);\n }\n const rangeSize = toBlock - fromBlock + 1;\n const splitSize = Math.ceil(rangeSize / parts);\n const ret = [];\n for (let b = fromBlock; b <= toBlock; b += splitSize) {\n ret.push({\n fromBlock: b,\n toBlock: Math.min(toBlock, b + splitSize - 1)\n });\n }\n return ret;\n }\n /**\n * Splits requested range into pages to avoid fetching too many blocks at once.\n * In case 'getLogs' returned with a common error message of \"more than X events\" dynamically decrease page size.\n */\n async _getPastEventsPaginated(contract, names, extraTopics, options) {\n if (options.toBlock == null) {\n // this is to avoid '!' for TypeScript\n options.toBlock = 'latest';\n }\n if (options.fromBlock == null) {\n options.fromBlock = 1;\n }\n // save 'getBlockNumber' roundtrip for a known max value (must match check in getLogsPagesForRange)\n if (this.maxPageSize !== Number.MAX_SAFE_INTEGER && options.toBlock === 'latest') {\n options.toBlock = await this.getBlockNumber();\n if (options.fromBlock > options.toBlock) {\n options.toBlock = options.fromBlock;\n }\n }\n if (options.fromBlock > options.toBlock) {\n const message = `fromBlock(${options.fromBlock.toString()}) > \n toBlock(${options.toBlock.toString()})`;\n this.logger.error(message);\n throw new Error(message);\n }\n let {\n pagesForRange: pagesCurrent,\n rangeSize\n } = await this.getLogsPagesForRange(options.fromBlock, options.toBlock);\n if (pagesCurrent > this.maxPageCount) {\n throw new Error(`Failed to make a paginated request to 'getPastEvents' in block range [${options.fromBlock.toString()}..${options.toBlock.toString()}] with page size ${rangeSize}.\nThis would require ${pagesCurrent} requests, and configured 'pastEventsQueryMaxPageCount' is ${this.maxPageCount}`);\n }\n const relayEventParts = [];\n while (true) {\n const rangeParts = await this.splitRange(options.fromBlock, options.toBlock, pagesCurrent);\n try {\n // eslint-disable-next-line\n for (const {\n fromBlock,\n toBlock\n } of rangeParts) {\n // this.logger.debug('Getting events from block ' + fromBlock.toString() + ' to ' + toBlock.toString())\n let attempts = 0;\n while (true) {\n try {\n const pastEvents = await this._getPastEvents(contract, names, extraTopics, Object.assign({}, options, {\n fromBlock,\n toBlock\n }));\n relayEventParts.push(pastEvents);\n break;\n } catch (e) {\n /* eslint-disable */\n this.logger.error(`error in getPastEvents. \n fromBlock: ${fromBlock.toString()} \n toBlock: ${toBlock.toString()} \n attempts: ${attempts.toString()}\n names: ${names.toString()}\n extraTopics: ${extraTopics.toString()}\n options: ${JSON.stringify(options)}\n \\n${e.toString()}`);\n /* eslint-enable */\n attempts++;\n if (attempts >= 100) {\n this.logger.error('Too many attempts. throwing ');\n throw e;\n }\n await (0, Utils_js_1.sleep)(300);\n }\n }\n }\n break;\n } catch (e) {\n // dynamically adjust query size fo some RPC providers\n if (e.toString().match(/query returned more than/) != null) {\n this.logger.warn('Received \"query returned more than X events\" error from server, will try to split the request into smaller chunks');\n if (pagesCurrent > 16) {\n throw new Error(`Too many events after splitting by ${pagesCurrent}`);\n }\n pagesCurrent *= 4;\n } else {\n throw e;\n }\n }\n }\n return relayEventParts.flat();\n }\n async _getPastEvents(contract, names, extraTopics, options) {\n const topics = [];\n const eventTopic = (0, Utils_1.event2topic)(contract, names);\n topics.push(eventTopic);\n // TODO: AFAIK this means only the first parameter of the event is supported\n if (extraTopics.length > 0) {\n topics.push(...extraTopics);\n }\n const logs = await this.provider.getLogs({\n fromBlock: options.fromBlock,\n toBlock: options.toBlock,\n address: contract.address,\n topics: topics\n });\n return logs.map(it => {\n return Object.assign(it, contract.interface.parseLog(it));\n });\n }\n async getBalance(address, defaultBlock = 'latest') {\n return (await this.provider.getBalance(address, defaultBlock)).toString();\n }\n async getBlockNumberRightNow() {\n return await this.provider.getBlockNumber();\n }\n async getBlockNumber() {\n let blockNumber = -1;\n let attempts = 0;\n while (blockNumber < this.lastBlockNumber && attempts <= 10) {\n try {\n blockNumber = await this.getBlockNumberRightNow();\n } catch (e) {\n this.logger.error(`getBlockNumber: ${e.message}`);\n }\n if (blockNumber >= this.lastBlockNumber) {\n break;\n }\n await (0, Utils_js_1.sleep)(1000);\n attempts++;\n }\n if (blockNumber < this.lastBlockNumber) {\n throw new Error(`couldn't retrieve latest blockNumber from node. last block: ${this.lastBlockNumber}, got block: ${blockNumber}`);\n }\n this.lastBlockNumber = blockNumber;\n return blockNumber;\n }\n async sendSignedTransaction(rawTx) {\n // noinspection ES6RedundantAwait - PromiEvent makes lint less happy about this line\n return await this.provider.sendTransaction(rawTx);\n }\n async estimateGas(transactionDetails) {\n let estimation = await this.provider.estimateGas(transactionDetails);\n // there is a bug that breaks tests that rely on exact gas limit:\n // https://ethereum.stackexchange.com/questions/20878/why-estimategas-return-21001-instead-21000\n if (parseInt(estimation.toString()) === 21001) {\n estimation = 21000;\n }\n return parseInt(estimation.toString());\n }\n /**\n * In order to calculate the inner transaction gas limit we perform an 'estimateGas' from the Forwarder address.\n * As the calldata is already on-chain, the is no need to include its cost in the gas limit, so we subtract it.\n */\n async estimateInnerCallGasLimit(gsnTransactionDetails) {\n const originalGasEstimation = await this.estimateGas(gsnTransactionDetails);\n // note: overriding 'calldataEstimationSlackFactor' here as this value is used for inner call gas limit\n // and therefore there is no need to add extra factor even in case of L2s\n const calldataGasCost = await this.calculateCalldataGasUsed(gsnTransactionDetails.data, this.environment, 1, this.provider);\n const adjustedEstimation = originalGasEstimation - calldataGasCost;\n this.logger.debug(`estimateGasWithoutCalldata: original estimation: ${originalGasEstimation}; calldata cost: ${calldataGasCost}; adjusted estimation: ${adjustedEstimation}`);\n if (adjustedEstimation < 0) {\n throw new Error(`estimateGasWithoutCalldata: calldataGasCost(${calldataGasCost}) exceeded originalGasEstimation(${originalGasEstimation})`);\n }\n return adjustedEstimation;\n }\n async getGasAndDataLimitsFromPaymaster(paymaster) {\n try {\n const paymasterContract = await this._createPaymaster(paymaster);\n return await paymasterContract.getGasAndDataLimits();\n } catch (e) {\n const error = e;\n let message = `unknown paymaster error: ${error.message}`;\n if ((e === null || e === void 0 ? void 0 : e.code) === 'CALL_EXCEPTION' ||\n // ethers.js does not differentiate revert reasons\n error.message.includes('Returned values aren\\'t valid, did it run Out of Gas?')) {\n message = `not a valid paymaster contract: ${paymaster}`;\n } else if (error.message.includes('no code at address')) {\n message = `'non-existent paymaster contract: ${paymaster}`;\n }\n throw new Error(message);\n }\n }\n /**\n * @returns result - maximum possible gas consumption by this relayed call\n * (calculated on chain by RelayHub.verifyGasAndDataLimits)\n */\n async calculateTransactionMaxPossibleGas(_) {\n const msgDataLength = (0, ethereumjs_util_1.toBuffer)(_.msgData).length;\n const msgDataGasCostInsideTransaction = (0, Web3JSUtils_1.toBN)(this.environment.dataOnChainHandlingGasCostPerByte).muln(msgDataLength).toNumber();\n const calldataCost = await this.calculateCalldataGasUsed(_.msgData, this.environment, this.calldataEstimationSlackFactor, this.provider);\n const result = (0, Utils_1.toNumber)(this.relayHubConfiguration.gasOverhead) + msgDataGasCostInsideTransaction + calldataCost + parseInt(_.relayCallGasLimit) + (0, Utils_1.toNumber)(_.gasAndDataLimits.preRelayedCallGasLimit) + (0, Utils_1.toNumber)(_.gasAndDataLimits.postRelayedCallGasLimit);\n this.logger.debug(`\ninput:\\n${JSON.stringify(_)}\nmsgDataLength: ${msgDataLength}\ncalldataCost: ${calldataCost}\nmsgDataGasCostInsideTransaction: ${msgDataGasCostInsideTransaction}\nenvironment: ${JSON.stringify(this.environment)}\nrelayHubConfiguration: ${JSON.stringify(this.relayHubConfiguration)}\ncalculateTransactionMaxPossibleGas: result: ${result}\n`);\n return result;\n }\n /**\n * Only used by the RelayClient.\n * @param relayRequestOriginal request input of the 'relayCall' method with some fields not yet initialized\n * @param variableFieldSizes configurable sizes of 'relayCall' parameters with variable size types\n * @return {PrefixedHexString} top boundary estimation of how much gas sending this data will consume\n */\n async estimateCalldataCostForRequest(relayRequestOriginal, variableFieldSizes) {\n // protecting the original object from temporary modifications done here\n const relayRequest = Object.assign({}, relayRequestOriginal, {\n relayData: Object.assign({}, relayRequestOriginal.relayData)\n });\n relayRequest.relayData.transactionCalldataGasUsed = '0xffffffffff';\n relayRequest.relayData.paymasterData = '0x' + 'ff'.repeat(variableFieldSizes.maxPaymasterDataLength);\n const maxAcceptanceBudget = '0xffffffffff';\n const signature = '0x' + 'ff'.repeat(65);\n const approvalData = '0x' + 'ff'.repeat(variableFieldSizes.maxApprovalDataLength);\n const encodedData = this.encodeABI({\n domainSeparatorName: this.domainSeparatorName,\n relayRequest,\n signature,\n approvalData,\n maxAcceptanceBudget\n });\n const calculatedCalldataGasUsed = await this.calculateCalldataGasUsed(encodedData, this.environment, this.calldataEstimationSlackFactor, this.provider);\n return `0x${calculatedCalldataGasUsed.toString(16)}`;\n }\n // note: when passing 'gasPrice' to a view call, the sender balance is checked to have sufficient balance\n // we must set 'from' and 'gas' parameters as well to avoid failing a view call with 'insufficient gas'\n async calculatePaymasterGasAndDataLimits(relayTransactionRequest, gasAndDataLimits, gasReserve, gasFactor, viewCallFrom, viewCallGasLimit) {\n if (gasAndDataLimits == null) {\n gasAndDataLimits = await this.getGasAndDataLimitsFromPaymaster(relayTransactionRequest.relayRequest.relayData.paymaster);\n }\n const {\n paymasterAcceptanceBudget,\n effectiveAcceptanceBudget,\n transactionCalldataGasUsed,\n maxPossibleGas\n } = await this.calculateRequestLimits(relayTransactionRequest, gasAndDataLimits);\n const maxPossibleGasFactorReserve = gasReserve + Math.floor(maxPossibleGas * gasFactor);\n // removing Ethers 'signer' to allow overriding 'from' address\n // note that it will remove the mapping of types to BN!\n const viewOnlyHub = this.relayHubInstance.contract.connect(this.provider);\n const maxPossibleCharge = await viewOnlyHub.calculateCharge(maxPossibleGasFactorReserve, relayTransactionRequest.relayRequest.relayData, {\n from: viewCallFrom,\n gasLimit: viewCallGasLimit,\n gasPrice: relayTransactionRequest.relayRequest.relayData.maxFeePerGas\n });\n return {\n paymasterAcceptanceBudget,\n effectiveAcceptanceBudget,\n transactionCalldataGasUsed,\n maxPossibleCharge: (0, Web3JSUtils_1.toBN)(maxPossibleCharge.toString()),\n maxPossibleGas: maxPossibleGasFactorReserve\n };\n }\n async calculateRequestLimits(relayTransactionRequest, gasAndDataLimits) {\n const relayCallAbiInput = {\n domainSeparatorName: relayTransactionRequest.metadata.domainSeparatorName,\n maxAcceptanceBudget: '0xffffffff',\n relayRequest: relayTransactionRequest.relayRequest,\n signature: relayTransactionRequest.metadata.signature,\n approvalData: relayTransactionRequest.metadata.approvalData\n };\n const msgData = this.encodeABI(relayCallAbiInput);\n const transactionCalldataGasUsed = await this.calculateCalldataGasUsed(msgData, this.environment, this.calldataEstimationSlackFactor, this.provider);\n const maxPossibleGas = await this.calculateTransactionMaxPossibleGas({\n msgData,\n gasAndDataLimits,\n relayCallGasLimit: relayTransactionRequest.relayRequest.request.gas\n });\n const paymasterAcceptanceBudget = gasAndDataLimits.acceptanceBudget.toNumber();\n const effectiveAcceptanceBudget = paymasterAcceptanceBudget + transactionCalldataGasUsed + transactionCalldataGasUsed;\n return {\n transactionCalldataGasUsed,\n maxPossibleGas,\n paymasterAcceptanceBudget,\n effectiveAcceptanceBudget\n };\n }\n // TODO: !This method is not really necessary - only used for a fraction of transactions. Replace with 'getGasFees'.\n // TODO: cache response for some time to optimize. It doesn't make sense to optimize these requests in calling code.\n async getGasPrice() {\n // TODO: this still uses pre-1559 gas value which may be a problem.\n const gasPriceFromNode = await this.provider.perform('getGasPrice', []);\n if (gasPriceFromNode == null) {\n throw new Error('getGasPrice: node returned null value');\n }\n // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions\n if (!this.environment.getGasPriceFactor) {\n this.logger.warn('Environment not set');\n return gasPriceFromNode;\n }\n const gasPriceActual = (0, Web3JSUtils_1.toBN)(gasPriceFromNode).muln(this.environment.getGasPriceFactor);\n return gasPriceActual.toString();\n }\n async getFeeHistory(blockCount, lastBlock, rewardPercentiles) {\n return await this.provider.send('eth_feeHistory', [blockCount, lastBlock, rewardPercentiles]);\n }\n async getGasFees(blockCount, rewardPercentile) {\n if (this.transactionType === TransactionType_1.TransactionType.LEGACY) {\n const gasPrice = await this.getGasPrice();\n return {\n baseFeePerGas: gasPrice,\n priorityFeePerGas: gasPrice\n };\n }\n const networkHistoryFees = await this.getFeeHistory((0, Web3JSUtils_1.toHex)(blockCount), 'pending', [rewardPercentile]);\n const baseFeePerGas = networkHistoryFees.baseFeePerGas[0];\n const priorityFeePerGas = (0, Utils_1.averageBN)(networkHistoryFees.reward.map(rewards => rewards[0]).map(Web3JSUtils_1.toBN)).toString();\n return {\n baseFeePerGas,\n priorityFeePerGas\n };\n }\n async getTransactionCount(address, defaultBlock) {\n return await this.provider.getTransactionCount(address, defaultBlock);\n }\n async getTransaction(transactionHash) {\n return await this.provider.getTransaction(transactionHash);\n }\n async getBlock(blockHashOrBlockNumber) {\n const block = await this.provider.getBlock(blockHashOrBlockNumber);\n if (block == null) {\n throw new Error('Failed to getBlock!');\n }\n return block;\n }\n validateAddress(address, exceptionTitle = 'invalid address:') {\n if (!ethers_1.ethers.utils.isAddress(address)) {\n throw new Error(exceptionTitle + ' ' + address);\n }\n }\n async getCode(address) {\n return await this.provider.getCode(address);\n }\n getNetworkId() {\n if (this.networkId == null) {\n throw new Error('_init not called');\n }\n return this.networkId;\n }\n async isContractDeployed(address) {\n const code = await this.getCode(address);\n return code !== '0x';\n }\n async workerToManager(worker) {\n return await this.relayHubInstance.getWorkerManager(worker);\n }\n async getMinimumStakePerToken(tokenAddress) {\n return await this.relayHubInstance.getMinimumStakePerToken(tokenAddress);\n }\n /**\n * Gets balance of an address on the current RelayHub.\n * @param address - can be a Paymaster or a Relay Manger\n */\n async hubBalanceOf(address) {\n return await this.relayHubInstance.balanceOf(address);\n }\n /**\n * Gets stake of an address on the current StakeManager.\n * @param managerAddress\n */\n async getStakeInfo(managerAddress) {\n const getStakeInfoResult = await this.stakeManagerInstance.getStakeInfo(managerAddress);\n // @ts-ignore - TypeChain generates incorrect type declarations for tuples\n return getStakeInfoResult[0];\n }\n async isRelayManagerStakedOnHub(relayManager) {\n const res = await new Promise(resolve => {\n const iface = new abi_1.Interface(this.relayHubInstance.contract.interface.fragments);\n const data = iface.encodeFunctionData('verifyRelayManagerStaked', [relayManager]);\n const params = [{\n to: this.relayHubInstance.address,\n data\n }, 'latest'];\n this.provider.send('eth_call', params).then(res => {\n resolve({\n isStaked: res === '0x',\n errorMessage: null\n });\n }).catch(err => {\n const errorMessage = this._decodeRevertFromResponse(err);\n resolve({\n isStaked: false,\n errorMessage\n });\n });\n });\n return res;\n }\n async initDeployment(deployment) {\n this.deployment = deployment;\n await this._initializeContracts();\n }\n getDeployment() {\n if (this.deployment == null) {\n throw new Error('Contracts deployment is not initialized for Contract Interactor!');\n }\n return this.deployment;\n }\n /**\n * Broadcast the \"raw\" signed hex-encoded Ethereum transaction.\n * This method sends the RPC call directly\n * @param signedTransaction - the raw signed transaction to broadcast\n */\n async broadcastTransaction(signedTransaction) {\n return await this.provider.send('eth_sendRawTransaction', [signedTransaction]);\n }\n async hubDepositFor(paymaster, transactionDetails) {\n return await this.relayHubInstance.depositFor(paymaster, transactionDetails);\n }\n async resolveDeploymentVersions() {\n const versionsMap = {};\n if (this.deployment.relayHubAddress != null) {\n versionsMap[this.deployment.relayHubAddress] = await this.relayHubInstance.versionHub();\n }\n if (this.deployment.penalizerAddress != null) {\n versionsMap[this.deployment.penalizerAddress] = await this.penalizerInstance.versionPenalizer();\n }\n if (this.deployment.stakeManagerAddress != null) {\n versionsMap[this.deployment.stakeManagerAddress] = await this.stakeManagerInstance.versionSM();\n }\n return versionsMap;\n }\n async queryDeploymentBalances() {\n const balances = {};\n if (this.deployment.relayHubAddress != null) {\n balances[this.deployment.relayHubAddress] = await this.getBalance(this.deployment.relayHubAddress);\n }\n if (this.deployment.penalizerAddress != null) {\n balances[this.deployment.penalizerAddress] = await this.getBalance(this.deployment.penalizerAddress);\n }\n if (this.deployment.stakeManagerAddress != null) {\n balances[this.deployment.stakeManagerAddress] = await this.getBalance(this.deployment.stakeManagerAddress);\n }\n return balances;\n }\n async _hubStakeManagerAddress() {\n return await this.relayHubInstance.getStakeManager();\n }\n stakeManagerAddress() {\n return this.stakeManagerInstance.address;\n }\n async _hubPenalizerAddress() {\n return await this.relayHubInstance.getPenalizer();\n }\n async _hubRelayRegistrarAddress() {\n return await this.relayHubInstance.getRelayRegistrar();\n }\n penalizerAddress() {\n return this.penalizerInstance.address;\n }\n async getRelayRegistrationMaxAge() {\n return await this.relayRegistrar.getRelayRegistrationMaxAge();\n }\n async getRelayInfo(relayManagerAddress) {\n const relayInfo = await this.relayRegistrar.getRelayInfo(this.relayHubInstance.address, relayManagerAddress);\n return Object.assign({}, relayInfo, {\n relayUrl: (0, Utils_1.packRelayUrlForRegistrar)(relayInfo.urlParts)\n });\n }\n /**\n * get registered relayers from registrar\n * (output format matches event info)\n */\n async getRegisteredRelays() {\n if (this.relayRegistrar == null) {\n throw new Error('Relay Registrar is not initialized');\n }\n const relayHub = this.relayHubInstance.address;\n if (relayHub == null) {\n throw new Error('RelayHub is not initialized!');\n }\n const relayInfos = await this.relayRegistrar.readRelayInfos(relayHub);\n return relayInfos.map(info => {\n return Object.assign({}, info, {\n relayUrl: (0, Utils_1.packRelayUrlForRegistrar)(info.urlParts)\n });\n });\n }\n async getCreationBlockFromRelayHub() {\n return await this.relayHubInstance.getCreationBlock();\n }\n async getRegisteredWorkers(managerAddress) {\n const topics = (0, Utils_1.address2topic)(managerAddress);\n const workersAddedEvents = await this.getPastEventsForHub([topics], {\n fromBlock: 1\n }, [GSNContractsDataTypes_1.RelayWorkersAdded]);\n return workersAddedEvents.map(it => it.args.newRelayWorkers).flat();\n }\n /**\n *\n * @param paymasterAddress\n * @param workerAddress\n * @param maxFeePerGas\n * @param maxViewableGasLimit\n * @param minViewableGasLimit\n */\n async calculateDryRunCallGasLimit(paymasterAddress, workerAddress, maxFeePerGas, maxViewableGasLimit, minViewableGasLimit) {\n const paymasterBalance = await this.hubBalanceOf(paymasterAddress);\n let workerBalance = Constants_1.constants.MAX_UINT256; // skipping worker address balance check in dry-run\n let workerBalanceMessage = '';\n if (!(0, Utils_1.isSameAddress)(workerAddress, Constants_1.constants.DRY_RUN_ADDRESS)) {\n const workerBalanceStr = await this.getBalance(workerAddress, 'pending');\n workerBalance = (0, Web3JSUtils_1.toBN)(workerBalanceStr);\n workerBalanceMessage = `Worker balance: ${workerBalance.toString()}\\n`;\n }\n const smallerBalance = bn_js_1.default.min(paymasterBalance, workerBalance);\n const pctRelayFeeDev = (0, Web3JSUtils_1.toBN)(this.relayHubConfiguration.pctRelayFee.toString()).addn(100);\n const smallerBalanceGasLimit = smallerBalance.div(maxFeePerGas).muln(100).div(pctRelayFeeDev).muln(3).divn(4); // hard-coded to use 75% of available worker/paymaster balance\n const blockGasLimitNum = await this.getBlockGasLimit();\n const blockGasLimit = (0, Web3JSUtils_1.toBN)(blockGasLimitNum).muln(3).divn(4); // hard-coded to use 75% of available block gas limit\n const warningMessage = workerBalanceMessage + `Paymaster balance: ${paymasterBalance.toString()}\\n` + `This is only enough for ${smallerBalanceGasLimit.toString()} gas for a view call at ${maxFeePerGas.toString()} per gas.\\n` + `Also, block gas limit is: ${blockGasLimit.toString()}\\n`;\n if (smallerBalanceGasLimit.lt(minViewableGasLimit)) {\n this.logger.warn(warningMessage + `Limiting the view call to minViewableGasLimit (${minViewableGasLimit.toString()}) but successful relaying is not likely.`);\n return minViewableGasLimit;\n }\n const minimalLimit = bn_js_1.default.min(maxViewableGasLimit, bn_js_1.default.min(smallerBalanceGasLimit, blockGasLimit));\n if (minimalLimit.eq(smallerBalanceGasLimit)) {\n this.logger.warn(warningMessage);\n }\n return minimalLimit;\n }\n}\nexports.ContractInteractor = ContractInteractor;\n/**\n * Ganache does not seem to enforce EIP-155 signature. Buidler does, though.\n * This is how {@link Transaction} constructor allows support for custom and private network.\n * @param chainId\n * @param networkId\n * @param chain\n * @return {{common: Common}}\n */\nfunction getRawTxOptions(chainId, networkId, chain) {\n if (chain == null || chain === 'main' || chain === 'private') {\n chain = 'mainnet';\n }\n return {\n common: common_1.default.forCustomChain(chain, {\n chainId,\n networkId\n }, 'london')\n };\n}\nexports.getRawTxOptions = getRawTxOptions;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.defaultEnvironment = exports.environments = exports.merge = exports.EnvironmentsKeys = void 0;\nconst Constants_1 = require(\"../Constants\");\nvar EnvironmentsKeys;\n(function (EnvironmentsKeys) {\n EnvironmentsKeys[\"ethereumMainnet\"] = \"ethereumMainnet\";\n EnvironmentsKeys[\"arbitrum\"] = \"arbitrum\";\n})(EnvironmentsKeys = exports.EnvironmentsKeys || (exports.EnvironmentsKeys = {}));\n// deep (3-level) merge of environments\nfunction merge(env1, env2) {\n var _a, _b;\n return Object.assign({}, env1, env2, {\n relayHubConfiguration: Object.assign({}, env1.relayHubConfiguration, env2.relayHubConfiguration),\n penalizerConfiguration: Object.assign({}, env1.penalizerConfiguration, env2.penalizerConfiguration),\n paymasterConfiguration: Object.assign({}, env1.paymasterConfiguration, env2.paymasterConfiguration),\n deploymentConfiguration: Object.assign({}, env1.deploymentConfiguration, env2.deploymentConfiguration, {\n minimumStakePerToken: Object.assign({}, (_a = env1.deploymentConfiguration) === null || _a === void 0 ? void 0 : _a.minimumStakePerToken, (_b = env2.deploymentConfiguration) === null || _b === void 0 ? void 0 : _b.minimumStakePerToken)\n })\n });\n}\nexports.merge = merge;\n/**\n * Maximum unstake delay is defined at around 3 years for the mainnet.\n * This is done to prevent mistakenly setting an unstake delay to millions of years.\n */\nconst defaultStakeManagerMaxUnstakeDelay = 100000000;\nconst defaultPenalizerConfiguration = {\n penalizeBlockDelay: 5,\n penalizeBlockExpiration: 60000\n};\nconst defaultRelayHubConfiguration = {\n gasOverhead: 34909,\n postOverhead: 38516,\n gasReserve: 100000,\n maxWorkerCount: 10,\n minimumUnstakeDelay: 15000,\n devAddress: '0xeFEfeFEfeFeFEFEFEfefeFeFefEfEfEfeFEFEFEf',\n devFee: 0,\n // TODO STOPSHIP: DECIDE!\n pctRelayFee: 0,\n baseRelayFee: 0\n};\n// TODO add as constructor params to paymaster instead of constants\nconst preRelayedCallGasLimit = 1e5;\nconst forwarderHubOverhead = 5e4;\nconst defaultPaymasterConfiguration = {\n forwarderHubOverhead: forwarderHubOverhead,\n preRelayedCallGasLimit: preRelayedCallGasLimit,\n postRelayedCallGasLimit: 11e4,\n acceptanceBudget: preRelayedCallGasLimit + forwarderHubOverhead,\n calldataSizeLimit: 10404\n};\nconst ethereumMainnet = {\n environmentsKey: EnvironmentsKeys.ethereumMainnet,\n calldataEstimationSlackFactor: 1,\n useEstimateGasForCalldataCost: false,\n dataOnChainHandlingGasCostPerByte: 13,\n relayHubConfiguration: defaultRelayHubConfiguration,\n penalizerConfiguration: defaultPenalizerConfiguration,\n paymasterConfiguration: defaultPaymasterConfiguration,\n maxUnstakeDelay: defaultStakeManagerMaxUnstakeDelay,\n stakeBurnAddress: Constants_1.constants.BURN_ADDRESS,\n abandonmentDelay: 31536000,\n escheatmentDelay: 2629746,\n mintxgascost: 21000,\n gtxdatanonzero: 16,\n gtxdatazero: 4,\n getGasPriceFactor: 1,\n nonZeroDevFeeGasOverhead: 5605\n};\n/* begin Arbitrum-specific Environment */\nconst arbitrumRelayHubConfigurationOverride = {\n gasOverhead: 1000000,\n postOverhead: 0\n};\nconst arbitrumRelayHubConfiguration = Object.assign({}, defaultRelayHubConfiguration, arbitrumRelayHubConfigurationOverride);\nconst arbitrum = Object.assign({}, ethereumMainnet, {\n environmentsKey: EnvironmentsKeys.arbitrum,\n calldataEstimationSlackFactor: 1.3,\n useEstimateGasForCalldataCost: true,\n relayHubConfiguration: arbitrumRelayHubConfiguration,\n penalizerConfiguration: defaultPenalizerConfiguration,\n paymasterConfiguration: defaultPaymasterConfiguration,\n maxUnstakeDelay: defaultStakeManagerMaxUnstakeDelay,\n mintxgascost: 0,\n gtxdatanonzero: 0,\n gtxdatazero: 0,\n // there is currently a hard-coded to be 2 at arbitrum:eth.go:43 (commit: 12483cfa17a29e7d68c354c456ebc371b05a6ea2)\n // setting factor to 0.6 instead of 0.5 to allow the transaction to pass in case of moderate gas price increase\n // note that excess will be collected by the Relay Server as an extra profit\n getGasPriceFactor: 0.6\n});\n/* end Arbitrum-specific Environment */\nexports.environments = {\n ethereumMainnet,\n arbitrum\n};\nexports.defaultEnvironment = exports.environments.ethereumMainnet;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HttpClient = void 0;\nconst Utils_1 = require(\"./Utils\");\nclass HttpClient {\n constructor(httpWrapper, logger) {\n this.httpWrapper = httpWrapper;\n this.logger = logger;\n }\n async getPingResponse(relayUrl, paymaster) {\n const url = new URL('getaddr', (0, Utils_1.appendSlashTrim)(relayUrl));\n if (paymaster != null) {\n url.searchParams.set('paymaster', paymaster);\n }\n const pingResponse = await this.httpWrapper.sendPromise(url);\n this.logger.info(`pingResponse: ${JSON.stringify(pingResponse)}`);\n if (pingResponse == null) {\n throw new Error('Relay responded without a body');\n }\n return pingResponse;\n }\n async relayTransaction(relayUrl, request) {\n const url = new URL('relay', (0, Utils_1.appendSlashTrim)(relayUrl));\n const {\n signedTx,\n nonceGapFilled,\n error\n } = await this.httpWrapper.sendPromise(url, request);\n this.logger.info(`relayTransaction response: ${signedTx}, error: ${error}`);\n if (error != null) {\n throw new Error(`Got error response from relay: ${error}`);\n }\n if (signedTx == null) {\n throw new Error('body.signedTx field missing.');\n }\n return {\n signedTx,\n nonceGapFilled\n };\n }\n async auditTransaction(relayUrl, signedTx) {\n const url = new URL('audit', (0, Utils_1.appendSlashTrim)(relayUrl));\n const auditRequest = {\n signedTx\n };\n const auditResponse = await this.httpWrapper.sendPromise(url, auditRequest);\n this.logger.info(`auditTransaction response: ${JSON.stringify(auditResponse)}`);\n return auditResponse;\n }\n async getNetworkConfiguration(clientDefaultConfigUrl) {\n const configResponse = await this.httpWrapper.sendPromise(new URL(clientDefaultConfigUrl));\n this.logger.info(`Config response: ${JSON.stringify(configResponse)}`);\n return configResponse;\n }\n async getVerifyingPaymasterAddress(verifierServerUrl, chainId) {\n const url = new URL('getPaymasterAddress', (0, Utils_1.appendSlashTrim)(verifierServerUrl));\n url.searchParams.set('chainId', chainId.toString());\n const {\n paymasterAddress\n } = await this.httpWrapper.sendPromise(url);\n this.logger.info(`VerifyingPaymaster address: ${JSON.stringify(paymasterAddress)}`);\n return paymasterAddress;\n }\n}\nexports.HttpClient = HttpClient;\n","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n return function wrap() {\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n return fn.apply(thisArg, args);\n };\n};","'use strict';\n\nvar bind = require('./helpers/bind');\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\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) && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n return typeof FormData !== 'undefined' && val instanceof FormData;\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n var result;\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n result = ArrayBuffer.isView(val);\n } else {\n result = val && val.buffer && val.buffer instanceof ArrayBuffer;\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a plain Object\n *\n * @param {Object} val The value to test\n * @return {boolean} True if value is a plain Object, otherwise false\n */\nfunction isPlainObject(val) {\n if (toString.call(val) !== '[object Object]') {\n return false;\n }\n var prototype = Object.getPrototypeOf(val);\n return prototype === null || prototype === Object.prototype;\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n return str.trim ? str.trim() : str.replace(/^\\s+|\\s+$/g, '');\n}\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 */\nfunction isStandardBrowserEnv() {\n if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' || navigator.product === 'NativeScript' || navigator.product === 'NS')) {\n return false;\n }\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\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 */\nfunction forEach(obj, fn) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\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 if (isArray(obj)) {\n // Iterate over array values\n for (var 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 for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n fn.call(null, obj[key], key, obj);\n }\n }\n }\n}\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 * @returns {Object} Result of all merge properties\n */\nfunction merge( /* obj1, obj2, obj3, ... */\n) {\n var result = {};\n function assignValue(val, key) {\n if (isPlainObject(result[key]) && isPlainObject(val)) {\n result[key] = merge(result[key], val);\n } else if (isPlainObject(val)) {\n result[key] = merge({}, val);\n } else if (isArray(val)) {\n result[key] = val.slice();\n } else {\n result[key] = val;\n }\n }\n for (var i = 0, l = arguments.length; i < l; i++) {\n 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 * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n forEach(b, function assignValue(val, key) {\n if (thisArg && typeof val === 'function') {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n });\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 * @return {string} content value without BOM\n */\nfunction stripBOM(content) {\n if (content.charCodeAt(0) === 0xFEFF) {\n content = content.slice(1);\n }\n return content;\n}\nmodule.exports = {\n isArray: isArray,\n isArrayBuffer: isArrayBuffer,\n isBuffer: isBuffer,\n isFormData: isFormData,\n isArrayBufferView: isArrayBufferView,\n isString: isString,\n isNumber: isNumber,\n isObject: isObject,\n isPlainObject: isPlainObject,\n isUndefined: isUndefined,\n isDate: isDate,\n isFile: isFile,\n isBlob: isBlob,\n isFunction: isFunction,\n isStream: isStream,\n isURLSearchParams: isURLSearchParams,\n isStandardBrowserEnv: isStandardBrowserEnv,\n forEach: forEach,\n merge: merge,\n extend: extend,\n trim: trim,\n stripBOM: stripBOM\n};","'use strict';\n\nvar utils = require('./../utils');\nfunction encode(val) {\n return encodeURIComponent(val).replace(/%3A/gi, ':').replace(/%24/g, '$').replace(/%2C/gi, ',').replace(/%20/g, '+').replace(/%5B/gi, '[').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 * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n var serializedParams;\n if (paramsSerializer) {\n serializedParams = paramsSerializer(params);\n } else if (utils.isURLSearchParams(params)) {\n serializedParams = params.toString();\n } else {\n var parts = [];\n utils.forEach(params, function serialize(val, key) {\n if (val === null || typeof val === 'undefined') {\n return;\n }\n if (utils.isArray(val)) {\n key = key + '[]';\n } else {\n val = [val];\n }\n utils.forEach(val, function parseValue(v) {\n if (utils.isDate(v)) {\n v = v.toISOString();\n } else if (utils.isObject(v)) {\n v = JSON.stringify(v);\n }\n parts.push(encode(key) + '=' + encode(v));\n });\n });\n serializedParams = parts.join('&');\n }\n if (serializedParams) {\n var hashmarkIndex = url.indexOf('#');\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n return url;\n};","'use strict';\n\nvar utils = require('./../utils');\nfunction InterceptorManager() {\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 */\nInterceptorManager.prototype.use = function use(fulfilled, rejected, options) {\n this.handlers.push({\n fulfilled: fulfilled,\n rejected: 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 */\nInterceptorManager.prototype.eject = function eject(id) {\n if (this.handlers[id]) {\n this.handlers[id] = null;\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 */\nInterceptorManager.prototype.forEach = function forEach(fn) {\n utils.forEach(this.handlers, function forEachHandler(h) {\n if (h !== null) {\n fn(h);\n }\n });\n};\nmodule.exports = InterceptorManager;","'use strict';\n\nvar utils = require('../utils');\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n utils.forEach(headers, function processHeader(value, name) {\n if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n headers[normalizedName] = value;\n delete headers[name];\n }\n });\n};","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n error.config = config;\n if (code) {\n error.code = code;\n }\n error.request = request;\n error.response = response;\n error.isAxiosError = true;\n error.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: this.config,\n code: this.code\n };\n };\n return error;\n};","'use strict';\n\nvar enhanceError = require('./enhanceError');\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 {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n var error = new Error(message);\n return enhanceError(error, config, code, request, response);\n};","'use strict';\n\nvar createError = require('./createError');\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 */\nmodule.exports = function settle(resolve, reject, response) {\n var validateStatus = response.config.validateStatus;\n if (!response.status || !validateStatus || validateStatus(response.status)) {\n resolve(response);\n } else {\n reject(createError('Request failed with status code ' + response.status, response.config, null, response.request, response));\n }\n};","'use strict';\n\nvar utils = require('./../utils');\nmodule.exports = utils.isStandardBrowserEnv() ?\n// Standard browser envs support document.cookie\nfunction standardBrowserEnv() {\n return {\n write: function write(name, value, expires, path, domain, secure) {\n var cookie = [];\n cookie.push(name + '=' + encodeURIComponent(value));\n if (utils.isNumber(expires)) {\n cookie.push('expires=' + new Date(expires).toGMTString());\n }\n if (utils.isString(path)) {\n cookie.push('path=' + path);\n }\n if (utils.isString(domain)) {\n cookie.push('domain=' + domain);\n }\n if (secure === true) {\n cookie.push('secure');\n }\n document.cookie = cookie.join('; ');\n },\n read: function read(name) {\n var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n return match ? decodeURIComponent(match[3]) : null;\n },\n remove: function remove(name) {\n this.write(name, '', Date.now() - 86400000);\n }\n };\n}() :\n// Non standard browser env (web workers, react-native) lack needed support.\nfunction nonStandardBrowserEnv() {\n return {\n write: function write() {},\n read: function read() {\n return null;\n },\n remove: function remove() {}\n };\n}();","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n // A URL is considered absolute if it begins with \"://\" 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};","'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 * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n return relativeURL ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '') : baseURL;\n};","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\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 * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n if (baseURL && !isAbsoluteURL(requestedURL)) {\n return combineURLs(baseURL, requestedURL);\n }\n return requestedURL;\n};","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = ['age', 'authorization', 'content-length', 'content-type', 'etag', 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since', 'last-modified', 'location', 'max-forwards', 'proxy-authorization', 'referer', 'retry-after', 'user-agent'];\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} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n var parsed = {};\n var key;\n var val;\n var i;\n if (!headers) {\n return parsed;\n }\n utils.forEach(headers.split('\\n'), function parser(line) {\n i = line.indexOf(':');\n key = utils.trim(line.substr(0, i)).toLowerCase();\n val = utils.trim(line.substr(i + 1));\n if (key) {\n if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n return;\n }\n if (key === 'set-cookie') {\n parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n } else {\n parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n }\n }\n });\n return parsed;\n};","'use strict';\n\nvar utils = require('./../utils');\nmodule.exports = utils.isStandardBrowserEnv() ?\n// Standard browser envs have full support of the APIs needed to test\n// whether the request URL is of the same origin as current location.\nfunction standardBrowserEnv() {\n var msie = /(msie|trident)/i.test(navigator.userAgent);\n var urlParsingNode = document.createElement('a');\n var originURL;\n\n /**\n * Parse a URL to discover it's components\n *\n * @param {String} url The URL to be parsed\n * @returns {Object}\n */\n function resolveURL(url) {\n var href = url;\n if (msie) {\n // IE needs attribute set twice to normalize properties\n urlParsingNode.setAttribute('href', href);\n href = urlParsingNode.href;\n }\n urlParsingNode.setAttribute('href', href);\n\n // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n return {\n href: urlParsingNode.href,\n protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n host: urlParsingNode.host,\n search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n hostname: urlParsingNode.hostname,\n port: urlParsingNode.port,\n pathname: urlParsingNode.pathname.charAt(0) === '/' ? urlParsingNode.pathname : '/' + urlParsingNode.pathname\n };\n }\n originURL = resolveURL(window.location.href);\n\n /**\n * Determine if a URL shares the same origin as the current location\n *\n * @param {String} requestURL The URL to test\n * @returns {boolean} True if URL shares the same origin, otherwise false\n */\n return function isURLSameOrigin(requestURL) {\n var parsed = utils.isString(requestURL) ? resolveURL(requestURL) : requestURL;\n return parsed.protocol === originURL.protocol && parsed.host === originURL.host;\n };\n}() :\n// Non standard browser envs (web workers, react-native) lack needed support.\nfunction nonStandardBrowserEnv() {\n return function isURLSameOrigin() {\n return true;\n };\n}();","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar cookies = require('./../helpers/cookies');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\nmodule.exports = function xhrAdapter(config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n var requestData = config.data;\n var requestHeaders = config.headers;\n var responseType = config.responseType;\n if (utils.isFormData(requestData)) {\n delete requestHeaders['Content-Type']; // Let the browser set it\n }\n var request = new XMLHttpRequest();\n\n // HTTP basic authentication\n if (config.auth) {\n var username = config.auth.username || '';\n var password = config.auth.password ? unescape(encodeURIComponent(config.auth.password)) : '';\n requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n }\n var fullPath = buildFullPath(config.baseURL, config.url);\n request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n // Set the request timeout in MS\n request.timeout = config.timeout;\n function onloadend() {\n if (!request) {\n return;\n }\n // Prepare the response\n var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n var responseData = !responseType || responseType === 'text' || responseType === 'json' ? request.responseText : request.response;\n var response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config: config,\n request: request\n };\n settle(resolve, reject, response);\n\n // Clean up request\n request = null;\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 reject(createError('Request aborted', config, 'ECONNABORTED', 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(createError('Network Error', config, null, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle timeout\n request.ontimeout = function handleTimeout() {\n var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n if (config.timeoutErrorMessage) {\n timeoutErrorMessage = config.timeoutErrorMessage;\n }\n reject(createError(timeoutErrorMessage, config, config.transitional && config.transitional.clarifyTimeoutError ? 'ETIMEDOUT' : 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\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 if (utils.isStandardBrowserEnv()) {\n // Add xsrf header\n var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ? cookies.read(config.xsrfCookieName) : undefined;\n if (xsrfValue) {\n requestHeaders[config.xsrfHeaderName] = xsrfValue;\n }\n }\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n // Remove Content-Type if data is undefined\n delete requestHeaders[key];\n } else {\n // Otherwise add header to the request\n request.setRequestHeader(key, val);\n }\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 (typeof config.onDownloadProgress === 'function') {\n request.addEventListener('progress', config.onDownloadProgress);\n }\n\n // Not all browsers support upload events\n if (typeof config.onUploadProgress === 'function' && request.upload) {\n request.upload.addEventListener('progress', config.onUploadProgress);\n }\n if (config.cancelToken) {\n // Handle cancellation\n config.cancelToken.promise.then(function onCanceled(cancel) {\n if (!request) {\n return;\n }\n request.abort();\n reject(cancel);\n // Clean up request\n request = null;\n });\n }\n if (!requestData) {\n requestData = null;\n }\n\n // Send the request\n request.send(requestData);\n });\n};","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\nvar enhanceError = require('./core/enhanceError');\nvar DEFAULT_CONTENT_TYPE = {\n 'Content-Type': 'application/x-www-form-urlencoded'\n};\nfunction setContentTypeIfUnset(headers, value) {\n if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n headers['Content-Type'] = value;\n }\n}\nfunction getDefaultAdapter() {\n var adapter;\n if (typeof XMLHttpRequest !== 'undefined') {\n // For browsers use XHR adapter\n adapter = require('./adapters/xhr');\n } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n // For node use HTTP adapter\n adapter = require('./adapters/http');\n }\n return adapter;\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 return (encoder || JSON.stringify)(rawValue);\n}\nvar defaults = {\n transitional: {\n silentJSONParsing: true,\n forcedJSONParsing: true,\n clarifyTimeoutError: false\n },\n adapter: getDefaultAdapter(),\n transformRequest: [function transformRequest(data, headers) {\n normalizeHeaderName(headers, 'Accept');\n normalizeHeaderName(headers, 'Content-Type');\n if (utils.isFormData(data) || utils.isArrayBuffer(data) || utils.isBuffer(data) || utils.isStream(data) || utils.isFile(data) || utils.isBlob(data)) {\n return data;\n }\n if (utils.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils.isURLSearchParams(data)) {\n setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n return data.toString();\n }\n if (utils.isObject(data) || headers && headers['Content-Type'] === 'application/json') {\n setContentTypeIfUnset(headers, 'application/json');\n return stringifySafely(data);\n }\n return data;\n }],\n transformResponse: [function transformResponse(data) {\n var transitional = this.transitional;\n var silentJSONParsing = transitional && transitional.silentJSONParsing;\n var forcedJSONParsing = transitional && transitional.forcedJSONParsing;\n var strictJSONParsing = !silentJSONParsing && this.responseType === 'json';\n if (strictJSONParsing || forcedJSONParsing && utils.isString(data) && data.length) {\n try {\n return JSON.parse(data);\n } catch (e) {\n if (strictJSONParsing) {\n if (e.name === 'SyntaxError') {\n throw enhanceError(e, this, 'E_JSON_PARSE');\n }\n throw e;\n }\n }\n }\n return data;\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 xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n maxContentLength: -1,\n maxBodyLength: -1,\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n }\n};\ndefaults.headers = {\n common: {\n 'Accept': 'application/json, text/plain, */*'\n }\n};\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n defaults.headers[method] = {};\n});\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\nmodule.exports = defaults;","'use strict';\n\nvar utils = require('./../utils');\nvar defaults = require('./../defaults');\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Object|String} data The data to be transformed\n * @param {Array} headers The headers for the request or response\n * @param {Array|Function} fns A single function or Array of functions\n * @returns {*} The resulting transformed data\n */\nmodule.exports = function transformData(data, headers, fns) {\n var context = this || defaults;\n /*eslint no-param-reassign:0*/\n utils.forEach(fns, function transform(fn) {\n data = fn.call(context, data, headers);\n });\n return data;\n};","'use strict';\n\nmodule.exports = function isCancel(value) {\n return !!(value && value.__CANCEL__);\n};","'use strict';\n\nvar utils = require('./../utils');\nvar transformData = require('./transformData');\nvar isCancel = require('../cancel/isCancel');\nvar defaults = require('../defaults');\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nfunction throwIfCancellationRequested(config) {\n if (config.cancelToken) {\n config.cancelToken.throwIfRequested();\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 * @returns {Promise} The Promise to be fulfilled\n */\nmodule.exports = function dispatchRequest(config) {\n throwIfCancellationRequested(config);\n\n // Ensure headers exist\n config.headers = config.headers || {};\n\n // Transform request data\n config.data = transformData.call(config, config.data, config.headers, config.transformRequest);\n\n // Flatten headers\n config.headers = utils.merge(config.headers.common || {}, config.headers[config.method] || {}, config.headers);\n utils.forEach(['delete', 'get', 'head', 'post', 'put', 'patch', 'common'], function cleanHeaderConfig(method) {\n delete config.headers[method];\n });\n var adapter = config.adapter || defaults.adapter;\n return adapter(config).then(function onAdapterResolution(response) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n response.data = transformData.call(config, response.data, response.headers, config.transformResponse);\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(config, reason.response.data, reason.response.headers, config.transformResponse);\n }\n }\n return Promise.reject(reason);\n });\n};","'use strict';\n\nvar utils = require('../utils');\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 * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n var config = {};\n var valueFromConfig2Keys = ['url', 'method', 'data'];\n var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy', 'params'];\n var defaultToConfig2Keys = ['baseURL', 'transformRequest', 'transformResponse', 'paramsSerializer', 'timeout', 'timeoutMessage', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName', 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress', 'decompress', 'maxContentLength', 'maxBodyLength', 'maxRedirects', 'transport', 'httpAgent', 'httpsAgent', 'cancelToken', 'socketPath', 'responseEncoding'];\n var directMergeKeys = ['validateStatus'];\n function getMergedValue(target, source) {\n if (utils.isPlainObject(target) && utils.isPlainObject(source)) {\n return utils.merge(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 function mergeDeepProperties(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n }\n utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n }\n });\n utils.forEach(mergeDeepPropertiesKeys, mergeDeepProperties);\n utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n utils.forEach(directMergeKeys, function merge(prop) {\n if (prop in config2) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (prop in config1) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n var axiosKeys = valueFromConfig2Keys.concat(mergeDeepPropertiesKeys).concat(defaultToConfig2Keys).concat(directMergeKeys);\n var otherKeys = Object.keys(config1).concat(Object.keys(config2)).filter(function filterAxiosKeys(key) {\n return axiosKeys.indexOf(key) === -1;\n });\n utils.forEach(otherKeys, mergeDeepProperties);\n return config;\n};","{\n \"name\": \"axios\",\n \"version\": \"0.21.4\",\n \"description\": \"Promise based HTTP client for the browser and node.js\",\n \"main\": \"index.js\",\n \"scripts\": {\n \"test\": \"grunt test\",\n \"start\": \"node ./sandbox/server.js\",\n \"build\": \"NODE_ENV=production grunt build\",\n \"preversion\": \"npm test\",\n \"version\": \"npm run build && grunt version && git add -A dist && git add CHANGELOG.md bower.json package.json\",\n \"postversion\": \"git push && git push --tags\",\n \"examples\": \"node ./examples/server.js\",\n \"coveralls\": \"cat coverage/lcov.info | ./node_modules/coveralls/bin/coveralls.js\",\n \"fix\": \"eslint --fix lib/**/*.js\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/axios/axios.git\"\n },\n \"keywords\": [\n \"xhr\",\n \"http\",\n \"ajax\",\n \"promise\",\n \"node\"\n ],\n \"author\": \"Matt Zabriskie\",\n \"license\": \"MIT\",\n \"bugs\": {\n \"url\": \"https://github.com/axios/axios/issues\"\n },\n \"homepage\": \"https://axios-http.com\",\n \"devDependencies\": {\n \"coveralls\": \"^3.0.0\",\n \"es6-promise\": \"^4.2.4\",\n \"grunt\": \"^1.3.0\",\n \"grunt-banner\": \"^0.6.0\",\n \"grunt-cli\": \"^1.2.0\",\n \"grunt-contrib-clean\": \"^1.1.0\",\n \"grunt-contrib-watch\": \"^1.0.0\",\n \"grunt-eslint\": \"^23.0.0\",\n \"grunt-karma\": \"^4.0.0\",\n \"grunt-mocha-test\": \"^0.13.3\",\n \"grunt-ts\": \"^6.0.0-beta.19\",\n \"grunt-webpack\": \"^4.0.2\",\n \"istanbul-instrumenter-loader\": \"^1.0.0\",\n \"jasmine-core\": \"^2.4.1\",\n \"karma\": \"^6.3.2\",\n \"karma-chrome-launcher\": \"^3.1.0\",\n \"karma-firefox-launcher\": \"^2.1.0\",\n \"karma-jasmine\": \"^1.1.1\",\n \"karma-jasmine-ajax\": \"^0.1.13\",\n \"karma-safari-launcher\": \"^1.0.0\",\n \"karma-sauce-launcher\": \"^4.3.6\",\n \"karma-sinon\": \"^1.0.5\",\n \"karma-sourcemap-loader\": \"^0.3.8\",\n \"karma-webpack\": \"^4.0.2\",\n \"load-grunt-tasks\": \"^3.5.2\",\n \"minimist\": \"^1.2.0\",\n \"mocha\": \"^8.2.1\",\n \"sinon\": \"^4.5.0\",\n \"terser-webpack-plugin\": \"^4.2.3\",\n \"typescript\": \"^4.0.5\",\n \"url-search-params\": \"^0.10.0\",\n \"webpack\": \"^4.44.2\",\n \"webpack-dev-server\": \"^3.11.0\"\n },\n \"browser\": {\n \"./lib/adapters/http.js\": \"./lib/adapters/xhr.js\"\n },\n \"jsdelivr\": \"dist/axios.min.js\",\n \"unpkg\": \"dist/axios.min.js\",\n \"typings\": \"./index.d.ts\",\n \"dependencies\": {\n \"follow-redirects\": \"^1.14.0\"\n },\n \"bundlesize\": [\n {\n \"path\": \"./dist/axios.min.js\",\n \"threshold\": \"5kB\"\n }\n ]\n}\n","'use strict';\n\nvar pkg = require('./../../package.json');\nvar validators = {};\n\n// eslint-disable-next-line func-names\n['object', 'boolean', 'number', 'function', 'string', 'symbol'].forEach(function (type, i) {\n validators[type] = function validator(thing) {\n return typeof thing === type || 'a' + (i < 1 ? 'n ' : ' ') + type;\n };\n});\nvar deprecatedWarnings = {};\nvar currentVerArr = pkg.version.split('.');\n\n/**\n * Compare package versions\n * @param {string} version\n * @param {string?} thanVersion\n * @returns {boolean}\n */\nfunction isOlderVersion(version, thanVersion) {\n var pkgVersionArr = thanVersion ? thanVersion.split('.') : currentVerArr;\n var destVer = version.split('.');\n for (var i = 0; i < 3; i++) {\n if (pkgVersionArr[i] > destVer[i]) {\n return true;\n } else if (pkgVersionArr[i] < destVer[i]) {\n return false;\n }\n }\n return false;\n}\n\n/**\n * Transitional option validator\n * @param {function|boolean?} validator\n * @param {string?} version\n * @param {string} message\n * @returns {function}\n */\nvalidators.transitional = function transitional(validator, version, message) {\n var isDeprecated = version && isOlderVersion(version);\n function formatMessage(opt, desc) {\n return '[Axios v' + pkg.version + '] Transitional option \\'' + opt + '\\'' + desc + (message ? '. ' + message : '');\n }\n\n // eslint-disable-next-line func-names\n return function (value, opt, opts) {\n if (validator === false) {\n throw new Error(formatMessage(opt, ' has been removed in ' + version));\n }\n if (isDeprecated && !deprecatedWarnings[opt]) {\n deprecatedWarnings[opt] = true;\n // eslint-disable-next-line no-console\n console.warn(formatMessage(opt, ' has been deprecated since v' + version + ' and will be removed in the near future'));\n }\n return validator ? validator(value, opt, opts) : true;\n };\n};\n\n/**\n * Assert object's properties type\n * @param {object} options\n * @param {object} schema\n * @param {boolean?} allowUnknown\n */\n\nfunction assertOptions(options, schema, allowUnknown) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n var keys = Object.keys(options);\n var i = keys.length;\n while (i-- > 0) {\n var opt = keys[i];\n var validator = schema[opt];\n if (validator) {\n var value = options[opt];\n var result = value === undefined || validator(value, opt, options);\n if (result !== true) {\n throw new TypeError('option ' + opt + ' must be ' + result);\n }\n continue;\n }\n if (allowUnknown !== true) {\n throw Error('Unknown option ' + opt);\n }\n }\n}\nmodule.exports = {\n isOlderVersion: isOlderVersion,\n assertOptions: assertOptions,\n validators: validators\n};","'use strict';\n\nvar utils = require('./../utils');\nvar buildURL = require('../helpers/buildURL');\nvar InterceptorManager = require('./InterceptorManager');\nvar dispatchRequest = require('./dispatchRequest');\nvar mergeConfig = require('./mergeConfig');\nvar validator = require('../helpers/validator');\nvar validators = validator.validators;\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n */\nfunction Axios(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 {Object} config The config specific for this request (merged with this.defaults)\n */\nAxios.prototype.request = function request(config) {\n /*eslint no-param-reassign:0*/\n // Allow for axios('example/url'[, config]) a la fetch API\n if (typeof config === 'string') {\n config = arguments[1] || {};\n config.url = arguments[0];\n } else {\n config = config || {};\n }\n config = mergeConfig(this.defaults, config);\n\n // Set config.method\n if (config.method) {\n config.method = config.method.toLowerCase();\n } else if (this.defaults.method) {\n config.method = this.defaults.method.toLowerCase();\n } else {\n config.method = 'get';\n }\n var transitional = config.transitional;\n if (transitional !== undefined) {\n validator.assertOptions(transitional, {\n silentJSONParsing: validators.transitional(validators.boolean, '1.0.0'),\n forcedJSONParsing: validators.transitional(validators.boolean, '1.0.0'),\n clarifyTimeoutError: validators.transitional(validators.boolean, '1.0.0')\n }, false);\n }\n\n // filter out skipped interceptors\n var requestInterceptorChain = [];\n var synchronousRequestInterceptors = true;\n this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n if (typeof interceptor.runWhen === 'function' && interceptor.runWhen(config) === false) {\n return;\n }\n synchronousRequestInterceptors = synchronousRequestInterceptors && interceptor.synchronous;\n requestInterceptorChain.unshift(interceptor.fulfilled, interceptor.rejected);\n });\n var responseInterceptorChain = [];\n this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n responseInterceptorChain.push(interceptor.fulfilled, interceptor.rejected);\n });\n var promise;\n if (!synchronousRequestInterceptors) {\n var chain = [dispatchRequest, undefined];\n Array.prototype.unshift.apply(chain, requestInterceptorChain);\n chain = chain.concat(responseInterceptorChain);\n promise = Promise.resolve(config);\n while (chain.length) {\n promise = promise.then(chain.shift(), chain.shift());\n }\n return promise;\n }\n var newConfig = config;\n while (requestInterceptorChain.length) {\n var onFulfilled = requestInterceptorChain.shift();\n var onRejected = requestInterceptorChain.shift();\n try {\n newConfig = onFulfilled(newConfig);\n } catch (error) {\n onRejected(error);\n break;\n }\n }\n try {\n promise = dispatchRequest(newConfig);\n } catch (error) {\n return Promise.reject(error);\n }\n while (responseInterceptorChain.length) {\n promise = promise.then(responseInterceptorChain.shift(), responseInterceptorChain.shift());\n }\n return promise;\n};\nAxios.prototype.getUri = function getUri(config) {\n config = mergeConfig(this.defaults, config);\n return buildURL(config.url, config.params, config.paramsSerializer).replace(/^\\?/, '');\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: method,\n url: url,\n data: (config || {}).data\n }));\n };\n});\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function (url, data, config) {\n return this.request(mergeConfig(config || {}, {\n method: method,\n url: url,\n data: data\n }));\n };\n});\nmodule.exports = Axios;","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n this.message = message;\n}\nCancel.prototype.toString = function toString() {\n return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\nCancel.prototype.__CANCEL__ = true;\nmodule.exports = Cancel;","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n if (typeof executor !== 'function') {\n throw new TypeError('executor must be a function.');\n }\n var resolvePromise;\n this.promise = new Promise(function promiseExecutor(resolve) {\n resolvePromise = resolve;\n });\n var token = this;\n executor(function cancel(message) {\n if (token.reason) {\n // Cancellation has already been requested\n return;\n }\n token.reason = new Cancel(message);\n resolvePromise(token.reason);\n });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n if (this.reason) {\n throw this.reason;\n }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n var cancel;\n var token = new CancelToken(function executor(c) {\n cancel = c;\n });\n return {\n token: token,\n cancel: cancel\n };\n};\nmodule.exports = CancelToken;","'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 * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n};","'use strict';\n\n/**\n * Determines whether the payload is an error thrown by Axios\n *\n * @param {*} payload The value to test\n * @returns {boolean} True if the payload is an error thrown by Axios, otherwise false\n */\nmodule.exports = function isAxiosError(payload) {\n return typeof payload === 'object' && payload.isAxiosError === true;\n};","'use strict';\n\nvar utils = require('./utils');\nvar bind = require('./helpers/bind');\nvar Axios = require('./core/Axios');\nvar mergeConfig = require('./core/mergeConfig');\nvar defaults = require('./defaults');\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n * @return {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n var context = new Axios(defaultConfig);\n var instance = bind(Axios.prototype.request, context);\n\n // Copy axios.prototype to instance\n utils.extend(instance, Axios.prototype, context);\n\n // Copy context to instance\n utils.extend(instance, context);\n return instance;\n}\n\n// Create the default instance to be exported\nvar axios = createInstance(defaults);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios;\n\n// Factory for creating new instances\naxios.create = function create(instanceConfig) {\n return createInstance(mergeConfig(axios.defaults, instanceConfig));\n};\n\n// Expose Cancel & CancelToken\naxios.Cancel = require('./cancel/Cancel');\naxios.CancelToken = require('./cancel/CancelToken');\naxios.isCancel = require('./cancel/isCancel');\n\n// Expose all/spread\naxios.all = function all(promises) {\n return Promise.all(promises);\n};\naxios.spread = require('./helpers/spread');\n\n// Expose isAxiosError\naxios.isAxiosError = require('./helpers/isAxiosError');\nmodule.exports = axios;\n\n// Allow use of default import syntax in TypeScript\nmodule.exports.default = axios;","module.exports = require('./lib/axios');","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HttpWrapper = void 0;\nconst axios_1 = __importDefault(require(\"axios\"));\nconst LOGMAXLEN = 120;\nconst DEFAULT_TIMEOUT = 15000;\nclass HttpWrapper {\n constructor(opts = {}, logreq = false) {\n this.provider = axios_1.default.create(Object.assign({\n timeout: DEFAULT_TIMEOUT,\n headers: {\n 'Content-Type': 'application/json'\n }\n }, opts));\n this.logreq = logreq;\n if (this.logreq) {\n this.provider.interceptors.response.use(function (response) {\n console.log('got response:', response.config.url, JSON.stringify(response.data).slice(0, LOGMAXLEN));\n return response;\n }, async function (error) {\n const errData = error.response != null ? error.response.data : {\n error: error.message\n };\n const errStr = (typeof errData === 'string' ? errData : JSON.stringify(errData)).slice(0, LOGMAXLEN);\n const errUrl = error.response != null ? error.response.config.url : error.address;\n console.log('got response:', errUrl, 'err=', errStr);\n return await Promise.reject(error);\n });\n }\n }\n async sendPromise(url, jsonRequestData) {\n if (this.logreq) {\n console.log('sending request:', url, JSON.stringify(jsonRequestData !== null && jsonRequestData !== void 0 ? jsonRequestData : {}).slice(0, LOGMAXLEN));\n }\n const response = await this.provider.request({\n url: url.toString(),\n method: jsonRequestData != null ? 'POST' : 'GET',\n data: jsonRequestData\n });\n return response.data;\n }\n}\nexports.HttpWrapper = HttpWrapper;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.notNull = void 0;\nfunction notNull(value) {\n return value !== null && value !== undefined;\n}\nexports.notNull = notNull;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.cloneRelayRequest = void 0;\nfunction cloneRelayRequest(relayRequest) {\n return {\n request: Object.assign({}, relayRequest.request),\n relayData: Object.assign({}, relayRequest.relayData)\n };\n}\nexports.cloneRelayRequest = cloneRelayRequest;\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert(val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits(ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN(number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n BN.BN = BN;\n BN.wordSize = 26;\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {}\n BN.isBN = function isBN(num) {\n if (num instanceof BN) {\n return true;\n }\n return num !== null && typeof num === 'object' && num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n BN.max = function max(left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n BN.min = function min(left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n BN.prototype._init = function init(number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n BN.prototype._initNumber = function _initNumber(number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff, 1];\n this.length = 3;\n }\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n BN.prototype._initArray = function _initArray(number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | number[i - 1] << 8 | number[i - 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | number[i + 1] << 8 | number[i + 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n function parseHex4Bits(string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return c - 48 & 0xf;\n }\n }\n function parseHexByte(string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n BN.prototype._parseHex = function _parseHex(number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n this.strip();\n };\n function parseBase(str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n BN.prototype._parseBase = function _parseBase(number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = limbPow / base | 0;\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n this.strip();\n };\n BN.prototype.copy = function copy(dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n BN.prototype.clone = function clone() {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n BN.prototype._expand = function _expand(size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip() {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n BN.prototype._normSign = function _normSign() {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n BN.prototype.inspect = function inspect() {\n return (this.red ? '';\n };\n\n /*\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n */\n\n var zeros = ['', '0', '00', '000', '0000', '00000', '000000', '0000000', '00000000', '000000000', '0000000000', '00000000000', '000000000000', '0000000000000', '00000000000000', '000000000000000', '0000000000000000', '00000000000000000', '000000000000000000', '0000000000000000000', '00000000000000000000', '000000000000000000000', '0000000000000000000000', '00000000000000000000000', '000000000000000000000000', '0000000000000000000000000'];\n var groupSizes = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5];\n var groupBases = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];\n BN.prototype.toString = function toString(base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = ((w << off | carry) & 0xffffff).toString(16);\n carry = w >>> 24 - off & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n assert(false, 'Base should be between 2 and 36');\n };\n BN.prototype.toNumber = function toNumber() {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + this.words[1] * 0x4000000;\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return this.negative !== 0 ? -ret : ret;\n };\n BN.prototype.toJSON = function toJSON() {\n return this.toString(16);\n };\n BN.prototype.toBuffer = function toBuffer(endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n BN.prototype.toArray = function toArray(endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n BN.prototype.toArrayLike = function toArrayLike(ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[i] = b;\n }\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n return res;\n };\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits(w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits(w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n BN.prototype._zeroBits = function _zeroBits(w) {\n // Short-cut\n if (w === 0) return 26;\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength() {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n function toBitArray(num) {\n var w = new Array(num.bitLength());\n for (var bit = 0; bit < w.length; bit++) {\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n w[bit] = (num.words[off] & 1 << wbit) >>> wbit;\n }\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits() {\n if (this.isZero()) return 0;\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n BN.prototype.byteLength = function byteLength() {\n return Math.ceil(this.bitLength() / 8);\n };\n BN.prototype.toTwos = function toTwos(width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n BN.prototype.fromTwos = function fromTwos(width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n BN.prototype.isNeg = function isNeg() {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg() {\n return this.clone().ineg();\n };\n BN.prototype.ineg = function ineg() {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor(num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n return this.strip();\n };\n BN.prototype.ior = function ior(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or(num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n BN.prototype.uor = function uor(num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand(num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n this.length = b.length;\n return this.strip();\n };\n BN.prototype.iand = function iand(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and(num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n BN.prototype.uand = function uand(num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor(num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = a.length;\n return this.strip();\n };\n BN.prototype.ixor = function ixor(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor(num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n BN.prototype.uxor = function uxor(num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn(width) {\n assert(typeof width === 'number' && width >= 0);\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & 0x3ffffff >> 26 - bitsLeft;\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n BN.prototype.notn = function notn(width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn(bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n this._expand(off + 1);\n if (val) {\n this.words[off] = this.words[off] | 1 << wbit;\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd(num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add(num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n if (this.length > num.length) return this.clone().iadd(num);\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub(num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = Math.max(this.length, i);\n if (a !== this) {\n this.negative = 1;\n }\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub(num) {\n return this.clone().isub(num);\n };\n function smallMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = self.length + num.length | 0;\n out.length = len;\n len = len - 1 | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n var carry = r / 0x4000000 | 0;\n out.words[0] = lo;\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += r / 0x4000000 | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo(self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = mid + Math.imul(ah0, bl0) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w0 >>> 26) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = mid + Math.imul(ah1, bl0) | 0;\n hi = Math.imul(ah1, bh0);\n lo = lo + Math.imul(al0, bl1) | 0;\n mid = mid + Math.imul(al0, bh1) | 0;\n mid = mid + Math.imul(ah0, bl1) | 0;\n hi = hi + Math.imul(ah0, bh1) | 0;\n var w1 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w1 >>> 26) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = mid + Math.imul(ah2, bl0) | 0;\n hi = Math.imul(ah2, bh0);\n lo = lo + Math.imul(al1, bl1) | 0;\n mid = mid + Math.imul(al1, bh1) | 0;\n mid = mid + Math.imul(ah1, bl1) | 0;\n hi = hi + Math.imul(ah1, bh1) | 0;\n lo = lo + Math.imul(al0, bl2) | 0;\n mid = mid + Math.imul(al0, bh2) | 0;\n mid = mid + Math.imul(ah0, bl2) | 0;\n hi = hi + Math.imul(ah0, bh2) | 0;\n var w2 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w2 >>> 26) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = mid + Math.imul(ah3, bl0) | 0;\n hi = Math.imul(ah3, bh0);\n lo = lo + Math.imul(al2, bl1) | 0;\n mid = mid + Math.imul(al2, bh1) | 0;\n mid = mid + Math.imul(ah2, bl1) | 0;\n hi = hi + Math.imul(ah2, bh1) | 0;\n lo = lo + Math.imul(al1, bl2) | 0;\n mid = mid + Math.imul(al1, bh2) | 0;\n mid = mid + Math.imul(ah1, bl2) | 0;\n hi = hi + Math.imul(ah1, bh2) | 0;\n lo = lo + Math.imul(al0, bl3) | 0;\n mid = mid + Math.imul(al0, bh3) | 0;\n mid = mid + Math.imul(ah0, bl3) | 0;\n hi = hi + Math.imul(ah0, bh3) | 0;\n var w3 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w3 >>> 26) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = mid + Math.imul(ah4, bl0) | 0;\n hi = Math.imul(ah4, bh0);\n lo = lo + Math.imul(al3, bl1) | 0;\n mid = mid + Math.imul(al3, bh1) | 0;\n mid = mid + Math.imul(ah3, bl1) | 0;\n hi = hi + Math.imul(ah3, bh1) | 0;\n lo = lo + Math.imul(al2, bl2) | 0;\n mid = mid + Math.imul(al2, bh2) | 0;\n mid = mid + Math.imul(ah2, bl2) | 0;\n hi = hi + Math.imul(ah2, bh2) | 0;\n lo = lo + Math.imul(al1, bl3) | 0;\n mid = mid + Math.imul(al1, bh3) | 0;\n mid = mid + Math.imul(ah1, bl3) | 0;\n hi = hi + Math.imul(ah1, bh3) | 0;\n lo = lo + Math.imul(al0, bl4) | 0;\n mid = mid + Math.imul(al0, bh4) | 0;\n mid = mid + Math.imul(ah0, bl4) | 0;\n hi = hi + Math.imul(ah0, bh4) | 0;\n var w4 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w4 >>> 26) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = mid + Math.imul(ah5, bl0) | 0;\n hi = Math.imul(ah5, bh0);\n lo = lo + Math.imul(al4, bl1) | 0;\n mid = mid + Math.imul(al4, bh1) | 0;\n mid = mid + Math.imul(ah4, bl1) | 0;\n hi = hi + Math.imul(ah4, bh1) | 0;\n lo = lo + Math.imul(al3, bl2) | 0;\n mid = mid + Math.imul(al3, bh2) | 0;\n mid = mid + Math.imul(ah3, bl2) | 0;\n hi = hi + Math.imul(ah3, bh2) | 0;\n lo = lo + Math.imul(al2, bl3) | 0;\n mid = mid + Math.imul(al2, bh3) | 0;\n mid = mid + Math.imul(ah2, bl3) | 0;\n hi = hi + Math.imul(ah2, bh3) | 0;\n lo = lo + Math.imul(al1, bl4) | 0;\n mid = mid + Math.imul(al1, bh4) | 0;\n mid = mid + Math.imul(ah1, bl4) | 0;\n hi = hi + Math.imul(ah1, bh4) | 0;\n lo = lo + Math.imul(al0, bl5) | 0;\n mid = mid + Math.imul(al0, bh5) | 0;\n mid = mid + Math.imul(ah0, bl5) | 0;\n hi = hi + Math.imul(ah0, bh5) | 0;\n var w5 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w5 >>> 26) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = mid + Math.imul(ah6, bl0) | 0;\n hi = Math.imul(ah6, bh0);\n lo = lo + Math.imul(al5, bl1) | 0;\n mid = mid + Math.imul(al5, bh1) | 0;\n mid = mid + Math.imul(ah5, bl1) | 0;\n hi = hi + Math.imul(ah5, bh1) | 0;\n lo = lo + Math.imul(al4, bl2) | 0;\n mid = mid + Math.imul(al4, bh2) | 0;\n mid = mid + Math.imul(ah4, bl2) | 0;\n hi = hi + Math.imul(ah4, bh2) | 0;\n lo = lo + Math.imul(al3, bl3) | 0;\n mid = mid + Math.imul(al3, bh3) | 0;\n mid = mid + Math.imul(ah3, bl3) | 0;\n hi = hi + Math.imul(ah3, bh3) | 0;\n lo = lo + Math.imul(al2, bl4) | 0;\n mid = mid + Math.imul(al2, bh4) | 0;\n mid = mid + Math.imul(ah2, bl4) | 0;\n hi = hi + Math.imul(ah2, bh4) | 0;\n lo = lo + Math.imul(al1, bl5) | 0;\n mid = mid + Math.imul(al1, bh5) | 0;\n mid = mid + Math.imul(ah1, bl5) | 0;\n hi = hi + Math.imul(ah1, bh5) | 0;\n lo = lo + Math.imul(al0, bl6) | 0;\n mid = mid + Math.imul(al0, bh6) | 0;\n mid = mid + Math.imul(ah0, bl6) | 0;\n hi = hi + Math.imul(ah0, bh6) | 0;\n var w6 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w6 >>> 26) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = mid + Math.imul(ah7, bl0) | 0;\n hi = Math.imul(ah7, bh0);\n lo = lo + Math.imul(al6, bl1) | 0;\n mid = mid + Math.imul(al6, bh1) | 0;\n mid = mid + Math.imul(ah6, bl1) | 0;\n hi = hi + Math.imul(ah6, bh1) | 0;\n lo = lo + Math.imul(al5, bl2) | 0;\n mid = mid + Math.imul(al5, bh2) | 0;\n mid = mid + Math.imul(ah5, bl2) | 0;\n hi = hi + Math.imul(ah5, bh2) | 0;\n lo = lo + Math.imul(al4, bl3) | 0;\n mid = mid + Math.imul(al4, bh3) | 0;\n mid = mid + Math.imul(ah4, bl3) | 0;\n hi = hi + Math.imul(ah4, bh3) | 0;\n lo = lo + Math.imul(al3, bl4) | 0;\n mid = mid + Math.imul(al3, bh4) | 0;\n mid = mid + Math.imul(ah3, bl4) | 0;\n hi = hi + Math.imul(ah3, bh4) | 0;\n lo = lo + Math.imul(al2, bl5) | 0;\n mid = mid + Math.imul(al2, bh5) | 0;\n mid = mid + Math.imul(ah2, bl5) | 0;\n hi = hi + Math.imul(ah2, bh5) | 0;\n lo = lo + Math.imul(al1, bl6) | 0;\n mid = mid + Math.imul(al1, bh6) | 0;\n mid = mid + Math.imul(ah1, bl6) | 0;\n hi = hi + Math.imul(ah1, bh6) | 0;\n lo = lo + Math.imul(al0, bl7) | 0;\n mid = mid + Math.imul(al0, bh7) | 0;\n mid = mid + Math.imul(ah0, bl7) | 0;\n hi = hi + Math.imul(ah0, bh7) | 0;\n var w7 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w7 >>> 26) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = mid + Math.imul(ah8, bl0) | 0;\n hi = Math.imul(ah8, bh0);\n lo = lo + Math.imul(al7, bl1) | 0;\n mid = mid + Math.imul(al7, bh1) | 0;\n mid = mid + Math.imul(ah7, bl1) | 0;\n hi = hi + Math.imul(ah7, bh1) | 0;\n lo = lo + Math.imul(al6, bl2) | 0;\n mid = mid + Math.imul(al6, bh2) | 0;\n mid = mid + Math.imul(ah6, bl2) | 0;\n hi = hi + Math.imul(ah6, bh2) | 0;\n lo = lo + Math.imul(al5, bl3) | 0;\n mid = mid + Math.imul(al5, bh3) | 0;\n mid = mid + Math.imul(ah5, bl3) | 0;\n hi = hi + Math.imul(ah5, bh3) | 0;\n lo = lo + Math.imul(al4, bl4) | 0;\n mid = mid + Math.imul(al4, bh4) | 0;\n mid = mid + Math.imul(ah4, bl4) | 0;\n hi = hi + Math.imul(ah4, bh4) | 0;\n lo = lo + Math.imul(al3, bl5) | 0;\n mid = mid + Math.imul(al3, bh5) | 0;\n mid = mid + Math.imul(ah3, bl5) | 0;\n hi = hi + Math.imul(ah3, bh5) | 0;\n lo = lo + Math.imul(al2, bl6) | 0;\n mid = mid + Math.imul(al2, bh6) | 0;\n mid = mid + Math.imul(ah2, bl6) | 0;\n hi = hi + Math.imul(ah2, bh6) | 0;\n lo = lo + Math.imul(al1, bl7) | 0;\n mid = mid + Math.imul(al1, bh7) | 0;\n mid = mid + Math.imul(ah1, bl7) | 0;\n hi = hi + Math.imul(ah1, bh7) | 0;\n lo = lo + Math.imul(al0, bl8) | 0;\n mid = mid + Math.imul(al0, bh8) | 0;\n mid = mid + Math.imul(ah0, bl8) | 0;\n hi = hi + Math.imul(ah0, bh8) | 0;\n var w8 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w8 >>> 26) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = mid + Math.imul(ah9, bl0) | 0;\n hi = Math.imul(ah9, bh0);\n lo = lo + Math.imul(al8, bl1) | 0;\n mid = mid + Math.imul(al8, bh1) | 0;\n mid = mid + Math.imul(ah8, bl1) | 0;\n hi = hi + Math.imul(ah8, bh1) | 0;\n lo = lo + Math.imul(al7, bl2) | 0;\n mid = mid + Math.imul(al7, bh2) | 0;\n mid = mid + Math.imul(ah7, bl2) | 0;\n hi = hi + Math.imul(ah7, bh2) | 0;\n lo = lo + Math.imul(al6, bl3) | 0;\n mid = mid + Math.imul(al6, bh3) | 0;\n mid = mid + Math.imul(ah6, bl3) | 0;\n hi = hi + Math.imul(ah6, bh3) | 0;\n lo = lo + Math.imul(al5, bl4) | 0;\n mid = mid + Math.imul(al5, bh4) | 0;\n mid = mid + Math.imul(ah5, bl4) | 0;\n hi = hi + Math.imul(ah5, bh4) | 0;\n lo = lo + Math.imul(al4, bl5) | 0;\n mid = mid + Math.imul(al4, bh5) | 0;\n mid = mid + Math.imul(ah4, bl5) | 0;\n hi = hi + Math.imul(ah4, bh5) | 0;\n lo = lo + Math.imul(al3, bl6) | 0;\n mid = mid + Math.imul(al3, bh6) | 0;\n mid = mid + Math.imul(ah3, bl6) | 0;\n hi = hi + Math.imul(ah3, bh6) | 0;\n lo = lo + Math.imul(al2, bl7) | 0;\n mid = mid + Math.imul(al2, bh7) | 0;\n mid = mid + Math.imul(ah2, bl7) | 0;\n hi = hi + Math.imul(ah2, bh7) | 0;\n lo = lo + Math.imul(al1, bl8) | 0;\n mid = mid + Math.imul(al1, bh8) | 0;\n mid = mid + Math.imul(ah1, bl8) | 0;\n hi = hi + Math.imul(ah1, bh8) | 0;\n lo = lo + Math.imul(al0, bl9) | 0;\n mid = mid + Math.imul(al0, bh9) | 0;\n mid = mid + Math.imul(ah0, bl9) | 0;\n hi = hi + Math.imul(ah0, bh9) | 0;\n var w9 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w9 >>> 26) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = mid + Math.imul(ah9, bl1) | 0;\n hi = Math.imul(ah9, bh1);\n lo = lo + Math.imul(al8, bl2) | 0;\n mid = mid + Math.imul(al8, bh2) | 0;\n mid = mid + Math.imul(ah8, bl2) | 0;\n hi = hi + Math.imul(ah8, bh2) | 0;\n lo = lo + Math.imul(al7, bl3) | 0;\n mid = mid + Math.imul(al7, bh3) | 0;\n mid = mid + Math.imul(ah7, bl3) | 0;\n hi = hi + Math.imul(ah7, bh3) | 0;\n lo = lo + Math.imul(al6, bl4) | 0;\n mid = mid + Math.imul(al6, bh4) | 0;\n mid = mid + Math.imul(ah6, bl4) | 0;\n hi = hi + Math.imul(ah6, bh4) | 0;\n lo = lo + Math.imul(al5, bl5) | 0;\n mid = mid + Math.imul(al5, bh5) | 0;\n mid = mid + Math.imul(ah5, bl5) | 0;\n hi = hi + Math.imul(ah5, bh5) | 0;\n lo = lo + Math.imul(al4, bl6) | 0;\n mid = mid + Math.imul(al4, bh6) | 0;\n mid = mid + Math.imul(ah4, bl6) | 0;\n hi = hi + Math.imul(ah4, bh6) | 0;\n lo = lo + Math.imul(al3, bl7) | 0;\n mid = mid + Math.imul(al3, bh7) | 0;\n mid = mid + Math.imul(ah3, bl7) | 0;\n hi = hi + Math.imul(ah3, bh7) | 0;\n lo = lo + Math.imul(al2, bl8) | 0;\n mid = mid + Math.imul(al2, bh8) | 0;\n mid = mid + Math.imul(ah2, bl8) | 0;\n hi = hi + Math.imul(ah2, bh8) | 0;\n lo = lo + Math.imul(al1, bl9) | 0;\n mid = mid + Math.imul(al1, bh9) | 0;\n mid = mid + Math.imul(ah1, bl9) | 0;\n hi = hi + Math.imul(ah1, bh9) | 0;\n var w10 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w10 >>> 26) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = mid + Math.imul(ah9, bl2) | 0;\n hi = Math.imul(ah9, bh2);\n lo = lo + Math.imul(al8, bl3) | 0;\n mid = mid + Math.imul(al8, bh3) | 0;\n mid = mid + Math.imul(ah8, bl3) | 0;\n hi = hi + Math.imul(ah8, bh3) | 0;\n lo = lo + Math.imul(al7, bl4) | 0;\n mid = mid + Math.imul(al7, bh4) | 0;\n mid = mid + Math.imul(ah7, bl4) | 0;\n hi = hi + Math.imul(ah7, bh4) | 0;\n lo = lo + Math.imul(al6, bl5) | 0;\n mid = mid + Math.imul(al6, bh5) | 0;\n mid = mid + Math.imul(ah6, bl5) | 0;\n hi = hi + Math.imul(ah6, bh5) | 0;\n lo = lo + Math.imul(al5, bl6) | 0;\n mid = mid + Math.imul(al5, bh6) | 0;\n mid = mid + Math.imul(ah5, bl6) | 0;\n hi = hi + Math.imul(ah5, bh6) | 0;\n lo = lo + Math.imul(al4, bl7) | 0;\n mid = mid + Math.imul(al4, bh7) | 0;\n mid = mid + Math.imul(ah4, bl7) | 0;\n hi = hi + Math.imul(ah4, bh7) | 0;\n lo = lo + Math.imul(al3, bl8) | 0;\n mid = mid + Math.imul(al3, bh8) | 0;\n mid = mid + Math.imul(ah3, bl8) | 0;\n hi = hi + Math.imul(ah3, bh8) | 0;\n lo = lo + Math.imul(al2, bl9) | 0;\n mid = mid + Math.imul(al2, bh9) | 0;\n mid = mid + Math.imul(ah2, bl9) | 0;\n hi = hi + Math.imul(ah2, bh9) | 0;\n var w11 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w11 >>> 26) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = mid + Math.imul(ah9, bl3) | 0;\n hi = Math.imul(ah9, bh3);\n lo = lo + Math.imul(al8, bl4) | 0;\n mid = mid + Math.imul(al8, bh4) | 0;\n mid = mid + Math.imul(ah8, bl4) | 0;\n hi = hi + Math.imul(ah8, bh4) | 0;\n lo = lo + Math.imul(al7, bl5) | 0;\n mid = mid + Math.imul(al7, bh5) | 0;\n mid = mid + Math.imul(ah7, bl5) | 0;\n hi = hi + Math.imul(ah7, bh5) | 0;\n lo = lo + Math.imul(al6, bl6) | 0;\n mid = mid + Math.imul(al6, bh6) | 0;\n mid = mid + Math.imul(ah6, bl6) | 0;\n hi = hi + Math.imul(ah6, bh6) | 0;\n lo = lo + Math.imul(al5, bl7) | 0;\n mid = mid + Math.imul(al5, bh7) | 0;\n mid = mid + Math.imul(ah5, bl7) | 0;\n hi = hi + Math.imul(ah5, bh7) | 0;\n lo = lo + Math.imul(al4, bl8) | 0;\n mid = mid + Math.imul(al4, bh8) | 0;\n mid = mid + Math.imul(ah4, bl8) | 0;\n hi = hi + Math.imul(ah4, bh8) | 0;\n lo = lo + Math.imul(al3, bl9) | 0;\n mid = mid + Math.imul(al3, bh9) | 0;\n mid = mid + Math.imul(ah3, bl9) | 0;\n hi = hi + Math.imul(ah3, bh9) | 0;\n var w12 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w12 >>> 26) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = mid + Math.imul(ah9, bl4) | 0;\n hi = Math.imul(ah9, bh4);\n lo = lo + Math.imul(al8, bl5) | 0;\n mid = mid + Math.imul(al8, bh5) | 0;\n mid = mid + Math.imul(ah8, bl5) | 0;\n hi = hi + Math.imul(ah8, bh5) | 0;\n lo = lo + Math.imul(al7, bl6) | 0;\n mid = mid + Math.imul(al7, bh6) | 0;\n mid = mid + Math.imul(ah7, bl6) | 0;\n hi = hi + Math.imul(ah7, bh6) | 0;\n lo = lo + Math.imul(al6, bl7) | 0;\n mid = mid + Math.imul(al6, bh7) | 0;\n mid = mid + Math.imul(ah6, bl7) | 0;\n hi = hi + Math.imul(ah6, bh7) | 0;\n lo = lo + Math.imul(al5, bl8) | 0;\n mid = mid + Math.imul(al5, bh8) | 0;\n mid = mid + Math.imul(ah5, bl8) | 0;\n hi = hi + Math.imul(ah5, bh8) | 0;\n lo = lo + Math.imul(al4, bl9) | 0;\n mid = mid + Math.imul(al4, bh9) | 0;\n mid = mid + Math.imul(ah4, bl9) | 0;\n hi = hi + Math.imul(ah4, bh9) | 0;\n var w13 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w13 >>> 26) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = mid + Math.imul(ah9, bl5) | 0;\n hi = Math.imul(ah9, bh5);\n lo = lo + Math.imul(al8, bl6) | 0;\n mid = mid + Math.imul(al8, bh6) | 0;\n mid = mid + Math.imul(ah8, bl6) | 0;\n hi = hi + Math.imul(ah8, bh6) | 0;\n lo = lo + Math.imul(al7, bl7) | 0;\n mid = mid + Math.imul(al7, bh7) | 0;\n mid = mid + Math.imul(ah7, bl7) | 0;\n hi = hi + Math.imul(ah7, bh7) | 0;\n lo = lo + Math.imul(al6, bl8) | 0;\n mid = mid + Math.imul(al6, bh8) | 0;\n mid = mid + Math.imul(ah6, bl8) | 0;\n hi = hi + Math.imul(ah6, bh8) | 0;\n lo = lo + Math.imul(al5, bl9) | 0;\n mid = mid + Math.imul(al5, bh9) | 0;\n mid = mid + Math.imul(ah5, bl9) | 0;\n hi = hi + Math.imul(ah5, bh9) | 0;\n var w14 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w14 >>> 26) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = mid + Math.imul(ah9, bl6) | 0;\n hi = Math.imul(ah9, bh6);\n lo = lo + Math.imul(al8, bl7) | 0;\n mid = mid + Math.imul(al8, bh7) | 0;\n mid = mid + Math.imul(ah8, bl7) | 0;\n hi = hi + Math.imul(ah8, bh7) | 0;\n lo = lo + Math.imul(al7, bl8) | 0;\n mid = mid + Math.imul(al7, bh8) | 0;\n mid = mid + Math.imul(ah7, bl8) | 0;\n hi = hi + Math.imul(ah7, bh8) | 0;\n lo = lo + Math.imul(al6, bl9) | 0;\n mid = mid + Math.imul(al6, bh9) | 0;\n mid = mid + Math.imul(ah6, bl9) | 0;\n hi = hi + Math.imul(ah6, bh9) | 0;\n var w15 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w15 >>> 26) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = mid + Math.imul(ah9, bl7) | 0;\n hi = Math.imul(ah9, bh7);\n lo = lo + Math.imul(al8, bl8) | 0;\n mid = mid + Math.imul(al8, bh8) | 0;\n mid = mid + Math.imul(ah8, bl8) | 0;\n hi = hi + Math.imul(ah8, bh8) | 0;\n lo = lo + Math.imul(al7, bl9) | 0;\n mid = mid + Math.imul(al7, bh9) | 0;\n mid = mid + Math.imul(ah7, bl9) | 0;\n hi = hi + Math.imul(ah7, bh9) | 0;\n var w16 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w16 >>> 26) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = mid + Math.imul(ah9, bl8) | 0;\n hi = Math.imul(ah9, bh8);\n lo = lo + Math.imul(al8, bl9) | 0;\n mid = mid + Math.imul(al8, bh9) | 0;\n mid = mid + Math.imul(ah8, bl9) | 0;\n hi = hi + Math.imul(ah8, bh9) | 0;\n var w17 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w17 >>> 26) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = mid + Math.imul(ah9, bl9) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w18 >>> 26) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n function bigMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n ncarry = ncarry + (r / 0x4000000 | 0) | 0;\n lo = lo + rword | 0;\n rword = lo & 0x3ffffff;\n ncarry = ncarry + (lo >>> 26) | 0;\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n return out.strip();\n }\n function jumboMulTo(self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n BN.prototype.mulTo = function mulTo(num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM(x, y) {\n this.x = x;\n this.y = y;\n }\n FFTM.prototype.makeRBT = function makeRBT(N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin(x, l, N) {\n if (x === 0 || x === N - 1) return x;\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << l - i - 1;\n x >>= 1;\n }\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute(rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n FFTM.prototype.transform = function transform(rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n var rx = rtwdf_ * ro - itwdf_ * io;\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n FFTM.prototype.guessLen13b = function guessLen13b(n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n return 1 << i + 1 + odd;\n };\n FFTM.prototype.conjugate = function conjugate(rws, iws, N) {\n if (N <= 1) return;\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n t = iws[i];\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n FFTM.prototype.normalize13b = function normalize13b(ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 + Math.round(ws[2 * i] / N) + carry;\n ws[i] = w & 0x3ffffff;\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n return ws;\n };\n FFTM.prototype.convert13b = function convert13b(ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n rws[2 * i] = carry & 0x1fff;\n carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff;\n carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n FFTM.prototype.stub = function stub(N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n return ph;\n };\n FFTM.prototype.mulp = function mulp(x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n var rbt = this.makeRBT(N);\n var _ = this.stub(N);\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n var rmws = out.words;\n rmws.length = N;\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul(num) {\n return this.clone().mulTo(num, this);\n };\n BN.prototype.imuln = function imuln(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += w / 0x4000000 | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.muln = function muln(num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr() {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr() {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow(num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n res = res.mul(q);\n }\n }\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = 0x3ffffff >>> 26 - r << 26 - r;\n var i;\n if (r !== 0) {\n var carry = 0;\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = (this.words[i] | 0) - newCarry << r;\n this.words[i] = c | carry;\n carry = newCarry >>> 26 - r;\n }\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n this.length += s;\n }\n return this.strip();\n };\n BN.prototype.ishln = function ishln(bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn(bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - hint % 26) / 26;\n } else {\n h = 0;\n }\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n var maskedWords = extended;\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = carry << 26 - r | word >>> r;\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n return this.strip();\n };\n BN.prototype.ishrn = function ishrn(bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln(bits) {\n return this.clone().ishln(bits);\n };\n BN.prototype.ushln = function ushln(bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn(bits) {\n return this.clone().ishrn(bits);\n };\n BN.prototype.ushrn = function ushrn(bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn(bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n if (this.length <= s) {\n return this;\n }\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n if (r !== 0) {\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n this.words[this.length - 1] &= mask;\n }\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn(bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n BN.prototype._iaddn = function _iaddn(num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n this.words[0] -= num;\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n return this.strip();\n };\n BN.prototype.addn = function addn(num) {\n return this.clone().iaddn(num);\n };\n BN.prototype.subn = function subn(num) {\n return this.clone().isubn(num);\n };\n BN.prototype.iabs = function iabs() {\n this.negative = 0;\n return this;\n };\n BN.prototype.abs = function abs() {\n return this.clone().iabs();\n };\n BN.prototype._ishlnsubmul = function _ishlnsubmul(num, mul, shift) {\n var len = num.length + shift;\n var i;\n this._expand(len);\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - (right / 0x4000000 | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n return this.strip();\n };\n BN.prototype._wordDiv = function _wordDiv(num, mode) {\n var shift = this.length - num.length;\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 + (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min(qj / bhi | 0, 0x3ffffff);\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod(num, mode, positive) {\n assert(!num.isZero());\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n return {\n div: div,\n mod: mod\n };\n }\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n return {\n div: div,\n mod: res.mod\n };\n }\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div(num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod(num) {\n return this.divmod(num, 'mod', false).mod;\n };\n BN.prototype.umod = function umod(num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound(num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n BN.prototype.modn = function modn(num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn(num) {\n assert(num <= 0x3ffffff);\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = w / num | 0;\n carry = w % num;\n }\n return this.strip();\n };\n BN.prototype.divn = function divn(num) {\n return this.clone().idivn(num);\n };\n BN.prototype.egcd = function egcd(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var x = this;\n var y = p.clone();\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n var g = 0;\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n var yp = y.clone();\n var xp = x.clone();\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var a = this;\n var b = p.clone();\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n var x1 = new BN(1);\n var x2 = new BN(0);\n var delta = b.clone();\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n x1.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n x2.iushrn(1);\n }\n }\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n return res;\n };\n BN.prototype.gcd = function gcd(num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n a.isub(b);\n } while (true);\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm(num) {\n return this.egcd(num).a.umod(num);\n };\n BN.prototype.isEven = function isEven() {\n return (this.words[0] & 1) === 0;\n };\n BN.prototype.isOdd = function isOdd() {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln(num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn(bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.isZero = function isZero() {\n return this.length === 1 && this.words[0] === 0;\n };\n BN.prototype.cmpn = function cmpn(num) {\n var negative = num < 0;\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n this.strip();\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n assert(num <= 0x3ffffff, 'Number is too big');\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp(num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp(num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n BN.prototype.gtn = function gtn(num) {\n return this.cmpn(num) === 1;\n };\n BN.prototype.gt = function gt(num) {\n return this.cmp(num) === 1;\n };\n BN.prototype.gten = function gten(num) {\n return this.cmpn(num) >= 0;\n };\n BN.prototype.gte = function gte(num) {\n return this.cmp(num) >= 0;\n };\n BN.prototype.ltn = function ltn(num) {\n return this.cmpn(num) === -1;\n };\n BN.prototype.lt = function lt(num) {\n return this.cmp(num) === -1;\n };\n BN.prototype.lten = function lten(num) {\n return this.cmpn(num) <= 0;\n };\n BN.prototype.lte = function lte(num) {\n return this.cmp(num) <= 0;\n };\n BN.prototype.eqn = function eqn(num) {\n return this.cmpn(num) === 0;\n };\n BN.prototype.eq = function eq(num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red(num) {\n return new Red(num);\n };\n BN.prototype.toRed = function toRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n BN.prototype.fromRed = function fromRed() {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n BN.prototype._forceRed = function _forceRed(ctx) {\n this.red = ctx;\n return this;\n };\n BN.prototype.forceRed = function forceRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n BN.prototype.redAdd = function redAdd(num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n BN.prototype.redIAdd = function redIAdd(num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n BN.prototype.redSub = function redSub(num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n BN.prototype.redISub = function redISub(num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n BN.prototype.redShl = function redShl(num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n BN.prototype.redMul = function redMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n BN.prototype.redIMul = function redIMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n BN.prototype.redSqr = function redSqr() {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n BN.prototype.redISqr = function redISqr() {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt() {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n BN.prototype.redInvm = function redInvm() {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg() {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n BN.prototype.redPow = function redPow(num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime(name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n this.tmp = this._tmp();\n }\n MPrime.prototype._tmp = function _tmp() {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n MPrime.prototype.ireduce = function ireduce(num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n return r;\n };\n MPrime.prototype.split = function split(input, out) {\n input.iushrn(this.n, 0, out);\n };\n MPrime.prototype.imulK = function imulK(num) {\n return num.imul(this.k);\n };\n function K256() {\n MPrime.call(this, 'k256', 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n K256.prototype.split = function split(input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = (next & mask) << 4 | prev >>> 22;\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n K256.prototype.imulK = function imulK(num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + (lo / 0x4000000 | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n function P224() {\n MPrime.call(this, 'p224', 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n function P192() {\n MPrime.call(this, 'p192', 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n function P25519() {\n // 2 ^ 255 - 19\n MPrime.call(this, '25519', '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n P25519.prototype.imulK = function imulK(num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime(name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red(m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n Red.prototype._verify1 = function _verify1(a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n Red.prototype._verify2 = function _verify2(a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red, 'red works only with red numbers');\n };\n Red.prototype.imod = function imod(a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n Red.prototype.neg = function neg(a) {\n if (a.isZero()) {\n return a.clone();\n }\n return this.m.sub(a)._forceRed(this);\n };\n Red.prototype.add = function add(a, b) {\n this._verify2(a, b);\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.iadd = function iadd(a, b) {\n this._verify2(a, b);\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n Red.prototype.sub = function sub(a, b) {\n this._verify2(a, b);\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.isub = function isub(a, b) {\n this._verify2(a, b);\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n Red.prototype.shl = function shl(a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n Red.prototype.imul = function imul(a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n Red.prototype.mul = function mul(a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n Red.prototype.isqr = function isqr(a) {\n return this.imul(a, a.clone());\n };\n Red.prototype.sqr = function sqr(a) {\n return this.mul(a, a);\n };\n Red.prototype.sqrt = function sqrt(a) {\n if (a.isZero()) return a.clone();\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n return r;\n };\n Red.prototype.invm = function invm(a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n Red.prototype.pow = function pow(a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = word >> j & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n return res;\n };\n Red.prototype.convertTo = function convertTo(num) {\n var r = num.umod(this.m);\n return r === num ? r.clone() : r;\n };\n Red.prototype.convertFrom = function convertFrom(num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont(num) {\n return new Mont(num);\n };\n function Mont(m) {\n Red.call(this, m);\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - this.shift % 26;\n }\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n Mont.prototype.convertTo = function convertTo(num) {\n return this.imod(num.ushln(this.shift));\n };\n Mont.prototype.convertFrom = function convertFrom(num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n Mont.prototype.imul = function imul(a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.mul = function mul(a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.invm = function invm(a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);","\"use strict\";\n\n// This file is imported from secp256k1 v3\n// https://github.com/cryptocoinjs/secp256k1-node/blob/master/LICENSE\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar BN = require(\"bn.js\");\nvar EC = require('elliptic').ec;\nvar ec = new EC('secp256k1');\nvar ecparams = ec.curve;\nexports.privateKeyExport = function (privateKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n var d = new BN(privateKey);\n if (d.ucmp(ecparams.n) >= 0) {\n throw new Error(\"couldn't export to DER format\");\n }\n var point = ec.g.mul(d);\n return toPublicKey(point.getX(), point.getY(), compressed);\n};\nexports.privateKeyModInverse = function (privateKey) {\n var bn = new BN(privateKey);\n if (bn.ucmp(ecparams.n) >= 0 || bn.isZero()) {\n throw new Error('private key range is invalid');\n }\n return bn.invm(ecparams.n).toArrayLike(Buffer, 'be', 32);\n};\nexports.signatureImport = function (sigObj) {\n var r = new BN(sigObj.r);\n if (r.ucmp(ecparams.n) >= 0) {\n r = new BN(0);\n }\n var s = new BN(sigObj.s);\n if (s.ucmp(ecparams.n) >= 0) {\n s = new BN(0);\n }\n return Buffer.concat([r.toArrayLike(Buffer, 'be', 32), s.toArrayLike(Buffer, 'be', 32)]);\n};\nexports.ecdhUnsafe = function (publicKey, privateKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n var point = ec.keyFromPublic(publicKey);\n var scalar = new BN(privateKey);\n if (scalar.ucmp(ecparams.n) >= 0 || scalar.isZero()) {\n throw new Error('scalar was invalid (zero or overflow)');\n }\n var shared = point.pub.mul(scalar);\n return toPublicKey(shared.getX(), shared.getY(), compressed);\n};\nvar toPublicKey = function (x, y, compressed) {\n var publicKey;\n if (compressed) {\n publicKey = Buffer.alloc(33);\n publicKey[0] = y.isOdd() ? 0x03 : 0x02;\n x.toArrayLike(Buffer, 'be', 32).copy(publicKey, 1);\n } else {\n publicKey = Buffer.alloc(65);\n publicKey[0] = 0x04;\n x.toArrayLike(Buffer, 'be', 32).copy(publicKey, 1);\n y.toArrayLike(Buffer, 'be', 32).copy(publicKey, 33);\n }\n return publicKey;\n};\n","\"use strict\";\n\n// This file is imported from secp256k1 v3\n// https://github.com/cryptocoinjs/secp256k1-node/blob/master/LICENSE\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar EC_PRIVKEY_EXPORT_DER_COMPRESSED = Buffer.from([\n// begin\n0x30, 0x81, 0xd3, 0x02, 0x01, 0x01, 0x04, 0x20,\n// private key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n// middle\n0xa0, 0x81, 0x85, 0x30, 0x81, 0x82, 0x02, 0x01, 0x01, 0x30, 0x2c, 0x06, 0x07, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x01, 0x01, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfc, 0x2f, 0x30, 0x06, 0x04, 0x01, 0x00, 0x04, 0x01, 0x07, 0x04, 0x21, 0x02, 0x79, 0xbe, 0x66, 0x7e, 0xf9, 0xdc, 0xbb, 0xac, 0x55, 0xa0, 0x62, 0x95, 0xce, 0x87, 0x0b, 0x07, 0x02, 0x9b, 0xfc, 0xdb, 0x2d, 0xce, 0x28, 0xd9, 0x59, 0xf2, 0x81, 0x5b, 0x16, 0xf8, 0x17, 0x98, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xba, 0xae, 0xdc, 0xe6, 0xaf, 0x48, 0xa0, 0x3b, 0xbf, 0xd2, 0x5e, 0x8c, 0xd0, 0x36, 0x41, 0x41, 0x02, 0x01, 0x01, 0xa1, 0x24, 0x03, 0x22, 0x00,\n// public key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00]);\nvar EC_PRIVKEY_EXPORT_DER_UNCOMPRESSED = Buffer.from([\n// begin\n0x30, 0x82, 0x01, 0x13, 0x02, 0x01, 0x01, 0x04, 0x20,\n// private key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n// middle\n0xa0, 0x81, 0xa5, 0x30, 0x81, 0xa2, 0x02, 0x01, 0x01, 0x30, 0x2c, 0x06, 0x07, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x01, 0x01, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfc, 0x2f, 0x30, 0x06, 0x04, 0x01, 0x00, 0x04, 0x01, 0x07, 0x04, 0x41, 0x04, 0x79, 0xbe, 0x66, 0x7e, 0xf9, 0xdc, 0xbb, 0xac, 0x55, 0xa0, 0x62, 0x95, 0xce, 0x87, 0x0b, 0x07, 0x02, 0x9b, 0xfc, 0xdb, 0x2d, 0xce, 0x28, 0xd9, 0x59, 0xf2, 0x81, 0x5b, 0x16, 0xf8, 0x17, 0x98, 0x48, 0x3a, 0xda, 0x77, 0x26, 0xa3, 0xc4, 0x65, 0x5d, 0xa4, 0xfb, 0xfc, 0x0e, 0x11, 0x08, 0xa8, 0xfd, 0x17, 0xb4, 0x48, 0xa6, 0x85, 0x54, 0x19, 0x9c, 0x47, 0xd0, 0x8f, 0xfb, 0x10, 0xd4, 0xb8, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xba, 0xae, 0xdc, 0xe6, 0xaf, 0x48, 0xa0, 0x3b, 0xbf, 0xd2, 0x5e, 0x8c, 0xd0, 0x36, 0x41, 0x41, 0x02, 0x01, 0x01, 0xa1, 0x44, 0x03, 0x42, 0x00,\n// public key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00]);\nexports.privateKeyExport = function (privateKey, publicKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n var result = Buffer.from(compressed ? EC_PRIVKEY_EXPORT_DER_COMPRESSED : EC_PRIVKEY_EXPORT_DER_UNCOMPRESSED);\n privateKey.copy(result, compressed ? 8 : 9);\n publicKey.copy(result, compressed ? 181 : 214);\n return result;\n};\nexports.privateKeyImport = function (privateKey) {\n var length = privateKey.length;\n // sequence header\n var index = 0;\n if (length < index + 1 || privateKey[index] !== 0x30) return null;\n index += 1;\n // sequence length constructor\n if (length < index + 1 || !(privateKey[index] & 0x80)) return null;\n var lenb = privateKey[index] & 0x7f;\n index += 1;\n if (lenb < 1 || lenb > 2) return null;\n if (length < index + lenb) return null;\n // sequence length\n var len = privateKey[index + lenb - 1] | (lenb > 1 ? privateKey[index + lenb - 2] << 8 : 0);\n index += lenb;\n if (length < index + len) return null;\n // sequence element 0: version number (=1)\n if (length < index + 3 || privateKey[index] !== 0x02 || privateKey[index + 1] !== 0x01 || privateKey[index + 2] !== 0x01) {\n return null;\n }\n index += 3;\n // sequence element 1: octet string, up to 32 bytes\n if (length < index + 2 || privateKey[index] !== 0x04 || privateKey[index + 1] > 0x20 || length < index + 2 + privateKey[index + 1]) {\n return null;\n }\n return privateKey.slice(index + 2, index + 2 + privateKey[index + 1]);\n};\nexports.signatureImportLax = function (signature) {\n var r = Buffer.alloc(32, 0);\n var s = Buffer.alloc(32, 0);\n var length = signature.length;\n var index = 0;\n // sequence tag byte\n if (signature[index++] !== 0x30) {\n return null;\n }\n // sequence length byte\n var lenbyte = signature[index++];\n if (lenbyte & 0x80) {\n index += lenbyte - 0x80;\n if (index > length) {\n return null;\n }\n }\n // sequence tag byte for r\n if (signature[index++] !== 0x02) {\n return null;\n }\n // length for r\n var rlen = signature[index++];\n if (rlen & 0x80) {\n lenbyte = rlen - 0x80;\n if (index + lenbyte > length) {\n return null;\n }\n for (; lenbyte > 0 && signature[index] === 0x00; index += 1, lenbyte -= 1);\n for (rlen = 0; lenbyte > 0; index += 1, lenbyte -= 1) rlen = (rlen << 8) + signature[index];\n }\n if (rlen > length - index) {\n return null;\n }\n var rindex = index;\n index += rlen;\n // sequence tag byte for s\n if (signature[index++] !== 0x02) {\n return null;\n }\n // length for s\n var slen = signature[index++];\n if (slen & 0x80) {\n lenbyte = slen - 0x80;\n if (index + lenbyte > length) {\n return null;\n }\n for (; lenbyte > 0 && signature[index] === 0x00; index += 1, lenbyte -= 1);\n for (slen = 0; lenbyte > 0; index += 1, lenbyte -= 1) slen = (slen << 8) + signature[index];\n }\n if (slen > length - index) {\n return null;\n }\n var sindex = index;\n index += slen;\n // ignore leading zeros in r\n for (; rlen > 0 && signature[rindex] === 0x00; rlen -= 1, rindex += 1);\n // copy r value\n if (rlen > 32) {\n return null;\n }\n var rvalue = signature.slice(rindex, rindex + rlen);\n rvalue.copy(r, 32 - rvalue.length);\n // ignore leading zeros in s\n for (; slen > 0 && signature[sindex] === 0x00; slen -= 1, sindex += 1);\n // copy s value\n if (slen > 32) {\n return null;\n }\n var svalue = signature.slice(sindex, sindex + slen);\n svalue.copy(s, 32 - svalue.length);\n return {\n r: r,\n s: s\n };\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ecdhUnsafe = exports.ecdh = exports.recover = exports.verify = exports.sign = exports.signatureImportLax = exports.signatureImport = exports.signatureExport = exports.signatureNormalize = exports.publicKeyCombine = exports.publicKeyTweakMul = exports.publicKeyTweakAdd = exports.publicKeyVerify = exports.publicKeyConvert = exports.publicKeyCreate = exports.privateKeyTweakMul = exports.privateKeyTweakAdd = exports.privateKeyModInverse = exports.privateKeyNegate = exports.privateKeyImport = exports.privateKeyExport = exports.privateKeyVerify = void 0;\nvar secp256k1 = require('ethereum-cryptography/secp256k1');\nvar secp256k1v3 = require('./secp256k1v3-lib/index');\nvar der = require('./secp256k1v3-lib/der');\n/**\n * Verify an ECDSA privateKey\n * @method privateKeyVerify\n * @param {Buffer} privateKey\n * @return {boolean}\n */\nexports.privateKeyVerify = function (privateKey) {\n // secp256k1 v4 version throws when privateKey length is not 32\n if (privateKey.length !== 32) {\n return false;\n }\n return secp256k1.privateKeyVerify(Uint8Array.from(privateKey));\n};\n/**\n * Export a privateKey in DER format\n * @method privateKeyExport\n * @param {Buffer} privateKey\n * @param {boolean} compressed\n * @return {boolean}\n */\nexports.privateKeyExport = function (privateKey, compressed) {\n // secp256k1 v4 version throws when privateKey length is not 32\n if (privateKey.length !== 32) {\n throw new RangeError('private key length is invalid');\n }\n var publicKey = secp256k1v3.privateKeyExport(privateKey, compressed);\n return der.privateKeyExport(privateKey, publicKey, compressed);\n};\n/**\n * Import a privateKey in DER format\n * @method privateKeyImport\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.privateKeyImport = function (privateKey) {\n // privateKeyImport method is not part of secp256k1 v4 package\n // this implementation is based on v3\n privateKey = der.privateKeyImport(privateKey);\n if (privateKey !== null && privateKey.length === 32 && exports.privateKeyVerify(privateKey)) {\n return privateKey;\n }\n throw new Error(\"couldn't import from DER format\");\n};\n/**\n * Negate a privateKey by subtracting it from the order of the curve's base point\n * @method privateKeyNegate\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.privateKeyNegate = function (privateKey) {\n return Buffer.from(secp256k1.privateKeyNegate(Uint8Array.from(privateKey)));\n};\n/**\n * Compute the inverse of a privateKey (modulo the order of the curve's base point).\n * @method privateKeyModInverse\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.privateKeyModInverse = function (privateKey) {\n if (privateKey.length !== 32) {\n throw new Error('private key length is invalid');\n }\n return Buffer.from(secp256k1v3.privateKeyModInverse(Uint8Array.from(privateKey)));\n};\n/**\n * Tweak a privateKey by adding tweak to it.\n * @method privateKeyTweakAdd\n * @param {Buffer} privateKey\n * @param {Buffer} tweak\n * @return {Buffer}\n */\nexports.privateKeyTweakAdd = function (privateKey, tweak) {\n return Buffer.from(secp256k1.privateKeyTweakAdd(Uint8Array.from(privateKey), tweak));\n};\n/**\n * Tweak a privateKey by multiplying it by a tweak.\n * @method privateKeyTweakMul\n * @param {Buffer} privateKey\n * @param {Buffer} tweak\n * @return {Buffer}\n */\nexports.privateKeyTweakMul = function (privateKey, tweak) {\n return Buffer.from(secp256k1.privateKeyTweakMul(Uint8Array.from(privateKey), Uint8Array.from(tweak)));\n};\n/**\n * Compute the public key for a privateKey.\n * @method publicKeyCreate\n * @param {Buffer} privateKey\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyCreate = function (privateKey, compressed) {\n return Buffer.from(secp256k1.publicKeyCreate(Uint8Array.from(privateKey), compressed));\n};\n/**\n * Convert a publicKey to compressed or uncompressed form.\n * @method publicKeyConvert\n * @param {Buffer} publicKey\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyConvert = function (publicKey, compressed) {\n return Buffer.from(secp256k1.publicKeyConvert(Uint8Array.from(publicKey), compressed));\n};\n/**\n * Verify an ECDSA publicKey.\n * @method publicKeyVerify\n * @param {Buffer} publicKey\n * @return {boolean}\n */\nexports.publicKeyVerify = function (publicKey) {\n // secp256k1 v4 version throws when publicKey length is not 33 or 65\n if (publicKey.length !== 33 && publicKey.length !== 65) {\n return false;\n }\n return secp256k1.publicKeyVerify(Uint8Array.from(publicKey));\n};\n/**\n * Tweak a publicKey by adding tweak times the generator to it.\n * @method publicKeyTweakAdd\n * @param {Buffer} publicKey\n * @param {Buffer} tweak\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyTweakAdd = function (publicKey, tweak, compressed) {\n return Buffer.from(secp256k1.publicKeyTweakAdd(Uint8Array.from(publicKey), Uint8Array.from(tweak), compressed));\n};\n/**\n * Tweak a publicKey by multiplying it by a tweak value\n * @method publicKeyTweakMul\n * @param {Buffer} publicKey\n * @param {Buffer} tweak\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyTweakMul = function (publicKey, tweak, compressed) {\n return Buffer.from(secp256k1.publicKeyTweakMul(Uint8Array.from(publicKey), Uint8Array.from(tweak), compressed));\n};\n/**\n * Add a given publicKeys together.\n * @method publicKeyCombine\n * @param {Array} publicKeys\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyCombine = function (publicKeys, compressed) {\n var keys = [];\n publicKeys.forEach(function (publicKey) {\n keys.push(Uint8Array.from(publicKey));\n });\n return Buffer.from(secp256k1.publicKeyCombine(keys, compressed));\n};\n/**\n * Convert a signature to a normalized lower-S form.\n * @method signatureNormalize\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureNormalize = function (signature) {\n return Buffer.from(secp256k1.signatureNormalize(Uint8Array.from(signature)));\n};\n/**\n * Serialize an ECDSA signature in DER format.\n * @method signatureExport\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureExport = function (signature) {\n return Buffer.from(secp256k1.signatureExport(Uint8Array.from(signature)));\n};\n/**\n * Parse a DER ECDSA signature (follow by [BIP66](https://github.com/bitcoin/bips/blob/master/bip-0066.mediawiki)).\n * @method signatureImport\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureImport = function (signature) {\n return Buffer.from(secp256k1.signatureImport(Uint8Array.from(signature)));\n};\n/**\n * Parse a DER ECDSA signature (not follow by [BIP66](https://github.com/bitcoin/bips/blob/master/bip-0066.mediawiki)).\n * @method signatureImportLax\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureImportLax = function (signature) {\n // signatureImportLax method is not part of secp256k1 v4 package\n // this implementation is based on v3\n // ensure that signature is greater than 0\n if (signature.length === 0) {\n throw new RangeError('signature length is invalid');\n }\n var sigObj = der.signatureImportLax(signature);\n if (sigObj === null) {\n throw new Error(\"couldn't parse DER signature\");\n }\n return secp256k1v3.signatureImport(sigObj);\n};\n/**\n * Create an ECDSA signature. Always return low-S signature.\n * @method sign\n * @param {Buffer} message\n * @param {Buffer} privateKey\n * @param {Object} options\n * @return {Buffer}\n */\nexports.sign = function (message, privateKey, options) {\n if (options === null) {\n throw new TypeError('options should be an Object');\n }\n var signOptions = undefined;\n if (options) {\n signOptions = {};\n if (options.data === null) {\n // validate option.data length\n throw new TypeError('options.data should be a Buffer');\n }\n if (options.data) {\n if (options.data.length != 32) {\n throw new RangeError('options.data length is invalid');\n }\n signOptions.data = new Uint8Array(options.data);\n }\n if (options.noncefn === null) {\n throw new TypeError('options.noncefn should be a Function');\n }\n if (options.noncefn) {\n // convert option.noncefn function signature\n signOptions.noncefn = function (message, privateKey, algo, data, attempt) {\n var bufferAlgo = algo != null ? Buffer.from(algo) : null;\n var bufferData = data != null ? Buffer.from(data) : null;\n var buffer = Buffer.from('');\n if (options.noncefn) {\n buffer = options.noncefn(Buffer.from(message), Buffer.from(privateKey), bufferAlgo, bufferData, attempt);\n }\n return new Uint8Array(buffer);\n };\n }\n }\n var sig = secp256k1.ecdsaSign(Uint8Array.from(message), Uint8Array.from(privateKey), signOptions);\n return {\n signature: Buffer.from(sig.signature),\n recovery: sig.recid\n };\n};\n/**\n * Verify an ECDSA signature.\n * @method verify\n * @param {Buffer} message\n * @param {Buffer} signature\n * @param {Buffer} publicKey\n * @return {boolean}\n */\nexports.verify = function (message, signature, publicKey) {\n return secp256k1.ecdsaVerify(Uint8Array.from(signature), Uint8Array.from(message), publicKey);\n};\n/**\n * Recover an ECDSA public key from a signature.\n * @method recover\n * @param {Buffer} message\n * @param {Buffer} signature\n * @param {Number} recid\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.recover = function (message, signature, recid, compressed) {\n return Buffer.from(secp256k1.ecdsaRecover(Uint8Array.from(signature), recid, Uint8Array.from(message), compressed));\n};\n/**\n * Compute an EC Diffie-Hellman secret and applied sha256 to compressed public key.\n * @method ecdh\n * @param {Buffer} publicKey\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.ecdh = function (publicKey, privateKey) {\n // note: secp256k1 v3 doesn't allow optional parameter\n return Buffer.from(secp256k1.ecdh(Uint8Array.from(publicKey), Uint8Array.from(privateKey), {}));\n};\nexports.ecdhUnsafe = function (publicKey, privateKey, compressed) {\n // ecdhUnsafe method is not part of secp256k1 v4 package\n // this implementation is based on v3\n // ensure valid publicKey length\n if (publicKey.length !== 33 && publicKey.length !== 65) {\n throw new RangeError('public key length is invalid');\n }\n // ensure valid privateKey length\n if (privateKey.length !== 32) {\n throw new RangeError('private key length is invalid');\n }\n return Buffer.from(secp256k1v3.ecdhUnsafe(Uint8Array.from(publicKey), Uint8Array.from(privateKey), compressed));\n};\n","'use strict';\n\nvar isHexPrefixed = require('is-hex-prefixed');\nvar stripHexPrefix = require('strip-hex-prefix');\n\n/**\n * Pads a `String` to have an even length\n * @param {String} value\n * @return {String} output\n */\nfunction padToEven(value) {\n var a = value; // eslint-disable-line\n\n if (typeof a !== 'string') {\n throw new Error('[ethjs-util] while padding to even, value must be string, is currently ' + typeof a + ', while padToEven.');\n }\n if (a.length % 2) {\n a = '0' + a;\n }\n return a;\n}\n\n/**\n * Converts a `Number` into a hex `String`\n * @param {Number} i\n * @return {String}\n */\nfunction intToHex(i) {\n var hex = i.toString(16); // eslint-disable-line\n\n return '0x' + hex;\n}\n\n/**\n * Converts an `Number` to a `Buffer`\n * @param {Number} i\n * @return {Buffer}\n */\nfunction intToBuffer(i) {\n var hex = intToHex(i);\n return new Buffer(padToEven(hex.slice(2)), 'hex');\n}\n\n/**\n * Get the binary size of a string\n * @param {String} str\n * @return {Number}\n */\nfunction getBinarySize(str) {\n if (typeof str !== 'string') {\n throw new Error('[ethjs-util] while getting binary size, method getBinarySize requires input \\'str\\' to be type String, got \\'' + typeof str + '\\'.');\n }\n return Buffer.byteLength(str, 'utf8');\n}\n\n/**\n * Returns TRUE if the first specified array contains all elements\n * from the second one. FALSE otherwise.\n *\n * @param {array} superset\n * @param {array} subset\n *\n * @returns {boolean}\n */\nfunction arrayContainsArray(superset, subset, some) {\n if (Array.isArray(superset) !== true) {\n throw new Error('[ethjs-util] method arrayContainsArray requires input \\'superset\\' to be an array got type \\'' + typeof superset + '\\'');\n }\n if (Array.isArray(subset) !== true) {\n throw new Error('[ethjs-util] method arrayContainsArray requires input \\'subset\\' to be an array got type \\'' + typeof subset + '\\'');\n }\n return subset[Boolean(some) && 'some' || 'every'](function (value) {\n return superset.indexOf(value) >= 0;\n });\n}\n\n/**\n * Should be called to get utf8 from it's hex representation\n *\n * @method toUtf8\n * @param {String} string in hex\n * @returns {String} ascii string representation of hex value\n */\nfunction toUtf8(hex) {\n var bufferValue = new Buffer(padToEven(stripHexPrefix(hex).replace(/^0+|0+$/g, '')), 'hex');\n return bufferValue.toString('utf8');\n}\n\n/**\n * Should be called to get ascii from it's hex representation\n *\n * @method toAscii\n * @param {String} string in hex\n * @returns {String} ascii string representation of hex value\n */\nfunction toAscii(hex) {\n var str = ''; // eslint-disable-line\n var i = 0,\n l = hex.length; // eslint-disable-line\n\n if (hex.substring(0, 2) === '0x') {\n i = 2;\n }\n for (; i < l; i += 2) {\n var code = parseInt(hex.substr(i, 2), 16);\n str += String.fromCharCode(code);\n }\n return str;\n}\n\n/**\n * Should be called to get hex representation (prefixed by 0x) of utf8 string\n *\n * @method fromUtf8\n * @param {String} string\n * @param {Number} optional padding\n * @returns {String} hex representation of input string\n */\nfunction fromUtf8(stringValue) {\n var str = new Buffer(stringValue, 'utf8');\n return '0x' + padToEven(str.toString('hex')).replace(/^0+|0+$/g, '');\n}\n\n/**\n * Should be called to get hex representation (prefixed by 0x) of ascii string\n *\n * @method fromAscii\n * @param {String} string\n * @param {Number} optional padding\n * @returns {String} hex representation of input string\n */\nfunction fromAscii(stringValue) {\n var hex = ''; // eslint-disable-line\n for (var i = 0; i < stringValue.length; i++) {\n // eslint-disable-line\n var code = stringValue.charCodeAt(i);\n var n = code.toString(16);\n hex += n.length < 2 ? '0' + n : n;\n }\n return '0x' + hex;\n}\n\n/**\n * getKeys([{a: 1, b: 2}, {a: 3, b: 4}], 'a') => [1, 3]\n *\n * @method getKeys get specific key from inner object array of objects\n * @param {String} params\n * @param {String} key\n * @param {Boolean} allowEmpty\n * @returns {Array} output just a simple array of output keys\n */\nfunction getKeys(params, key, allowEmpty) {\n if (!Array.isArray(params)) {\n throw new Error('[ethjs-util] method getKeys expecting type Array as \\'params\\' input, got \\'' + typeof params + '\\'');\n }\n if (typeof key !== 'string') {\n throw new Error('[ethjs-util] method getKeys expecting type String for input \\'key\\' got \\'' + typeof key + '\\'.');\n }\n var result = []; // eslint-disable-line\n\n for (var i = 0; i < params.length; i++) {\n // eslint-disable-line\n var value = params[i][key]; // eslint-disable-line\n if (allowEmpty && !value) {\n value = '';\n } else if (typeof value !== 'string') {\n throw new Error('invalid abi');\n }\n result.push(value);\n }\n return result;\n}\n\n/**\n * Is the string a hex string.\n *\n * @method check if string is hex string of specific length\n * @param {String} value\n * @param {Number} length\n * @returns {Boolean} output the string is a hex string\n */\nfunction isHexString(value, length) {\n if (typeof value !== 'string' || !value.match(/^0x[0-9A-Fa-f]*$/)) {\n return false;\n }\n if (length && value.length !== 2 + 2 * length) {\n return false;\n }\n return true;\n}\nmodule.exports = {\n arrayContainsArray: arrayContainsArray,\n intToBuffer: intToBuffer,\n getBinarySize: getBinarySize,\n isHexPrefixed: isHexPrefixed,\n stripHexPrefix: stripHexPrefix,\n padToEven: padToEven,\n intToHex: intToHex,\n fromAscii: fromAscii,\n fromUtf8: fromUtf8,\n toAscii: toAscii,\n toUtf8: toUtf8,\n getKeys: getKeys,\n isHexString: isHexString\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.KECCAK256_RLP = exports.KECCAK256_RLP_S = exports.KECCAK256_RLP_ARRAY = exports.KECCAK256_RLP_ARRAY_S = exports.KECCAK256_NULL = exports.KECCAK256_NULL_S = exports.TWO_POW256 = exports.MAX_INTEGER = void 0;\nvar BN = require(\"bn.js\");\n/**\n * The max integer that this VM can handle\n */\nexports.MAX_INTEGER = new BN('ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', 16);\n/**\n * 2^256\n */\nexports.TWO_POW256 = new BN('10000000000000000000000000000000000000000000000000000000000000000', 16);\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL_S = 'c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470';\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL = Buffer.from(exports.KECCAK256_NULL_S, 'hex');\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY_S = '1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347';\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY = Buffer.from(exports.KECCAK256_RLP_ARRAY_S, 'hex');\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP_S = '56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421';\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP = Buffer.from(exports.KECCAK256_RLP_S, 'hex');\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.baToJSON = exports.addHexPrefix = exports.toUnsigned = exports.fromSigned = exports.bufferToHex = exports.bufferToInt = exports.toBuffer = exports.stripZeros = exports.unpad = exports.setLengthRight = exports.setLength = exports.setLengthLeft = exports.zeros = void 0;\nvar ethjsUtil = require('ethjs-util');\nvar BN = require(\"bn.js\");\n/**\n * Returns a buffer filled with 0s.\n * @param bytes the number of bytes the buffer should be\n */\nexports.zeros = function (bytes) {\n return Buffer.allocUnsafe(bytes).fill(0);\n};\n/**\n * Left Pads an `Array` or `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @param msg the value to pad (Buffer|Array)\n * @param length the number of bytes the output should be\n * @param right whether to start padding form the left or right\n * @return (Buffer|Array)\n */\nexports.setLengthLeft = function (msg, length, right) {\n if (right === void 0) {\n right = false;\n }\n var buf = exports.zeros(length);\n msg = exports.toBuffer(msg);\n if (right) {\n if (msg.length < length) {\n msg.copy(buf);\n return buf;\n }\n return msg.slice(0, length);\n } else {\n if (msg.length < length) {\n msg.copy(buf, length - msg.length);\n return buf;\n }\n return msg.slice(-length);\n }\n};\nexports.setLength = exports.setLengthLeft;\n/**\n * Right Pads an `Array` or `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @param msg the value to pad (Buffer|Array)\n * @param length the number of bytes the output should be\n * @return (Buffer|Array)\n */\nexports.setLengthRight = function (msg, length) {\n return exports.setLength(msg, length, true);\n};\n/**\n * Trims leading zeros from a `Buffer` or an `Array`.\n * @param a (Buffer|Array|String)\n * @return (Buffer|Array|String)\n */\nexports.unpad = function (a) {\n a = ethjsUtil.stripHexPrefix(a);\n var first = a[0];\n while (a.length > 0 && first.toString() === '0') {\n a = a.slice(1);\n first = a[0];\n }\n return a;\n};\nexports.stripZeros = exports.unpad;\n/**\n * Attempts to turn a value into a `Buffer`. As input it supports `Buffer`, `String`, `Number`, null/undefined, `BN` and other objects with a `toArray()` method.\n * @param v the value\n */\nexports.toBuffer = function (v) {\n if (!Buffer.isBuffer(v)) {\n if (Array.isArray(v)) {\n v = Buffer.from(v);\n } else if (typeof v === 'string') {\n if (ethjsUtil.isHexString(v)) {\n v = Buffer.from(ethjsUtil.padToEven(ethjsUtil.stripHexPrefix(v)), 'hex');\n } else {\n throw new Error(\"Cannot convert string to buffer. toBuffer only supports 0x-prefixed hex strings and this string was given: \" + v);\n }\n } else if (typeof v === 'number') {\n v = ethjsUtil.intToBuffer(v);\n } else if (v === null || v === undefined) {\n v = Buffer.allocUnsafe(0);\n } else if (BN.isBN(v)) {\n v = v.toArrayLike(Buffer);\n } else if (v.toArray) {\n // converts a BN to a Buffer\n v = Buffer.from(v.toArray());\n } else {\n throw new Error('invalid type');\n }\n }\n return v;\n};\n/**\n * Converts a `Buffer` to a `Number`.\n * @param buf `Buffer` object to convert\n * @throws If the input number exceeds 53 bits.\n */\nexports.bufferToInt = function (buf) {\n return new BN(exports.toBuffer(buf)).toNumber();\n};\n/**\n * Converts a `Buffer` into a `0x`-prefixed hex `String`.\n * @param buf `Buffer` object to convert\n */\nexports.bufferToHex = function (buf) {\n buf = exports.toBuffer(buf);\n return '0x' + buf.toString('hex');\n};\n/**\n * Interprets a `Buffer` as a signed integer and returns a `BN`. Assumes 256-bit numbers.\n * @param num Signed integer value\n */\nexports.fromSigned = function (num) {\n return new BN(num).fromTwos(256);\n};\n/**\n * Converts a `BN` to an unsigned integer and returns it as a `Buffer`. Assumes 256-bit numbers.\n * @param num\n */\nexports.toUnsigned = function (num) {\n return Buffer.from(num.toTwos(256).toArray());\n};\n/**\n * Adds \"0x\" to a given `String` if it does not already start with \"0x\".\n */\nexports.addHexPrefix = function (str) {\n if (typeof str !== 'string') {\n return str;\n }\n return ethjsUtil.isHexPrefixed(str) ? str : '0x' + str;\n};\n/**\n * Converts a `Buffer` or `Array` to JSON.\n * @param ba (Buffer|Array)\n * @return (Array|String|null)\n */\nexports.baToJSON = function (ba) {\n if (Buffer.isBuffer(ba)) {\n return \"0x\" + ba.toString('hex');\n } else if (ba instanceof Array) {\n var array = [];\n for (var i = 0; i < ba.length; i++) {\n array.push(exports.baToJSON(ba[i]));\n }\n return array;\n }\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rlphash = exports.ripemd160 = exports.sha256 = exports.keccak256 = exports.keccak = void 0;\nvar _a = require('ethereum-cryptography/keccak'),\n keccak224 = _a.keccak224,\n keccak384 = _a.keccak384,\n k256 = _a.keccak256,\n keccak512 = _a.keccak512;\nvar createHash = require('create-hash');\nvar ethjsUtil = require('ethjs-util');\nvar rlp = require(\"rlp\");\nvar bytes_1 = require(\"./bytes\");\n/**\n * Creates Keccak hash of the input\n * @param a The input data (Buffer|Array|String|Number) If the string is a 0x-prefixed hex value\n * it's interpreted as hexadecimal, otherwise as utf8.\n * @param bits The Keccak width\n */\nexports.keccak = function (a, bits) {\n if (bits === void 0) {\n bits = 256;\n }\n if (typeof a === 'string' && !ethjsUtil.isHexString(a)) {\n a = Buffer.from(a, 'utf8');\n } else {\n a = bytes_1.toBuffer(a);\n }\n if (!bits) bits = 256;\n switch (bits) {\n case 224:\n {\n return keccak224(a);\n }\n case 256:\n {\n return k256(a);\n }\n case 384:\n {\n return keccak384(a);\n }\n case 512:\n {\n return keccak512(a);\n }\n default:\n {\n throw new Error(\"Invald algorithm: keccak\" + bits);\n }\n }\n};\n/**\n * Creates Keccak-256 hash of the input, alias for keccak(a, 256).\n * @param a The input data (Buffer|Array|String|Number)\n */\nexports.keccak256 = function (a) {\n return exports.keccak(a);\n};\n/**\n * Creates SHA256 hash of the input.\n * @param a The input data (Buffer|Array|String|Number)\n */\nexports.sha256 = function (a) {\n a = bytes_1.toBuffer(a);\n return createHash('sha256').update(a).digest();\n};\n/**\n * Creates RIPEMD160 hash of the input.\n * @param a The input data (Buffer|Array|String|Number)\n * @param padded Whether it should be padded to 256 bits or not\n */\nexports.ripemd160 = function (a, padded) {\n a = bytes_1.toBuffer(a);\n var hash = createHash('rmd160').update(a).digest();\n if (padded === true) {\n return bytes_1.setLength(hash, 32);\n } else {\n return hash;\n }\n};\n/**\n * Creates SHA-3 hash of the RLP encoded version of the input.\n * @param a The input data\n */\nexports.rlphash = function (a) {\n return exports.keccak(rlp.encode(a));\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.importPublic = exports.privateToPublic = exports.privateToAddress = exports.publicToAddress = exports.pubToAddress = exports.isValidPublic = exports.isValidPrivate = exports.isPrecompiled = exports.generateAddress2 = exports.generateAddress = exports.isValidChecksumAddress = exports.toChecksumAddress = exports.isZeroAddress = exports.isValidAddress = exports.zeroAddress = void 0;\nvar assert = require('assert');\nvar ethjsUtil = require('ethjs-util');\nvar secp256k1 = require('./secp256k1v3-adapter');\nvar BN = require(\"bn.js\");\nvar bytes_1 = require(\"./bytes\");\nvar hash_1 = require(\"./hash\");\n/**\n * Returns a zero address.\n */\nexports.zeroAddress = function () {\n var addressLength = 20;\n var addr = bytes_1.zeros(addressLength);\n return bytes_1.bufferToHex(addr);\n};\n/**\n * Checks if the address is a valid. Accepts checksummed addresses too.\n */\nexports.isValidAddress = function (address) {\n return /^0x[0-9a-fA-F]{40}$/.test(address);\n};\n/**\n * Checks if a given address is a zero address.\n */\nexports.isZeroAddress = function (address) {\n var zeroAddr = exports.zeroAddress();\n return zeroAddr === bytes_1.addHexPrefix(address);\n};\n/**\n * Returns a checksummed address.\n *\n * If a eip1191ChainId is provided, the chainId will be included in the checksum calculation. This\n * has the effect of checksummed addresses for one chain having invalid checksums for others.\n * For more details, consult EIP-1191.\n *\n * WARNING: Checksums with and without the chainId will differ. As of 2019-06-26, the most commonly\n * used variation in Ethereum was without the chainId. This may change in the future.\n */\nexports.toChecksumAddress = function (address, eip1191ChainId) {\n address = ethjsUtil.stripHexPrefix(address).toLowerCase();\n var prefix = eip1191ChainId !== undefined ? eip1191ChainId.toString() + '0x' : '';\n var hash = hash_1.keccak(prefix + address).toString('hex');\n var ret = '0x';\n for (var i = 0; i < address.length; i++) {\n if (parseInt(hash[i], 16) >= 8) {\n ret += address[i].toUpperCase();\n } else {\n ret += address[i];\n }\n }\n return ret;\n};\n/**\n * Checks if the address is a valid checksummed address.\n *\n * See toChecksumAddress' documentation for details about the eip1191ChainId parameter.\n */\nexports.isValidChecksumAddress = function (address, eip1191ChainId) {\n return exports.isValidAddress(address) && exports.toChecksumAddress(address, eip1191ChainId) === address;\n};\n/**\n * Generates an address of a newly created contract.\n * @param from The address which is creating this new address\n * @param nonce The nonce of the from account\n */\nexports.generateAddress = function (from, nonce) {\n from = bytes_1.toBuffer(from);\n var nonceBN = new BN(nonce);\n if (nonceBN.isZero()) {\n // in RLP we want to encode null in the case of zero nonce\n // read the RLP documentation for an answer if you dare\n return hash_1.rlphash([from, null]).slice(-20);\n }\n // Only take the lower 160bits of the hash\n return hash_1.rlphash([from, Buffer.from(nonceBN.toArray())]).slice(-20);\n};\n/**\n * Generates an address for a contract created using CREATE2.\n * @param from The address which is creating this new address\n * @param salt A salt\n * @param initCode The init code of the contract being created\n */\nexports.generateAddress2 = function (from, salt, initCode) {\n var fromBuf = bytes_1.toBuffer(from);\n var saltBuf = bytes_1.toBuffer(salt);\n var initCodeBuf = bytes_1.toBuffer(initCode);\n assert(fromBuf.length === 20);\n assert(saltBuf.length === 32);\n var address = hash_1.keccak256(Buffer.concat([Buffer.from('ff', 'hex'), fromBuf, saltBuf, hash_1.keccak256(initCodeBuf)]));\n return address.slice(-20);\n};\n/**\n * Returns true if the supplied address belongs to a precompiled account (Byzantium).\n */\nexports.isPrecompiled = function (address) {\n var a = bytes_1.unpad(address);\n return a.length === 1 && a[0] >= 1 && a[0] <= 8;\n};\n/**\n * Checks if the private key satisfies the rules of the curve secp256k1.\n */\nexports.isValidPrivate = function (privateKey) {\n return secp256k1.privateKeyVerify(privateKey);\n};\n/**\n * Checks if the public key satisfies the rules of the curve secp256k1\n * and the requirements of Ethereum.\n * @param publicKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nexports.isValidPublic = function (publicKey, sanitize) {\n if (sanitize === void 0) {\n sanitize = false;\n }\n if (publicKey.length === 64) {\n // Convert to SEC1 for secp256k1\n return secp256k1.publicKeyVerify(Buffer.concat([Buffer.from([4]), publicKey]));\n }\n if (!sanitize) {\n return false;\n }\n return secp256k1.publicKeyVerify(publicKey);\n};\n/**\n * Returns the ethereum address of a given public key.\n * Accepts \"Ethereum public keys\" and SEC1 encoded keys.\n * @param pubKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nexports.pubToAddress = function (pubKey, sanitize) {\n if (sanitize === void 0) {\n sanitize = false;\n }\n pubKey = bytes_1.toBuffer(pubKey);\n if (sanitize && pubKey.length !== 64) {\n pubKey = secp256k1.publicKeyConvert(pubKey, false).slice(1);\n }\n assert(pubKey.length === 64);\n // Only take the lower 160bits of the hash\n return hash_1.keccak(pubKey).slice(-20);\n};\nexports.publicToAddress = exports.pubToAddress;\n/**\n * Returns the ethereum address of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nexports.privateToAddress = function (privateKey) {\n return exports.publicToAddress(exports.privateToPublic(privateKey));\n};\n/**\n * Returns the ethereum public key of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nexports.privateToPublic = function (privateKey) {\n privateKey = bytes_1.toBuffer(privateKey);\n // skip the type flag and use the X, Y points\n return secp256k1.publicKeyCreate(privateKey, false).slice(1);\n};\n/**\n * Converts a public key to the Ethereum format.\n */\nexports.importPublic = function (publicKey) {\n publicKey = bytes_1.toBuffer(publicKey);\n if (publicKey.length !== 64) {\n publicKey = secp256k1.publicKeyConvert(publicKey, false).slice(1);\n }\n return publicKey;\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hashPersonalMessage = exports.isValidSignature = exports.fromRpcSig = exports.toRpcSig = exports.ecrecover = exports.ecsign = void 0;\nvar secp256k1 = require('./secp256k1v3-adapter');\nvar BN = require(\"bn.js\");\nvar bytes_1 = require(\"./bytes\");\nvar hash_1 = require(\"./hash\");\n/**\n * Returns the ECDSA signature of a message hash.\n */\nexports.ecsign = function (msgHash, privateKey, chainId) {\n var sig = secp256k1.sign(msgHash, privateKey);\n var recovery = sig.recovery;\n var ret = {\n r: sig.signature.slice(0, 32),\n s: sig.signature.slice(32, 64),\n v: chainId ? recovery + (chainId * 2 + 35) : recovery + 27\n };\n return ret;\n};\n/**\n * ECDSA public key recovery from signature.\n * @returns Recovered public key\n */\nexports.ecrecover = function (msgHash, v, r, s, chainId) {\n var signature = Buffer.concat([bytes_1.setLength(r, 32), bytes_1.setLength(s, 32)], 64);\n var recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n var senderPubKey = secp256k1.recover(msgHash, signature, recovery);\n return secp256k1.publicKeyConvert(senderPubKey, false).slice(1);\n};\n/**\n * Convert signature parameters into the format of `eth_sign` RPC method.\n * @returns Signature\n */\nexports.toRpcSig = function (v, r, s, chainId) {\n var recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n // geth (and the RPC eth_sign method) uses the 65 byte format used by Bitcoin\n return bytes_1.bufferToHex(Buffer.concat([bytes_1.setLengthLeft(r, 32), bytes_1.setLengthLeft(s, 32), bytes_1.toBuffer(v)]));\n};\n/**\n * Convert signature format of the `eth_sign` RPC method to signature parameters\n * NOTE: all because of a bug in geth: https://github.com/ethereum/go-ethereum/issues/2053\n */\nexports.fromRpcSig = function (sig) {\n var buf = bytes_1.toBuffer(sig);\n // NOTE: with potential introduction of chainId this might need to be updated\n if (buf.length !== 65) {\n throw new Error('Invalid signature length');\n }\n var v = buf[64];\n // support both versions of `eth_sign` responses\n if (v < 27) {\n v += 27;\n }\n return {\n v: v,\n r: buf.slice(0, 32),\n s: buf.slice(32, 64)\n };\n};\n/**\n * Validate a ECDSA signature.\n * @param homesteadOrLater Indicates whether this is being used on either the homestead hardfork or a later one\n */\nexports.isValidSignature = function (v, r, s, homesteadOrLater, chainId) {\n if (homesteadOrLater === void 0) {\n homesteadOrLater = true;\n }\n var SECP256K1_N_DIV_2 = new BN('7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a0', 16);\n var SECP256K1_N = new BN('fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141', 16);\n if (r.length !== 32 || s.length !== 32) {\n return false;\n }\n if (!isValidSigRecovery(calculateSigRecovery(v, chainId))) {\n return false;\n }\n var rBN = new BN(r);\n var sBN = new BN(s);\n if (rBN.isZero() || rBN.gt(SECP256K1_N) || sBN.isZero() || sBN.gt(SECP256K1_N)) {\n return false;\n }\n if (homesteadOrLater && sBN.cmp(SECP256K1_N_DIV_2) === 1) {\n return false;\n }\n return true;\n};\n/**\n * Returns the keccak-256 hash of `message`, prefixed with the header used by the `eth_sign` RPC call.\n * The output of this function can be fed into `ecsign` to produce the same signature as the `eth_sign`\n * call for a given `message`, or fed to `ecrecover` along with a signature to recover the public key\n * used to produce the signature.\n */\nexports.hashPersonalMessage = function (message) {\n var prefix = Buffer.from(\"\\u0019Ethereum Signed Message:\\n\" + message.length.toString(), 'utf-8');\n return hash_1.keccak(Buffer.concat([prefix, message]));\n};\nfunction calculateSigRecovery(v, chainId) {\n return chainId ? v - (2 * chainId + 35) : v - 27;\n}\nfunction isValidSigRecovery(recovery) {\n return recovery === 0 || recovery === 1;\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.defineProperties = void 0;\nvar assert = require('assert');\nvar ethjsUtil = require('ethjs-util');\nvar rlp = require(\"rlp\");\nvar bytes_1 = require(\"./bytes\");\n/**\n * Defines properties on a `Object`. It make the assumption that underlying data is binary.\n * @param self the `Object` to define properties on\n * @param fields an array fields to define. Fields can contain:\n * * `name` - the name of the properties\n * * `length` - the number of bytes the field can have\n * * `allowLess` - if the field can be less than the length\n * * `allowEmpty`\n * @param data data to be validated against the definitions\n * @deprecated\n */\nexports.defineProperties = function (self, fields, data) {\n self.raw = [];\n self._fields = [];\n // attach the `toJSON`\n self.toJSON = function (label) {\n if (label === void 0) {\n label = false;\n }\n if (label) {\n var obj_1 = {};\n self._fields.forEach(function (field) {\n obj_1[field] = \"0x\" + self[field].toString('hex');\n });\n return obj_1;\n }\n return bytes_1.baToJSON(self.raw);\n };\n self.serialize = function serialize() {\n return rlp.encode(self.raw);\n };\n fields.forEach(function (field, i) {\n self._fields.push(field.name);\n function getter() {\n return self.raw[i];\n }\n function setter(v) {\n v = bytes_1.toBuffer(v);\n if (v.toString('hex') === '00' && !field.allowZero) {\n v = Buffer.allocUnsafe(0);\n }\n if (field.allowLess && field.length) {\n v = bytes_1.stripZeros(v);\n assert(field.length >= v.length, \"The field \" + field.name + \" must not have more \" + field.length + \" bytes\");\n } else if (!(field.allowZero && v.length === 0) && field.length) {\n assert(field.length === v.length, \"The field \" + field.name + \" must have byte length of \" + field.length);\n }\n self.raw[i] = v;\n }\n Object.defineProperty(self, field.name, {\n enumerable: true,\n configurable: true,\n get: getter,\n set: setter\n });\n if (field.default) {\n self[field.name] = field.default;\n }\n // attach alias\n if (field.alias) {\n Object.defineProperty(self, field.alias, {\n enumerable: false,\n configurable: true,\n set: setter,\n get: getter\n });\n }\n });\n // if the constuctor is passed data\n if (data) {\n if (typeof data === 'string') {\n data = Buffer.from(ethjsUtil.stripHexPrefix(data), 'hex');\n }\n if (Buffer.isBuffer(data)) {\n data = rlp.decode(data);\n }\n if (Array.isArray(data)) {\n if (data.length > self._fields.length) {\n throw new Error('wrong number of fields in data');\n }\n // make sure all the items are buffers\n data.forEach(function (d, i) {\n self[self._fields[i]] = bytes_1.toBuffer(d);\n });\n } else if (typeof data === 'object') {\n var keys_1 = Object.keys(data);\n fields.forEach(function (field) {\n if (keys_1.indexOf(field.name) !== -1) self[field.name] = data[field.name];\n if (keys_1.indexOf(field.alias) !== -1) self[field.alias] = data[field.alias];\n });\n } else {\n throw new Error('invalid data');\n }\n }\n};\n","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\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\" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.secp256k1 = exports.rlp = exports.BN = void 0;\nvar secp256k1 = require('./secp256k1v3-adapter');\nexports.secp256k1 = secp256k1;\nvar ethjsUtil = require('ethjs-util');\nvar BN = require(\"bn.js\");\nexports.BN = BN;\nvar rlp = require(\"rlp\");\nexports.rlp = rlp;\nObject.assign(exports, ethjsUtil);\n/**\n * Constants\n */\n__exportStar(require(\"./constants\"), exports);\n/**\n * Public-key cryptography (secp256k1) and addresses\n */\n__exportStar(require(\"./account\"), exports);\n/**\n * Hash functions\n */\n__exportStar(require(\"./hash\"), exports);\n/**\n * ECDSA signature\n */\n__exportStar(require(\"./signature\"), exports);\n/**\n * Utilities for manipulating Buffers, byte arrays, etc.\n */\n__exportStar(require(\"./bytes\"), exports);\n/**\n * Function for definining properties on an object\n */\n__exportStar(require(\"./object\"), exports);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.normalize = exports.recoverPublicKey = exports.concatSig = exports.legacyToBuffer = exports.isNullish = exports.padWithZeroes = void 0;\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst ethjs_util_1 = require(\"ethjs-util\");\n/**\n * Pads the front of the given hex string with zeroes until it reaches the\n * target length. If the input string is already longer than or equal to the\n * target length, it is returned unmodified.\n *\n * If the input string is \"0x\"-prefixed or not a hex string, an error will be\n * thrown.\n *\n * @param hexString - The hexadecimal string to pad with zeroes.\n * @param targetLength - The target length of the hexadecimal string.\n * @returns The input string front-padded with zeroes, or the original string\n * if it was already greater than or equal to to the target length.\n */\nfunction padWithZeroes(hexString, targetLength) {\n if (hexString !== '' && !/^[a-f0-9]+$/iu.test(hexString)) {\n throw new Error(`Expected an unprefixed hex string. Received: ${hexString}`);\n }\n if (targetLength < 0) {\n throw new Error(`Expected a non-negative integer target length. Received: ${targetLength}`);\n }\n return String.prototype.padStart.call(hexString, targetLength, '0');\n}\nexports.padWithZeroes = padWithZeroes;\n/**\n * Returns `true` if the given value is nullish.\n *\n * @param value - The value being checked.\n * @returns Whether the value is nullish.\n */\nfunction isNullish(value) {\n return value === null || value === undefined;\n}\nexports.isNullish = isNullish;\n/**\n * Convert a value to a Buffer. This function should be equivalent to the `toBuffer` function in\n * `ethereumjs-util@5.2.1`.\n *\n * @param value - The value to convert to a Buffer.\n * @returns The given value as a Buffer.\n */\nfunction legacyToBuffer(value) {\n return typeof value === 'string' && !ethjs_util_1.isHexString(value) ? Buffer.from(value) : ethereumjs_util_1.toBuffer(value);\n}\nexports.legacyToBuffer = legacyToBuffer;\n/**\n * Concatenate an extended ECDSA signature into a single '0x'-prefixed hex string.\n *\n * @param v - The 'v' portion of the signature.\n * @param r - The 'r' portion of the signature.\n * @param s - The 's' portion of the signature.\n * @returns The concatenated ECDSA signature as a '0x'-prefixed string.\n */\nfunction concatSig(v, r, s) {\n const rSig = ethereumjs_util_1.fromSigned(r);\n const sSig = ethereumjs_util_1.fromSigned(s);\n const vSig = ethereumjs_util_1.bufferToInt(v);\n const rStr = padWithZeroes(ethereumjs_util_1.toUnsigned(rSig).toString('hex'), 64);\n const sStr = padWithZeroes(ethereumjs_util_1.toUnsigned(sSig).toString('hex'), 64);\n const vStr = ethjs_util_1.stripHexPrefix(ethjs_util_1.intToHex(vSig));\n return ethereumjs_util_1.addHexPrefix(rStr.concat(sStr, vStr));\n}\nexports.concatSig = concatSig;\n/**\n * Recover the public key from the given signature and message hash.\n *\n * @param messageHash - The hash of the signed message.\n * @param signature - The signature.\n * @returns The public key of the signer.\n */\nfunction recoverPublicKey(messageHash, signature) {\n const sigParams = ethereumjs_util_1.fromRpcSig(signature);\n return ethereumjs_util_1.ecrecover(messageHash, sigParams.v, sigParams.r, sigParams.s);\n}\nexports.recoverPublicKey = recoverPublicKey;\n/**\n * Normalize the input to a lower-cased '0x'-prefixed hex string.\n *\n * @param input - The value to normalize.\n * @returns The normalized value.\n */\nfunction normalize(input) {\n if (!input) {\n return undefined;\n }\n if (typeof input === 'number') {\n const buffer = ethereumjs_util_1.toBuffer(input);\n input = ethereumjs_util_1.bufferToHex(buffer);\n }\n if (typeof input !== 'string') {\n let msg = 'eth-sig-util.normalize() requires hex string or integer input.';\n msg += ` received ${typeof input}: ${input}`;\n throw new Error(msg);\n }\n return ethereumjs_util_1.addHexPrefix(input.toLowerCase());\n}\nexports.normalize = normalize;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.extractPublicKey = exports.recoverPersonalSignature = exports.personalSign = void 0;\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst utils_1 = require(\"./utils\");\n/**\n * Create an Ethereum-specific signature for a message.\n *\n * This function is equivalent to the `eth_sign` Ethereum JSON-RPC method as specified in EIP-1417,\n * as well as the MetaMask's `personal_sign` method.\n *\n * @param options - The personal sign options.\n * @param options.privateKey - The key to sign with.\n * @param options.data - The hex data to sign.\n * @returns The '0x'-prefixed hex encoded signature.\n */\nfunction personalSign({\n privateKey,\n data\n}) {\n if (utils_1.isNullish(data)) {\n throw new Error('Missing data parameter');\n } else if (utils_1.isNullish(privateKey)) {\n throw new Error('Missing privateKey parameter');\n }\n const message = utils_1.legacyToBuffer(data);\n const msgHash = ethereumjs_util_1.hashPersonalMessage(message);\n const sig = ethereumjs_util_1.ecsign(msgHash, privateKey);\n const serialized = utils_1.concatSig(ethereumjs_util_1.toBuffer(sig.v), sig.r, sig.s);\n return serialized;\n}\nexports.personalSign = personalSign;\n/**\n * Recover the address of the account used to create the given Ethereum signature. The message\n * must have been signed using the `personalSign` function, or an equivalent function.\n *\n * @param options - The signature recovery options.\n * @param options.data - The hex data that was signed.\n * @param options.signature - The '0x'-prefixed hex encoded message signature.\n * @returns The '0x'-prefixed hex encoded address of the message signer.\n */\nfunction recoverPersonalSignature({\n data,\n signature\n}) {\n if (utils_1.isNullish(data)) {\n throw new Error('Missing data parameter');\n } else if (utils_1.isNullish(signature)) {\n throw new Error('Missing signature parameter');\n }\n const publicKey = getPublicKeyFor(data, signature);\n const sender = ethereumjs_util_1.publicToAddress(publicKey);\n const senderHex = ethereumjs_util_1.bufferToHex(sender);\n return senderHex;\n}\nexports.recoverPersonalSignature = recoverPersonalSignature;\n/**\n * Recover the public key of the account used to create the given Ethereum signature. The message\n * must have been signed using the `personalSign` function, or an equivalent function.\n *\n * @param options - The public key recovery options.\n * @param options.data - The hex data that was signed.\n * @param options.signature - The '0x'-prefixed hex encoded message signature.\n * @returns The '0x'-prefixed hex encoded public key of the message signer.\n */\nfunction extractPublicKey({\n data,\n signature\n}) {\n if (utils_1.isNullish(data)) {\n throw new Error('Missing data parameter');\n } else if (utils_1.isNullish(signature)) {\n throw new Error('Missing signature parameter');\n }\n const publicKey = getPublicKeyFor(data, signature);\n return `0x${publicKey.toString('hex')}`;\n}\nexports.extractPublicKey = extractPublicKey;\n/**\n * Get the public key for the given signature and message.\n *\n * @param message - The message that was signed.\n * @param signature - The '0x'-prefixed hex encoded message signature.\n * @returns The public key of the signer.\n */\nfunction getPublicKeyFor(message, signature) {\n const messageHash = ethereumjs_util_1.hashPersonalMessage(utils_1.legacyToBuffer(message));\n return utils_1.recoverPublicKey(messageHash, signature);\n}\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert(val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits(ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN(number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n BN.BN = BN;\n BN.wordSize = 26;\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {}\n BN.isBN = function isBN(num) {\n if (num instanceof BN) {\n return true;\n }\n return num !== null && typeof num === 'object' && num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n BN.max = function max(left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n BN.min = function min(left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n BN.prototype._init = function init(number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n BN.prototype._initNumber = function _initNumber(number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [number & 0x3ffffff, number / 0x4000000 & 0x3ffffff, 1];\n this.length = 3;\n }\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n BN.prototype._initArray = function _initArray(number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | number[i - 1] << 8 | number[i - 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | number[i + 1] << 8 | number[i + 2] << 16;\n this.words[j] |= w << off & 0x3ffffff;\n this.words[j + 1] = w >>> 26 - off & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this.strip();\n };\n function parseHex4Bits(string, index) {\n var c = string.charCodeAt(index);\n // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return c - 48 & 0xf;\n }\n }\n function parseHexByte(string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n BN.prototype._parseHex = function _parseHex(number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n this.strip();\n };\n function parseBase(str, start, end, mul) {\n var r = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\n }\n return r;\n }\n BN.prototype._parseBase = function _parseBase(number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = limbPow / base | 0;\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n this.strip();\n };\n BN.prototype.copy = function copy(dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n BN.prototype.clone = function clone() {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n BN.prototype._expand = function _expand(size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype.strip = function strip() {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n BN.prototype._normSign = function _normSign() {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n BN.prototype.inspect = function inspect() {\n return (this.red ? '';\n };\n\n /*\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n */\n\n var zeros = ['', '0', '00', '000', '0000', '00000', '000000', '0000000', '00000000', '000000000', '0000000000', '00000000000', '000000000000', '0000000000000', '00000000000000', '000000000000000', '0000000000000000', '00000000000000000', '000000000000000000', '0000000000000000000', '00000000000000000000', '000000000000000000000', '0000000000000000000000', '00000000000000000000000', '000000000000000000000000', '0000000000000000000000000'];\n var groupSizes = [0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5];\n var groupBases = [0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176];\n BN.prototype.toString = function toString(base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = ((w << off | carry) & 0xffffff).toString(16);\n carry = w >>> 24 - off & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modn(groupBase).toString(base);\n c = c.idivn(groupBase);\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n assert(false, 'Base should be between 2 and 36');\n };\n BN.prototype.toNumber = function toNumber() {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + this.words[1] * 0x4000000;\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return this.negative !== 0 ? -ret : ret;\n };\n BN.prototype.toJSON = function toJSON() {\n return this.toString(16);\n };\n BN.prototype.toBuffer = function toBuffer(endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n BN.prototype.toArray = function toArray(endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n BN.prototype.toArrayLike = function toArrayLike(ArrayType, endian, length) {\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n res[i] = b;\n }\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n return res;\n };\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits(w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits(w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n BN.prototype._zeroBits = function _zeroBits(w) {\n // Short-cut\n if (w === 0) return 26;\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength() {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n function toBitArray(num) {\n var w = new Array(num.bitLength());\n for (var bit = 0; bit < w.length; bit++) {\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n w[bit] = (num.words[off] & 1 << wbit) >>> wbit;\n }\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits() {\n if (this.isZero()) return 0;\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n BN.prototype.byteLength = function byteLength() {\n return Math.ceil(this.bitLength() / 8);\n };\n BN.prototype.toTwos = function toTwos(width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n BN.prototype.fromTwos = function fromTwos(width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n BN.prototype.isNeg = function isNeg() {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg() {\n return this.clone().ineg();\n };\n BN.prototype.ineg = function ineg() {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor(num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n return this.strip();\n };\n BN.prototype.ior = function ior(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or(num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n BN.prototype.uor = function uor(num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand(num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n this.length = b.length;\n return this.strip();\n };\n BN.prototype.iand = function iand(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and(num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n BN.prototype.uand = function uand(num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor(num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = a.length;\n return this.strip();\n };\n BN.prototype.ixor = function ixor(num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor(num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n BN.prototype.uxor = function uxor(num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn(width) {\n assert(typeof width === 'number' && width >= 0);\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & 0x3ffffff >> 26 - bitsLeft;\n }\n\n // And remove leading zeroes\n return this.strip();\n };\n BN.prototype.notn = function notn(width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn(bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n var off = bit / 26 | 0;\n var wbit = bit % 26;\n this._expand(off + 1);\n if (val) {\n this.words[off] = this.words[off] | 1 << wbit;\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n return this.strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd(num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add(num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n if (this.length > num.length) return this.clone().iadd(num);\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub(num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n this.length = Math.max(this.length, i);\n if (a !== this) {\n this.negative = 1;\n }\n return this.strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub(num) {\n return this.clone().isub(num);\n };\n function smallMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = self.length + num.length | 0;\n out.length = len;\n len = len - 1 | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n var carry = r / 0x4000000 | 0;\n out.words[0] = lo;\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += r / 0x4000000 | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n return out.strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo(self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = mid + Math.imul(ah0, bl0) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w0 >>> 26) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = mid + Math.imul(ah1, bl0) | 0;\n hi = Math.imul(ah1, bh0);\n lo = lo + Math.imul(al0, bl1) | 0;\n mid = mid + Math.imul(al0, bh1) | 0;\n mid = mid + Math.imul(ah0, bl1) | 0;\n hi = hi + Math.imul(ah0, bh1) | 0;\n var w1 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w1 >>> 26) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = mid + Math.imul(ah2, bl0) | 0;\n hi = Math.imul(ah2, bh0);\n lo = lo + Math.imul(al1, bl1) | 0;\n mid = mid + Math.imul(al1, bh1) | 0;\n mid = mid + Math.imul(ah1, bl1) | 0;\n hi = hi + Math.imul(ah1, bh1) | 0;\n lo = lo + Math.imul(al0, bl2) | 0;\n mid = mid + Math.imul(al0, bh2) | 0;\n mid = mid + Math.imul(ah0, bl2) | 0;\n hi = hi + Math.imul(ah0, bh2) | 0;\n var w2 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w2 >>> 26) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = mid + Math.imul(ah3, bl0) | 0;\n hi = Math.imul(ah3, bh0);\n lo = lo + Math.imul(al2, bl1) | 0;\n mid = mid + Math.imul(al2, bh1) | 0;\n mid = mid + Math.imul(ah2, bl1) | 0;\n hi = hi + Math.imul(ah2, bh1) | 0;\n lo = lo + Math.imul(al1, bl2) | 0;\n mid = mid + Math.imul(al1, bh2) | 0;\n mid = mid + Math.imul(ah1, bl2) | 0;\n hi = hi + Math.imul(ah1, bh2) | 0;\n lo = lo + Math.imul(al0, bl3) | 0;\n mid = mid + Math.imul(al0, bh3) | 0;\n mid = mid + Math.imul(ah0, bl3) | 0;\n hi = hi + Math.imul(ah0, bh3) | 0;\n var w3 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w3 >>> 26) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = mid + Math.imul(ah4, bl0) | 0;\n hi = Math.imul(ah4, bh0);\n lo = lo + Math.imul(al3, bl1) | 0;\n mid = mid + Math.imul(al3, bh1) | 0;\n mid = mid + Math.imul(ah3, bl1) | 0;\n hi = hi + Math.imul(ah3, bh1) | 0;\n lo = lo + Math.imul(al2, bl2) | 0;\n mid = mid + Math.imul(al2, bh2) | 0;\n mid = mid + Math.imul(ah2, bl2) | 0;\n hi = hi + Math.imul(ah2, bh2) | 0;\n lo = lo + Math.imul(al1, bl3) | 0;\n mid = mid + Math.imul(al1, bh3) | 0;\n mid = mid + Math.imul(ah1, bl3) | 0;\n hi = hi + Math.imul(ah1, bh3) | 0;\n lo = lo + Math.imul(al0, bl4) | 0;\n mid = mid + Math.imul(al0, bh4) | 0;\n mid = mid + Math.imul(ah0, bl4) | 0;\n hi = hi + Math.imul(ah0, bh4) | 0;\n var w4 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w4 >>> 26) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = mid + Math.imul(ah5, bl0) | 0;\n hi = Math.imul(ah5, bh0);\n lo = lo + Math.imul(al4, bl1) | 0;\n mid = mid + Math.imul(al4, bh1) | 0;\n mid = mid + Math.imul(ah4, bl1) | 0;\n hi = hi + Math.imul(ah4, bh1) | 0;\n lo = lo + Math.imul(al3, bl2) | 0;\n mid = mid + Math.imul(al3, bh2) | 0;\n mid = mid + Math.imul(ah3, bl2) | 0;\n hi = hi + Math.imul(ah3, bh2) | 0;\n lo = lo + Math.imul(al2, bl3) | 0;\n mid = mid + Math.imul(al2, bh3) | 0;\n mid = mid + Math.imul(ah2, bl3) | 0;\n hi = hi + Math.imul(ah2, bh3) | 0;\n lo = lo + Math.imul(al1, bl4) | 0;\n mid = mid + Math.imul(al1, bh4) | 0;\n mid = mid + Math.imul(ah1, bl4) | 0;\n hi = hi + Math.imul(ah1, bh4) | 0;\n lo = lo + Math.imul(al0, bl5) | 0;\n mid = mid + Math.imul(al0, bh5) | 0;\n mid = mid + Math.imul(ah0, bl5) | 0;\n hi = hi + Math.imul(ah0, bh5) | 0;\n var w5 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w5 >>> 26) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = mid + Math.imul(ah6, bl0) | 0;\n hi = Math.imul(ah6, bh0);\n lo = lo + Math.imul(al5, bl1) | 0;\n mid = mid + Math.imul(al5, bh1) | 0;\n mid = mid + Math.imul(ah5, bl1) | 0;\n hi = hi + Math.imul(ah5, bh1) | 0;\n lo = lo + Math.imul(al4, bl2) | 0;\n mid = mid + Math.imul(al4, bh2) | 0;\n mid = mid + Math.imul(ah4, bl2) | 0;\n hi = hi + Math.imul(ah4, bh2) | 0;\n lo = lo + Math.imul(al3, bl3) | 0;\n mid = mid + Math.imul(al3, bh3) | 0;\n mid = mid + Math.imul(ah3, bl3) | 0;\n hi = hi + Math.imul(ah3, bh3) | 0;\n lo = lo + Math.imul(al2, bl4) | 0;\n mid = mid + Math.imul(al2, bh4) | 0;\n mid = mid + Math.imul(ah2, bl4) | 0;\n hi = hi + Math.imul(ah2, bh4) | 0;\n lo = lo + Math.imul(al1, bl5) | 0;\n mid = mid + Math.imul(al1, bh5) | 0;\n mid = mid + Math.imul(ah1, bl5) | 0;\n hi = hi + Math.imul(ah1, bh5) | 0;\n lo = lo + Math.imul(al0, bl6) | 0;\n mid = mid + Math.imul(al0, bh6) | 0;\n mid = mid + Math.imul(ah0, bl6) | 0;\n hi = hi + Math.imul(ah0, bh6) | 0;\n var w6 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w6 >>> 26) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = mid + Math.imul(ah7, bl0) | 0;\n hi = Math.imul(ah7, bh0);\n lo = lo + Math.imul(al6, bl1) | 0;\n mid = mid + Math.imul(al6, bh1) | 0;\n mid = mid + Math.imul(ah6, bl1) | 0;\n hi = hi + Math.imul(ah6, bh1) | 0;\n lo = lo + Math.imul(al5, bl2) | 0;\n mid = mid + Math.imul(al5, bh2) | 0;\n mid = mid + Math.imul(ah5, bl2) | 0;\n hi = hi + Math.imul(ah5, bh2) | 0;\n lo = lo + Math.imul(al4, bl3) | 0;\n mid = mid + Math.imul(al4, bh3) | 0;\n mid = mid + Math.imul(ah4, bl3) | 0;\n hi = hi + Math.imul(ah4, bh3) | 0;\n lo = lo + Math.imul(al3, bl4) | 0;\n mid = mid + Math.imul(al3, bh4) | 0;\n mid = mid + Math.imul(ah3, bl4) | 0;\n hi = hi + Math.imul(ah3, bh4) | 0;\n lo = lo + Math.imul(al2, bl5) | 0;\n mid = mid + Math.imul(al2, bh5) | 0;\n mid = mid + Math.imul(ah2, bl5) | 0;\n hi = hi + Math.imul(ah2, bh5) | 0;\n lo = lo + Math.imul(al1, bl6) | 0;\n mid = mid + Math.imul(al1, bh6) | 0;\n mid = mid + Math.imul(ah1, bl6) | 0;\n hi = hi + Math.imul(ah1, bh6) | 0;\n lo = lo + Math.imul(al0, bl7) | 0;\n mid = mid + Math.imul(al0, bh7) | 0;\n mid = mid + Math.imul(ah0, bl7) | 0;\n hi = hi + Math.imul(ah0, bh7) | 0;\n var w7 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w7 >>> 26) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = mid + Math.imul(ah8, bl0) | 0;\n hi = Math.imul(ah8, bh0);\n lo = lo + Math.imul(al7, bl1) | 0;\n mid = mid + Math.imul(al7, bh1) | 0;\n mid = mid + Math.imul(ah7, bl1) | 0;\n hi = hi + Math.imul(ah7, bh1) | 0;\n lo = lo + Math.imul(al6, bl2) | 0;\n mid = mid + Math.imul(al6, bh2) | 0;\n mid = mid + Math.imul(ah6, bl2) | 0;\n hi = hi + Math.imul(ah6, bh2) | 0;\n lo = lo + Math.imul(al5, bl3) | 0;\n mid = mid + Math.imul(al5, bh3) | 0;\n mid = mid + Math.imul(ah5, bl3) | 0;\n hi = hi + Math.imul(ah5, bh3) | 0;\n lo = lo + Math.imul(al4, bl4) | 0;\n mid = mid + Math.imul(al4, bh4) | 0;\n mid = mid + Math.imul(ah4, bl4) | 0;\n hi = hi + Math.imul(ah4, bh4) | 0;\n lo = lo + Math.imul(al3, bl5) | 0;\n mid = mid + Math.imul(al3, bh5) | 0;\n mid = mid + Math.imul(ah3, bl5) | 0;\n hi = hi + Math.imul(ah3, bh5) | 0;\n lo = lo + Math.imul(al2, bl6) | 0;\n mid = mid + Math.imul(al2, bh6) | 0;\n mid = mid + Math.imul(ah2, bl6) | 0;\n hi = hi + Math.imul(ah2, bh6) | 0;\n lo = lo + Math.imul(al1, bl7) | 0;\n mid = mid + Math.imul(al1, bh7) | 0;\n mid = mid + Math.imul(ah1, bl7) | 0;\n hi = hi + Math.imul(ah1, bh7) | 0;\n lo = lo + Math.imul(al0, bl8) | 0;\n mid = mid + Math.imul(al0, bh8) | 0;\n mid = mid + Math.imul(ah0, bl8) | 0;\n hi = hi + Math.imul(ah0, bh8) | 0;\n var w8 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w8 >>> 26) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = mid + Math.imul(ah9, bl0) | 0;\n hi = Math.imul(ah9, bh0);\n lo = lo + Math.imul(al8, bl1) | 0;\n mid = mid + Math.imul(al8, bh1) | 0;\n mid = mid + Math.imul(ah8, bl1) | 0;\n hi = hi + Math.imul(ah8, bh1) | 0;\n lo = lo + Math.imul(al7, bl2) | 0;\n mid = mid + Math.imul(al7, bh2) | 0;\n mid = mid + Math.imul(ah7, bl2) | 0;\n hi = hi + Math.imul(ah7, bh2) | 0;\n lo = lo + Math.imul(al6, bl3) | 0;\n mid = mid + Math.imul(al6, bh3) | 0;\n mid = mid + Math.imul(ah6, bl3) | 0;\n hi = hi + Math.imul(ah6, bh3) | 0;\n lo = lo + Math.imul(al5, bl4) | 0;\n mid = mid + Math.imul(al5, bh4) | 0;\n mid = mid + Math.imul(ah5, bl4) | 0;\n hi = hi + Math.imul(ah5, bh4) | 0;\n lo = lo + Math.imul(al4, bl5) | 0;\n mid = mid + Math.imul(al4, bh5) | 0;\n mid = mid + Math.imul(ah4, bl5) | 0;\n hi = hi + Math.imul(ah4, bh5) | 0;\n lo = lo + Math.imul(al3, bl6) | 0;\n mid = mid + Math.imul(al3, bh6) | 0;\n mid = mid + Math.imul(ah3, bl6) | 0;\n hi = hi + Math.imul(ah3, bh6) | 0;\n lo = lo + Math.imul(al2, bl7) | 0;\n mid = mid + Math.imul(al2, bh7) | 0;\n mid = mid + Math.imul(ah2, bl7) | 0;\n hi = hi + Math.imul(ah2, bh7) | 0;\n lo = lo + Math.imul(al1, bl8) | 0;\n mid = mid + Math.imul(al1, bh8) | 0;\n mid = mid + Math.imul(ah1, bl8) | 0;\n hi = hi + Math.imul(ah1, bh8) | 0;\n lo = lo + Math.imul(al0, bl9) | 0;\n mid = mid + Math.imul(al0, bh9) | 0;\n mid = mid + Math.imul(ah0, bl9) | 0;\n hi = hi + Math.imul(ah0, bh9) | 0;\n var w9 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w9 >>> 26) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = mid + Math.imul(ah9, bl1) | 0;\n hi = Math.imul(ah9, bh1);\n lo = lo + Math.imul(al8, bl2) | 0;\n mid = mid + Math.imul(al8, bh2) | 0;\n mid = mid + Math.imul(ah8, bl2) | 0;\n hi = hi + Math.imul(ah8, bh2) | 0;\n lo = lo + Math.imul(al7, bl3) | 0;\n mid = mid + Math.imul(al7, bh3) | 0;\n mid = mid + Math.imul(ah7, bl3) | 0;\n hi = hi + Math.imul(ah7, bh3) | 0;\n lo = lo + Math.imul(al6, bl4) | 0;\n mid = mid + Math.imul(al6, bh4) | 0;\n mid = mid + Math.imul(ah6, bl4) | 0;\n hi = hi + Math.imul(ah6, bh4) | 0;\n lo = lo + Math.imul(al5, bl5) | 0;\n mid = mid + Math.imul(al5, bh5) | 0;\n mid = mid + Math.imul(ah5, bl5) | 0;\n hi = hi + Math.imul(ah5, bh5) | 0;\n lo = lo + Math.imul(al4, bl6) | 0;\n mid = mid + Math.imul(al4, bh6) | 0;\n mid = mid + Math.imul(ah4, bl6) | 0;\n hi = hi + Math.imul(ah4, bh6) | 0;\n lo = lo + Math.imul(al3, bl7) | 0;\n mid = mid + Math.imul(al3, bh7) | 0;\n mid = mid + Math.imul(ah3, bl7) | 0;\n hi = hi + Math.imul(ah3, bh7) | 0;\n lo = lo + Math.imul(al2, bl8) | 0;\n mid = mid + Math.imul(al2, bh8) | 0;\n mid = mid + Math.imul(ah2, bl8) | 0;\n hi = hi + Math.imul(ah2, bh8) | 0;\n lo = lo + Math.imul(al1, bl9) | 0;\n mid = mid + Math.imul(al1, bh9) | 0;\n mid = mid + Math.imul(ah1, bl9) | 0;\n hi = hi + Math.imul(ah1, bh9) | 0;\n var w10 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w10 >>> 26) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = mid + Math.imul(ah9, bl2) | 0;\n hi = Math.imul(ah9, bh2);\n lo = lo + Math.imul(al8, bl3) | 0;\n mid = mid + Math.imul(al8, bh3) | 0;\n mid = mid + Math.imul(ah8, bl3) | 0;\n hi = hi + Math.imul(ah8, bh3) | 0;\n lo = lo + Math.imul(al7, bl4) | 0;\n mid = mid + Math.imul(al7, bh4) | 0;\n mid = mid + Math.imul(ah7, bl4) | 0;\n hi = hi + Math.imul(ah7, bh4) | 0;\n lo = lo + Math.imul(al6, bl5) | 0;\n mid = mid + Math.imul(al6, bh5) | 0;\n mid = mid + Math.imul(ah6, bl5) | 0;\n hi = hi + Math.imul(ah6, bh5) | 0;\n lo = lo + Math.imul(al5, bl6) | 0;\n mid = mid + Math.imul(al5, bh6) | 0;\n mid = mid + Math.imul(ah5, bl6) | 0;\n hi = hi + Math.imul(ah5, bh6) | 0;\n lo = lo + Math.imul(al4, bl7) | 0;\n mid = mid + Math.imul(al4, bh7) | 0;\n mid = mid + Math.imul(ah4, bl7) | 0;\n hi = hi + Math.imul(ah4, bh7) | 0;\n lo = lo + Math.imul(al3, bl8) | 0;\n mid = mid + Math.imul(al3, bh8) | 0;\n mid = mid + Math.imul(ah3, bl8) | 0;\n hi = hi + Math.imul(ah3, bh8) | 0;\n lo = lo + Math.imul(al2, bl9) | 0;\n mid = mid + Math.imul(al2, bh9) | 0;\n mid = mid + Math.imul(ah2, bl9) | 0;\n hi = hi + Math.imul(ah2, bh9) | 0;\n var w11 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w11 >>> 26) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = mid + Math.imul(ah9, bl3) | 0;\n hi = Math.imul(ah9, bh3);\n lo = lo + Math.imul(al8, bl4) | 0;\n mid = mid + Math.imul(al8, bh4) | 0;\n mid = mid + Math.imul(ah8, bl4) | 0;\n hi = hi + Math.imul(ah8, bh4) | 0;\n lo = lo + Math.imul(al7, bl5) | 0;\n mid = mid + Math.imul(al7, bh5) | 0;\n mid = mid + Math.imul(ah7, bl5) | 0;\n hi = hi + Math.imul(ah7, bh5) | 0;\n lo = lo + Math.imul(al6, bl6) | 0;\n mid = mid + Math.imul(al6, bh6) | 0;\n mid = mid + Math.imul(ah6, bl6) | 0;\n hi = hi + Math.imul(ah6, bh6) | 0;\n lo = lo + Math.imul(al5, bl7) | 0;\n mid = mid + Math.imul(al5, bh7) | 0;\n mid = mid + Math.imul(ah5, bl7) | 0;\n hi = hi + Math.imul(ah5, bh7) | 0;\n lo = lo + Math.imul(al4, bl8) | 0;\n mid = mid + Math.imul(al4, bh8) | 0;\n mid = mid + Math.imul(ah4, bl8) | 0;\n hi = hi + Math.imul(ah4, bh8) | 0;\n lo = lo + Math.imul(al3, bl9) | 0;\n mid = mid + Math.imul(al3, bh9) | 0;\n mid = mid + Math.imul(ah3, bl9) | 0;\n hi = hi + Math.imul(ah3, bh9) | 0;\n var w12 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w12 >>> 26) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = mid + Math.imul(ah9, bl4) | 0;\n hi = Math.imul(ah9, bh4);\n lo = lo + Math.imul(al8, bl5) | 0;\n mid = mid + Math.imul(al8, bh5) | 0;\n mid = mid + Math.imul(ah8, bl5) | 0;\n hi = hi + Math.imul(ah8, bh5) | 0;\n lo = lo + Math.imul(al7, bl6) | 0;\n mid = mid + Math.imul(al7, bh6) | 0;\n mid = mid + Math.imul(ah7, bl6) | 0;\n hi = hi + Math.imul(ah7, bh6) | 0;\n lo = lo + Math.imul(al6, bl7) | 0;\n mid = mid + Math.imul(al6, bh7) | 0;\n mid = mid + Math.imul(ah6, bl7) | 0;\n hi = hi + Math.imul(ah6, bh7) | 0;\n lo = lo + Math.imul(al5, bl8) | 0;\n mid = mid + Math.imul(al5, bh8) | 0;\n mid = mid + Math.imul(ah5, bl8) | 0;\n hi = hi + Math.imul(ah5, bh8) | 0;\n lo = lo + Math.imul(al4, bl9) | 0;\n mid = mid + Math.imul(al4, bh9) | 0;\n mid = mid + Math.imul(ah4, bl9) | 0;\n hi = hi + Math.imul(ah4, bh9) | 0;\n var w13 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w13 >>> 26) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = mid + Math.imul(ah9, bl5) | 0;\n hi = Math.imul(ah9, bh5);\n lo = lo + Math.imul(al8, bl6) | 0;\n mid = mid + Math.imul(al8, bh6) | 0;\n mid = mid + Math.imul(ah8, bl6) | 0;\n hi = hi + Math.imul(ah8, bh6) | 0;\n lo = lo + Math.imul(al7, bl7) | 0;\n mid = mid + Math.imul(al7, bh7) | 0;\n mid = mid + Math.imul(ah7, bl7) | 0;\n hi = hi + Math.imul(ah7, bh7) | 0;\n lo = lo + Math.imul(al6, bl8) | 0;\n mid = mid + Math.imul(al6, bh8) | 0;\n mid = mid + Math.imul(ah6, bl8) | 0;\n hi = hi + Math.imul(ah6, bh8) | 0;\n lo = lo + Math.imul(al5, bl9) | 0;\n mid = mid + Math.imul(al5, bh9) | 0;\n mid = mid + Math.imul(ah5, bl9) | 0;\n hi = hi + Math.imul(ah5, bh9) | 0;\n var w14 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w14 >>> 26) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = mid + Math.imul(ah9, bl6) | 0;\n hi = Math.imul(ah9, bh6);\n lo = lo + Math.imul(al8, bl7) | 0;\n mid = mid + Math.imul(al8, bh7) | 0;\n mid = mid + Math.imul(ah8, bl7) | 0;\n hi = hi + Math.imul(ah8, bh7) | 0;\n lo = lo + Math.imul(al7, bl8) | 0;\n mid = mid + Math.imul(al7, bh8) | 0;\n mid = mid + Math.imul(ah7, bl8) | 0;\n hi = hi + Math.imul(ah7, bh8) | 0;\n lo = lo + Math.imul(al6, bl9) | 0;\n mid = mid + Math.imul(al6, bh9) | 0;\n mid = mid + Math.imul(ah6, bl9) | 0;\n hi = hi + Math.imul(ah6, bh9) | 0;\n var w15 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w15 >>> 26) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = mid + Math.imul(ah9, bl7) | 0;\n hi = Math.imul(ah9, bh7);\n lo = lo + Math.imul(al8, bl8) | 0;\n mid = mid + Math.imul(al8, bh8) | 0;\n mid = mid + Math.imul(ah8, bl8) | 0;\n hi = hi + Math.imul(ah8, bh8) | 0;\n lo = lo + Math.imul(al7, bl9) | 0;\n mid = mid + Math.imul(al7, bh9) | 0;\n mid = mid + Math.imul(ah7, bl9) | 0;\n hi = hi + Math.imul(ah7, bh9) | 0;\n var w16 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w16 >>> 26) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = mid + Math.imul(ah9, bl8) | 0;\n hi = Math.imul(ah9, bh8);\n lo = lo + Math.imul(al8, bl9) | 0;\n mid = mid + Math.imul(al8, bh9) | 0;\n mid = mid + Math.imul(ah8, bl9) | 0;\n hi = hi + Math.imul(ah8, bh9) | 0;\n var w17 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w17 >>> 26) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = mid + Math.imul(ah9, bl9) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (c + lo | 0) + ((mid & 0x1fff) << 13) | 0;\n c = (hi + (mid >>> 13) | 0) + (w18 >>> 26) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n function bigMulTo(self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n var lo = r & 0x3ffffff;\n ncarry = ncarry + (r / 0x4000000 | 0) | 0;\n lo = lo + rword | 0;\n rword = lo & 0x3ffffff;\n ncarry = ncarry + (lo >>> 26) | 0;\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n return out.strip();\n }\n function jumboMulTo(self, num, out) {\n var fftm = new FFTM();\n return fftm.mulp(self, num, out);\n }\n BN.prototype.mulTo = function mulTo(num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM(x, y) {\n this.x = x;\n this.y = y;\n }\n FFTM.prototype.makeRBT = function makeRBT(N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin(x, l, N) {\n if (x === 0 || x === N - 1) return x;\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << l - i - 1;\n x >>= 1;\n }\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute(rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n FFTM.prototype.transform = function transform(rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n var rx = rtwdf_ * ro - itwdf_ * io;\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n FFTM.prototype.guessLen13b = function guessLen13b(n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n return 1 << i + 1 + odd;\n };\n FFTM.prototype.conjugate = function conjugate(rws, iws, N) {\n if (N <= 1) return;\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n t = iws[i];\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n FFTM.prototype.normalize13b = function normalize13b(ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 + Math.round(ws[2 * i] / N) + carry;\n ws[i] = w & 0x3ffffff;\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n return ws;\n };\n FFTM.prototype.convert13b = function convert13b(ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n rws[2 * i] = carry & 0x1fff;\n carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff;\n carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n FFTM.prototype.stub = function stub(N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n return ph;\n };\n FFTM.prototype.mulp = function mulp(x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n var rbt = this.makeRBT(N);\n var _ = this.stub(N);\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n var rmws = out.words;\n rmws.length = N;\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out.strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf(num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul(num) {\n return this.clone().mulTo(num, this);\n };\n BN.prototype.imuln = function imuln(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += w / 0x4000000 | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.muln = function muln(num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr() {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr() {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow(num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n res = res.mul(q);\n }\n }\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = 0x3ffffff >>> 26 - r << 26 - r;\n var i;\n if (r !== 0) {\n var carry = 0;\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = (this.words[i] | 0) - newCarry << r;\n this.words[i] = c | carry;\n carry = newCarry >>> 26 - r;\n }\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n this.length += s;\n }\n return this.strip();\n };\n BN.prototype.ishln = function ishln(bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn(bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - hint % 26) / 26;\n } else {\n h = 0;\n }\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n var maskedWords = extended;\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = carry << 26 - r | word >>> r;\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n return this.strip();\n };\n BN.prototype.ishrn = function ishrn(bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln(bits) {\n return this.clone().ishln(bits);\n };\n BN.prototype.ushln = function ushln(bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn(bits) {\n return this.clone().ishrn(bits);\n };\n BN.prototype.ushrn = function ushrn(bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn(bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn(bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n if (this.length <= s) {\n return this;\n }\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n if (r !== 0) {\n var mask = 0x3ffffff ^ 0x3ffffff >>> r << r;\n this.words[this.length - 1] &= mask;\n }\n return this.strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn(bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) < num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n BN.prototype._iaddn = function _iaddn(num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn(num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n this.words[0] -= num;\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n return this.strip();\n };\n BN.prototype.addn = function addn(num) {\n return this.clone().iaddn(num);\n };\n BN.prototype.subn = function subn(num) {\n return this.clone().isubn(num);\n };\n BN.prototype.iabs = function iabs() {\n this.negative = 0;\n return this;\n };\n BN.prototype.abs = function abs() {\n return this.clone().iabs();\n };\n BN.prototype._ishlnsubmul = function _ishlnsubmul(num, mul, shift) {\n var len = num.length + shift;\n var i;\n this._expand(len);\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - (right / 0x4000000 | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n if (carry === 0) return this.strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n return this.strip();\n };\n BN.prototype._wordDiv = function _wordDiv(num, mode) {\n var shift = this.length - num.length;\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 + (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min(qj / bhi | 0, 0x3ffffff);\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q.strip();\n }\n a.strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod(num, mode, positive) {\n assert(!num.isZero());\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n return {\n div: div,\n mod: mod\n };\n }\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n return {\n div: div,\n mod: res.mod\n };\n }\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(num.words[0]))\n };\n }\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div(num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod(num) {\n return this.divmod(num, 'mod', false).mod;\n };\n BN.prototype.umod = function umod(num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound(num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n BN.prototype.modn = function modn(num) {\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n return acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn(num) {\n assert(num <= 0x3ffffff);\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = w / num | 0;\n carry = w % num;\n }\n return this.strip();\n };\n BN.prototype.divn = function divn(num) {\n return this.clone().idivn(num);\n };\n BN.prototype.egcd = function egcd(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var x = this;\n var y = p.clone();\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n var g = 0;\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n var yp = y.clone();\n var xp = x.clone();\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp(p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n var a = this;\n var b = p.clone();\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n var x1 = new BN(1);\n var x2 = new BN(0);\n var delta = b.clone();\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n x1.iushrn(1);\n }\n }\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n x2.iushrn(1);\n }\n }\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n return res;\n };\n BN.prototype.gcd = function gcd(num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n a.isub(b);\n } while (true);\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm(num) {\n return this.egcd(num).a.umod(num);\n };\n BN.prototype.isEven = function isEven() {\n return (this.words[0] & 1) === 0;\n };\n BN.prototype.isOdd = function isOdd() {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln(num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn(bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n BN.prototype.isZero = function isZero() {\n return this.length === 1 && this.words[0] === 0;\n };\n BN.prototype.cmpn = function cmpn(num) {\n var negative = num < 0;\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n this.strip();\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n assert(num <= 0x3ffffff, 'Number is too big');\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp(num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp(num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n BN.prototype.gtn = function gtn(num) {\n return this.cmpn(num) === 1;\n };\n BN.prototype.gt = function gt(num) {\n return this.cmp(num) === 1;\n };\n BN.prototype.gten = function gten(num) {\n return this.cmpn(num) >= 0;\n };\n BN.prototype.gte = function gte(num) {\n return this.cmp(num) >= 0;\n };\n BN.prototype.ltn = function ltn(num) {\n return this.cmpn(num) === -1;\n };\n BN.prototype.lt = function lt(num) {\n return this.cmp(num) === -1;\n };\n BN.prototype.lten = function lten(num) {\n return this.cmpn(num) <= 0;\n };\n BN.prototype.lte = function lte(num) {\n return this.cmp(num) <= 0;\n };\n BN.prototype.eqn = function eqn(num) {\n return this.cmpn(num) === 0;\n };\n BN.prototype.eq = function eq(num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red(num) {\n return new Red(num);\n };\n BN.prototype.toRed = function toRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n BN.prototype.fromRed = function fromRed() {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n BN.prototype._forceRed = function _forceRed(ctx) {\n this.red = ctx;\n return this;\n };\n BN.prototype.forceRed = function forceRed(ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n BN.prototype.redAdd = function redAdd(num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n BN.prototype.redIAdd = function redIAdd(num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n BN.prototype.redSub = function redSub(num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n BN.prototype.redISub = function redISub(num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n BN.prototype.redShl = function redShl(num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n BN.prototype.redMul = function redMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n BN.prototype.redIMul = function redIMul(num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n BN.prototype.redSqr = function redSqr() {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n BN.prototype.redISqr = function redISqr() {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt() {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n BN.prototype.redInvm = function redInvm() {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg() {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n BN.prototype.redPow = function redPow(num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime(name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n this.tmp = this._tmp();\n }\n MPrime.prototype._tmp = function _tmp() {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n MPrime.prototype.ireduce = function ireduce(num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is BN v4 instance\n r.strip();\n } else {\n // r is BN v5 instance\n r._strip();\n }\n }\n return r;\n };\n MPrime.prototype.split = function split(input, out) {\n input.iushrn(this.n, 0, out);\n };\n MPrime.prototype.imulK = function imulK(num) {\n return num.imul(this.k);\n };\n function K256() {\n MPrime.call(this, 'k256', 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n K256.prototype.split = function split(input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = (next & mask) << 4 | prev >>> 22;\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n K256.prototype.imulK = function imulK(num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + (lo / 0x4000000 | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n function P224() {\n MPrime.call(this, 'p224', 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n function P192() {\n MPrime.call(this, 'p192', 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n function P25519() {\n // 2 ^ 255 - 19\n MPrime.call(this, '25519', '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n P25519.prototype.imulK = function imulK(num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime(name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red(m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n Red.prototype._verify1 = function _verify1(a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n Red.prototype._verify2 = function _verify2(a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red, 'red works only with red numbers');\n };\n Red.prototype.imod = function imod(a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n return a.umod(this.m)._forceRed(this);\n };\n Red.prototype.neg = function neg(a) {\n if (a.isZero()) {\n return a.clone();\n }\n return this.m.sub(a)._forceRed(this);\n };\n Red.prototype.add = function add(a, b) {\n this._verify2(a, b);\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.iadd = function iadd(a, b) {\n this._verify2(a, b);\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n Red.prototype.sub = function sub(a, b) {\n this._verify2(a, b);\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Red.prototype.isub = function isub(a, b) {\n this._verify2(a, b);\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n Red.prototype.shl = function shl(a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n Red.prototype.imul = function imul(a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n Red.prototype.mul = function mul(a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n Red.prototype.isqr = function isqr(a) {\n return this.imul(a, a.clone());\n };\n Red.prototype.sqr = function sqr(a) {\n return this.mul(a, a);\n };\n Red.prototype.sqrt = function sqrt(a) {\n if (a.isZero()) return a.clone();\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n return r;\n };\n Red.prototype.invm = function invm(a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n Red.prototype.pow = function pow(a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = word >> j & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n return res;\n };\n Red.prototype.convertTo = function convertTo(num) {\n var r = num.umod(this.m);\n return r === num ? r.clone() : r;\n };\n Red.prototype.convertFrom = function convertFrom(num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont(num) {\n return new Mont(num);\n };\n function Mont(m) {\n Red.call(this, m);\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - this.shift % 26;\n }\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n Mont.prototype.convertTo = function convertTo(num) {\n return this.imod(num.ushln(this.shift));\n };\n Mont.prototype.convertFrom = function convertFrom(num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n Mont.prototype.imul = function imul(a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.mul = function mul(a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n return res._forceRed(this);\n };\n Mont.prototype.invm = function invm(a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);","\"use strict\";\n\n// This file is imported from secp256k1 v3\n// https://github.com/cryptocoinjs/secp256k1-node/blob/master/LICENSE\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar BN = require(\"bn.js\");\nvar EC = require('elliptic').ec;\nvar ec = new EC('secp256k1');\nvar ecparams = ec.curve;\nexports.privateKeyExport = function (privateKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n var d = new BN(privateKey);\n if (d.ucmp(ecparams.n) >= 0) {\n throw new Error(\"couldn't export to DER format\");\n }\n var point = ec.g.mul(d);\n return toPublicKey(point.getX(), point.getY(), compressed);\n};\nexports.privateKeyModInverse = function (privateKey) {\n var bn = new BN(privateKey);\n if (bn.ucmp(ecparams.n) >= 0 || bn.isZero()) {\n throw new Error('private key range is invalid');\n }\n return bn.invm(ecparams.n).toArrayLike(Buffer, 'be', 32);\n};\nexports.signatureImport = function (sigObj) {\n var r = new BN(sigObj.r);\n if (r.ucmp(ecparams.n) >= 0) {\n r = new BN(0);\n }\n var s = new BN(sigObj.s);\n if (s.ucmp(ecparams.n) >= 0) {\n s = new BN(0);\n }\n return Buffer.concat([r.toArrayLike(Buffer, 'be', 32), s.toArrayLike(Buffer, 'be', 32)]);\n};\nexports.ecdhUnsafe = function (publicKey, privateKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n var point = ec.keyFromPublic(publicKey);\n var scalar = new BN(privateKey);\n if (scalar.ucmp(ecparams.n) >= 0 || scalar.isZero()) {\n throw new Error('scalar was invalid (zero or overflow)');\n }\n var shared = point.pub.mul(scalar);\n return toPublicKey(shared.getX(), shared.getY(), compressed);\n};\nvar toPublicKey = function (x, y, compressed) {\n var publicKey;\n if (compressed) {\n publicKey = Buffer.alloc(33);\n publicKey[0] = y.isOdd() ? 0x03 : 0x02;\n x.toArrayLike(Buffer, 'be', 32).copy(publicKey, 1);\n } else {\n publicKey = Buffer.alloc(65);\n publicKey[0] = 0x04;\n x.toArrayLike(Buffer, 'be', 32).copy(publicKey, 1);\n y.toArrayLike(Buffer, 'be', 32).copy(publicKey, 33);\n }\n return publicKey;\n};\n","\"use strict\";\n\n// This file is imported from secp256k1 v3\n// https://github.com/cryptocoinjs/secp256k1-node/blob/master/LICENSE\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar EC_PRIVKEY_EXPORT_DER_COMPRESSED = Buffer.from([\n// begin\n0x30, 0x81, 0xd3, 0x02, 0x01, 0x01, 0x04, 0x20,\n// private key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n// middle\n0xa0, 0x81, 0x85, 0x30, 0x81, 0x82, 0x02, 0x01, 0x01, 0x30, 0x2c, 0x06, 0x07, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x01, 0x01, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfc, 0x2f, 0x30, 0x06, 0x04, 0x01, 0x00, 0x04, 0x01, 0x07, 0x04, 0x21, 0x02, 0x79, 0xbe, 0x66, 0x7e, 0xf9, 0xdc, 0xbb, 0xac, 0x55, 0xa0, 0x62, 0x95, 0xce, 0x87, 0x0b, 0x07, 0x02, 0x9b, 0xfc, 0xdb, 0x2d, 0xce, 0x28, 0xd9, 0x59, 0xf2, 0x81, 0x5b, 0x16, 0xf8, 0x17, 0x98, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xba, 0xae, 0xdc, 0xe6, 0xaf, 0x48, 0xa0, 0x3b, 0xbf, 0xd2, 0x5e, 0x8c, 0xd0, 0x36, 0x41, 0x41, 0x02, 0x01, 0x01, 0xa1, 0x24, 0x03, 0x22, 0x00,\n// public key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00]);\nvar EC_PRIVKEY_EXPORT_DER_UNCOMPRESSED = Buffer.from([\n// begin\n0x30, 0x82, 0x01, 0x13, 0x02, 0x01, 0x01, 0x04, 0x20,\n// private key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n// middle\n0xa0, 0x81, 0xa5, 0x30, 0x81, 0xa2, 0x02, 0x01, 0x01, 0x30, 0x2c, 0x06, 0x07, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x01, 0x01, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfc, 0x2f, 0x30, 0x06, 0x04, 0x01, 0x00, 0x04, 0x01, 0x07, 0x04, 0x41, 0x04, 0x79, 0xbe, 0x66, 0x7e, 0xf9, 0xdc, 0xbb, 0xac, 0x55, 0xa0, 0x62, 0x95, 0xce, 0x87, 0x0b, 0x07, 0x02, 0x9b, 0xfc, 0xdb, 0x2d, 0xce, 0x28, 0xd9, 0x59, 0xf2, 0x81, 0x5b, 0x16, 0xf8, 0x17, 0x98, 0x48, 0x3a, 0xda, 0x77, 0x26, 0xa3, 0xc4, 0x65, 0x5d, 0xa4, 0xfb, 0xfc, 0x0e, 0x11, 0x08, 0xa8, 0xfd, 0x17, 0xb4, 0x48, 0xa6, 0x85, 0x54, 0x19, 0x9c, 0x47, 0xd0, 0x8f, 0xfb, 0x10, 0xd4, 0xb8, 0x02, 0x21, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xba, 0xae, 0xdc, 0xe6, 0xaf, 0x48, 0xa0, 0x3b, 0xbf, 0xd2, 0x5e, 0x8c, 0xd0, 0x36, 0x41, 0x41, 0x02, 0x01, 0x01, 0xa1, 0x44, 0x03, 0x42, 0x00,\n// public key\n0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00]);\nexports.privateKeyExport = function (privateKey, publicKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n var result = Buffer.from(compressed ? EC_PRIVKEY_EXPORT_DER_COMPRESSED : EC_PRIVKEY_EXPORT_DER_UNCOMPRESSED);\n privateKey.copy(result, compressed ? 8 : 9);\n publicKey.copy(result, compressed ? 181 : 214);\n return result;\n};\nexports.privateKeyImport = function (privateKey) {\n var length = privateKey.length;\n // sequence header\n var index = 0;\n if (length < index + 1 || privateKey[index] !== 0x30) return null;\n index += 1;\n // sequence length constructor\n if (length < index + 1 || !(privateKey[index] & 0x80)) return null;\n var lenb = privateKey[index] & 0x7f;\n index += 1;\n if (lenb < 1 || lenb > 2) return null;\n if (length < index + lenb) return null;\n // sequence length\n var len = privateKey[index + lenb - 1] | (lenb > 1 ? privateKey[index + lenb - 2] << 8 : 0);\n index += lenb;\n if (length < index + len) return null;\n // sequence element 0: version number (=1)\n if (length < index + 3 || privateKey[index] !== 0x02 || privateKey[index + 1] !== 0x01 || privateKey[index + 2] !== 0x01) {\n return null;\n }\n index += 3;\n // sequence element 1: octet string, up to 32 bytes\n if (length < index + 2 || privateKey[index] !== 0x04 || privateKey[index + 1] > 0x20 || length < index + 2 + privateKey[index + 1]) {\n return null;\n }\n return privateKey.slice(index + 2, index + 2 + privateKey[index + 1]);\n};\nexports.signatureImportLax = function (signature) {\n var r = Buffer.alloc(32, 0);\n var s = Buffer.alloc(32, 0);\n var length = signature.length;\n var index = 0;\n // sequence tag byte\n if (signature[index++] !== 0x30) {\n return null;\n }\n // sequence length byte\n var lenbyte = signature[index++];\n if (lenbyte & 0x80) {\n index += lenbyte - 0x80;\n if (index > length) {\n return null;\n }\n }\n // sequence tag byte for r\n if (signature[index++] !== 0x02) {\n return null;\n }\n // length for r\n var rlen = signature[index++];\n if (rlen & 0x80) {\n lenbyte = rlen - 0x80;\n if (index + lenbyte > length) {\n return null;\n }\n for (; lenbyte > 0 && signature[index] === 0x00; index += 1, lenbyte -= 1);\n for (rlen = 0; lenbyte > 0; index += 1, lenbyte -= 1) rlen = (rlen << 8) + signature[index];\n }\n if (rlen > length - index) {\n return null;\n }\n var rindex = index;\n index += rlen;\n // sequence tag byte for s\n if (signature[index++] !== 0x02) {\n return null;\n }\n // length for s\n var slen = signature[index++];\n if (slen & 0x80) {\n lenbyte = slen - 0x80;\n if (index + lenbyte > length) {\n return null;\n }\n for (; lenbyte > 0 && signature[index] === 0x00; index += 1, lenbyte -= 1);\n for (slen = 0; lenbyte > 0; index += 1, lenbyte -= 1) slen = (slen << 8) + signature[index];\n }\n if (slen > length - index) {\n return null;\n }\n var sindex = index;\n index += slen;\n // ignore leading zeros in r\n for (; rlen > 0 && signature[rindex] === 0x00; rlen -= 1, rindex += 1);\n // copy r value\n if (rlen > 32) {\n return null;\n }\n var rvalue = signature.slice(rindex, rindex + rlen);\n rvalue.copy(r, 32 - rvalue.length);\n // ignore leading zeros in s\n for (; slen > 0 && signature[sindex] === 0x00; slen -= 1, sindex += 1);\n // copy s value\n if (slen > 32) {\n return null;\n }\n var svalue = signature.slice(sindex, sindex + slen);\n svalue.copy(s, 32 - svalue.length);\n return {\n r: r,\n s: s\n };\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ecdhUnsafe = exports.ecdh = exports.recover = exports.verify = exports.sign = exports.signatureImportLax = exports.signatureImport = exports.signatureExport = exports.signatureNormalize = exports.publicKeyCombine = exports.publicKeyTweakMul = exports.publicKeyTweakAdd = exports.publicKeyVerify = exports.publicKeyConvert = exports.publicKeyCreate = exports.privateKeyTweakMul = exports.privateKeyTweakAdd = exports.privateKeyModInverse = exports.privateKeyNegate = exports.privateKeyImport = exports.privateKeyExport = exports.privateKeyVerify = void 0;\nvar secp256k1 = require('ethereum-cryptography/secp256k1');\nvar secp256k1v3 = require('./secp256k1v3-lib/index');\nvar der = require('./secp256k1v3-lib/der');\n/**\n * Verify an ECDSA privateKey\n * @method privateKeyVerify\n * @param {Buffer} privateKey\n * @return {boolean}\n */\nexports.privateKeyVerify = function (privateKey) {\n // secp256k1 v4 version throws when privateKey length is not 32\n if (privateKey.length !== 32) {\n return false;\n }\n return secp256k1.privateKeyVerify(Uint8Array.from(privateKey));\n};\n/**\n * Export a privateKey in DER format\n * @method privateKeyExport\n * @param {Buffer} privateKey\n * @param {boolean} compressed\n * @return {boolean}\n */\nexports.privateKeyExport = function (privateKey, compressed) {\n // secp256k1 v4 version throws when privateKey length is not 32\n if (privateKey.length !== 32) {\n throw new RangeError('private key length is invalid');\n }\n var publicKey = secp256k1v3.privateKeyExport(privateKey, compressed);\n return der.privateKeyExport(privateKey, publicKey, compressed);\n};\n/**\n * Import a privateKey in DER format\n * @method privateKeyImport\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.privateKeyImport = function (privateKey) {\n // privateKeyImport method is not part of secp256k1 v4 package\n // this implementation is based on v3\n privateKey = der.privateKeyImport(privateKey);\n if (privateKey !== null && privateKey.length === 32 && exports.privateKeyVerify(privateKey)) {\n return privateKey;\n }\n throw new Error(\"couldn't import from DER format\");\n};\n/**\n * Negate a privateKey by subtracting it from the order of the curve's base point\n * @method privateKeyNegate\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.privateKeyNegate = function (privateKey) {\n return Buffer.from(secp256k1.privateKeyNegate(Uint8Array.from(privateKey)));\n};\n/**\n * Compute the inverse of a privateKey (modulo the order of the curve's base point).\n * @method privateKeyModInverse\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.privateKeyModInverse = function (privateKey) {\n if (privateKey.length !== 32) {\n throw new Error('private key length is invalid');\n }\n return Buffer.from(secp256k1v3.privateKeyModInverse(Uint8Array.from(privateKey)));\n};\n/**\n * Tweak a privateKey by adding tweak to it.\n * @method privateKeyTweakAdd\n * @param {Buffer} privateKey\n * @param {Buffer} tweak\n * @return {Buffer}\n */\nexports.privateKeyTweakAdd = function (privateKey, tweak) {\n return Buffer.from(secp256k1.privateKeyTweakAdd(Uint8Array.from(privateKey), tweak));\n};\n/**\n * Tweak a privateKey by multiplying it by a tweak.\n * @method privateKeyTweakMul\n * @param {Buffer} privateKey\n * @param {Buffer} tweak\n * @return {Buffer}\n */\nexports.privateKeyTweakMul = function (privateKey, tweak) {\n return Buffer.from(secp256k1.privateKeyTweakMul(Uint8Array.from(privateKey), Uint8Array.from(tweak)));\n};\n/**\n * Compute the public key for a privateKey.\n * @method publicKeyCreate\n * @param {Buffer} privateKey\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyCreate = function (privateKey, compressed) {\n return Buffer.from(secp256k1.publicKeyCreate(Uint8Array.from(privateKey), compressed));\n};\n/**\n * Convert a publicKey to compressed or uncompressed form.\n * @method publicKeyConvert\n * @param {Buffer} publicKey\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyConvert = function (publicKey, compressed) {\n return Buffer.from(secp256k1.publicKeyConvert(Uint8Array.from(publicKey), compressed));\n};\n/**\n * Verify an ECDSA publicKey.\n * @method publicKeyVerify\n * @param {Buffer} publicKey\n * @return {boolean}\n */\nexports.publicKeyVerify = function (publicKey) {\n // secp256k1 v4 version throws when publicKey length is not 33 or 65\n if (publicKey.length !== 33 && publicKey.length !== 65) {\n return false;\n }\n return secp256k1.publicKeyVerify(Uint8Array.from(publicKey));\n};\n/**\n * Tweak a publicKey by adding tweak times the generator to it.\n * @method publicKeyTweakAdd\n * @param {Buffer} publicKey\n * @param {Buffer} tweak\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyTweakAdd = function (publicKey, tweak, compressed) {\n return Buffer.from(secp256k1.publicKeyTweakAdd(Uint8Array.from(publicKey), Uint8Array.from(tweak), compressed));\n};\n/**\n * Tweak a publicKey by multiplying it by a tweak value\n * @method publicKeyTweakMul\n * @param {Buffer} publicKey\n * @param {Buffer} tweak\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyTweakMul = function (publicKey, tweak, compressed) {\n return Buffer.from(secp256k1.publicKeyTweakMul(Uint8Array.from(publicKey), Uint8Array.from(tweak), compressed));\n};\n/**\n * Add a given publicKeys together.\n * @method publicKeyCombine\n * @param {Array} publicKeys\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.publicKeyCombine = function (publicKeys, compressed) {\n var keys = [];\n publicKeys.forEach(function (publicKey) {\n keys.push(Uint8Array.from(publicKey));\n });\n return Buffer.from(secp256k1.publicKeyCombine(keys, compressed));\n};\n/**\n * Convert a signature to a normalized lower-S form.\n * @method signatureNormalize\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureNormalize = function (signature) {\n return Buffer.from(secp256k1.signatureNormalize(Uint8Array.from(signature)));\n};\n/**\n * Serialize an ECDSA signature in DER format.\n * @method signatureExport\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureExport = function (signature) {\n return Buffer.from(secp256k1.signatureExport(Uint8Array.from(signature)));\n};\n/**\n * Parse a DER ECDSA signature (follow by [BIP66](https://github.com/bitcoin/bips/blob/master/bip-0066.mediawiki)).\n * @method signatureImport\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureImport = function (signature) {\n return Buffer.from(secp256k1.signatureImport(Uint8Array.from(signature)));\n};\n/**\n * Parse a DER ECDSA signature (not follow by [BIP66](https://github.com/bitcoin/bips/blob/master/bip-0066.mediawiki)).\n * @method signatureImportLax\n * @param {Buffer} signature\n * @return {Buffer}\n */\nexports.signatureImportLax = function (signature) {\n // signatureImportLax method is not part of secp256k1 v4 package\n // this implementation is based on v3\n // ensure that signature is greater than 0\n if (signature.length === 0) {\n throw new RangeError('signature length is invalid');\n }\n var sigObj = der.signatureImportLax(signature);\n if (sigObj === null) {\n throw new Error(\"couldn't parse DER signature\");\n }\n return secp256k1v3.signatureImport(sigObj);\n};\n/**\n * Create an ECDSA signature. Always return low-S signature.\n * @method sign\n * @param {Buffer} message\n * @param {Buffer} privateKey\n * @param {Object} options\n * @return {Buffer}\n */\nexports.sign = function (message, privateKey, options) {\n if (options === null) {\n throw new TypeError('options should be an Object');\n }\n var signOptions = undefined;\n if (options) {\n signOptions = {};\n if (options.data === null) {\n // validate option.data length\n throw new TypeError('options.data should be a Buffer');\n }\n if (options.data) {\n if (options.data.length != 32) {\n throw new RangeError('options.data length is invalid');\n }\n signOptions.data = new Uint8Array(options.data);\n }\n if (options.noncefn === null) {\n throw new TypeError('options.noncefn should be a Function');\n }\n if (options.noncefn) {\n // convert option.noncefn function signature\n signOptions.noncefn = function (message, privateKey, algo, data, attempt) {\n var bufferAlgo = algo != null ? Buffer.from(algo) : null;\n var bufferData = data != null ? Buffer.from(data) : null;\n var buffer = Buffer.from('');\n if (options.noncefn) {\n buffer = options.noncefn(Buffer.from(message), Buffer.from(privateKey), bufferAlgo, bufferData, attempt);\n }\n return new Uint8Array(buffer);\n };\n }\n }\n var sig = secp256k1.ecdsaSign(Uint8Array.from(message), Uint8Array.from(privateKey), signOptions);\n return {\n signature: Buffer.from(sig.signature),\n recovery: sig.recid\n };\n};\n/**\n * Verify an ECDSA signature.\n * @method verify\n * @param {Buffer} message\n * @param {Buffer} signature\n * @param {Buffer} publicKey\n * @return {boolean}\n */\nexports.verify = function (message, signature, publicKey) {\n return secp256k1.ecdsaVerify(Uint8Array.from(signature), Uint8Array.from(message), publicKey);\n};\n/**\n * Recover an ECDSA public key from a signature.\n * @method recover\n * @param {Buffer} message\n * @param {Buffer} signature\n * @param {Number} recid\n * @param {boolean} compressed\n * @return {Buffer}\n */\nexports.recover = function (message, signature, recid, compressed) {\n return Buffer.from(secp256k1.ecdsaRecover(Uint8Array.from(signature), recid, Uint8Array.from(message), compressed));\n};\n/**\n * Compute an EC Diffie-Hellman secret and applied sha256 to compressed public key.\n * @method ecdh\n * @param {Buffer} publicKey\n * @param {Buffer} privateKey\n * @return {Buffer}\n */\nexports.ecdh = function (publicKey, privateKey) {\n // note: secp256k1 v3 doesn't allow optional parameter\n return Buffer.from(secp256k1.ecdh(Uint8Array.from(publicKey), Uint8Array.from(privateKey), {}));\n};\nexports.ecdhUnsafe = function (publicKey, privateKey, compressed) {\n // ecdhUnsafe method is not part of secp256k1 v4 package\n // this implementation is based on v3\n // ensure valid publicKey length\n if (publicKey.length !== 33 && publicKey.length !== 65) {\n throw new RangeError('public key length is invalid');\n }\n // ensure valid privateKey length\n if (privateKey.length !== 32) {\n throw new RangeError('private key length is invalid');\n }\n return Buffer.from(secp256k1v3.ecdhUnsafe(Uint8Array.from(publicKey), Uint8Array.from(privateKey), compressed));\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.KECCAK256_RLP = exports.KECCAK256_RLP_S = exports.KECCAK256_RLP_ARRAY = exports.KECCAK256_RLP_ARRAY_S = exports.KECCAK256_NULL = exports.KECCAK256_NULL_S = exports.TWO_POW256 = exports.MAX_INTEGER = void 0;\nvar BN = require(\"bn.js\");\n/**\n * The max integer that this VM can handle\n */\nexports.MAX_INTEGER = new BN('ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', 16);\n/**\n * 2^256\n */\nexports.TWO_POW256 = new BN('10000000000000000000000000000000000000000000000000000000000000000', 16);\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL_S = 'c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470';\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL = Buffer.from(exports.KECCAK256_NULL_S, 'hex');\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY_S = '1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347';\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY = Buffer.from(exports.KECCAK256_RLP_ARRAY_S, 'hex');\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP_S = '56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421';\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP = Buffer.from(exports.KECCAK256_RLP_S, 'hex');\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.baToJSON = exports.addHexPrefix = exports.toUnsigned = exports.fromSigned = exports.bufferToHex = exports.bufferToInt = exports.toBuffer = exports.stripZeros = exports.unpad = exports.setLengthRight = exports.setLength = exports.setLengthLeft = exports.zeros = void 0;\nvar ethjsUtil = require('ethjs-util');\nvar BN = require(\"bn.js\");\n/**\n * Returns a buffer filled with 0s.\n * @param bytes the number of bytes the buffer should be\n */\nexports.zeros = function (bytes) {\n return Buffer.allocUnsafe(bytes).fill(0);\n};\n/**\n * Left Pads an `Array` or `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @param msg the value to pad (Buffer|Array)\n * @param length the number of bytes the output should be\n * @param right whether to start padding form the left or right\n * @return (Buffer|Array)\n */\nexports.setLengthLeft = function (msg, length, right) {\n if (right === void 0) {\n right = false;\n }\n var buf = exports.zeros(length);\n msg = exports.toBuffer(msg);\n if (right) {\n if (msg.length < length) {\n msg.copy(buf);\n return buf;\n }\n return msg.slice(0, length);\n } else {\n if (msg.length < length) {\n msg.copy(buf, length - msg.length);\n return buf;\n }\n return msg.slice(-length);\n }\n};\nexports.setLength = exports.setLengthLeft;\n/**\n * Right Pads an `Array` or `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @param msg the value to pad (Buffer|Array)\n * @param length the number of bytes the output should be\n * @return (Buffer|Array)\n */\nexports.setLengthRight = function (msg, length) {\n return exports.setLength(msg, length, true);\n};\n/**\n * Trims leading zeros from a `Buffer` or an `Array`.\n * @param a (Buffer|Array|String)\n * @return (Buffer|Array|String)\n */\nexports.unpad = function (a) {\n a = ethjsUtil.stripHexPrefix(a);\n var first = a[0];\n while (a.length > 0 && first.toString() === '0') {\n a = a.slice(1);\n first = a[0];\n }\n return a;\n};\nexports.stripZeros = exports.unpad;\n/**\n * Attempts to turn a value into a `Buffer`. As input it supports `Buffer`, `String`, `Number`, null/undefined, `BN` and other objects with a `toArray()` method.\n * @param v the value\n */\nexports.toBuffer = function (v) {\n if (!Buffer.isBuffer(v)) {\n if (Array.isArray(v)) {\n v = Buffer.from(v);\n } else if (typeof v === 'string') {\n if (ethjsUtil.isHexString(v)) {\n v = Buffer.from(ethjsUtil.padToEven(ethjsUtil.stripHexPrefix(v)), 'hex');\n } else {\n throw new Error(\"Cannot convert string to buffer. toBuffer only supports 0x-prefixed hex strings and this string was given: \" + v);\n }\n } else if (typeof v === 'number') {\n v = ethjsUtil.intToBuffer(v);\n } else if (v === null || v === undefined) {\n v = Buffer.allocUnsafe(0);\n } else if (BN.isBN(v)) {\n v = v.toArrayLike(Buffer);\n } else if (v.toArray) {\n // converts a BN to a Buffer\n v = Buffer.from(v.toArray());\n } else {\n throw new Error('invalid type');\n }\n }\n return v;\n};\n/**\n * Converts a `Buffer` to a `Number`.\n * @param buf `Buffer` object to convert\n * @throws If the input number exceeds 53 bits.\n */\nexports.bufferToInt = function (buf) {\n return new BN(exports.toBuffer(buf)).toNumber();\n};\n/**\n * Converts a `Buffer` into a `0x`-prefixed hex `String`.\n * @param buf `Buffer` object to convert\n */\nexports.bufferToHex = function (buf) {\n buf = exports.toBuffer(buf);\n return '0x' + buf.toString('hex');\n};\n/**\n * Interprets a `Buffer` as a signed integer and returns a `BN`. Assumes 256-bit numbers.\n * @param num Signed integer value\n */\nexports.fromSigned = function (num) {\n return new BN(num).fromTwos(256);\n};\n/**\n * Converts a `BN` to an unsigned integer and returns it as a `Buffer`. Assumes 256-bit numbers.\n * @param num\n */\nexports.toUnsigned = function (num) {\n return Buffer.from(num.toTwos(256).toArray());\n};\n/**\n * Adds \"0x\" to a given `String` if it does not already start with \"0x\".\n */\nexports.addHexPrefix = function (str) {\n if (typeof str !== 'string') {\n return str;\n }\n return ethjsUtil.isHexPrefixed(str) ? str : '0x' + str;\n};\n/**\n * Converts a `Buffer` or `Array` to JSON.\n * @param ba (Buffer|Array)\n * @return (Array|String|null)\n */\nexports.baToJSON = function (ba) {\n if (Buffer.isBuffer(ba)) {\n return \"0x\" + ba.toString('hex');\n } else if (ba instanceof Array) {\n var array = [];\n for (var i = 0; i < ba.length; i++) {\n array.push(exports.baToJSON(ba[i]));\n }\n return array;\n }\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.rlphash = exports.ripemd160 = exports.sha256 = exports.keccak256 = exports.keccak = void 0;\nvar _a = require('ethereum-cryptography/keccak'),\n keccak224 = _a.keccak224,\n keccak384 = _a.keccak384,\n k256 = _a.keccak256,\n keccak512 = _a.keccak512;\nvar createHash = require('create-hash');\nvar ethjsUtil = require('ethjs-util');\nvar rlp = require(\"rlp\");\nvar bytes_1 = require(\"./bytes\");\n/**\n * Creates Keccak hash of the input\n * @param a The input data (Buffer|Array|String|Number) If the string is a 0x-prefixed hex value\n * it's interpreted as hexadecimal, otherwise as utf8.\n * @param bits The Keccak width\n */\nexports.keccak = function (a, bits) {\n if (bits === void 0) {\n bits = 256;\n }\n if (typeof a === 'string' && !ethjsUtil.isHexString(a)) {\n a = Buffer.from(a, 'utf8');\n } else {\n a = bytes_1.toBuffer(a);\n }\n if (!bits) bits = 256;\n switch (bits) {\n case 224:\n {\n return keccak224(a);\n }\n case 256:\n {\n return k256(a);\n }\n case 384:\n {\n return keccak384(a);\n }\n case 512:\n {\n return keccak512(a);\n }\n default:\n {\n throw new Error(\"Invald algorithm: keccak\" + bits);\n }\n }\n};\n/**\n * Creates Keccak-256 hash of the input, alias for keccak(a, 256).\n * @param a The input data (Buffer|Array|String|Number)\n */\nexports.keccak256 = function (a) {\n return exports.keccak(a);\n};\n/**\n * Creates SHA256 hash of the input.\n * @param a The input data (Buffer|Array|String|Number)\n */\nexports.sha256 = function (a) {\n a = bytes_1.toBuffer(a);\n return createHash('sha256').update(a).digest();\n};\n/**\n * Creates RIPEMD160 hash of the input.\n * @param a The input data (Buffer|Array|String|Number)\n * @param padded Whether it should be padded to 256 bits or not\n */\nexports.ripemd160 = function (a, padded) {\n a = bytes_1.toBuffer(a);\n var hash = createHash('rmd160').update(a).digest();\n if (padded === true) {\n return bytes_1.setLength(hash, 32);\n } else {\n return hash;\n }\n};\n/**\n * Creates SHA-3 hash of the RLP encoded version of the input.\n * @param a The input data\n */\nexports.rlphash = function (a) {\n return exports.keccak(rlp.encode(a));\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.importPublic = exports.privateToPublic = exports.privateToAddress = exports.publicToAddress = exports.pubToAddress = exports.isValidPublic = exports.isValidPrivate = exports.isPrecompiled = exports.generateAddress2 = exports.generateAddress = exports.isValidChecksumAddress = exports.toChecksumAddress = exports.isZeroAddress = exports.isValidAddress = exports.zeroAddress = void 0;\nvar assert = require('assert');\nvar ethjsUtil = require('ethjs-util');\nvar secp256k1 = require('./secp256k1v3-adapter');\nvar BN = require(\"bn.js\");\nvar bytes_1 = require(\"./bytes\");\nvar hash_1 = require(\"./hash\");\n/**\n * Returns a zero address.\n */\nexports.zeroAddress = function () {\n var addressLength = 20;\n var addr = bytes_1.zeros(addressLength);\n return bytes_1.bufferToHex(addr);\n};\n/**\n * Checks if the address is a valid. Accepts checksummed addresses too.\n */\nexports.isValidAddress = function (address) {\n return /^0x[0-9a-fA-F]{40}$/.test(address);\n};\n/**\n * Checks if a given address is a zero address.\n */\nexports.isZeroAddress = function (address) {\n var zeroAddr = exports.zeroAddress();\n return zeroAddr === bytes_1.addHexPrefix(address);\n};\n/**\n * Returns a checksummed address.\n *\n * If a eip1191ChainId is provided, the chainId will be included in the checksum calculation. This\n * has the effect of checksummed addresses for one chain having invalid checksums for others.\n * For more details, consult EIP-1191.\n *\n * WARNING: Checksums with and without the chainId will differ. As of 2019-06-26, the most commonly\n * used variation in Ethereum was without the chainId. This may change in the future.\n */\nexports.toChecksumAddress = function (address, eip1191ChainId) {\n address = ethjsUtil.stripHexPrefix(address).toLowerCase();\n var prefix = eip1191ChainId !== undefined ? eip1191ChainId.toString() + '0x' : '';\n var hash = hash_1.keccak(prefix + address).toString('hex');\n var ret = '0x';\n for (var i = 0; i < address.length; i++) {\n if (parseInt(hash[i], 16) >= 8) {\n ret += address[i].toUpperCase();\n } else {\n ret += address[i];\n }\n }\n return ret;\n};\n/**\n * Checks if the address is a valid checksummed address.\n *\n * See toChecksumAddress' documentation for details about the eip1191ChainId parameter.\n */\nexports.isValidChecksumAddress = function (address, eip1191ChainId) {\n return exports.isValidAddress(address) && exports.toChecksumAddress(address, eip1191ChainId) === address;\n};\n/**\n * Generates an address of a newly created contract.\n * @param from The address which is creating this new address\n * @param nonce The nonce of the from account\n */\nexports.generateAddress = function (from, nonce) {\n from = bytes_1.toBuffer(from);\n var nonceBN = new BN(nonce);\n if (nonceBN.isZero()) {\n // in RLP we want to encode null in the case of zero nonce\n // read the RLP documentation for an answer if you dare\n return hash_1.rlphash([from, null]).slice(-20);\n }\n // Only take the lower 160bits of the hash\n return hash_1.rlphash([from, Buffer.from(nonceBN.toArray())]).slice(-20);\n};\n/**\n * Generates an address for a contract created using CREATE2.\n * @param from The address which is creating this new address\n * @param salt A salt\n * @param initCode The init code of the contract being created\n */\nexports.generateAddress2 = function (from, salt, initCode) {\n var fromBuf = bytes_1.toBuffer(from);\n var saltBuf = bytes_1.toBuffer(salt);\n var initCodeBuf = bytes_1.toBuffer(initCode);\n assert(fromBuf.length === 20);\n assert(saltBuf.length === 32);\n var address = hash_1.keccak256(Buffer.concat([Buffer.from('ff', 'hex'), fromBuf, saltBuf, hash_1.keccak256(initCodeBuf)]));\n return address.slice(-20);\n};\n/**\n * Returns true if the supplied address belongs to a precompiled account (Byzantium).\n */\nexports.isPrecompiled = function (address) {\n var a = bytes_1.unpad(address);\n return a.length === 1 && a[0] >= 1 && a[0] <= 8;\n};\n/**\n * Checks if the private key satisfies the rules of the curve secp256k1.\n */\nexports.isValidPrivate = function (privateKey) {\n return secp256k1.privateKeyVerify(privateKey);\n};\n/**\n * Checks if the public key satisfies the rules of the curve secp256k1\n * and the requirements of Ethereum.\n * @param publicKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nexports.isValidPublic = function (publicKey, sanitize) {\n if (sanitize === void 0) {\n sanitize = false;\n }\n if (publicKey.length === 64) {\n // Convert to SEC1 for secp256k1\n return secp256k1.publicKeyVerify(Buffer.concat([Buffer.from([4]), publicKey]));\n }\n if (!sanitize) {\n return false;\n }\n return secp256k1.publicKeyVerify(publicKey);\n};\n/**\n * Returns the ethereum address of a given public key.\n * Accepts \"Ethereum public keys\" and SEC1 encoded keys.\n * @param pubKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nexports.pubToAddress = function (pubKey, sanitize) {\n if (sanitize === void 0) {\n sanitize = false;\n }\n pubKey = bytes_1.toBuffer(pubKey);\n if (sanitize && pubKey.length !== 64) {\n pubKey = secp256k1.publicKeyConvert(pubKey, false).slice(1);\n }\n assert(pubKey.length === 64);\n // Only take the lower 160bits of the hash\n return hash_1.keccak(pubKey).slice(-20);\n};\nexports.publicToAddress = exports.pubToAddress;\n/**\n * Returns the ethereum address of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nexports.privateToAddress = function (privateKey) {\n return exports.publicToAddress(exports.privateToPublic(privateKey));\n};\n/**\n * Returns the ethereum public key of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nexports.privateToPublic = function (privateKey) {\n privateKey = bytes_1.toBuffer(privateKey);\n // skip the type flag and use the X, Y points\n return secp256k1.publicKeyCreate(privateKey, false).slice(1);\n};\n/**\n * Converts a public key to the Ethereum format.\n */\nexports.importPublic = function (publicKey) {\n publicKey = bytes_1.toBuffer(publicKey);\n if (publicKey.length !== 64) {\n publicKey = secp256k1.publicKeyConvert(publicKey, false).slice(1);\n }\n return publicKey;\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hashPersonalMessage = exports.isValidSignature = exports.fromRpcSig = exports.toRpcSig = exports.ecrecover = exports.ecsign = void 0;\nvar secp256k1 = require('./secp256k1v3-adapter');\nvar BN = require(\"bn.js\");\nvar bytes_1 = require(\"./bytes\");\nvar hash_1 = require(\"./hash\");\n/**\n * Returns the ECDSA signature of a message hash.\n */\nexports.ecsign = function (msgHash, privateKey, chainId) {\n var sig = secp256k1.sign(msgHash, privateKey);\n var recovery = sig.recovery;\n var ret = {\n r: sig.signature.slice(0, 32),\n s: sig.signature.slice(32, 64),\n v: chainId ? recovery + (chainId * 2 + 35) : recovery + 27\n };\n return ret;\n};\n/**\n * ECDSA public key recovery from signature.\n * @returns Recovered public key\n */\nexports.ecrecover = function (msgHash, v, r, s, chainId) {\n var signature = Buffer.concat([bytes_1.setLength(r, 32), bytes_1.setLength(s, 32)], 64);\n var recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n var senderPubKey = secp256k1.recover(msgHash, signature, recovery);\n return secp256k1.publicKeyConvert(senderPubKey, false).slice(1);\n};\n/**\n * Convert signature parameters into the format of `eth_sign` RPC method.\n * @returns Signature\n */\nexports.toRpcSig = function (v, r, s, chainId) {\n var recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n // geth (and the RPC eth_sign method) uses the 65 byte format used by Bitcoin\n return bytes_1.bufferToHex(Buffer.concat([bytes_1.setLengthLeft(r, 32), bytes_1.setLengthLeft(s, 32), bytes_1.toBuffer(v)]));\n};\n/**\n * Convert signature format of the `eth_sign` RPC method to signature parameters\n * NOTE: all because of a bug in geth: https://github.com/ethereum/go-ethereum/issues/2053\n */\nexports.fromRpcSig = function (sig) {\n var buf = bytes_1.toBuffer(sig);\n // NOTE: with potential introduction of chainId this might need to be updated\n if (buf.length !== 65) {\n throw new Error('Invalid signature length');\n }\n var v = buf[64];\n // support both versions of `eth_sign` responses\n if (v < 27) {\n v += 27;\n }\n return {\n v: v,\n r: buf.slice(0, 32),\n s: buf.slice(32, 64)\n };\n};\n/**\n * Validate a ECDSA signature.\n * @param homesteadOrLater Indicates whether this is being used on either the homestead hardfork or a later one\n */\nexports.isValidSignature = function (v, r, s, homesteadOrLater, chainId) {\n if (homesteadOrLater === void 0) {\n homesteadOrLater = true;\n }\n var SECP256K1_N_DIV_2 = new BN('7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a0', 16);\n var SECP256K1_N = new BN('fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141', 16);\n if (r.length !== 32 || s.length !== 32) {\n return false;\n }\n if (!isValidSigRecovery(calculateSigRecovery(v, chainId))) {\n return false;\n }\n var rBN = new BN(r);\n var sBN = new BN(s);\n if (rBN.isZero() || rBN.gt(SECP256K1_N) || sBN.isZero() || sBN.gt(SECP256K1_N)) {\n return false;\n }\n if (homesteadOrLater && sBN.cmp(SECP256K1_N_DIV_2) === 1) {\n return false;\n }\n return true;\n};\n/**\n * Returns the keccak-256 hash of `message`, prefixed with the header used by the `eth_sign` RPC call.\n * The output of this function can be fed into `ecsign` to produce the same signature as the `eth_sign`\n * call for a given `message`, or fed to `ecrecover` along with a signature to recover the public key\n * used to produce the signature.\n */\nexports.hashPersonalMessage = function (message) {\n var prefix = Buffer.from(\"\\u0019Ethereum Signed Message:\\n\" + message.length.toString(), 'utf-8');\n return hash_1.keccak(Buffer.concat([prefix, message]));\n};\nfunction calculateSigRecovery(v, chainId) {\n return chainId ? v - (2 * chainId + 35) : v - 27;\n}\nfunction isValidSigRecovery(recovery) {\n return recovery === 0 || recovery === 1;\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.defineProperties = void 0;\nvar assert = require('assert');\nvar ethjsUtil = require('ethjs-util');\nvar rlp = require(\"rlp\");\nvar bytes_1 = require(\"./bytes\");\n/**\n * Defines properties on a `Object`. It make the assumption that underlying data is binary.\n * @param self the `Object` to define properties on\n * @param fields an array fields to define. Fields can contain:\n * * `name` - the name of the properties\n * * `length` - the number of bytes the field can have\n * * `allowLess` - if the field can be less than the length\n * * `allowEmpty`\n * @param data data to be validated against the definitions\n * @deprecated\n */\nexports.defineProperties = function (self, fields, data) {\n self.raw = [];\n self._fields = [];\n // attach the `toJSON`\n self.toJSON = function (label) {\n if (label === void 0) {\n label = false;\n }\n if (label) {\n var obj_1 = {};\n self._fields.forEach(function (field) {\n obj_1[field] = \"0x\" + self[field].toString('hex');\n });\n return obj_1;\n }\n return bytes_1.baToJSON(self.raw);\n };\n self.serialize = function serialize() {\n return rlp.encode(self.raw);\n };\n fields.forEach(function (field, i) {\n self._fields.push(field.name);\n function getter() {\n return self.raw[i];\n }\n function setter(v) {\n v = bytes_1.toBuffer(v);\n if (v.toString('hex') === '00' && !field.allowZero) {\n v = Buffer.allocUnsafe(0);\n }\n if (field.allowLess && field.length) {\n v = bytes_1.stripZeros(v);\n assert(field.length >= v.length, \"The field \" + field.name + \" must not have more \" + field.length + \" bytes\");\n } else if (!(field.allowZero && v.length === 0) && field.length) {\n assert(field.length === v.length, \"The field \" + field.name + \" must have byte length of \" + field.length);\n }\n self.raw[i] = v;\n }\n Object.defineProperty(self, field.name, {\n enumerable: true,\n configurable: true,\n get: getter,\n set: setter\n });\n if (field.default) {\n self[field.name] = field.default;\n }\n // attach alias\n if (field.alias) {\n Object.defineProperty(self, field.alias, {\n enumerable: false,\n configurable: true,\n set: setter,\n get: getter\n });\n }\n });\n // if the constuctor is passed data\n if (data) {\n if (typeof data === 'string') {\n data = Buffer.from(ethjsUtil.stripHexPrefix(data), 'hex');\n }\n if (Buffer.isBuffer(data)) {\n data = rlp.decode(data);\n }\n if (Array.isArray(data)) {\n if (data.length > self._fields.length) {\n throw new Error('wrong number of fields in data');\n }\n // make sure all the items are buffers\n data.forEach(function (d, i) {\n self[self._fields[i]] = bytes_1.toBuffer(d);\n });\n } else if (typeof data === 'object') {\n var keys_1 = Object.keys(data);\n fields.forEach(function (field) {\n if (keys_1.indexOf(field.name) !== -1) self[field.name] = data[field.name];\n if (keys_1.indexOf(field.alias) !== -1) self[field.alias] = data[field.alias];\n });\n } else {\n throw new Error('invalid data');\n }\n }\n};\n","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\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\" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.secp256k1 = exports.rlp = exports.BN = void 0;\nvar secp256k1 = require('./secp256k1v3-adapter');\nexports.secp256k1 = secp256k1;\nvar ethjsUtil = require('ethjs-util');\nvar BN = require(\"bn.js\");\nexports.BN = BN;\nvar rlp = require(\"rlp\");\nexports.rlp = rlp;\nObject.assign(exports, ethjsUtil);\n/**\n * Constants\n */\n__exportStar(require(\"./constants\"), exports);\n/**\n * Public-key cryptography (secp256k1) and addresses\n */\n__exportStar(require(\"./account\"), exports);\n/**\n * Hash functions\n */\n__exportStar(require(\"./hash\"), exports);\n/**\n * ECDSA signature\n */\n__exportStar(require(\"./signature\"), exports);\n/**\n * Utilities for manipulating Buffers, byte arrays, etc.\n */\n__exportStar(require(\"./bytes\"), exports);\n/**\n * Function for definining properties on an object\n */\n__exportStar(require(\"./object\"), exports);\n","/* eslint-disable no-useless-escape */\nconst utils = require('ethereumjs-util');\nconst BN = require('bn.js');\nvar ABI = function () {};\n\n// Convert from short to canonical names\n// FIXME: optimise or make this nicer?\nfunction elementaryName(name) {\n if (name.startsWith('int[')) {\n return 'int256' + name.slice(3);\n } else if (name === 'int') {\n return 'int256';\n } else if (name.startsWith('uint[')) {\n return 'uint256' + name.slice(4);\n } else if (name === 'uint') {\n return 'uint256';\n } else if (name.startsWith('fixed[')) {\n return 'fixed128x128' + name.slice(5);\n } else if (name === 'fixed') {\n return 'fixed128x128';\n } else if (name.startsWith('ufixed[')) {\n return 'ufixed128x128' + name.slice(6);\n } else if (name === 'ufixed') {\n return 'ufixed128x128';\n }\n return name;\n}\nABI.eventID = function (name, types) {\n // FIXME: use node.js util.format?\n var sig = name + '(' + types.map(elementaryName).join(',') + ')';\n return utils.keccak256(Buffer.from(sig));\n};\nABI.methodID = function (name, types) {\n return ABI.eventID(name, types).slice(0, 4);\n};\n\n// Parse N from type\nfunction parseTypeN(type) {\n return parseInt(/^\\D+(\\d+)$/.exec(type)[1], 10);\n}\n\n// Parse N,M from typex\nfunction parseTypeNxM(type) {\n var tmp = /^\\D+(\\d+)x(\\d+)$/.exec(type);\n return [parseInt(tmp[1], 10), parseInt(tmp[2], 10)];\n}\n\n// Parse N in type[] where \"type\" can itself be an array type.\nfunction parseTypeArray(type) {\n var tmp = type.match(/(.*)\\[(.*?)\\]$/);\n if (tmp) {\n return tmp[2] === '' ? 'dynamic' : parseInt(tmp[2], 10);\n }\n return null;\n}\nfunction parseNumber(arg) {\n var type = typeof arg;\n if (type === 'string') {\n if (utils.isHexPrefixed(arg)) {\n return new BN(utils.stripHexPrefix(arg), 16);\n } else {\n return new BN(arg, 10);\n }\n } else if (type === 'number') {\n return new BN(arg);\n } else if (arg.toArray) {\n // assume this is a BN for the moment, replace with BN.isBN soon\n return arg;\n } else {\n throw new Error('Argument is not a number');\n }\n}\n\n// someMethod(bytes,uint)\n// someMethod(bytes,uint):(boolean)\nfunction parseSignature(sig) {\n var tmp = /^(\\w+)\\((.*)\\)$/.exec(sig);\n if (tmp.length !== 3) {\n throw new Error('Invalid method signature');\n }\n var args = /^(.+)\\):\\((.+)$/.exec(tmp[2]);\n if (args !== null && args.length === 3) {\n return {\n method: tmp[1],\n args: args[1].split(','),\n retargs: args[2].split(',')\n };\n } else {\n var params = tmp[2].split(',');\n if (params.length === 1 && params[0] === '') {\n // Special-case (possibly naive) fixup for functions that take no arguments.\n // TODO: special cases are always bad, but this makes the function return\n // match what the calling functions expect\n params = [];\n }\n return {\n method: tmp[1],\n args: params\n };\n }\n}\n\n// Encodes a single item (can be dynamic array)\n// @returns: Buffer\nfunction encodeSingle(type, arg) {\n var size, num, ret, i;\n if (type === 'address') {\n return encodeSingle('uint160', parseNumber(arg));\n } else if (type === 'bool') {\n return encodeSingle('uint8', arg ? 1 : 0);\n } else if (type === 'string') {\n return encodeSingle('bytes', Buffer.from(arg, 'utf8'));\n } else if (isArray(type)) {\n // this part handles fixed-length ([2]) and variable length ([]) arrays\n // NOTE: we catch here all calls to arrays, that simplifies the rest\n if (typeof arg.length === 'undefined') {\n throw new Error('Not an array?');\n }\n size = parseTypeArray(type);\n if (size !== 'dynamic' && size !== 0 && arg.length > size) {\n throw new Error('Elements exceed array size: ' + size);\n }\n ret = [];\n type = type.slice(0, type.lastIndexOf('['));\n if (typeof arg === 'string') {\n arg = JSON.parse(arg);\n }\n for (i in arg) {\n ret.push(encodeSingle(type, arg[i]));\n }\n if (size === 'dynamic') {\n var length = encodeSingle('uint256', arg.length);\n ret.unshift(length);\n }\n return Buffer.concat(ret);\n } else if (type === 'bytes') {\n arg = Buffer.from(arg);\n ret = Buffer.concat([encodeSingle('uint256', arg.length), arg]);\n if (arg.length % 32 !== 0) {\n ret = Buffer.concat([ret, utils.zeros(32 - arg.length % 32)]);\n }\n return ret;\n } else if (type.startsWith('bytes')) {\n size = parseTypeN(type);\n if (size < 1 || size > 32) {\n throw new Error('Invalid bytes width: ' + size);\n }\n return utils.setLengthRight(arg, 32);\n } else if (type.startsWith('uint')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid uint width: ' + size);\n }\n num = parseNumber(arg);\n if (num.bitLength() > size) {\n throw new Error('Supplied uint exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n if (num < 0) {\n throw new Error('Supplied uint is negative');\n }\n return num.toArrayLike(Buffer, 'be', 32);\n } else if (type.startsWith('int')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid int width: ' + size);\n }\n num = parseNumber(arg);\n if (num.bitLength() > size) {\n throw new Error('Supplied int exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n return num.toTwos(256).toArrayLike(Buffer, 'be', 32);\n } else if (type.startsWith('ufixed')) {\n size = parseTypeNxM(type);\n num = parseNumber(arg);\n if (num < 0) {\n throw new Error('Supplied ufixed is negative');\n }\n return encodeSingle('uint256', num.mul(new BN(2).pow(new BN(size[1]))));\n } else if (type.startsWith('fixed')) {\n size = parseTypeNxM(type);\n return encodeSingle('int256', parseNumber(arg).mul(new BN(2).pow(new BN(size[1]))));\n }\n throw new Error('Unsupported or invalid type: ' + type);\n}\n\n// Decodes a single item (can be dynamic array)\n// @returns: array\n// FIXME: this method will need a lot of attention at checking limits and validation\nfunction decodeSingle(parsedType, data, offset) {\n if (typeof parsedType === 'string') {\n parsedType = parseType(parsedType);\n }\n var size, num, ret, i;\n if (parsedType.name === 'address') {\n return decodeSingle(parsedType.rawType, data, offset).toArrayLike(Buffer, 'be', 20).toString('hex');\n } else if (parsedType.name === 'bool') {\n return decodeSingle(parsedType.rawType, data, offset).toString() === new BN(1).toString();\n } else if (parsedType.name === 'string') {\n var bytes = decodeSingle(parsedType.rawType, data, offset);\n return Buffer.from(bytes, 'utf8').toString();\n } else if (parsedType.isArray) {\n // this part handles fixed-length arrays ([2]) and variable length ([]) arrays\n // NOTE: we catch here all calls to arrays, that simplifies the rest\n ret = [];\n size = parsedType.size;\n if (parsedType.size === 'dynamic') {\n offset = decodeSingle('uint256', data, offset).toNumber();\n size = decodeSingle('uint256', data, offset).toNumber();\n offset = offset + 32;\n }\n for (i = 0; i < size; i++) {\n var decoded = decodeSingle(parsedType.subArray, data, offset);\n ret.push(decoded);\n offset += parsedType.subArray.memoryUsage;\n }\n return ret;\n } else if (parsedType.name === 'bytes') {\n offset = decodeSingle('uint256', data, offset).toNumber();\n size = decodeSingle('uint256', data, offset).toNumber();\n return data.slice(offset + 32, offset + 32 + size);\n } else if (parsedType.name.startsWith('bytes')) {\n return data.slice(offset, offset + parsedType.size);\n } else if (parsedType.name.startsWith('uint')) {\n num = new BN(data.slice(offset, offset + 32), 16, 'be');\n if (num.bitLength() > parsedType.size) {\n throw new Error('Decoded int exceeds width: ' + parsedType.size + ' vs ' + num.bitLength());\n }\n return num;\n } else if (parsedType.name.startsWith('int')) {\n num = new BN(data.slice(offset, offset + 32), 16, 'be').fromTwos(256);\n if (num.bitLength() > parsedType.size) {\n throw new Error('Decoded uint exceeds width: ' + parsedType.size + ' vs ' + num.bitLength());\n }\n return num;\n } else if (parsedType.name.startsWith('ufixed')) {\n size = new BN(2).pow(new BN(parsedType.size[1]));\n num = decodeSingle('uint256', data, offset);\n if (!num.mod(size).isZero()) {\n throw new Error('Decimals not supported yet');\n }\n return num.div(size);\n } else if (parsedType.name.startsWith('fixed')) {\n size = new BN(2).pow(new BN(parsedType.size[1]));\n num = decodeSingle('int256', data, offset);\n if (!num.mod(size).isZero()) {\n throw new Error('Decimals not supported yet');\n }\n return num.div(size);\n }\n throw new Error('Unsupported or invalid type: ' + parsedType.name);\n}\n\n// Parse the given type\n// @returns: {} containing the type itself, memory usage and (including size and subArray if applicable)\nfunction parseType(type) {\n var size;\n var ret;\n if (isArray(type)) {\n size = parseTypeArray(type);\n var subArray = type.slice(0, type.lastIndexOf('['));\n subArray = parseType(subArray);\n ret = {\n isArray: true,\n name: type,\n size: size,\n memoryUsage: size === 'dynamic' ? 32 : subArray.memoryUsage * size,\n subArray: subArray\n };\n return ret;\n } else {\n var rawType;\n switch (type) {\n case 'address':\n rawType = 'uint160';\n break;\n case 'bool':\n rawType = 'uint8';\n break;\n case 'string':\n rawType = 'bytes';\n break;\n }\n ret = {\n rawType: rawType,\n name: type,\n memoryUsage: 32\n };\n if (type.startsWith('bytes') && type !== 'bytes' || type.startsWith('uint') || type.startsWith('int')) {\n ret.size = parseTypeN(type);\n } else if (type.startsWith('ufixed') || type.startsWith('fixed')) {\n ret.size = parseTypeNxM(type);\n }\n if (type.startsWith('bytes') && type !== 'bytes' && (ret.size < 1 || ret.size > 32)) {\n throw new Error('Invalid bytes width: ' + ret.size);\n }\n if ((type.startsWith('uint') || type.startsWith('int')) && (ret.size % 8 || ret.size < 8 || ret.size > 256)) {\n throw new Error('Invalid int/uint width: ' + ret.size);\n }\n return ret;\n }\n}\n\n// Is a type dynamic?\nfunction isDynamic(type) {\n // FIXME: handle all types? I don't think anything is missing now\n return type === 'string' || type === 'bytes' || parseTypeArray(type) === 'dynamic';\n}\n\n// Is a type an array?\nfunction isArray(type) {\n return type.lastIndexOf(']') === type.length - 1;\n}\n\n// Encode a method/event with arguments\n// @types an array of string type names\n// @args an array of the appropriate values\nABI.rawEncode = function (types, values) {\n var output = [];\n var data = [];\n var headLength = 0;\n types.forEach(function (type) {\n if (isArray(type)) {\n var size = parseTypeArray(type);\n if (size !== 'dynamic') {\n headLength += 32 * size;\n } else {\n headLength += 32;\n }\n } else {\n headLength += 32;\n }\n });\n for (var i = 0; i < types.length; i++) {\n var type = elementaryName(types[i]);\n var value = values[i];\n var cur = encodeSingle(type, value);\n\n // Use the head/tail method for storing dynamic data\n if (isDynamic(type)) {\n output.push(encodeSingle('uint256', headLength));\n data.push(cur);\n headLength += cur.length;\n } else {\n output.push(cur);\n }\n }\n return Buffer.concat(output.concat(data));\n};\nABI.rawDecode = function (types, data) {\n var ret = [];\n data = Buffer.from(data);\n var offset = 0;\n for (var i = 0; i < types.length; i++) {\n var type = elementaryName(types[i]);\n var parsed = parseType(type, data, offset);\n var decoded = decodeSingle(parsed, data, offset);\n offset += parsed.memoryUsage;\n ret.push(decoded);\n }\n return ret;\n};\nABI.simpleEncode = function (method) {\n var args = Array.prototype.slice.call(arguments).slice(1);\n var sig = parseSignature(method);\n\n // FIXME: validate/convert arguments\n if (args.length !== sig.args.length) {\n throw new Error('Argument count mismatch');\n }\n return Buffer.concat([ABI.methodID(sig.method, sig.args), ABI.rawEncode(sig.args, args)]);\n};\nABI.simpleDecode = function (method, data) {\n var sig = parseSignature(method);\n\n // FIXME: validate/convert arguments\n if (!sig.retargs) {\n throw new Error('No return values in method');\n }\n return ABI.rawDecode(sig.retargs, data);\n};\nfunction stringify(type, value) {\n if (type.startsWith('address') || type.startsWith('bytes')) {\n return '0x' + value.toString('hex');\n } else {\n return value.toString();\n }\n}\nABI.stringify = function (types, values) {\n var ret = [];\n for (var i in types) {\n var type = types[i];\n var value = values[i];\n\n // if it is an array type, concat the items\n if (/^[^\\[]+\\[.*\\]$/.test(type)) {\n value = value.map(function (item) {\n return stringify(type, item);\n }).join(', ');\n } else {\n value = stringify(type, value);\n }\n ret.push(value);\n }\n return ret;\n};\nABI.solidityHexValue = function (type, value, bitsize) {\n // pass in bitsize = null if use default bitsize\n var size, num;\n if (isArray(type)) {\n var subType = type.replace(/\\[.*?\\]/, '');\n if (!isArray(subType)) {\n var arraySize = parseTypeArray(type);\n if (arraySize !== 'dynamic' && arraySize !== 0 && value.length > arraySize) {\n throw new Error('Elements exceed array size: ' + arraySize);\n }\n }\n var arrayValues = value.map(function (v) {\n return ABI.solidityHexValue(subType, v, 256);\n });\n return Buffer.concat(arrayValues);\n } else if (type === 'bytes') {\n return value;\n } else if (type === 'string') {\n return Buffer.from(value, 'utf8');\n } else if (type === 'bool') {\n bitsize = bitsize || 8;\n var padding = Array(bitsize / 4).join('0');\n return Buffer.from(value ? padding + '1' : padding + '0', 'hex');\n } else if (type === 'address') {\n var bytesize = 20;\n if (bitsize) {\n bytesize = bitsize / 8;\n }\n return utils.setLengthLeft(value, bytesize);\n } else if (type.startsWith('bytes')) {\n size = parseTypeN(type);\n if (size < 1 || size > 32) {\n throw new Error('Invalid bytes width: ' + size);\n }\n return utils.setLengthRight(value, size);\n } else if (type.startsWith('uint')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid uint width: ' + size);\n }\n num = parseNumber(value);\n if (num.bitLength() > size) {\n throw new Error('Supplied uint exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n bitsize = bitsize || size;\n return num.toArrayLike(Buffer, 'be', bitsize / 8);\n } else if (type.startsWith('int')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid int width: ' + size);\n }\n num = parseNumber(value);\n if (num.bitLength() > size) {\n throw new Error('Supplied int exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n bitsize = bitsize || size;\n return num.toTwos(size).toArrayLike(Buffer, 'be', bitsize / 8);\n } else {\n // FIXME: support all other types\n throw new Error('Unsupported or invalid type: ' + type);\n }\n};\nABI.solidityPack = function (types, values) {\n if (types.length !== values.length) {\n throw new Error('Number of types are not matching the values');\n }\n var ret = [];\n for (var i = 0; i < types.length; i++) {\n var type = elementaryName(types[i]);\n var value = values[i];\n ret.push(ABI.solidityHexValue(type, value, null));\n }\n return Buffer.concat(ret);\n};\nABI.soliditySHA3 = function (types, values) {\n return utils.keccak256(ABI.solidityPack(types, values));\n};\nABI.soliditySHA256 = function (types, values) {\n return utils.sha256(ABI.solidityPack(types, values));\n};\nABI.solidityRIPEMD160 = function (types, values) {\n return utils.ripemd160(ABI.solidityPack(types, values), true);\n};\n\n// Serpent's users are familiar with this encoding\n// - s: string\n// - b: bytes\n// - b: bytes\n// - i: int256\n// - a: int256[]\n\nfunction isNumeric(c) {\n // FIXME: is this correct? Seems to work\n return c >= '0' && c <= '9';\n}\n\n// For a \"documentation\" refer to https://github.com/ethereum/serpent/blob/develop/preprocess.cpp\nABI.fromSerpent = function (sig) {\n var ret = [];\n for (var i = 0; i < sig.length; i++) {\n var type = sig[i];\n if (type === 's') {\n ret.push('bytes');\n } else if (type === 'b') {\n var tmp = 'bytes';\n var j = i + 1;\n while (j < sig.length && isNumeric(sig[j])) {\n tmp += sig[j] - '0';\n j++;\n }\n i = j - 1;\n ret.push(tmp);\n } else if (type === 'i') {\n ret.push('int256');\n } else if (type === 'a') {\n ret.push('int256[]');\n } else {\n throw new Error('Unsupported or invalid type: ' + type);\n }\n }\n return ret;\n};\nABI.toSerpent = function (types) {\n var ret = [];\n for (var i = 0; i < types.length; i++) {\n var type = types[i];\n if (type === 'bytes') {\n ret.push('s');\n } else if (type.startsWith('bytes')) {\n ret.push('b' + parseTypeN(type));\n } else if (type === 'int256') {\n ret.push('i');\n } else if (type === 'int256[]') {\n ret.push('a');\n } else {\n throw new Error('Unsupported or invalid type: ' + type);\n }\n }\n return ret.join('');\n};\nmodule.exports = ABI;","module.exports = require('./lib/index.js');","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.recoverTypedSignature = exports.signTypedData = exports.typedSignatureHash = exports.TypedDataUtils = exports.TYPED_MESSAGE_SCHEMA = exports.SignTypedDataVersion = void 0;\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst ethereumjs_abi_1 = require(\"ethereumjs-abi\");\nconst utils_1 = require(\"./utils\");\n/**\n * Represents the version of `signTypedData` being used.\n *\n * V1 is based upon [an early version of EIP-712](https://github.com/ethereum/EIPs/pull/712/commits/21abe254fe0452d8583d5b132b1d7be87c0439ca)\n * that lacked some later security improvements, and should generally be neglected in favor of\n * later versions.\n *\n * V3 is based on EIP-712, except that arrays and recursive data structures are not supported.\n *\n * V4 is based on EIP-712, and includes full support of arrays and recursive data structures.\n */\nvar SignTypedDataVersion;\n(function (SignTypedDataVersion) {\n SignTypedDataVersion[\"V1\"] = \"V1\";\n SignTypedDataVersion[\"V3\"] = \"V3\";\n SignTypedDataVersion[\"V4\"] = \"V4\";\n})(SignTypedDataVersion = exports.SignTypedDataVersion || (exports.SignTypedDataVersion = {}));\nexports.TYPED_MESSAGE_SCHEMA = {\n type: 'object',\n properties: {\n types: {\n type: 'object',\n additionalProperties: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n name: {\n type: 'string'\n },\n type: {\n type: 'string'\n }\n },\n required: ['name', 'type']\n }\n }\n },\n primaryType: {\n type: 'string'\n },\n domain: {\n type: 'object'\n },\n message: {\n type: 'object'\n }\n },\n required: ['types', 'primaryType', 'domain', 'message']\n};\n/**\n * Validate that the given value is a valid version string.\n *\n * @param version - The version value to validate.\n * @param allowedVersions - A list of allowed versions. If omitted, all versions are assumed to be\n * allowed.\n */\nfunction validateVersion(version, allowedVersions) {\n if (!Object.keys(SignTypedDataVersion).includes(version)) {\n throw new Error(`Invalid version: '${version}'`);\n } else if (allowedVersions && !allowedVersions.includes(version)) {\n throw new Error(`SignTypedDataVersion not allowed: '${version}'. Allowed versions are: ${allowedVersions.join(', ')}`);\n }\n}\n/**\n * Encode a single field.\n *\n * @param types - All type definitions.\n * @param name - The name of the field to encode.\n * @param type - The type of the field being encoded.\n * @param value - The value to encode.\n * @param version - The EIP-712 version the encoding should comply with.\n * @returns Encoded representation of the field.\n */\nfunction encodeField(types, name, type, value, version) {\n validateVersion(version, [SignTypedDataVersion.V3, SignTypedDataVersion.V4]);\n if (types[type] !== undefined) {\n return ['bytes32', version === SignTypedDataVersion.V4 && value == null // eslint-disable-line no-eq-null\n ? '0x0000000000000000000000000000000000000000000000000000000000000000' : ethereumjs_util_1.keccak(encodeData(type, value, types, version))];\n }\n if (value === undefined) {\n throw new Error(`missing value for field ${name} of type ${type}`);\n }\n if (type === 'bytes') {\n return ['bytes32', ethereumjs_util_1.keccak(value)];\n }\n if (type === 'string') {\n // convert string to buffer - prevents ethUtil from interpreting strings like '0xabcd' as hex\n if (typeof value === 'string') {\n value = Buffer.from(value, 'utf8');\n }\n return ['bytes32', ethereumjs_util_1.keccak(value)];\n }\n if (type.lastIndexOf(']') === type.length - 1) {\n if (version === SignTypedDataVersion.V3) {\n throw new Error('Arrays are unimplemented in encodeData; use V4 extension');\n }\n const parsedType = type.slice(0, type.lastIndexOf('['));\n const typeValuePairs = value.map(item => encodeField(types, name, parsedType, item, version));\n return ['bytes32', ethereumjs_util_1.keccak(ethereumjs_abi_1.rawEncode(typeValuePairs.map(([t]) => t), typeValuePairs.map(([, v]) => v)))];\n }\n return [type, value];\n}\n/**\n * Encodes an object by encoding and concatenating each of its members.\n *\n * @param primaryType - The root type.\n * @param data - The object to encode.\n * @param types - Type definitions for all types included in the message.\n * @param version - The EIP-712 version the encoding should comply with.\n * @returns An encoded representation of an object.\n */\nfunction encodeData(primaryType, data, types, version) {\n validateVersion(version, [SignTypedDataVersion.V3, SignTypedDataVersion.V4]);\n const encodedTypes = ['bytes32'];\n const encodedValues = [hashType(primaryType, types)];\n for (const field of types[primaryType]) {\n if (version === SignTypedDataVersion.V3 && data[field.name] === undefined) {\n continue;\n }\n const [type, value] = encodeField(types, field.name, field.type, data[field.name], version);\n encodedTypes.push(type);\n encodedValues.push(value);\n }\n return ethereumjs_abi_1.rawEncode(encodedTypes, encodedValues);\n}\n/**\n * Encodes the type of an object by encoding a comma delimited list of its members.\n *\n * @param primaryType - The root type to encode.\n * @param types - Type definitions for all types included in the message.\n * @returns An encoded representation of the primary type.\n */\nfunction encodeType(primaryType, types) {\n let result = '';\n const unsortedDeps = findTypeDependencies(primaryType, types);\n unsortedDeps.delete(primaryType);\n const deps = [primaryType, ...Array.from(unsortedDeps).sort()];\n for (const type of deps) {\n const children = types[type];\n if (!children) {\n throw new Error(`No type definition specified: ${type}`);\n }\n result += `${type}(${types[type].map(({\n name,\n type: t\n }) => `${t} ${name}`).join(',')})`;\n }\n return result;\n}\n/**\n * Finds all types within a type definition object.\n *\n * @param primaryType - The root type.\n * @param types - Type definitions for all types included in the message.\n * @param results - The current set of accumulated types.\n * @returns The set of all types found in the type definition.\n */\nfunction findTypeDependencies(primaryType, types, results = new Set()) {\n [primaryType] = primaryType.match(/^\\w*/u);\n if (results.has(primaryType) || types[primaryType] === undefined) {\n return results;\n }\n results.add(primaryType);\n for (const field of types[primaryType]) {\n findTypeDependencies(field.type, types, results);\n }\n return results;\n}\n/**\n * Hashes an object.\n *\n * @param primaryType - The root type.\n * @param data - The object to hash.\n * @param types - Type definitions for all types included in the message.\n * @param version - The EIP-712 version the encoding should comply with.\n * @returns The hash of the object.\n */\nfunction hashStruct(primaryType, data, types, version) {\n validateVersion(version, [SignTypedDataVersion.V3, SignTypedDataVersion.V4]);\n return ethereumjs_util_1.keccak(encodeData(primaryType, data, types, version));\n}\n/**\n * Hashes the type of an object.\n *\n * @param primaryType - The root type to hash.\n * @param types - Type definitions for all types included in the message.\n * @returns The hash of the object type.\n */\nfunction hashType(primaryType, types) {\n return ethereumjs_util_1.keccak(encodeType(primaryType, types));\n}\n/**\n * Removes properties from a message object that are not defined per EIP-712.\n *\n * @param data - The typed message object.\n * @returns The typed message object with only allowed fields.\n */\nfunction sanitizeData(data) {\n const sanitizedData = {};\n for (const key in exports.TYPED_MESSAGE_SCHEMA.properties) {\n if (data[key]) {\n sanitizedData[key] = data[key];\n }\n }\n if ('types' in sanitizedData) {\n sanitizedData.types = Object.assign({\n EIP712Domain: []\n }, sanitizedData.types);\n }\n return sanitizedData;\n}\n/**\n * Hash a typed message according to EIP-712. The returned message starts with the EIP-712 prefix,\n * which is \"1901\", followed by the hash of the domain separator, then the data (if any).\n * The result is hashed again and returned.\n *\n * This function does not sign the message. The resulting hash must still be signed to create an\n * EIP-712 signature.\n *\n * @param typedData - The typed message to hash.\n * @param version - The EIP-712 version the encoding should comply with.\n * @returns The hash of the typed message.\n */\nfunction eip712Hash(typedData, version) {\n validateVersion(version, [SignTypedDataVersion.V3, SignTypedDataVersion.V4]);\n const sanitizedData = sanitizeData(typedData);\n const parts = [Buffer.from('1901', 'hex')];\n parts.push(hashStruct('EIP712Domain', sanitizedData.domain, sanitizedData.types, version));\n if (sanitizedData.primaryType !== 'EIP712Domain') {\n parts.push(hashStruct(\n // TODO: Validate that this is a string, so this type cast can be removed.\n sanitizedData.primaryType, sanitizedData.message, sanitizedData.types, version));\n }\n return ethereumjs_util_1.keccak(Buffer.concat(parts));\n}\n/**\n * A collection of utility functions used for signing typed data.\n */\nexports.TypedDataUtils = {\n encodeData,\n encodeType,\n findTypeDependencies,\n hashStruct,\n hashType,\n sanitizeData,\n eip712Hash\n};\n/**\n * Generate the \"V1\" hash for the provided typed message.\n *\n * The hash will be generated in accordance with an earlier version of the EIP-712\n * specification. This hash is used in `signTypedData_v1`.\n *\n * @param typedData - The typed message.\n * @returns The '0x'-prefixed hex encoded hash representing the type of the provided message.\n */\nfunction typedSignatureHash(typedData) {\n const hashBuffer = _typedSignatureHash(typedData);\n return ethereumjs_util_1.bufferToHex(hashBuffer);\n}\nexports.typedSignatureHash = typedSignatureHash;\n/**\n * Generate the \"V1\" hash for the provided typed message.\n *\n * The hash will be generated in accordance with an earlier version of the EIP-712\n * specification. This hash is used in `signTypedData_v1`.\n *\n * @param typedData - The typed message.\n * @returns The hash representing the type of the provided message.\n */\nfunction _typedSignatureHash(typedData) {\n const error = new Error('Expect argument to be non-empty array');\n if (typeof typedData !== 'object' || !('length' in typedData) || !typedData.length) {\n throw error;\n }\n const data = typedData.map(function (e) {\n if (e.type !== 'bytes') {\n return e.value;\n }\n return utils_1.legacyToBuffer(e.value);\n });\n const types = typedData.map(function (e) {\n return e.type;\n });\n const schema = typedData.map(function (e) {\n if (!e.name) {\n throw error;\n }\n return `${e.type} ${e.name}`;\n });\n return ethereumjs_abi_1.soliditySHA3(['bytes32', 'bytes32'], [ethereumjs_abi_1.soliditySHA3(new Array(typedData.length).fill('string'), schema), ethereumjs_abi_1.soliditySHA3(types, data)]);\n}\n/**\n * Sign typed data according to EIP-712. The signing differs based upon the `version`.\n *\n * V1 is based upon [an early version of EIP-712](https://github.com/ethereum/EIPs/pull/712/commits/21abe254fe0452d8583d5b132b1d7be87c0439ca)\n * that lacked some later security improvements, and should generally be neglected in favor of\n * later versions.\n *\n * V3 is based on [EIP-712](https://eips.ethereum.org/EIPS/eip-712), except that arrays and\n * recursive data structures are not supported.\n *\n * V4 is based on [EIP-712](https://eips.ethereum.org/EIPS/eip-712), and includes full support of\n * arrays and recursive data structures.\n *\n * @param options - The signing options.\n * @param options.privateKey - The private key to sign with.\n * @param options.data - The typed data to sign.\n * @param options.version - The signing version to use.\n * @returns The '0x'-prefixed hex encoded signature.\n */\nfunction signTypedData({\n privateKey,\n data,\n version\n}) {\n validateVersion(version);\n if (utils_1.isNullish(data)) {\n throw new Error('Missing data parameter');\n } else if (utils_1.isNullish(privateKey)) {\n throw new Error('Missing private key parameter');\n }\n const messageHash = version === SignTypedDataVersion.V1 ? _typedSignatureHash(data) : exports.TypedDataUtils.eip712Hash(data, version);\n const sig = ethereumjs_util_1.ecsign(messageHash, privateKey);\n return utils_1.concatSig(ethereumjs_util_1.toBuffer(sig.v), sig.r, sig.s);\n}\nexports.signTypedData = signTypedData;\n/**\n * Recover the address of the account that created the given EIP-712\n * signature. The version provided must match the version used to\n * create the signature.\n *\n * @param options - The signature recovery options.\n * @param options.data - The typed data that was signed.\n * @param options.signature - The '0x-prefixed hex encoded message signature.\n * @param options.version - The signing version to use.\n * @returns The '0x'-prefixed hex address of the signer.\n */\nfunction recoverTypedSignature({\n data,\n signature,\n version\n}) {\n validateVersion(version);\n if (utils_1.isNullish(data)) {\n throw new Error('Missing data parameter');\n } else if (utils_1.isNullish(signature)) {\n throw new Error('Missing signature parameter');\n }\n const messageHash = version === SignTypedDataVersion.V1 ? _typedSignatureHash(data) : exports.TypedDataUtils.eip712Hash(data, version);\n const publicKey = utils_1.recoverPublicKey(messageHash, signature);\n const sender = ethereumjs_util_1.publicToAddress(publicKey);\n return ethereumjs_util_1.bufferToHex(sender);\n}\nexports.recoverTypedSignature = recoverTypedSignature;\n","(function (nacl) {\n 'use strict';\n\n // Ported in 2014 by Dmitry Chestnykh and Devi Mandiri.\n // Public domain.\n //\n // Implementation derived from TweetNaCl version 20140427.\n // See for details: http://tweetnacl.cr.yp.to/\n var gf = function (init) {\n var i,\n r = new Float64Array(16);\n if (init) for (i = 0; i < init.length; i++) r[i] = init[i];\n return r;\n };\n\n // Pluggable, initialized in high-level API below.\n var randombytes = function /* x, n */ () {\n throw new Error('no PRNG');\n };\n var _0 = new Uint8Array(16);\n var _9 = new Uint8Array(32);\n _9[0] = 9;\n var gf0 = gf(),\n gf1 = gf([1]),\n _121665 = gf([0xdb41, 1]),\n D = gf([0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070, 0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]),\n D2 = gf([0xf159, 0x26b2, 0x9b94, 0xebd6, 0xb156, 0x8283, 0x149a, 0x00e0, 0xd130, 0xeef3, 0x80f2, 0x198e, 0xfce7, 0x56df, 0xd9dc, 0x2406]),\n X = gf([0xd51a, 0x8f25, 0x2d60, 0xc956, 0xa7b2, 0x9525, 0xc760, 0x692c, 0xdc5c, 0xfdd6, 0xe231, 0xc0a4, 0x53fe, 0xcd6e, 0x36d3, 0x2169]),\n Y = gf([0x6658, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666]),\n I = gf([0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43, 0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]);\n function ts64(x, i, h, l) {\n x[i] = h >> 24 & 0xff;\n x[i + 1] = h >> 16 & 0xff;\n x[i + 2] = h >> 8 & 0xff;\n x[i + 3] = h & 0xff;\n x[i + 4] = l >> 24 & 0xff;\n x[i + 5] = l >> 16 & 0xff;\n x[i + 6] = l >> 8 & 0xff;\n x[i + 7] = l & 0xff;\n }\n function vn(x, xi, y, yi, n) {\n var i,\n d = 0;\n for (i = 0; i < n; i++) d |= x[xi + i] ^ y[yi + i];\n return (1 & d - 1 >>> 8) - 1;\n }\n function crypto_verify_16(x, xi, y, yi) {\n return vn(x, xi, y, yi, 16);\n }\n function crypto_verify_32(x, xi, y, yi) {\n return vn(x, xi, y, yi, 32);\n }\n function core_salsa20(o, p, k, c) {\n var j0 = c[0] & 0xff | (c[1] & 0xff) << 8 | (c[2] & 0xff) << 16 | (c[3] & 0xff) << 24,\n j1 = k[0] & 0xff | (k[1] & 0xff) << 8 | (k[2] & 0xff) << 16 | (k[3] & 0xff) << 24,\n j2 = k[4] & 0xff | (k[5] & 0xff) << 8 | (k[6] & 0xff) << 16 | (k[7] & 0xff) << 24,\n j3 = k[8] & 0xff | (k[9] & 0xff) << 8 | (k[10] & 0xff) << 16 | (k[11] & 0xff) << 24,\n j4 = k[12] & 0xff | (k[13] & 0xff) << 8 | (k[14] & 0xff) << 16 | (k[15] & 0xff) << 24,\n j5 = c[4] & 0xff | (c[5] & 0xff) << 8 | (c[6] & 0xff) << 16 | (c[7] & 0xff) << 24,\n j6 = p[0] & 0xff | (p[1] & 0xff) << 8 | (p[2] & 0xff) << 16 | (p[3] & 0xff) << 24,\n j7 = p[4] & 0xff | (p[5] & 0xff) << 8 | (p[6] & 0xff) << 16 | (p[7] & 0xff) << 24,\n j8 = p[8] & 0xff | (p[9] & 0xff) << 8 | (p[10] & 0xff) << 16 | (p[11] & 0xff) << 24,\n j9 = p[12] & 0xff | (p[13] & 0xff) << 8 | (p[14] & 0xff) << 16 | (p[15] & 0xff) << 24,\n j10 = c[8] & 0xff | (c[9] & 0xff) << 8 | (c[10] & 0xff) << 16 | (c[11] & 0xff) << 24,\n j11 = k[16] & 0xff | (k[17] & 0xff) << 8 | (k[18] & 0xff) << 16 | (k[19] & 0xff) << 24,\n j12 = k[20] & 0xff | (k[21] & 0xff) << 8 | (k[22] & 0xff) << 16 | (k[23] & 0xff) << 24,\n j13 = k[24] & 0xff | (k[25] & 0xff) << 8 | (k[26] & 0xff) << 16 | (k[27] & 0xff) << 24,\n j14 = k[28] & 0xff | (k[29] & 0xff) << 8 | (k[30] & 0xff) << 16 | (k[31] & 0xff) << 24,\n j15 = c[12] & 0xff | (c[13] & 0xff) << 8 | (c[14] & 0xff) << 16 | (c[15] & 0xff) << 24;\n var x0 = j0,\n x1 = j1,\n x2 = j2,\n x3 = j3,\n x4 = j4,\n x5 = j5,\n x6 = j6,\n x7 = j7,\n x8 = j8,\n x9 = j9,\n x10 = j10,\n x11 = j11,\n x12 = j12,\n x13 = j13,\n x14 = j14,\n x15 = j15,\n u;\n for (var i = 0; i < 20; i += 2) {\n u = x0 + x12 | 0;\n x4 ^= u << 7 | u >>> 32 - 7;\n u = x4 + x0 | 0;\n x8 ^= u << 9 | u >>> 32 - 9;\n u = x8 + x4 | 0;\n x12 ^= u << 13 | u >>> 32 - 13;\n u = x12 + x8 | 0;\n x0 ^= u << 18 | u >>> 32 - 18;\n u = x5 + x1 | 0;\n x9 ^= u << 7 | u >>> 32 - 7;\n u = x9 + x5 | 0;\n x13 ^= u << 9 | u >>> 32 - 9;\n u = x13 + x9 | 0;\n x1 ^= u << 13 | u >>> 32 - 13;\n u = x1 + x13 | 0;\n x5 ^= u << 18 | u >>> 32 - 18;\n u = x10 + x6 | 0;\n x14 ^= u << 7 | u >>> 32 - 7;\n u = x14 + x10 | 0;\n x2 ^= u << 9 | u >>> 32 - 9;\n u = x2 + x14 | 0;\n x6 ^= u << 13 | u >>> 32 - 13;\n u = x6 + x2 | 0;\n x10 ^= u << 18 | u >>> 32 - 18;\n u = x15 + x11 | 0;\n x3 ^= u << 7 | u >>> 32 - 7;\n u = x3 + x15 | 0;\n x7 ^= u << 9 | u >>> 32 - 9;\n u = x7 + x3 | 0;\n x11 ^= u << 13 | u >>> 32 - 13;\n u = x11 + x7 | 0;\n x15 ^= u << 18 | u >>> 32 - 18;\n u = x0 + x3 | 0;\n x1 ^= u << 7 | u >>> 32 - 7;\n u = x1 + x0 | 0;\n x2 ^= u << 9 | u >>> 32 - 9;\n u = x2 + x1 | 0;\n x3 ^= u << 13 | u >>> 32 - 13;\n u = x3 + x2 | 0;\n x0 ^= u << 18 | u >>> 32 - 18;\n u = x5 + x4 | 0;\n x6 ^= u << 7 | u >>> 32 - 7;\n u = x6 + x5 | 0;\n x7 ^= u << 9 | u >>> 32 - 9;\n u = x7 + x6 | 0;\n x4 ^= u << 13 | u >>> 32 - 13;\n u = x4 + x7 | 0;\n x5 ^= u << 18 | u >>> 32 - 18;\n u = x10 + x9 | 0;\n x11 ^= u << 7 | u >>> 32 - 7;\n u = x11 + x10 | 0;\n x8 ^= u << 9 | u >>> 32 - 9;\n u = x8 + x11 | 0;\n x9 ^= u << 13 | u >>> 32 - 13;\n u = x9 + x8 | 0;\n x10 ^= u << 18 | u >>> 32 - 18;\n u = x15 + x14 | 0;\n x12 ^= u << 7 | u >>> 32 - 7;\n u = x12 + x15 | 0;\n x13 ^= u << 9 | u >>> 32 - 9;\n u = x13 + x12 | 0;\n x14 ^= u << 13 | u >>> 32 - 13;\n u = x14 + x13 | 0;\n x15 ^= u << 18 | u >>> 32 - 18;\n }\n x0 = x0 + j0 | 0;\n x1 = x1 + j1 | 0;\n x2 = x2 + j2 | 0;\n x3 = x3 + j3 | 0;\n x4 = x4 + j4 | 0;\n x5 = x5 + j5 | 0;\n x6 = x6 + j6 | 0;\n x7 = x7 + j7 | 0;\n x8 = x8 + j8 | 0;\n x9 = x9 + j9 | 0;\n x10 = x10 + j10 | 0;\n x11 = x11 + j11 | 0;\n x12 = x12 + j12 | 0;\n x13 = x13 + j13 | 0;\n x14 = x14 + j14 | 0;\n x15 = x15 + j15 | 0;\n o[0] = x0 >>> 0 & 0xff;\n o[1] = x0 >>> 8 & 0xff;\n o[2] = x0 >>> 16 & 0xff;\n o[3] = x0 >>> 24 & 0xff;\n o[4] = x1 >>> 0 & 0xff;\n o[5] = x1 >>> 8 & 0xff;\n o[6] = x1 >>> 16 & 0xff;\n o[7] = x1 >>> 24 & 0xff;\n o[8] = x2 >>> 0 & 0xff;\n o[9] = x2 >>> 8 & 0xff;\n o[10] = x2 >>> 16 & 0xff;\n o[11] = x2 >>> 24 & 0xff;\n o[12] = x3 >>> 0 & 0xff;\n o[13] = x3 >>> 8 & 0xff;\n o[14] = x3 >>> 16 & 0xff;\n o[15] = x3 >>> 24 & 0xff;\n o[16] = x4 >>> 0 & 0xff;\n o[17] = x4 >>> 8 & 0xff;\n o[18] = x4 >>> 16 & 0xff;\n o[19] = x4 >>> 24 & 0xff;\n o[20] = x5 >>> 0 & 0xff;\n o[21] = x5 >>> 8 & 0xff;\n o[22] = x5 >>> 16 & 0xff;\n o[23] = x5 >>> 24 & 0xff;\n o[24] = x6 >>> 0 & 0xff;\n o[25] = x6 >>> 8 & 0xff;\n o[26] = x6 >>> 16 & 0xff;\n o[27] = x6 >>> 24 & 0xff;\n o[28] = x7 >>> 0 & 0xff;\n o[29] = x7 >>> 8 & 0xff;\n o[30] = x7 >>> 16 & 0xff;\n o[31] = x7 >>> 24 & 0xff;\n o[32] = x8 >>> 0 & 0xff;\n o[33] = x8 >>> 8 & 0xff;\n o[34] = x8 >>> 16 & 0xff;\n o[35] = x8 >>> 24 & 0xff;\n o[36] = x9 >>> 0 & 0xff;\n o[37] = x9 >>> 8 & 0xff;\n o[38] = x9 >>> 16 & 0xff;\n o[39] = x9 >>> 24 & 0xff;\n o[40] = x10 >>> 0 & 0xff;\n o[41] = x10 >>> 8 & 0xff;\n o[42] = x10 >>> 16 & 0xff;\n o[43] = x10 >>> 24 & 0xff;\n o[44] = x11 >>> 0 & 0xff;\n o[45] = x11 >>> 8 & 0xff;\n o[46] = x11 >>> 16 & 0xff;\n o[47] = x11 >>> 24 & 0xff;\n o[48] = x12 >>> 0 & 0xff;\n o[49] = x12 >>> 8 & 0xff;\n o[50] = x12 >>> 16 & 0xff;\n o[51] = x12 >>> 24 & 0xff;\n o[52] = x13 >>> 0 & 0xff;\n o[53] = x13 >>> 8 & 0xff;\n o[54] = x13 >>> 16 & 0xff;\n o[55] = x13 >>> 24 & 0xff;\n o[56] = x14 >>> 0 & 0xff;\n o[57] = x14 >>> 8 & 0xff;\n o[58] = x14 >>> 16 & 0xff;\n o[59] = x14 >>> 24 & 0xff;\n o[60] = x15 >>> 0 & 0xff;\n o[61] = x15 >>> 8 & 0xff;\n o[62] = x15 >>> 16 & 0xff;\n o[63] = x15 >>> 24 & 0xff;\n }\n function core_hsalsa20(o, p, k, c) {\n var j0 = c[0] & 0xff | (c[1] & 0xff) << 8 | (c[2] & 0xff) << 16 | (c[3] & 0xff) << 24,\n j1 = k[0] & 0xff | (k[1] & 0xff) << 8 | (k[2] & 0xff) << 16 | (k[3] & 0xff) << 24,\n j2 = k[4] & 0xff | (k[5] & 0xff) << 8 | (k[6] & 0xff) << 16 | (k[7] & 0xff) << 24,\n j3 = k[8] & 0xff | (k[9] & 0xff) << 8 | (k[10] & 0xff) << 16 | (k[11] & 0xff) << 24,\n j4 = k[12] & 0xff | (k[13] & 0xff) << 8 | (k[14] & 0xff) << 16 | (k[15] & 0xff) << 24,\n j5 = c[4] & 0xff | (c[5] & 0xff) << 8 | (c[6] & 0xff) << 16 | (c[7] & 0xff) << 24,\n j6 = p[0] & 0xff | (p[1] & 0xff) << 8 | (p[2] & 0xff) << 16 | (p[3] & 0xff) << 24,\n j7 = p[4] & 0xff | (p[5] & 0xff) << 8 | (p[6] & 0xff) << 16 | (p[7] & 0xff) << 24,\n j8 = p[8] & 0xff | (p[9] & 0xff) << 8 | (p[10] & 0xff) << 16 | (p[11] & 0xff) << 24,\n j9 = p[12] & 0xff | (p[13] & 0xff) << 8 | (p[14] & 0xff) << 16 | (p[15] & 0xff) << 24,\n j10 = c[8] & 0xff | (c[9] & 0xff) << 8 | (c[10] & 0xff) << 16 | (c[11] & 0xff) << 24,\n j11 = k[16] & 0xff | (k[17] & 0xff) << 8 | (k[18] & 0xff) << 16 | (k[19] & 0xff) << 24,\n j12 = k[20] & 0xff | (k[21] & 0xff) << 8 | (k[22] & 0xff) << 16 | (k[23] & 0xff) << 24,\n j13 = k[24] & 0xff | (k[25] & 0xff) << 8 | (k[26] & 0xff) << 16 | (k[27] & 0xff) << 24,\n j14 = k[28] & 0xff | (k[29] & 0xff) << 8 | (k[30] & 0xff) << 16 | (k[31] & 0xff) << 24,\n j15 = c[12] & 0xff | (c[13] & 0xff) << 8 | (c[14] & 0xff) << 16 | (c[15] & 0xff) << 24;\n var x0 = j0,\n x1 = j1,\n x2 = j2,\n x3 = j3,\n x4 = j4,\n x5 = j5,\n x6 = j6,\n x7 = j7,\n x8 = j8,\n x9 = j9,\n x10 = j10,\n x11 = j11,\n x12 = j12,\n x13 = j13,\n x14 = j14,\n x15 = j15,\n u;\n for (var i = 0; i < 20; i += 2) {\n u = x0 + x12 | 0;\n x4 ^= u << 7 | u >>> 32 - 7;\n u = x4 + x0 | 0;\n x8 ^= u << 9 | u >>> 32 - 9;\n u = x8 + x4 | 0;\n x12 ^= u << 13 | u >>> 32 - 13;\n u = x12 + x8 | 0;\n x0 ^= u << 18 | u >>> 32 - 18;\n u = x5 + x1 | 0;\n x9 ^= u << 7 | u >>> 32 - 7;\n u = x9 + x5 | 0;\n x13 ^= u << 9 | u >>> 32 - 9;\n u = x13 + x9 | 0;\n x1 ^= u << 13 | u >>> 32 - 13;\n u = x1 + x13 | 0;\n x5 ^= u << 18 | u >>> 32 - 18;\n u = x10 + x6 | 0;\n x14 ^= u << 7 | u >>> 32 - 7;\n u = x14 + x10 | 0;\n x2 ^= u << 9 | u >>> 32 - 9;\n u = x2 + x14 | 0;\n x6 ^= u << 13 | u >>> 32 - 13;\n u = x6 + x2 | 0;\n x10 ^= u << 18 | u >>> 32 - 18;\n u = x15 + x11 | 0;\n x3 ^= u << 7 | u >>> 32 - 7;\n u = x3 + x15 | 0;\n x7 ^= u << 9 | u >>> 32 - 9;\n u = x7 + x3 | 0;\n x11 ^= u << 13 | u >>> 32 - 13;\n u = x11 + x7 | 0;\n x15 ^= u << 18 | u >>> 32 - 18;\n u = x0 + x3 | 0;\n x1 ^= u << 7 | u >>> 32 - 7;\n u = x1 + x0 | 0;\n x2 ^= u << 9 | u >>> 32 - 9;\n u = x2 + x1 | 0;\n x3 ^= u << 13 | u >>> 32 - 13;\n u = x3 + x2 | 0;\n x0 ^= u << 18 | u >>> 32 - 18;\n u = x5 + x4 | 0;\n x6 ^= u << 7 | u >>> 32 - 7;\n u = x6 + x5 | 0;\n x7 ^= u << 9 | u >>> 32 - 9;\n u = x7 + x6 | 0;\n x4 ^= u << 13 | u >>> 32 - 13;\n u = x4 + x7 | 0;\n x5 ^= u << 18 | u >>> 32 - 18;\n u = x10 + x9 | 0;\n x11 ^= u << 7 | u >>> 32 - 7;\n u = x11 + x10 | 0;\n x8 ^= u << 9 | u >>> 32 - 9;\n u = x8 + x11 | 0;\n x9 ^= u << 13 | u >>> 32 - 13;\n u = x9 + x8 | 0;\n x10 ^= u << 18 | u >>> 32 - 18;\n u = x15 + x14 | 0;\n x12 ^= u << 7 | u >>> 32 - 7;\n u = x12 + x15 | 0;\n x13 ^= u << 9 | u >>> 32 - 9;\n u = x13 + x12 | 0;\n x14 ^= u << 13 | u >>> 32 - 13;\n u = x14 + x13 | 0;\n x15 ^= u << 18 | u >>> 32 - 18;\n }\n o[0] = x0 >>> 0 & 0xff;\n o[1] = x0 >>> 8 & 0xff;\n o[2] = x0 >>> 16 & 0xff;\n o[3] = x0 >>> 24 & 0xff;\n o[4] = x5 >>> 0 & 0xff;\n o[5] = x5 >>> 8 & 0xff;\n o[6] = x5 >>> 16 & 0xff;\n o[7] = x5 >>> 24 & 0xff;\n o[8] = x10 >>> 0 & 0xff;\n o[9] = x10 >>> 8 & 0xff;\n o[10] = x10 >>> 16 & 0xff;\n o[11] = x10 >>> 24 & 0xff;\n o[12] = x15 >>> 0 & 0xff;\n o[13] = x15 >>> 8 & 0xff;\n o[14] = x15 >>> 16 & 0xff;\n o[15] = x15 >>> 24 & 0xff;\n o[16] = x6 >>> 0 & 0xff;\n o[17] = x6 >>> 8 & 0xff;\n o[18] = x6 >>> 16 & 0xff;\n o[19] = x6 >>> 24 & 0xff;\n o[20] = x7 >>> 0 & 0xff;\n o[21] = x7 >>> 8 & 0xff;\n o[22] = x7 >>> 16 & 0xff;\n o[23] = x7 >>> 24 & 0xff;\n o[24] = x8 >>> 0 & 0xff;\n o[25] = x8 >>> 8 & 0xff;\n o[26] = x8 >>> 16 & 0xff;\n o[27] = x8 >>> 24 & 0xff;\n o[28] = x9 >>> 0 & 0xff;\n o[29] = x9 >>> 8 & 0xff;\n o[30] = x9 >>> 16 & 0xff;\n o[31] = x9 >>> 24 & 0xff;\n }\n function crypto_core_salsa20(out, inp, k, c) {\n core_salsa20(out, inp, k, c);\n }\n function crypto_core_hsalsa20(out, inp, k, c) {\n core_hsalsa20(out, inp, k, c);\n }\n var sigma = new Uint8Array([101, 120, 112, 97, 110, 100, 32, 51, 50, 45, 98, 121, 116, 101, 32, 107]);\n // \"expand 32-byte k\"\n\n function crypto_stream_salsa20_xor(c, cpos, m, mpos, b, n, k) {\n var z = new Uint8Array(16),\n x = new Uint8Array(64);\n var u, i;\n for (i = 0; i < 16; i++) z[i] = 0;\n for (i = 0; i < 8; i++) z[i] = n[i];\n while (b >= 64) {\n crypto_core_salsa20(x, z, k, sigma);\n for (i = 0; i < 64; i++) c[cpos + i] = m[mpos + i] ^ x[i];\n u = 1;\n for (i = 8; i < 16; i++) {\n u = u + (z[i] & 0xff) | 0;\n z[i] = u & 0xff;\n u >>>= 8;\n }\n b -= 64;\n cpos += 64;\n mpos += 64;\n }\n if (b > 0) {\n crypto_core_salsa20(x, z, k, sigma);\n for (i = 0; i < b; i++) c[cpos + i] = m[mpos + i] ^ x[i];\n }\n return 0;\n }\n function crypto_stream_salsa20(c, cpos, b, n, k) {\n var z = new Uint8Array(16),\n x = new Uint8Array(64);\n var u, i;\n for (i = 0; i < 16; i++) z[i] = 0;\n for (i = 0; i < 8; i++) z[i] = n[i];\n while (b >= 64) {\n crypto_core_salsa20(x, z, k, sigma);\n for (i = 0; i < 64; i++) c[cpos + i] = x[i];\n u = 1;\n for (i = 8; i < 16; i++) {\n u = u + (z[i] & 0xff) | 0;\n z[i] = u & 0xff;\n u >>>= 8;\n }\n b -= 64;\n cpos += 64;\n }\n if (b > 0) {\n crypto_core_salsa20(x, z, k, sigma);\n for (i = 0; i < b; i++) c[cpos + i] = x[i];\n }\n return 0;\n }\n function crypto_stream(c, cpos, d, n, k) {\n var s = new Uint8Array(32);\n crypto_core_hsalsa20(s, n, k, sigma);\n var sn = new Uint8Array(8);\n for (var i = 0; i < 8; i++) sn[i] = n[i + 16];\n return crypto_stream_salsa20(c, cpos, d, sn, s);\n }\n function crypto_stream_xor(c, cpos, m, mpos, d, n, k) {\n var s = new Uint8Array(32);\n crypto_core_hsalsa20(s, n, k, sigma);\n var sn = new Uint8Array(8);\n for (var i = 0; i < 8; i++) sn[i] = n[i + 16];\n return crypto_stream_salsa20_xor(c, cpos, m, mpos, d, sn, s);\n }\n\n /*\n * Port of Andrew Moon's Poly1305-donna-16. Public domain.\n * https://github.com/floodyberry/poly1305-donna\n */\n\n var poly1305 = function (key) {\n this.buffer = new Uint8Array(16);\n this.r = new Uint16Array(10);\n this.h = new Uint16Array(10);\n this.pad = new Uint16Array(8);\n this.leftover = 0;\n this.fin = 0;\n var t0, t1, t2, t3, t4, t5, t6, t7;\n t0 = key[0] & 0xff | (key[1] & 0xff) << 8;\n this.r[0] = t0 & 0x1fff;\n t1 = key[2] & 0xff | (key[3] & 0xff) << 8;\n this.r[1] = (t0 >>> 13 | t1 << 3) & 0x1fff;\n t2 = key[4] & 0xff | (key[5] & 0xff) << 8;\n this.r[2] = (t1 >>> 10 | t2 << 6) & 0x1f03;\n t3 = key[6] & 0xff | (key[7] & 0xff) << 8;\n this.r[3] = (t2 >>> 7 | t3 << 9) & 0x1fff;\n t4 = key[8] & 0xff | (key[9] & 0xff) << 8;\n this.r[4] = (t3 >>> 4 | t4 << 12) & 0x00ff;\n this.r[5] = t4 >>> 1 & 0x1ffe;\n t5 = key[10] & 0xff | (key[11] & 0xff) << 8;\n this.r[6] = (t4 >>> 14 | t5 << 2) & 0x1fff;\n t6 = key[12] & 0xff | (key[13] & 0xff) << 8;\n this.r[7] = (t5 >>> 11 | t6 << 5) & 0x1f81;\n t7 = key[14] & 0xff | (key[15] & 0xff) << 8;\n this.r[8] = (t6 >>> 8 | t7 << 8) & 0x1fff;\n this.r[9] = t7 >>> 5 & 0x007f;\n this.pad[0] = key[16] & 0xff | (key[17] & 0xff) << 8;\n this.pad[1] = key[18] & 0xff | (key[19] & 0xff) << 8;\n this.pad[2] = key[20] & 0xff | (key[21] & 0xff) << 8;\n this.pad[3] = key[22] & 0xff | (key[23] & 0xff) << 8;\n this.pad[4] = key[24] & 0xff | (key[25] & 0xff) << 8;\n this.pad[5] = key[26] & 0xff | (key[27] & 0xff) << 8;\n this.pad[6] = key[28] & 0xff | (key[29] & 0xff) << 8;\n this.pad[7] = key[30] & 0xff | (key[31] & 0xff) << 8;\n };\n poly1305.prototype.blocks = function (m, mpos, bytes) {\n var hibit = this.fin ? 0 : 1 << 11;\n var t0, t1, t2, t3, t4, t5, t6, t7, c;\n var d0, d1, d2, d3, d4, d5, d6, d7, d8, d9;\n var h0 = this.h[0],\n h1 = this.h[1],\n h2 = this.h[2],\n h3 = this.h[3],\n h4 = this.h[4],\n h5 = this.h[5],\n h6 = this.h[6],\n h7 = this.h[7],\n h8 = this.h[8],\n h9 = this.h[9];\n var r0 = this.r[0],\n r1 = this.r[1],\n r2 = this.r[2],\n r3 = this.r[3],\n r4 = this.r[4],\n r5 = this.r[5],\n r6 = this.r[6],\n r7 = this.r[7],\n r8 = this.r[8],\n r9 = this.r[9];\n while (bytes >= 16) {\n t0 = m[mpos + 0] & 0xff | (m[mpos + 1] & 0xff) << 8;\n h0 += t0 & 0x1fff;\n t1 = m[mpos + 2] & 0xff | (m[mpos + 3] & 0xff) << 8;\n h1 += (t0 >>> 13 | t1 << 3) & 0x1fff;\n t2 = m[mpos + 4] & 0xff | (m[mpos + 5] & 0xff) << 8;\n h2 += (t1 >>> 10 | t2 << 6) & 0x1fff;\n t3 = m[mpos + 6] & 0xff | (m[mpos + 7] & 0xff) << 8;\n h3 += (t2 >>> 7 | t3 << 9) & 0x1fff;\n t4 = m[mpos + 8] & 0xff | (m[mpos + 9] & 0xff) << 8;\n h4 += (t3 >>> 4 | t4 << 12) & 0x1fff;\n h5 += t4 >>> 1 & 0x1fff;\n t5 = m[mpos + 10] & 0xff | (m[mpos + 11] & 0xff) << 8;\n h6 += (t4 >>> 14 | t5 << 2) & 0x1fff;\n t6 = m[mpos + 12] & 0xff | (m[mpos + 13] & 0xff) << 8;\n h7 += (t5 >>> 11 | t6 << 5) & 0x1fff;\n t7 = m[mpos + 14] & 0xff | (m[mpos + 15] & 0xff) << 8;\n h8 += (t6 >>> 8 | t7 << 8) & 0x1fff;\n h9 += t7 >>> 5 | hibit;\n c = 0;\n d0 = c;\n d0 += h0 * r0;\n d0 += h1 * (5 * r9);\n d0 += h2 * (5 * r8);\n d0 += h3 * (5 * r7);\n d0 += h4 * (5 * r6);\n c = d0 >>> 13;\n d0 &= 0x1fff;\n d0 += h5 * (5 * r5);\n d0 += h6 * (5 * r4);\n d0 += h7 * (5 * r3);\n d0 += h8 * (5 * r2);\n d0 += h9 * (5 * r1);\n c += d0 >>> 13;\n d0 &= 0x1fff;\n d1 = c;\n d1 += h0 * r1;\n d1 += h1 * r0;\n d1 += h2 * (5 * r9);\n d1 += h3 * (5 * r8);\n d1 += h4 * (5 * r7);\n c = d1 >>> 13;\n d1 &= 0x1fff;\n d1 += h5 * (5 * r6);\n d1 += h6 * (5 * r5);\n d1 += h7 * (5 * r4);\n d1 += h8 * (5 * r3);\n d1 += h9 * (5 * r2);\n c += d1 >>> 13;\n d1 &= 0x1fff;\n d2 = c;\n d2 += h0 * r2;\n d2 += h1 * r1;\n d2 += h2 * r0;\n d2 += h3 * (5 * r9);\n d2 += h4 * (5 * r8);\n c = d2 >>> 13;\n d2 &= 0x1fff;\n d2 += h5 * (5 * r7);\n d2 += h6 * (5 * r6);\n d2 += h7 * (5 * r5);\n d2 += h8 * (5 * r4);\n d2 += h9 * (5 * r3);\n c += d2 >>> 13;\n d2 &= 0x1fff;\n d3 = c;\n d3 += h0 * r3;\n d3 += h1 * r2;\n d3 += h2 * r1;\n d3 += h3 * r0;\n d3 += h4 * (5 * r9);\n c = d3 >>> 13;\n d3 &= 0x1fff;\n d3 += h5 * (5 * r8);\n d3 += h6 * (5 * r7);\n d3 += h7 * (5 * r6);\n d3 += h8 * (5 * r5);\n d3 += h9 * (5 * r4);\n c += d3 >>> 13;\n d3 &= 0x1fff;\n d4 = c;\n d4 += h0 * r4;\n d4 += h1 * r3;\n d4 += h2 * r2;\n d4 += h3 * r1;\n d4 += h4 * r0;\n c = d4 >>> 13;\n d4 &= 0x1fff;\n d4 += h5 * (5 * r9);\n d4 += h6 * (5 * r8);\n d4 += h7 * (5 * r7);\n d4 += h8 * (5 * r6);\n d4 += h9 * (5 * r5);\n c += d4 >>> 13;\n d4 &= 0x1fff;\n d5 = c;\n d5 += h0 * r5;\n d5 += h1 * r4;\n d5 += h2 * r3;\n d5 += h3 * r2;\n d5 += h4 * r1;\n c = d5 >>> 13;\n d5 &= 0x1fff;\n d5 += h5 * r0;\n d5 += h6 * (5 * r9);\n d5 += h7 * (5 * r8);\n d5 += h8 * (5 * r7);\n d5 += h9 * (5 * r6);\n c += d5 >>> 13;\n d5 &= 0x1fff;\n d6 = c;\n d6 += h0 * r6;\n d6 += h1 * r5;\n d6 += h2 * r4;\n d6 += h3 * r3;\n d6 += h4 * r2;\n c = d6 >>> 13;\n d6 &= 0x1fff;\n d6 += h5 * r1;\n d6 += h6 * r0;\n d6 += h7 * (5 * r9);\n d6 += h8 * (5 * r8);\n d6 += h9 * (5 * r7);\n c += d6 >>> 13;\n d6 &= 0x1fff;\n d7 = c;\n d7 += h0 * r7;\n d7 += h1 * r6;\n d7 += h2 * r5;\n d7 += h3 * r4;\n d7 += h4 * r3;\n c = d7 >>> 13;\n d7 &= 0x1fff;\n d7 += h5 * r2;\n d7 += h6 * r1;\n d7 += h7 * r0;\n d7 += h8 * (5 * r9);\n d7 += h9 * (5 * r8);\n c += d7 >>> 13;\n d7 &= 0x1fff;\n d8 = c;\n d8 += h0 * r8;\n d8 += h1 * r7;\n d8 += h2 * r6;\n d8 += h3 * r5;\n d8 += h4 * r4;\n c = d8 >>> 13;\n d8 &= 0x1fff;\n d8 += h5 * r3;\n d8 += h6 * r2;\n d8 += h7 * r1;\n d8 += h8 * r0;\n d8 += h9 * (5 * r9);\n c += d8 >>> 13;\n d8 &= 0x1fff;\n d9 = c;\n d9 += h0 * r9;\n d9 += h1 * r8;\n d9 += h2 * r7;\n d9 += h3 * r6;\n d9 += h4 * r5;\n c = d9 >>> 13;\n d9 &= 0x1fff;\n d9 += h5 * r4;\n d9 += h6 * r3;\n d9 += h7 * r2;\n d9 += h8 * r1;\n d9 += h9 * r0;\n c += d9 >>> 13;\n d9 &= 0x1fff;\n c = (c << 2) + c | 0;\n c = c + d0 | 0;\n d0 = c & 0x1fff;\n c = c >>> 13;\n d1 += c;\n h0 = d0;\n h1 = d1;\n h2 = d2;\n h3 = d3;\n h4 = d4;\n h5 = d5;\n h6 = d6;\n h7 = d7;\n h8 = d8;\n h9 = d9;\n mpos += 16;\n bytes -= 16;\n }\n this.h[0] = h0;\n this.h[1] = h1;\n this.h[2] = h2;\n this.h[3] = h3;\n this.h[4] = h4;\n this.h[5] = h5;\n this.h[6] = h6;\n this.h[7] = h7;\n this.h[8] = h8;\n this.h[9] = h9;\n };\n poly1305.prototype.finish = function (mac, macpos) {\n var g = new Uint16Array(10);\n var c, mask, f, i;\n if (this.leftover) {\n i = this.leftover;\n this.buffer[i++] = 1;\n for (; i < 16; i++) this.buffer[i] = 0;\n this.fin = 1;\n this.blocks(this.buffer, 0, 16);\n }\n c = this.h[1] >>> 13;\n this.h[1] &= 0x1fff;\n for (i = 2; i < 10; i++) {\n this.h[i] += c;\n c = this.h[i] >>> 13;\n this.h[i] &= 0x1fff;\n }\n this.h[0] += c * 5;\n c = this.h[0] >>> 13;\n this.h[0] &= 0x1fff;\n this.h[1] += c;\n c = this.h[1] >>> 13;\n this.h[1] &= 0x1fff;\n this.h[2] += c;\n g[0] = this.h[0] + 5;\n c = g[0] >>> 13;\n g[0] &= 0x1fff;\n for (i = 1; i < 10; i++) {\n g[i] = this.h[i] + c;\n c = g[i] >>> 13;\n g[i] &= 0x1fff;\n }\n g[9] -= 1 << 13;\n mask = (c ^ 1) - 1;\n for (i = 0; i < 10; i++) g[i] &= mask;\n mask = ~mask;\n for (i = 0; i < 10; i++) this.h[i] = this.h[i] & mask | g[i];\n this.h[0] = (this.h[0] | this.h[1] << 13) & 0xffff;\n this.h[1] = (this.h[1] >>> 3 | this.h[2] << 10) & 0xffff;\n this.h[2] = (this.h[2] >>> 6 | this.h[3] << 7) & 0xffff;\n this.h[3] = (this.h[3] >>> 9 | this.h[4] << 4) & 0xffff;\n this.h[4] = (this.h[4] >>> 12 | this.h[5] << 1 | this.h[6] << 14) & 0xffff;\n this.h[5] = (this.h[6] >>> 2 | this.h[7] << 11) & 0xffff;\n this.h[6] = (this.h[7] >>> 5 | this.h[8] << 8) & 0xffff;\n this.h[7] = (this.h[8] >>> 8 | this.h[9] << 5) & 0xffff;\n f = this.h[0] + this.pad[0];\n this.h[0] = f & 0xffff;\n for (i = 1; i < 8; i++) {\n f = (this.h[i] + this.pad[i] | 0) + (f >>> 16) | 0;\n this.h[i] = f & 0xffff;\n }\n mac[macpos + 0] = this.h[0] >>> 0 & 0xff;\n mac[macpos + 1] = this.h[0] >>> 8 & 0xff;\n mac[macpos + 2] = this.h[1] >>> 0 & 0xff;\n mac[macpos + 3] = this.h[1] >>> 8 & 0xff;\n mac[macpos + 4] = this.h[2] >>> 0 & 0xff;\n mac[macpos + 5] = this.h[2] >>> 8 & 0xff;\n mac[macpos + 6] = this.h[3] >>> 0 & 0xff;\n mac[macpos + 7] = this.h[3] >>> 8 & 0xff;\n mac[macpos + 8] = this.h[4] >>> 0 & 0xff;\n mac[macpos + 9] = this.h[4] >>> 8 & 0xff;\n mac[macpos + 10] = this.h[5] >>> 0 & 0xff;\n mac[macpos + 11] = this.h[5] >>> 8 & 0xff;\n mac[macpos + 12] = this.h[6] >>> 0 & 0xff;\n mac[macpos + 13] = this.h[6] >>> 8 & 0xff;\n mac[macpos + 14] = this.h[7] >>> 0 & 0xff;\n mac[macpos + 15] = this.h[7] >>> 8 & 0xff;\n };\n poly1305.prototype.update = function (m, mpos, bytes) {\n var i, want;\n if (this.leftover) {\n want = 16 - this.leftover;\n if (want > bytes) want = bytes;\n for (i = 0; i < want; i++) this.buffer[this.leftover + i] = m[mpos + i];\n bytes -= want;\n mpos += want;\n this.leftover += want;\n if (this.leftover < 16) return;\n this.blocks(this.buffer, 0, 16);\n this.leftover = 0;\n }\n if (bytes >= 16) {\n want = bytes - bytes % 16;\n this.blocks(m, mpos, want);\n mpos += want;\n bytes -= want;\n }\n if (bytes) {\n for (i = 0; i < bytes; i++) this.buffer[this.leftover + i] = m[mpos + i];\n this.leftover += bytes;\n }\n };\n function crypto_onetimeauth(out, outpos, m, mpos, n, k) {\n var s = new poly1305(k);\n s.update(m, mpos, n);\n s.finish(out, outpos);\n return 0;\n }\n function crypto_onetimeauth_verify(h, hpos, m, mpos, n, k) {\n var x = new Uint8Array(16);\n crypto_onetimeauth(x, 0, m, mpos, n, k);\n return crypto_verify_16(h, hpos, x, 0);\n }\n function crypto_secretbox(c, m, d, n, k) {\n var i;\n if (d < 32) return -1;\n crypto_stream_xor(c, 0, m, 0, d, n, k);\n crypto_onetimeauth(c, 16, c, 32, d - 32, c);\n for (i = 0; i < 16; i++) c[i] = 0;\n return 0;\n }\n function crypto_secretbox_open(m, c, d, n, k) {\n var i;\n var x = new Uint8Array(32);\n if (d < 32) return -1;\n crypto_stream(x, 0, 32, n, k);\n if (crypto_onetimeauth_verify(c, 16, c, 32, d - 32, x) !== 0) return -1;\n crypto_stream_xor(m, 0, c, 0, d, n, k);\n for (i = 0; i < 32; i++) m[i] = 0;\n return 0;\n }\n function set25519(r, a) {\n var i;\n for (i = 0; i < 16; i++) r[i] = a[i] | 0;\n }\n function car25519(o) {\n var i,\n v,\n 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 function sel25519(p, q, b) {\n var t,\n 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 function pack25519(o, n) {\n var i, j, b;\n var m = gf(),\n t = gf();\n for (i = 0; i < 16; i++) t[i] = n[i];\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 function neq25519(a, b) {\n var c = new Uint8Array(32),\n d = new Uint8Array(32);\n pack25519(c, a);\n pack25519(d, b);\n return crypto_verify_32(c, 0, d, 0);\n }\n function par25519(a) {\n var d = new Uint8Array(32);\n pack25519(d, a);\n return d[0] & 1;\n }\n function unpack25519(o, n) {\n var i;\n for (i = 0; i < 16; i++) o[i] = n[2 * i] + (n[2 * i + 1] << 8);\n o[15] &= 0x7fff;\n }\n function A(o, a, b) {\n for (var i = 0; i < 16; i++) o[i] = a[i] + b[i];\n }\n function Z(o, a, b) {\n for (var i = 0; i < 16; i++) o[i] = a[i] - b[i];\n }\n function M(o, a, b) {\n var v,\n c,\n t0 = 0,\n t1 = 0,\n t2 = 0,\n t3 = 0,\n t4 = 0,\n t5 = 0,\n t6 = 0,\n t7 = 0,\n t8 = 0,\n t9 = 0,\n t10 = 0,\n t11 = 0,\n t12 = 0,\n t13 = 0,\n t14 = 0,\n t15 = 0,\n t16 = 0,\n t17 = 0,\n t18 = 0,\n t19 = 0,\n t20 = 0,\n t21 = 0,\n t22 = 0,\n t23 = 0,\n t24 = 0,\n t25 = 0,\n t26 = 0,\n t27 = 0,\n t28 = 0,\n t29 = 0,\n 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 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 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;\n c = Math.floor(v / 65536);\n t0 = v - c * 65536;\n v = t1 + c + 65535;\n c = Math.floor(v / 65536);\n t1 = v - c * 65536;\n v = t2 + c + 65535;\n c = Math.floor(v / 65536);\n t2 = v - c * 65536;\n v = t3 + c + 65535;\n c = Math.floor(v / 65536);\n t3 = v - c * 65536;\n v = t4 + c + 65535;\n c = Math.floor(v / 65536);\n t4 = v - c * 65536;\n v = t5 + c + 65535;\n c = Math.floor(v / 65536);\n t5 = v - c * 65536;\n v = t6 + c + 65535;\n c = Math.floor(v / 65536);\n t6 = v - c * 65536;\n v = t7 + c + 65535;\n c = Math.floor(v / 65536);\n t7 = v - c * 65536;\n v = t8 + c + 65535;\n c = Math.floor(v / 65536);\n t8 = v - c * 65536;\n v = t9 + c + 65535;\n c = Math.floor(v / 65536);\n t9 = v - c * 65536;\n v = t10 + c + 65535;\n c = Math.floor(v / 65536);\n t10 = v - c * 65536;\n v = t11 + c + 65535;\n c = Math.floor(v / 65536);\n t11 = v - c * 65536;\n v = t12 + c + 65535;\n c = Math.floor(v / 65536);\n t12 = v - c * 65536;\n v = t13 + c + 65535;\n c = Math.floor(v / 65536);\n t13 = v - c * 65536;\n v = t14 + c + 65535;\n c = Math.floor(v / 65536);\n t14 = v - c * 65536;\n v = t15 + c + 65535;\n c = Math.floor(v / 65536);\n t15 = v - c * 65536;\n t0 += c - 1 + 37 * (c - 1);\n\n // second car\n c = 1;\n v = t0 + c + 65535;\n c = Math.floor(v / 65536);\n t0 = v - c * 65536;\n v = t1 + c + 65535;\n c = Math.floor(v / 65536);\n t1 = v - c * 65536;\n v = t2 + c + 65535;\n c = Math.floor(v / 65536);\n t2 = v - c * 65536;\n v = t3 + c + 65535;\n c = Math.floor(v / 65536);\n t3 = v - c * 65536;\n v = t4 + c + 65535;\n c = Math.floor(v / 65536);\n t4 = v - c * 65536;\n v = t5 + c + 65535;\n c = Math.floor(v / 65536);\n t5 = v - c * 65536;\n v = t6 + c + 65535;\n c = Math.floor(v / 65536);\n t6 = v - c * 65536;\n v = t7 + c + 65535;\n c = Math.floor(v / 65536);\n t7 = v - c * 65536;\n v = t8 + c + 65535;\n c = Math.floor(v / 65536);\n t8 = v - c * 65536;\n v = t9 + c + 65535;\n c = Math.floor(v / 65536);\n t9 = v - c * 65536;\n v = t10 + c + 65535;\n c = Math.floor(v / 65536);\n t10 = v - c * 65536;\n v = t11 + c + 65535;\n c = Math.floor(v / 65536);\n t11 = v - c * 65536;\n v = t12 + c + 65535;\n c = Math.floor(v / 65536);\n t12 = v - c * 65536;\n v = t13 + c + 65535;\n c = Math.floor(v / 65536);\n t13 = v - c * 65536;\n v = t14 + c + 65535;\n c = Math.floor(v / 65536);\n t14 = v - c * 65536;\n v = t15 + c + 65535;\n c = Math.floor(v / 65536);\n t15 = v - c * 65536;\n t0 += c - 1 + 37 * (c - 1);\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 function S(o, a) {\n M(o, a, a);\n }\n function inv25519(o, i) {\n var c = gf();\n var a;\n for (a = 0; a < 16; a++) c[a] = i[a];\n for (a = 253; a >= 0; a--) {\n S(c, c);\n if (a !== 2 && a !== 4) M(c, c, i);\n }\n for (a = 0; a < 16; a++) o[a] = c[a];\n }\n function pow2523(o, i) {\n var c = gf();\n var a;\n for (a = 0; a < 16; a++) c[a] = i[a];\n for (a = 250; a >= 0; a--) {\n S(c, c);\n if (a !== 1) M(c, c, i);\n }\n for (a = 0; a < 16; a++) o[a] = c[a];\n }\n function crypto_scalarmult(q, n, p) {\n var z = new Uint8Array(32);\n var x = new Float64Array(80),\n r,\n i;\n var a = gf(),\n b = gf(),\n c = gf(),\n d = gf(),\n e = gf(),\n f = gf();\n for (i = 0; i < 31; i++) z[i] = n[i];\n z[31] = n[31] & 127 | 64;\n z[0] &= 248;\n unpack25519(x, p);\n for (i = 0; i < 16; i++) {\n b[i] = x[i];\n d[i] = a[i] = c[i] = 0;\n }\n a[0] = d[0] = 1;\n for (i = 254; i >= 0; --i) {\n r = z[i >>> 3] >>> (i & 7) & 1;\n sel25519(a, b, r);\n sel25519(c, d, r);\n A(e, a, c);\n Z(a, a, c);\n A(c, b, d);\n Z(b, b, d);\n S(d, e);\n S(f, a);\n M(a, c, a);\n M(c, b, e);\n A(e, a, c);\n Z(a, a, c);\n S(b, a);\n Z(c, d, f);\n M(a, c, _121665);\n A(a, a, d);\n M(c, c, a);\n M(a, d, f);\n M(d, b, x);\n S(b, e);\n sel25519(a, b, r);\n sel25519(c, d, r);\n }\n for (i = 0; i < 16; i++) {\n x[i + 16] = a[i];\n x[i + 32] = c[i];\n x[i + 48] = b[i];\n x[i + 64] = d[i];\n }\n var x32 = x.subarray(32);\n var x16 = x.subarray(16);\n inv25519(x32, x32);\n M(x16, x16, x32);\n pack25519(q, x16);\n return 0;\n }\n function crypto_scalarmult_base(q, n) {\n return crypto_scalarmult(q, n, _9);\n }\n function crypto_box_keypair(y, x) {\n randombytes(x, 32);\n return crypto_scalarmult_base(y, x);\n }\n function crypto_box_beforenm(k, y, x) {\n var s = new Uint8Array(32);\n crypto_scalarmult(s, x, y);\n return crypto_core_hsalsa20(k, _0, s, sigma);\n }\n var crypto_box_afternm = crypto_secretbox;\n var crypto_box_open_afternm = crypto_secretbox_open;\n function crypto_box(c, m, d, n, y, x) {\n var k = new Uint8Array(32);\n crypto_box_beforenm(k, y, x);\n return crypto_box_afternm(c, m, d, n, k);\n }\n function crypto_box_open(m, c, d, n, y, x) {\n var k = new Uint8Array(32);\n crypto_box_beforenm(k, y, x);\n return crypto_box_open_afternm(m, c, d, n, k);\n }\n var K = [0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd, 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc, 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019, 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118, 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe, 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2, 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1, 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694, 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3, 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65, 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483, 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5, 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210, 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4, 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725, 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70, 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926, 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df, 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8, 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b, 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001, 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30, 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910, 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8, 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53, 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8, 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb, 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3, 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60, 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec, 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9, 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b, 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207, 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178, 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6, 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b, 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493, 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c, 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a, 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817];\n function crypto_hashblocks_hl(hh, hl, m, n) {\n var wh = new Int32Array(16),\n wl = new Int32Array(16),\n bh0,\n bh1,\n bh2,\n bh3,\n bh4,\n bh5,\n bh6,\n bh7,\n bl0,\n bl1,\n bl2,\n bl3,\n bl4,\n bl5,\n bl6,\n bl7,\n th,\n tl,\n i,\n j,\n h,\n l,\n a,\n b,\n c,\n d;\n var ah0 = hh[0],\n ah1 = hh[1],\n ah2 = hh[2],\n ah3 = hh[3],\n ah4 = hh[4],\n ah5 = hh[5],\n ah6 = hh[6],\n ah7 = hh[7],\n al0 = hl[0],\n al1 = hl[1],\n al2 = hl[2],\n al3 = hl[3],\n al4 = hl[4],\n al5 = hl[5],\n al6 = hl[6],\n al7 = hl[7];\n var pos = 0;\n while (n >= 128) {\n for (i = 0; i < 16; i++) {\n j = 8 * i + pos;\n wh[i] = m[j + 0] << 24 | m[j + 1] << 16 | m[j + 2] << 8 | m[j + 3];\n wl[i] = m[j + 4] << 24 | m[j + 5] << 16 | m[j + 6] << 8 | m[j + 7];\n }\n for (i = 0; i < 80; i++) {\n bh0 = ah0;\n bh1 = ah1;\n bh2 = ah2;\n bh3 = ah3;\n bh4 = ah4;\n bh5 = ah5;\n bh6 = ah6;\n bh7 = ah7;\n bl0 = al0;\n bl1 = al1;\n bl2 = al2;\n bl3 = al3;\n bl4 = al4;\n bl5 = al5;\n bl6 = al6;\n bl7 = al7;\n\n // add\n h = ah7;\n l = al7;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n\n // Sigma1\n h = (ah4 >>> 14 | al4 << 32 - 14) ^ (ah4 >>> 18 | al4 << 32 - 18) ^ (al4 >>> 41 - 32 | ah4 << 32 - (41 - 32));\n l = (al4 >>> 14 | ah4 << 32 - 14) ^ (al4 >>> 18 | ah4 << 32 - 18) ^ (ah4 >>> 41 - 32 | al4 << 32 - (41 - 32));\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n\n // Ch\n h = ah4 & ah5 ^ ~ah4 & ah6;\n l = al4 & al5 ^ ~al4 & al6;\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n\n // K\n h = K[i * 2];\n l = K[i * 2 + 1];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n\n // w\n h = wh[i % 16];\n l = wl[i % 16];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n th = c & 0xffff | d << 16;\n tl = a & 0xffff | b << 16;\n\n // add\n h = th;\n l = tl;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n\n // Sigma0\n h = (ah0 >>> 28 | al0 << 32 - 28) ^ (al0 >>> 34 - 32 | ah0 << 32 - (34 - 32)) ^ (al0 >>> 39 - 32 | ah0 << 32 - (39 - 32));\n l = (al0 >>> 28 | ah0 << 32 - 28) ^ (ah0 >>> 34 - 32 | al0 << 32 - (34 - 32)) ^ (ah0 >>> 39 - 32 | al0 << 32 - (39 - 32));\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n\n // Maj\n h = ah0 & ah1 ^ ah0 & ah2 ^ ah1 & ah2;\n l = al0 & al1 ^ al0 & al2 ^ al1 & al2;\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n bh7 = c & 0xffff | d << 16;\n bl7 = a & 0xffff | b << 16;\n\n // add\n h = bh3;\n l = bl3;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = th;\n l = tl;\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n bh3 = c & 0xffff | d << 16;\n bl3 = a & 0xffff | b << 16;\n ah1 = bh0;\n ah2 = bh1;\n ah3 = bh2;\n ah4 = bh3;\n ah5 = bh4;\n ah6 = bh5;\n ah7 = bh6;\n ah0 = bh7;\n al1 = bl0;\n al2 = bl1;\n al3 = bl2;\n al4 = bl3;\n al5 = bl4;\n al6 = bl5;\n al7 = bl6;\n al0 = bl7;\n if (i % 16 === 15) {\n for (j = 0; j < 16; j++) {\n // add\n h = wh[j];\n l = wl[j];\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = wh[(j + 9) % 16];\n l = wl[(j + 9) % 16];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n\n // sigma0\n th = wh[(j + 1) % 16];\n tl = wl[(j + 1) % 16];\n h = (th >>> 1 | tl << 32 - 1) ^ (th >>> 8 | tl << 32 - 8) ^ th >>> 7;\n l = (tl >>> 1 | th << 32 - 1) ^ (tl >>> 8 | th << 32 - 8) ^ (tl >>> 7 | th << 32 - 7);\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n\n // sigma1\n th = wh[(j + 14) % 16];\n tl = wl[(j + 14) % 16];\n h = (th >>> 19 | tl << 32 - 19) ^ (tl >>> 61 - 32 | th << 32 - (61 - 32)) ^ th >>> 6;\n l = (tl >>> 19 | th << 32 - 19) ^ (th >>> 61 - 32 | tl << 32 - (61 - 32)) ^ (tl >>> 6 | th << 32 - 6);\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n wh[j] = c & 0xffff | d << 16;\n wl[j] = a & 0xffff | b << 16;\n }\n }\n }\n\n // add\n h = ah0;\n l = al0;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[0];\n l = hl[0];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[0] = ah0 = c & 0xffff | d << 16;\n hl[0] = al0 = a & 0xffff | b << 16;\n h = ah1;\n l = al1;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[1];\n l = hl[1];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[1] = ah1 = c & 0xffff | d << 16;\n hl[1] = al1 = a & 0xffff | b << 16;\n h = ah2;\n l = al2;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[2];\n l = hl[2];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[2] = ah2 = c & 0xffff | d << 16;\n hl[2] = al2 = a & 0xffff | b << 16;\n h = ah3;\n l = al3;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[3];\n l = hl[3];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[3] = ah3 = c & 0xffff | d << 16;\n hl[3] = al3 = a & 0xffff | b << 16;\n h = ah4;\n l = al4;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[4];\n l = hl[4];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[4] = ah4 = c & 0xffff | d << 16;\n hl[4] = al4 = a & 0xffff | b << 16;\n h = ah5;\n l = al5;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[5];\n l = hl[5];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[5] = ah5 = c & 0xffff | d << 16;\n hl[5] = al5 = a & 0xffff | b << 16;\n h = ah6;\n l = al6;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[6];\n l = hl[6];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[6] = ah6 = c & 0xffff | d << 16;\n hl[6] = al6 = a & 0xffff | b << 16;\n h = ah7;\n l = al7;\n a = l & 0xffff;\n b = l >>> 16;\n c = h & 0xffff;\n d = h >>> 16;\n h = hh[7];\n l = hl[7];\n a += l & 0xffff;\n b += l >>> 16;\n c += h & 0xffff;\n d += h >>> 16;\n b += a >>> 16;\n c += b >>> 16;\n d += c >>> 16;\n hh[7] = ah7 = c & 0xffff | d << 16;\n hl[7] = al7 = a & 0xffff | b << 16;\n pos += 128;\n n -= 128;\n }\n return n;\n }\n function crypto_hash(out, m, n) {\n var hh = new Int32Array(8),\n hl = new Int32Array(8),\n x = new Uint8Array(256),\n i,\n b = n;\n hh[0] = 0x6a09e667;\n hh[1] = 0xbb67ae85;\n hh[2] = 0x3c6ef372;\n hh[3] = 0xa54ff53a;\n hh[4] = 0x510e527f;\n hh[5] = 0x9b05688c;\n hh[6] = 0x1f83d9ab;\n hh[7] = 0x5be0cd19;\n hl[0] = 0xf3bcc908;\n hl[1] = 0x84caa73b;\n hl[2] = 0xfe94f82b;\n hl[3] = 0x5f1d36f1;\n hl[4] = 0xade682d1;\n hl[5] = 0x2b3e6c1f;\n hl[6] = 0xfb41bd6b;\n hl[7] = 0x137e2179;\n crypto_hashblocks_hl(hh, hl, m, n);\n n %= 128;\n for (i = 0; i < n; i++) x[i] = m[b - n + i];\n x[n] = 128;\n n = 256 - 128 * (n < 112 ? 1 : 0);\n x[n - 9] = 0;\n ts64(x, n - 8, b / 0x20000000 | 0, b << 3);\n crypto_hashblocks_hl(hh, hl, x, n);\n for (i = 0; i < 8; i++) ts64(out, 8 * i, hh[i], hl[i]);\n return 0;\n }\n function add(p, q) {\n var a = gf(),\n b = gf(),\n c = gf(),\n d = gf(),\n e = gf(),\n f = gf(),\n g = gf(),\n h = gf(),\n t = gf();\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 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 function cswap(p, q, b) {\n var i;\n for (i = 0; i < 4; i++) {\n sel25519(p[i], q[i], b);\n }\n }\n function pack(r, p) {\n var tx = gf(),\n ty = gf(),\n 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 function 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 function 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 function crypto_sign_keypair(pk, sk, seeded) {\n var d = new Uint8Array(64);\n var p = [gf(), gf(), gf(), gf()];\n var i;\n if (!seeded) randombytes(sk, 32);\n crypto_hash(d, sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n scalarbase(p, d);\n pack(pk, p);\n for (i = 0; i < 32; i++) sk[i + 32] = pk[i];\n return 0;\n }\n var L = new Float64Array([0xed, 0xd3, 0xf5, 0x5c, 0x1a, 0x63, 0x12, 0x58, 0xd6, 0x9c, 0xf7, 0xa2, 0xde, 0xf9, 0xde, 0x14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x10]);\n function 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 = Math.floor((x[j] + 128) / 256);\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++) x[j] -= carry * L[j];\n for (i = 0; i < 32; i++) {\n x[i + 1] += x[i] >> 8;\n r[i] = x[i] & 255;\n }\n }\n function reduce(r) {\n var x = new Float64Array(64),\n i;\n for (i = 0; i < 64; i++) x[i] = r[i];\n for (i = 0; i < 64; i++) r[i] = 0;\n modL(r, x);\n }\n\n // Note: difference from C - smlen returned, not passed as argument.\n function crypto_sign(sm, m, n, sk) {\n var d = new Uint8Array(64),\n h = new Uint8Array(64),\n r = new Uint8Array(64);\n var i,\n j,\n x = new Float64Array(64);\n var p = [gf(), gf(), gf(), gf()];\n crypto_hash(d, sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n var smlen = n + 64;\n for (i = 0; i < n; i++) sm[64 + i] = m[i];\n for (i = 0; i < 32; i++) sm[32 + i] = d[32 + i];\n crypto_hash(r, sm.subarray(32), n + 32);\n reduce(r);\n scalarbase(p, r);\n pack(sm, p);\n for (i = 32; i < 64; i++) sm[i] = sk[i];\n crypto_hash(h, sm, n + 64);\n reduce(h);\n for (i = 0; i < 64; i++) x[i] = 0;\n for (i = 0; i < 32; i++) x[i] = r[i];\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 modL(sm.subarray(32), x);\n return smlen;\n }\n function unpackneg(r, p) {\n var t = gf(),\n chk = gf(),\n num = gf(),\n den = gf(),\n den2 = gf(),\n den4 = gf(),\n den6 = gf();\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 S(den2, den);\n S(den4, den2);\n M(den6, den4, den2);\n M(t, den6, num);\n M(t, t, den);\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 S(chk, r[0]);\n M(chk, chk, den);\n if (neq25519(chk, num)) M(r[0], r[0], I);\n S(chk, r[0]);\n M(chk, chk, den);\n if (neq25519(chk, num)) return -1;\n if (par25519(r[0]) === p[31] >> 7) Z(r[0], gf0, r[0]);\n M(r[3], r[0], r[1]);\n return 0;\n }\n function crypto_sign_open(m, sm, n, pk) {\n var i;\n var t = new Uint8Array(32),\n h = new Uint8Array(64);\n var p = [gf(), gf(), gf(), gf()],\n q = [gf(), gf(), gf(), gf()];\n if (n < 64) return -1;\n if (unpackneg(q, pk)) return -1;\n for (i = 0; i < n; i++) m[i] = sm[i];\n for (i = 0; i < 32; i++) m[i + 32] = pk[i];\n crypto_hash(h, m, n);\n reduce(h);\n scalarmult(p, q, h);\n scalarbase(q, sm.subarray(32));\n add(p, q);\n pack(t, p);\n n -= 64;\n if (crypto_verify_32(sm, 0, t, 0)) {\n for (i = 0; i < n; i++) m[i] = 0;\n return -1;\n }\n for (i = 0; i < n; i++) m[i] = sm[i + 64];\n return n;\n }\n var crypto_secretbox_KEYBYTES = 32,\n crypto_secretbox_NONCEBYTES = 24,\n crypto_secretbox_ZEROBYTES = 32,\n crypto_secretbox_BOXZEROBYTES = 16,\n crypto_scalarmult_BYTES = 32,\n crypto_scalarmult_SCALARBYTES = 32,\n crypto_box_PUBLICKEYBYTES = 32,\n crypto_box_SECRETKEYBYTES = 32,\n crypto_box_BEFORENMBYTES = 32,\n crypto_box_NONCEBYTES = crypto_secretbox_NONCEBYTES,\n crypto_box_ZEROBYTES = crypto_secretbox_ZEROBYTES,\n crypto_box_BOXZEROBYTES = crypto_secretbox_BOXZEROBYTES,\n crypto_sign_BYTES = 64,\n crypto_sign_PUBLICKEYBYTES = 32,\n crypto_sign_SECRETKEYBYTES = 64,\n crypto_sign_SEEDBYTES = 32,\n crypto_hash_BYTES = 64;\n nacl.lowlevel = {\n crypto_core_hsalsa20: crypto_core_hsalsa20,\n crypto_stream_xor: crypto_stream_xor,\n crypto_stream: crypto_stream,\n crypto_stream_salsa20_xor: crypto_stream_salsa20_xor,\n crypto_stream_salsa20: crypto_stream_salsa20,\n crypto_onetimeauth: crypto_onetimeauth,\n crypto_onetimeauth_verify: crypto_onetimeauth_verify,\n crypto_verify_16: crypto_verify_16,\n crypto_verify_32: crypto_verify_32,\n crypto_secretbox: crypto_secretbox,\n crypto_secretbox_open: crypto_secretbox_open,\n crypto_scalarmult: crypto_scalarmult,\n crypto_scalarmult_base: crypto_scalarmult_base,\n crypto_box_beforenm: crypto_box_beforenm,\n crypto_box_afternm: crypto_box_afternm,\n crypto_box: crypto_box,\n crypto_box_open: crypto_box_open,\n crypto_box_keypair: crypto_box_keypair,\n crypto_hash: crypto_hash,\n crypto_sign: crypto_sign,\n crypto_sign_keypair: crypto_sign_keypair,\n crypto_sign_open: crypto_sign_open,\n crypto_secretbox_KEYBYTES: crypto_secretbox_KEYBYTES,\n crypto_secretbox_NONCEBYTES: crypto_secretbox_NONCEBYTES,\n crypto_secretbox_ZEROBYTES: crypto_secretbox_ZEROBYTES,\n crypto_secretbox_BOXZEROBYTES: crypto_secretbox_BOXZEROBYTES,\n crypto_scalarmult_BYTES: crypto_scalarmult_BYTES,\n crypto_scalarmult_SCALARBYTES: crypto_scalarmult_SCALARBYTES,\n crypto_box_PUBLICKEYBYTES: crypto_box_PUBLICKEYBYTES,\n crypto_box_SECRETKEYBYTES: crypto_box_SECRETKEYBYTES,\n crypto_box_BEFORENMBYTES: crypto_box_BEFORENMBYTES,\n crypto_box_NONCEBYTES: crypto_box_NONCEBYTES,\n crypto_box_ZEROBYTES: crypto_box_ZEROBYTES,\n crypto_box_BOXZEROBYTES: crypto_box_BOXZEROBYTES,\n crypto_sign_BYTES: crypto_sign_BYTES,\n crypto_sign_PUBLICKEYBYTES: crypto_sign_PUBLICKEYBYTES,\n crypto_sign_SECRETKEYBYTES: crypto_sign_SECRETKEYBYTES,\n crypto_sign_SEEDBYTES: crypto_sign_SEEDBYTES,\n crypto_hash_BYTES: crypto_hash_BYTES,\n gf: gf,\n D: D,\n L: L,\n pack25519: pack25519,\n unpack25519: unpack25519,\n M: M,\n A: A,\n S: S,\n Z: Z,\n pow2523: pow2523,\n add: add,\n set25519: set25519,\n modL: modL,\n scalarmult: scalarmult,\n scalarbase: scalarbase\n };\n\n /* High-level API */\n\n function checkLengths(k, n) {\n if (k.length !== crypto_secretbox_KEYBYTES) throw new Error('bad key size');\n if (n.length !== crypto_secretbox_NONCEBYTES) throw new Error('bad nonce size');\n }\n function checkBoxLengths(pk, sk) {\n if (pk.length !== crypto_box_PUBLICKEYBYTES) throw new Error('bad public key size');\n if (sk.length !== crypto_box_SECRETKEYBYTES) throw new Error('bad secret key size');\n }\n function checkArrayTypes() {\n for (var i = 0; i < arguments.length; i++) {\n if (!(arguments[i] instanceof Uint8Array)) throw new TypeError('unexpected type, use Uint8Array');\n }\n }\n function cleanup(arr) {\n for (var i = 0; i < arr.length; i++) arr[i] = 0;\n }\n nacl.randomBytes = function (n) {\n var b = new Uint8Array(n);\n randombytes(b, n);\n return b;\n };\n nacl.secretbox = function (msg, nonce, key) {\n checkArrayTypes(msg, nonce, key);\n checkLengths(key, nonce);\n var m = new Uint8Array(crypto_secretbox_ZEROBYTES + msg.length);\n var c = new Uint8Array(m.length);\n for (var i = 0; i < msg.length; i++) m[i + crypto_secretbox_ZEROBYTES] = msg[i];\n crypto_secretbox(c, m, m.length, nonce, key);\n return c.subarray(crypto_secretbox_BOXZEROBYTES);\n };\n nacl.secretbox.open = function (box, nonce, key) {\n checkArrayTypes(box, nonce, key);\n checkLengths(key, nonce);\n var c = new Uint8Array(crypto_secretbox_BOXZEROBYTES + box.length);\n var m = new Uint8Array(c.length);\n for (var i = 0; i < box.length; i++) c[i + crypto_secretbox_BOXZEROBYTES] = box[i];\n if (c.length < 32) return null;\n if (crypto_secretbox_open(m, c, c.length, nonce, key) !== 0) return null;\n return m.subarray(crypto_secretbox_ZEROBYTES);\n };\n nacl.secretbox.keyLength = crypto_secretbox_KEYBYTES;\n nacl.secretbox.nonceLength = crypto_secretbox_NONCEBYTES;\n nacl.secretbox.overheadLength = crypto_secretbox_BOXZEROBYTES;\n nacl.scalarMult = function (n, p) {\n checkArrayTypes(n, p);\n if (n.length !== crypto_scalarmult_SCALARBYTES) throw new Error('bad n size');\n if (p.length !== crypto_scalarmult_BYTES) throw new Error('bad p size');\n var q = new Uint8Array(crypto_scalarmult_BYTES);\n crypto_scalarmult(q, n, p);\n return q;\n };\n nacl.scalarMult.base = function (n) {\n checkArrayTypes(n);\n if (n.length !== crypto_scalarmult_SCALARBYTES) throw new Error('bad n size');\n var q = new Uint8Array(crypto_scalarmult_BYTES);\n crypto_scalarmult_base(q, n);\n return q;\n };\n nacl.scalarMult.scalarLength = crypto_scalarmult_SCALARBYTES;\n nacl.scalarMult.groupElementLength = crypto_scalarmult_BYTES;\n nacl.box = function (msg, nonce, publicKey, secretKey) {\n var k = nacl.box.before(publicKey, secretKey);\n return nacl.secretbox(msg, nonce, k);\n };\n nacl.box.before = function (publicKey, secretKey) {\n checkArrayTypes(publicKey, secretKey);\n checkBoxLengths(publicKey, secretKey);\n var k = new Uint8Array(crypto_box_BEFORENMBYTES);\n crypto_box_beforenm(k, publicKey, secretKey);\n return k;\n };\n nacl.box.after = nacl.secretbox;\n nacl.box.open = function (msg, nonce, publicKey, secretKey) {\n var k = nacl.box.before(publicKey, secretKey);\n return nacl.secretbox.open(msg, nonce, k);\n };\n nacl.box.open.after = nacl.secretbox.open;\n nacl.box.keyPair = function () {\n var pk = new Uint8Array(crypto_box_PUBLICKEYBYTES);\n var sk = new Uint8Array(crypto_box_SECRETKEYBYTES);\n crypto_box_keypair(pk, sk);\n return {\n publicKey: pk,\n secretKey: sk\n };\n };\n nacl.box.keyPair.fromSecretKey = function (secretKey) {\n checkArrayTypes(secretKey);\n if (secretKey.length !== crypto_box_SECRETKEYBYTES) throw new Error('bad secret key size');\n var pk = new Uint8Array(crypto_box_PUBLICKEYBYTES);\n crypto_scalarmult_base(pk, secretKey);\n return {\n publicKey: pk,\n secretKey: new Uint8Array(secretKey)\n };\n };\n nacl.box.publicKeyLength = crypto_box_PUBLICKEYBYTES;\n nacl.box.secretKeyLength = crypto_box_SECRETKEYBYTES;\n nacl.box.sharedKeyLength = crypto_box_BEFORENMBYTES;\n nacl.box.nonceLength = crypto_box_NONCEBYTES;\n nacl.box.overheadLength = nacl.secretbox.overheadLength;\n nacl.sign = function (msg, secretKey) {\n checkArrayTypes(msg, secretKey);\n if (secretKey.length !== crypto_sign_SECRETKEYBYTES) throw new Error('bad secret key size');\n var signedMsg = new Uint8Array(crypto_sign_BYTES + msg.length);\n crypto_sign(signedMsg, msg, msg.length, secretKey);\n return signedMsg;\n };\n nacl.sign.open = function (signedMsg, publicKey) {\n checkArrayTypes(signedMsg, publicKey);\n if (publicKey.length !== crypto_sign_PUBLICKEYBYTES) throw new Error('bad public key size');\n var tmp = new Uint8Array(signedMsg.length);\n var mlen = crypto_sign_open(tmp, signedMsg, signedMsg.length, publicKey);\n if (mlen < 0) return null;\n var m = new Uint8Array(mlen);\n for (var i = 0; i < m.length; i++) m[i] = tmp[i];\n return m;\n };\n nacl.sign.detached = function (msg, secretKey) {\n var signedMsg = nacl.sign(msg, secretKey);\n var sig = new Uint8Array(crypto_sign_BYTES);\n for (var i = 0; i < sig.length; i++) sig[i] = signedMsg[i];\n return sig;\n };\n nacl.sign.detached.verify = function (msg, sig, publicKey) {\n checkArrayTypes(msg, sig, publicKey);\n if (sig.length !== crypto_sign_BYTES) throw new Error('bad signature size');\n if (publicKey.length !== crypto_sign_PUBLICKEYBYTES) throw new Error('bad public key size');\n var sm = new Uint8Array(crypto_sign_BYTES + msg.length);\n var m = new Uint8Array(crypto_sign_BYTES + msg.length);\n var i;\n for (i = 0; i < crypto_sign_BYTES; i++) sm[i] = sig[i];\n for (i = 0; i < msg.length; i++) sm[i + crypto_sign_BYTES] = msg[i];\n return crypto_sign_open(m, sm, sm.length, publicKey) >= 0;\n };\n nacl.sign.keyPair = function () {\n var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES);\n var sk = new Uint8Array(crypto_sign_SECRETKEYBYTES);\n crypto_sign_keypair(pk, sk);\n return {\n publicKey: pk,\n secretKey: sk\n };\n };\n nacl.sign.keyPair.fromSecretKey = function (secretKey) {\n checkArrayTypes(secretKey);\n if (secretKey.length !== crypto_sign_SECRETKEYBYTES) throw new Error('bad secret key size');\n var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES);\n for (var i = 0; i < pk.length; i++) pk[i] = secretKey[32 + i];\n return {\n publicKey: pk,\n secretKey: new Uint8Array(secretKey)\n };\n };\n nacl.sign.keyPair.fromSeed = function (seed) {\n checkArrayTypes(seed);\n if (seed.length !== crypto_sign_SEEDBYTES) throw new Error('bad seed size');\n var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES);\n var sk = new Uint8Array(crypto_sign_SECRETKEYBYTES);\n for (var i = 0; i < 32; i++) sk[i] = seed[i];\n crypto_sign_keypair(pk, sk, true);\n return {\n publicKey: pk,\n secretKey: sk\n };\n };\n nacl.sign.publicKeyLength = crypto_sign_PUBLICKEYBYTES;\n nacl.sign.secretKeyLength = crypto_sign_SECRETKEYBYTES;\n nacl.sign.seedLength = crypto_sign_SEEDBYTES;\n nacl.sign.signatureLength = crypto_sign_BYTES;\n nacl.hash = function (msg) {\n checkArrayTypes(msg);\n var h = new Uint8Array(crypto_hash_BYTES);\n crypto_hash(h, msg, msg.length);\n return h;\n };\n nacl.hash.hashLength = crypto_hash_BYTES;\n nacl.verify = function (x, y) {\n checkArrayTypes(x, y);\n // Zero length arguments are considered not equal.\n if (x.length === 0 || y.length === 0) return false;\n if (x.length !== y.length) return false;\n return vn(x, 0, y, 0, x.length) === 0 ? true : false;\n };\n nacl.setPRNG = function (fn) {\n randombytes = fn;\n };\n (function () {\n // Initialize PRNG if environment provides CSPRNG.\n // If not, methods calling randombytes will throw.\n var crypto = typeof self !== 'undefined' ? self.crypto || self.msCrypto : null;\n if (crypto && crypto.getRandomValues) {\n // Browsers.\n var QUOTA = 65536;\n nacl.setPRNG(function (x, n) {\n var i,\n v = new Uint8Array(n);\n for (i = 0; i < n; i += QUOTA) {\n crypto.getRandomValues(v.subarray(i, i + Math.min(n - i, QUOTA)));\n }\n for (i = 0; i < n; i++) x[i] = v[i];\n cleanup(v);\n });\n } else if (typeof require !== 'undefined') {\n // Node.js.\n crypto = require('crypto');\n if (crypto && crypto.randomBytes) {\n nacl.setPRNG(function (x, n) {\n var i,\n v = crypto.randomBytes(n);\n for (i = 0; i < n; i++) x[i] = v[i];\n cleanup(v);\n });\n }\n }\n })();\n})(typeof module !== 'undefined' && module.exports ? module.exports : self.nacl = self.nacl || {});","// Written in 2014-2016 by Dmitry Chestnykh and Devi Mandiri.\n// Public domain.\n(function (root, f) {\n 'use strict';\n\n if (typeof module !== 'undefined' && module.exports) module.exports = f();else if (root.nacl) root.nacl.util = f();else {\n root.nacl = {};\n root.nacl.util = f();\n }\n})(this, function () {\n 'use strict';\n\n var util = {};\n function validateBase64(s) {\n if (!/^(?:[A-Za-z0-9+\\/]{2}[A-Za-z0-9+\\/]{2})*(?:[A-Za-z0-9+\\/]{2}==|[A-Za-z0-9+\\/]{3}=)?$/.test(s)) {\n throw new TypeError('invalid encoding');\n }\n }\n util.decodeUTF8 = function (s) {\n if (typeof s !== 'string') throw new TypeError('expected string');\n var i,\n d = unescape(encodeURIComponent(s)),\n b = new Uint8Array(d.length);\n for (i = 0; i < d.length; i++) b[i] = d.charCodeAt(i);\n return b;\n };\n util.encodeUTF8 = function (arr) {\n var i,\n s = [];\n for (i = 0; i < arr.length; i++) s.push(String.fromCharCode(arr[i]));\n return decodeURIComponent(escape(s.join('')));\n };\n if (typeof atob === 'undefined') {\n // Node.js\n\n if (typeof Buffer.from !== 'undefined') {\n // Node v6 and later\n util.encodeBase64 = function (arr) {\n // v6 and later\n return Buffer.from(arr).toString('base64');\n };\n util.decodeBase64 = function (s) {\n validateBase64(s);\n return new Uint8Array(Array.prototype.slice.call(Buffer.from(s, 'base64'), 0));\n };\n } else {\n // Node earlier than v6\n util.encodeBase64 = function (arr) {\n // v6 and later\n return new Buffer(arr).toString('base64');\n };\n util.decodeBase64 = function (s) {\n validateBase64(s);\n return new Uint8Array(Array.prototype.slice.call(new Buffer(s, 'base64'), 0));\n };\n }\n } else {\n // Browsers\n\n util.encodeBase64 = function (arr) {\n var i,\n s = [],\n len = arr.length;\n for (i = 0; i < len; i++) s.push(String.fromCharCode(arr[i]));\n return btoa(s.join(''));\n };\n util.decodeBase64 = function (s) {\n validateBase64(s);\n var i,\n d = atob(s),\n b = new Uint8Array(d.length);\n for (i = 0; i < d.length; i++) b[i] = d.charCodeAt(i);\n return b;\n };\n }\n return util;\n});","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\n} : function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\nvar __setModuleDefault = this && this.__setModuleDefault || (Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getEncryptionPublicKey = exports.decryptSafely = exports.decrypt = exports.encryptSafely = exports.encrypt = void 0;\nconst nacl = __importStar(require(\"tweetnacl\"));\nconst naclUtil = __importStar(require(\"tweetnacl-util\"));\nconst utils_1 = require(\"./utils\");\n/**\n * Encrypt a message.\n *\n * @param options - The encryption options.\n * @param options.publicKey - The public key of the message recipient.\n * @param options.data - The message data.\n * @param options.version - The type of encryption to use.\n * @returns The encrypted data.\n */\nfunction encrypt({\n publicKey,\n data,\n version\n}) {\n if (utils_1.isNullish(publicKey)) {\n throw new Error('Missing publicKey parameter');\n } else if (utils_1.isNullish(data)) {\n throw new Error('Missing data parameter');\n } else if (utils_1.isNullish(version)) {\n throw new Error('Missing version parameter');\n }\n switch (version) {\n case 'x25519-xsalsa20-poly1305':\n {\n if (typeof data !== 'string') {\n throw new Error('Message data must be given as a string');\n }\n // generate ephemeral keypair\n const ephemeralKeyPair = nacl.box.keyPair();\n // assemble encryption parameters - from string to UInt8\n let pubKeyUInt8Array;\n try {\n pubKeyUInt8Array = naclUtil.decodeBase64(publicKey);\n } catch (err) {\n throw new Error('Bad public key');\n }\n const msgParamsUInt8Array = naclUtil.decodeUTF8(data);\n const nonce = nacl.randomBytes(nacl.box.nonceLength);\n // encrypt\n const encryptedMessage = nacl.box(msgParamsUInt8Array, nonce, pubKeyUInt8Array, ephemeralKeyPair.secretKey);\n // handle encrypted data\n const output = {\n version: 'x25519-xsalsa20-poly1305',\n nonce: naclUtil.encodeBase64(nonce),\n ephemPublicKey: naclUtil.encodeBase64(ephemeralKeyPair.publicKey),\n ciphertext: naclUtil.encodeBase64(encryptedMessage)\n };\n // return encrypted msg data\n return output;\n }\n default:\n throw new Error('Encryption type/version not supported');\n }\n}\nexports.encrypt = encrypt;\n/**\n * Encrypt a message in a way that obscures the message length.\n *\n * The message is padded to a multiple of 2048 before being encrypted so that the length of the\n * resulting encrypted message can't be used to guess the exact length of the original message.\n *\n * @param options - The encryption options.\n * @param options.publicKey - The public key of the message recipient.\n * @param options.data - The message data.\n * @param options.version - The type of encryption to use.\n * @returns The encrypted data.\n */\nfunction encryptSafely({\n publicKey,\n data,\n version\n}) {\n if (utils_1.isNullish(publicKey)) {\n throw new Error('Missing publicKey parameter');\n } else if (utils_1.isNullish(data)) {\n throw new Error('Missing data parameter');\n } else if (utils_1.isNullish(version)) {\n throw new Error('Missing version parameter');\n }\n const DEFAULT_PADDING_LENGTH = 2 ** 11;\n const NACL_EXTRA_BYTES = 16;\n if (typeof data === 'object' && 'toJSON' in data) {\n // remove toJSON attack vector\n // TODO, check all possible children\n throw new Error('Cannot encrypt with toJSON property. Please remove toJSON property');\n }\n // add padding\n const dataWithPadding = {\n data,\n padding: ''\n };\n // calculate padding\n const dataLength = Buffer.byteLength(JSON.stringify(dataWithPadding), 'utf-8');\n const modVal = dataLength % DEFAULT_PADDING_LENGTH;\n let padLength = 0;\n // Only pad if necessary\n if (modVal > 0) {\n padLength = DEFAULT_PADDING_LENGTH - modVal - NACL_EXTRA_BYTES; // nacl extra bytes\n }\n dataWithPadding.padding = '0'.repeat(padLength);\n const paddedMessage = JSON.stringify(dataWithPadding);\n return encrypt({\n publicKey,\n data: paddedMessage,\n version\n });\n}\nexports.encryptSafely = encryptSafely;\n/**\n * Decrypt a message.\n *\n * @param options - The decryption options.\n * @param options.encryptedData - The encrypted data.\n * @param options.privateKey - The private key to decrypt with.\n * @returns The decrypted message.\n */\nfunction decrypt({\n encryptedData,\n privateKey\n}) {\n if (utils_1.isNullish(encryptedData)) {\n throw new Error('Missing encryptedData parameter');\n } else if (utils_1.isNullish(privateKey)) {\n throw new Error('Missing privateKey parameter');\n }\n switch (encryptedData.version) {\n case 'x25519-xsalsa20-poly1305':\n {\n // string to buffer to UInt8Array\n const recieverPrivateKeyUint8Array = nacl_decodeHex(privateKey);\n const recieverEncryptionPrivateKey = nacl.box.keyPair.fromSecretKey(recieverPrivateKeyUint8Array).secretKey;\n // assemble decryption parameters\n const nonce = naclUtil.decodeBase64(encryptedData.nonce);\n const ciphertext = naclUtil.decodeBase64(encryptedData.ciphertext);\n const ephemPublicKey = naclUtil.decodeBase64(encryptedData.ephemPublicKey);\n // decrypt\n const decryptedMessage = nacl.box.open(ciphertext, nonce, ephemPublicKey, recieverEncryptionPrivateKey);\n // return decrypted msg data\n let output;\n try {\n output = naclUtil.encodeUTF8(decryptedMessage);\n } catch (err) {\n throw new Error('Decryption failed.');\n }\n if (output) {\n return output;\n }\n throw new Error('Decryption failed.');\n }\n default:\n throw new Error('Encryption type/version not supported.');\n }\n}\nexports.decrypt = decrypt;\n/**\n * Decrypt a message that has been encrypted using `encryptSafely`.\n *\n * @param options - The decryption options.\n * @param options.encryptedData - The encrypted data.\n * @param options.privateKey - The private key to decrypt with.\n * @returns The decrypted message.\n */\nfunction decryptSafely({\n encryptedData,\n privateKey\n}) {\n if (utils_1.isNullish(encryptedData)) {\n throw new Error('Missing encryptedData parameter');\n } else if (utils_1.isNullish(privateKey)) {\n throw new Error('Missing privateKey parameter');\n }\n const dataWithPadding = JSON.parse(decrypt({\n encryptedData,\n privateKey\n }));\n return dataWithPadding.data;\n}\nexports.decryptSafely = decryptSafely;\n/**\n * Get the encryption public key for the given key.\n *\n * @param privateKey - The private key to generate the encryption public key with.\n * @returns The encryption public key.\n */\nfunction getEncryptionPublicKey(privateKey) {\n const privateKeyUint8Array = nacl_decodeHex(privateKey);\n const encryptionPublicKey = nacl.box.keyPair.fromSecretKey(privateKeyUint8Array).publicKey;\n return naclUtil.encodeBase64(encryptionPublicKey);\n}\nexports.getEncryptionPublicKey = getEncryptionPublicKey;\n/**\n * Convert a hex string to the UInt8Array format used by nacl.\n *\n * @param msgHex - The string to convert.\n * @returns The converted string.\n */\nfunction nacl_decodeHex(msgHex) {\n const msgBase64 = Buffer.from(msgHex, 'hex').toString('base64');\n return naclUtil.decodeBase64(msgBase64);\n}\n","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\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\", {\n value: true\n});\nexports.normalize = exports.concatSig = void 0;\n__exportStar(require(\"./personal-sign\"), exports);\n__exportStar(require(\"./sign-typed-data\"), exports);\n__exportStar(require(\"./encryption\"), exports);\nvar utils_1 = require(\"./utils\");\nObject.defineProperty(exports, \"concatSig\", {\n enumerable: true,\n get: function () {\n return utils_1.concatSig;\n }\n});\nObject.defineProperty(exports, \"normalize\", {\n enumerable: true,\n get: function () {\n return utils_1.normalize;\n }\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.GsnRequestType = exports.TypedRequestData = exports.getDomainSeparatorHash = exports.getDomainSeparator = exports.GsnDomainSeparatorType = exports.EIP712DomainTypeWithoutVersion = exports.EIP712DomainType = void 0;\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst eth_sig_util_1 = require(\"@metamask/eth-sig-util\");\nexports.EIP712DomainType = [{\n name: 'name',\n type: 'string'\n}, {\n name: 'version',\n type: 'string'\n}, {\n name: 'chainId',\n type: 'uint256'\n}, {\n name: 'verifyingContract',\n type: 'address'\n}];\nexports.EIP712DomainTypeWithoutVersion = [{\n name: 'name',\n type: 'string'\n}, {\n name: 'chainId',\n type: 'uint256'\n}, {\n name: 'verifyingContract',\n type: 'address'\n}];\nconst RelayDataType = [{\n name: 'maxFeePerGas',\n type: 'uint256'\n}, {\n name: 'maxPriorityFeePerGas',\n type: 'uint256'\n}, {\n name: 'transactionCalldataGasUsed',\n type: 'uint256'\n}, {\n name: 'relayWorker',\n type: 'address'\n}, {\n name: 'paymaster',\n type: 'address'\n}, {\n name: 'forwarder',\n type: 'address'\n}, {\n name: 'paymasterData',\n type: 'bytes'\n}, {\n name: 'clientId',\n type: 'uint256'\n}];\nconst ForwardRequestType = [{\n name: 'from',\n type: 'address'\n}, {\n name: 'to',\n type: 'address'\n}, {\n name: 'value',\n type: 'uint256'\n}, {\n name: 'gas',\n type: 'uint256'\n}, {\n name: 'nonce',\n type: 'uint256'\n}, {\n name: 'data',\n type: 'bytes'\n}, {\n name: 'validUntilTime',\n type: 'uint256'\n}];\nconst RelayRequestType = [...ForwardRequestType, {\n name: 'relayData',\n type: 'RelayData'\n}];\n// use these values in registerDomainSeparator\nexports.GsnDomainSeparatorType = {\n prefix: 'string name,string version',\n version: '3'\n};\nfunction getDomainSeparator(name, verifier, chainId) {\n return {\n name,\n version: exports.GsnDomainSeparatorType.version,\n chainId: chainId,\n verifyingContract: verifier\n };\n}\nexports.getDomainSeparator = getDomainSeparator;\nfunction getDomainSeparatorHash(name, verifier, chainId) {\n return (0, ethereumjs_util_1.bufferToHex)(eth_sig_util_1.TypedDataUtils.hashStruct('EIP712Domain', getDomainSeparator(name, verifier, chainId), {\n EIP712Domain: exports.EIP712DomainType\n }, eth_sig_util_1.SignTypedDataVersion.V4));\n}\nexports.getDomainSeparatorHash = getDomainSeparatorHash;\nclass TypedRequestData {\n constructor(name, chainId, verifier, relayRequest) {\n this.types = {\n EIP712Domain: exports.EIP712DomainType,\n RelayRequest: RelayRequestType,\n RelayData: RelayDataType\n };\n this.domain = getDomainSeparator(name, verifier, chainId);\n this.primaryType = 'RelayRequest';\n // in the signature, all \"request\" fields are flattened out at the top structure.\n // other params are inside \"relayData\" sub-type\n this.message = Object.assign(Object.assign({}, relayRequest.request), {\n relayData: relayRequest.relayData\n });\n }\n}\nexports.TypedRequestData = TypedRequestData;\nexports.GsnRequestType = {\n typeName: 'RelayRequest',\n typeSuffix: 'RelayData relayData)RelayData(uint256 maxFeePerGas,uint256 maxPriorityFeePerGas,uint256 transactionCalldataGasUsed,address relayWorker,address paymaster,address forwarder,bytes paymasterData,uint256 clientId)'\n};\n","'use strict';\n\nconst callsites = () => {\n const _prepareStackTrace = Error.prepareStackTrace;\n Error.prepareStackTrace = (_, stack) => stack;\n const stack = new Error().stack.slice(1);\n Error.prepareStackTrace = _prepareStackTrace;\n return stack;\n};\nmodule.exports = callsites;\n// TODO: Remove this for the next major release\nmodule.exports.default = callsites;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.inferLabel = void 0;\nconst inferLabel = () => {};\nexports.inferLabel = inferLabel;","\"use strict\";\n\n/// \n/// \n/// \nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst typedArrayTypeNames = ['Int8Array', 'Uint8Array', 'Uint8ClampedArray', 'Int16Array', 'Uint16Array', 'Int32Array', 'Uint32Array', 'Float32Array', 'Float64Array', 'BigInt64Array', 'BigUint64Array'];\nfunction isTypedArrayName(name) {\n return typedArrayTypeNames.includes(name);\n}\nconst objectTypeNames = ['Function', 'Generator', 'AsyncGenerator', 'GeneratorFunction', 'AsyncGeneratorFunction', 'AsyncFunction', 'Observable', 'Array', 'Buffer', 'Blob', 'Object', 'RegExp', 'Date', 'Error', 'Map', 'Set', 'WeakMap', 'WeakSet', 'ArrayBuffer', 'SharedArrayBuffer', 'DataView', 'Promise', 'URL', 'FormData', 'URLSearchParams', 'HTMLElement', ...typedArrayTypeNames];\nfunction isObjectTypeName(name) {\n return objectTypeNames.includes(name);\n}\nconst primitiveTypeNames = ['null', 'undefined', 'string', 'number', 'bigint', 'boolean', 'symbol'];\nfunction isPrimitiveTypeName(name) {\n return primitiveTypeNames.includes(name);\n}\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction isOfType(type) {\n return value => typeof value === type;\n}\nconst {\n toString\n} = Object.prototype;\nconst getObjectType = value => {\n const objectTypeName = toString.call(value).slice(8, -1);\n if (/HTML\\w+Element/.test(objectTypeName) && is.domElement(value)) {\n return 'HTMLElement';\n }\n if (isObjectTypeName(objectTypeName)) {\n return objectTypeName;\n }\n return undefined;\n};\nconst isObjectOfType = type => value => getObjectType(value) === type;\nfunction is(value) {\n if (value === null) {\n return 'null';\n }\n switch (typeof value) {\n case 'undefined':\n return 'undefined';\n case 'string':\n return 'string';\n case 'number':\n return 'number';\n case 'boolean':\n return 'boolean';\n case 'function':\n return 'Function';\n case 'bigint':\n return 'bigint';\n case 'symbol':\n return 'symbol';\n default:\n }\n if (is.observable(value)) {\n return 'Observable';\n }\n if (is.array(value)) {\n return 'Array';\n }\n if (is.buffer(value)) {\n return 'Buffer';\n }\n const tagType = getObjectType(value);\n if (tagType) {\n return tagType;\n }\n if (value instanceof String || value instanceof Boolean || value instanceof Number) {\n throw new TypeError('Please don\\'t use object wrappers for primitive types');\n }\n return 'Object';\n}\nis.undefined = isOfType('undefined');\nis.string = isOfType('string');\nconst isNumberType = isOfType('number');\nis.number = value => isNumberType(value) && !is.nan(value);\nis.bigint = isOfType('bigint');\n// eslint-disable-next-line @typescript-eslint/ban-types\nis.function_ = isOfType('function');\nis.null_ = value => value === null;\nis.class_ = value => is.function_(value) && value.toString().startsWith('class ');\nis.boolean = value => value === true || value === false;\nis.symbol = isOfType('symbol');\nis.numericString = value => is.string(value) && !is.emptyStringOrWhitespace(value) && !Number.isNaN(Number(value));\nis.array = (value, assertion) => {\n if (!Array.isArray(value)) {\n return false;\n }\n if (!is.function_(assertion)) {\n return true;\n }\n return value.every(assertion);\n};\nis.buffer = value => {\n var _a, _b, _c, _d;\n return (_d = (_c = (_b = (_a = value) === null || _a === void 0 ? void 0 : _a.constructor) === null || _b === void 0 ? void 0 : _b.isBuffer) === null || _c === void 0 ? void 0 : _c.call(_b, value)) !== null && _d !== void 0 ? _d : false;\n};\nis.blob = value => isObjectOfType('Blob')(value);\nis.nullOrUndefined = value => is.null_(value) || is.undefined(value);\nis.object = value => !is.null_(value) && (typeof value === 'object' || is.function_(value));\nis.iterable = value => {\n var _a;\n return is.function_((_a = value) === null || _a === void 0 ? void 0 : _a[Symbol.iterator]);\n};\nis.asyncIterable = value => {\n var _a;\n return is.function_((_a = value) === null || _a === void 0 ? void 0 : _a[Symbol.asyncIterator]);\n};\nis.generator = value => {\n var _a, _b;\n return is.iterable(value) && is.function_((_a = value) === null || _a === void 0 ? void 0 : _a.next) && is.function_((_b = value) === null || _b === void 0 ? void 0 : _b.throw);\n};\nis.asyncGenerator = value => is.asyncIterable(value) && is.function_(value.next) && is.function_(value.throw);\nis.nativePromise = value => isObjectOfType('Promise')(value);\nconst hasPromiseAPI = value => {\n var _a, _b;\n return is.function_((_a = value) === null || _a === void 0 ? void 0 : _a.then) && is.function_((_b = value) === null || _b === void 0 ? void 0 : _b.catch);\n};\nis.promise = value => is.nativePromise(value) || hasPromiseAPI(value);\nis.generatorFunction = isObjectOfType('GeneratorFunction');\nis.asyncGeneratorFunction = value => getObjectType(value) === 'AsyncGeneratorFunction';\nis.asyncFunction = value => getObjectType(value) === 'AsyncFunction';\n// eslint-disable-next-line no-prototype-builtins, @typescript-eslint/ban-types\nis.boundFunction = value => is.function_(value) && !value.hasOwnProperty('prototype');\nis.regExp = isObjectOfType('RegExp');\nis.date = isObjectOfType('Date');\nis.error = isObjectOfType('Error');\nis.map = value => isObjectOfType('Map')(value);\nis.set = value => isObjectOfType('Set')(value);\nis.weakMap = value => isObjectOfType('WeakMap')(value);\nis.weakSet = value => isObjectOfType('WeakSet')(value);\nis.int8Array = isObjectOfType('Int8Array');\nis.uint8Array = isObjectOfType('Uint8Array');\nis.uint8ClampedArray = isObjectOfType('Uint8ClampedArray');\nis.int16Array = isObjectOfType('Int16Array');\nis.uint16Array = isObjectOfType('Uint16Array');\nis.int32Array = isObjectOfType('Int32Array');\nis.uint32Array = isObjectOfType('Uint32Array');\nis.float32Array = isObjectOfType('Float32Array');\nis.float64Array = isObjectOfType('Float64Array');\nis.bigInt64Array = isObjectOfType('BigInt64Array');\nis.bigUint64Array = isObjectOfType('BigUint64Array');\nis.arrayBuffer = isObjectOfType('ArrayBuffer');\nis.sharedArrayBuffer = isObjectOfType('SharedArrayBuffer');\nis.dataView = isObjectOfType('DataView');\nis.enumCase = (value, targetEnum) => Object.values(targetEnum).includes(value);\nis.directInstanceOf = (instance, class_) => Object.getPrototypeOf(instance) === class_.prototype;\nis.urlInstance = value => isObjectOfType('URL')(value);\nis.urlString = value => {\n if (!is.string(value)) {\n return false;\n }\n try {\n new URL(value); // eslint-disable-line no-new\n return true;\n } catch (_a) {\n return false;\n }\n};\n// Example: `is.truthy = (value: unknown): value is (not false | not 0 | not '' | not undefined | not null) => Boolean(value);`\nis.truthy = value => Boolean(value);\n// Example: `is.falsy = (value: unknown): value is (not true | 0 | '' | undefined | null) => Boolean(value);`\nis.falsy = value => !value;\nis.nan = value => Number.isNaN(value);\nis.primitive = value => is.null_(value) || isPrimitiveTypeName(typeof value);\nis.integer = value => Number.isInteger(value);\nis.safeInteger = value => Number.isSafeInteger(value);\nis.plainObject = value => {\n // From: https://github.com/sindresorhus/is-plain-obj/blob/main/index.js\n if (toString.call(value) !== '[object Object]') {\n return false;\n }\n const prototype = Object.getPrototypeOf(value);\n return prototype === null || prototype === Object.getPrototypeOf({});\n};\nis.typedArray = value => isTypedArrayName(getObjectType(value));\nconst isValidLength = value => is.safeInteger(value) && value >= 0;\nis.arrayLike = value => !is.nullOrUndefined(value) && !is.function_(value) && isValidLength(value.length);\nis.inRange = (value, range) => {\n if (is.number(range)) {\n return value >= Math.min(0, range) && value <= Math.max(range, 0);\n }\n if (is.array(range) && range.length === 2) {\n return value >= Math.min(...range) && value <= Math.max(...range);\n }\n throw new TypeError(`Invalid range: ${JSON.stringify(range)}`);\n};\nconst NODE_TYPE_ELEMENT = 1;\nconst DOM_PROPERTIES_TO_CHECK = ['innerHTML', 'ownerDocument', 'style', 'attributes', 'nodeValue'];\nis.domElement = value => {\n return is.object(value) && value.nodeType === NODE_TYPE_ELEMENT && is.string(value.nodeName) && !is.plainObject(value) && DOM_PROPERTIES_TO_CHECK.every(property => property in value);\n};\nis.observable = value => {\n var _a, _b, _c, _d;\n if (!value) {\n return false;\n }\n // eslint-disable-next-line no-use-extend-native/no-use-extend-native\n if (value === ((_b = (_a = value)[Symbol.observable]) === null || _b === void 0 ? void 0 : _b.call(_a))) {\n return true;\n }\n if (value === ((_d = (_c = value)['@@observable']) === null || _d === void 0 ? void 0 : _d.call(_c))) {\n return true;\n }\n return false;\n};\nis.nodeStream = value => is.object(value) && is.function_(value.pipe) && !is.observable(value);\nis.infinite = value => value === Infinity || value === -Infinity;\nconst isAbsoluteMod2 = remainder => value => is.integer(value) && Math.abs(value % 2) === remainder;\nis.evenInteger = isAbsoluteMod2(0);\nis.oddInteger = isAbsoluteMod2(1);\nis.emptyArray = value => is.array(value) && value.length === 0;\nis.nonEmptyArray = value => is.array(value) && value.length > 0;\nis.emptyString = value => is.string(value) && value.length === 0;\nconst isWhiteSpaceString = value => is.string(value) && !/\\S/.test(value);\nis.emptyStringOrWhitespace = value => is.emptyString(value) || isWhiteSpaceString(value);\n// TODO: Use `not ''` when the `not` operator is available.\nis.nonEmptyString = value => is.string(value) && value.length > 0;\n// TODO: Use `not ''` when the `not` operator is available.\nis.nonEmptyStringAndNotWhitespace = value => is.string(value) && !is.emptyStringOrWhitespace(value);\nis.emptyObject = value => is.object(value) && !is.map(value) && !is.set(value) && Object.keys(value).length === 0;\n// TODO: Use `not` operator here to remove `Map` and `Set` from type guard:\n// - https://github.com/Microsoft/TypeScript/pull/29317\nis.nonEmptyObject = value => is.object(value) && !is.map(value) && !is.set(value) && Object.keys(value).length > 0;\nis.emptySet = value => is.set(value) && value.size === 0;\nis.nonEmptySet = value => is.set(value) && value.size > 0;\nis.emptyMap = value => is.map(value) && value.size === 0;\nis.nonEmptyMap = value => is.map(value) && value.size > 0;\n// `PropertyKey` is any value that can be used as an object key (string, number, or symbol)\nis.propertyKey = value => is.any([is.string, is.number, is.symbol], value);\nis.formData = value => isObjectOfType('FormData')(value);\nis.urlSearchParams = value => isObjectOfType('URLSearchParams')(value);\nconst predicateOnArray = (method, predicate, values) => {\n if (!is.function_(predicate)) {\n throw new TypeError(`Invalid predicate: ${JSON.stringify(predicate)}`);\n }\n if (values.length === 0) {\n throw new TypeError('Invalid number of values');\n }\n return method.call(values, predicate);\n};\nis.any = (predicate, ...values) => {\n const predicates = is.array(predicate) ? predicate : [predicate];\n return predicates.some(singlePredicate => predicateOnArray(Array.prototype.some, singlePredicate, values));\n};\nis.all = (predicate, ...values) => predicateOnArray(Array.prototype.every, predicate, values);\nconst assertType = (condition, description, value, options = {}) => {\n if (!condition) {\n const {\n multipleValues\n } = options;\n const valuesMessage = multipleValues ? `received values of types ${[...new Set(value.map(singleValue => `\\`${is(singleValue)}\\``))].join(', ')}` : `received value of type \\`${is(value)}\\``;\n throw new TypeError(`Expected value which is \\`${description}\\`, ${valuesMessage}.`);\n }\n};\nexports.assert = {\n // Unknowns.\n undefined: value => assertType(is.undefined(value), 'undefined', value),\n string: value => assertType(is.string(value), 'string', value),\n number: value => assertType(is.number(value), 'number', value),\n bigint: value => assertType(is.bigint(value), 'bigint', value),\n // eslint-disable-next-line @typescript-eslint/ban-types\n function_: value => assertType(is.function_(value), 'Function', value),\n null_: value => assertType(is.null_(value), 'null', value),\n class_: value => assertType(is.class_(value), \"Class\" /* class_ */, value),\n boolean: value => assertType(is.boolean(value), 'boolean', value),\n symbol: value => assertType(is.symbol(value), 'symbol', value),\n numericString: value => assertType(is.numericString(value), \"string with a number\" /* numericString */, value),\n array: (value, assertion) => {\n const assert = assertType;\n assert(is.array(value), 'Array', value);\n if (assertion) {\n value.forEach(assertion);\n }\n },\n buffer: value => assertType(is.buffer(value), 'Buffer', value),\n blob: value => assertType(is.blob(value), 'Blob', value),\n nullOrUndefined: value => assertType(is.nullOrUndefined(value), \"null or undefined\" /* nullOrUndefined */, value),\n object: value => assertType(is.object(value), 'Object', value),\n iterable: value => assertType(is.iterable(value), \"Iterable\" /* iterable */, value),\n asyncIterable: value => assertType(is.asyncIterable(value), \"AsyncIterable\" /* asyncIterable */, value),\n generator: value => assertType(is.generator(value), 'Generator', value),\n asyncGenerator: value => assertType(is.asyncGenerator(value), 'AsyncGenerator', value),\n nativePromise: value => assertType(is.nativePromise(value), \"native Promise\" /* nativePromise */, value),\n promise: value => assertType(is.promise(value), 'Promise', value),\n generatorFunction: value => assertType(is.generatorFunction(value), 'GeneratorFunction', value),\n asyncGeneratorFunction: value => assertType(is.asyncGeneratorFunction(value), 'AsyncGeneratorFunction', value),\n // eslint-disable-next-line @typescript-eslint/ban-types\n asyncFunction: value => assertType(is.asyncFunction(value), 'AsyncFunction', value),\n // eslint-disable-next-line @typescript-eslint/ban-types\n boundFunction: value => assertType(is.boundFunction(value), 'Function', value),\n regExp: value => assertType(is.regExp(value), 'RegExp', value),\n date: value => assertType(is.date(value), 'Date', value),\n error: value => assertType(is.error(value), 'Error', value),\n map: value => assertType(is.map(value), 'Map', value),\n set: value => assertType(is.set(value), 'Set', value),\n weakMap: value => assertType(is.weakMap(value), 'WeakMap', value),\n weakSet: value => assertType(is.weakSet(value), 'WeakSet', value),\n int8Array: value => assertType(is.int8Array(value), 'Int8Array', value),\n uint8Array: value => assertType(is.uint8Array(value), 'Uint8Array', value),\n uint8ClampedArray: value => assertType(is.uint8ClampedArray(value), 'Uint8ClampedArray', value),\n int16Array: value => assertType(is.int16Array(value), 'Int16Array', value),\n uint16Array: value => assertType(is.uint16Array(value), 'Uint16Array', value),\n int32Array: value => assertType(is.int32Array(value), 'Int32Array', value),\n uint32Array: value => assertType(is.uint32Array(value), 'Uint32Array', value),\n float32Array: value => assertType(is.float32Array(value), 'Float32Array', value),\n float64Array: value => assertType(is.float64Array(value), 'Float64Array', value),\n bigInt64Array: value => assertType(is.bigInt64Array(value), 'BigInt64Array', value),\n bigUint64Array: value => assertType(is.bigUint64Array(value), 'BigUint64Array', value),\n arrayBuffer: value => assertType(is.arrayBuffer(value), 'ArrayBuffer', value),\n sharedArrayBuffer: value => assertType(is.sharedArrayBuffer(value), 'SharedArrayBuffer', value),\n dataView: value => assertType(is.dataView(value), 'DataView', value),\n enumCase: (value, targetEnum) => assertType(is.enumCase(value, targetEnum), 'EnumCase', value),\n urlInstance: value => assertType(is.urlInstance(value), 'URL', value),\n urlString: value => assertType(is.urlString(value), \"string with a URL\" /* urlString */, value),\n truthy: value => assertType(is.truthy(value), \"truthy\" /* truthy */, value),\n falsy: value => assertType(is.falsy(value), \"falsy\" /* falsy */, value),\n nan: value => assertType(is.nan(value), \"NaN\" /* nan */, value),\n primitive: value => assertType(is.primitive(value), \"primitive\" /* primitive */, value),\n integer: value => assertType(is.integer(value), \"integer\" /* integer */, value),\n safeInteger: value => assertType(is.safeInteger(value), \"integer\" /* safeInteger */, value),\n plainObject: value => assertType(is.plainObject(value), \"plain object\" /* plainObject */, value),\n typedArray: value => assertType(is.typedArray(value), \"TypedArray\" /* typedArray */, value),\n arrayLike: value => assertType(is.arrayLike(value), \"array-like\" /* arrayLike */, value),\n domElement: value => assertType(is.domElement(value), \"HTMLElement\" /* domElement */, value),\n observable: value => assertType(is.observable(value), 'Observable', value),\n nodeStream: value => assertType(is.nodeStream(value), \"Node.js Stream\" /* nodeStream */, value),\n infinite: value => assertType(is.infinite(value), \"infinite number\" /* infinite */, value),\n emptyArray: value => assertType(is.emptyArray(value), \"empty array\" /* emptyArray */, value),\n nonEmptyArray: value => assertType(is.nonEmptyArray(value), \"non-empty array\" /* nonEmptyArray */, value),\n emptyString: value => assertType(is.emptyString(value), \"empty string\" /* emptyString */, value),\n emptyStringOrWhitespace: value => assertType(is.emptyStringOrWhitespace(value), \"empty string or whitespace\" /* emptyStringOrWhitespace */, value),\n nonEmptyString: value => assertType(is.nonEmptyString(value), \"non-empty string\" /* nonEmptyString */, value),\n nonEmptyStringAndNotWhitespace: value => assertType(is.nonEmptyStringAndNotWhitespace(value), \"non-empty string and not whitespace\" /* nonEmptyStringAndNotWhitespace */, value),\n emptyObject: value => assertType(is.emptyObject(value), \"empty object\" /* emptyObject */, value),\n nonEmptyObject: value => assertType(is.nonEmptyObject(value), \"non-empty object\" /* nonEmptyObject */, value),\n emptySet: value => assertType(is.emptySet(value), \"empty set\" /* emptySet */, value),\n nonEmptySet: value => assertType(is.nonEmptySet(value), \"non-empty set\" /* nonEmptySet */, value),\n emptyMap: value => assertType(is.emptyMap(value), \"empty map\" /* emptyMap */, value),\n nonEmptyMap: value => assertType(is.nonEmptyMap(value), \"non-empty map\" /* nonEmptyMap */, value),\n propertyKey: value => assertType(is.propertyKey(value), 'PropertyKey', value),\n formData: value => assertType(is.formData(value), 'FormData', value),\n urlSearchParams: value => assertType(is.urlSearchParams(value), 'URLSearchParams', value),\n // Numbers.\n evenInteger: value => assertType(is.evenInteger(value), \"even integer\" /* evenInteger */, value),\n oddInteger: value => assertType(is.oddInteger(value), \"odd integer\" /* oddInteger */, value),\n // Two arguments.\n directInstanceOf: (instance, class_) => assertType(is.directInstanceOf(instance, class_), \"T\" /* directInstanceOf */, instance),\n inRange: (value, range) => assertType(is.inRange(value, range), \"in range\" /* inRange */, value),\n // Variadic functions.\n any: (predicate, ...values) => {\n return assertType(is.any(predicate, ...values), \"predicate returns truthy for any value\" /* any */, values, {\n multipleValues: true\n });\n },\n all: (predicate, ...values) => assertType(is.all(predicate, ...values), \"predicate returns truthy for all values\" /* all */, values, {\n multipleValues: true\n })\n};\n// Some few keywords are reserved, but we'll populate them for Node.js users\n// See https://github.com/Microsoft/TypeScript/issues/2536\nObject.defineProperties(is, {\n class: {\n value: is.class_\n },\n function: {\n value: is.function_\n },\n null: {\n value: is.null_\n }\n});\nObject.defineProperties(exports.assert, {\n class: {\n value: exports.assert.class_\n },\n function: {\n value: exports.assert.function_\n },\n null: {\n value: exports.assert.null_\n }\n});\nexports.default = is;\n// For CommonJS default export support\nmodule.exports = is;\nmodule.exports.default = is;\nmodule.exports.assert = exports.assert;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.generateStackTrace = void 0;\n/**\nGenerates a useful stacktrace that points to the user's code where the error happened on platforms without the `Error.captureStackTrace()` method.\n\n@hidden\n*/\nconst generateStackTrace = () => {\n const stack = new RangeError('INTERNAL_OW_ERROR').stack;\n return stack;\n};\nexports.generateStackTrace = generateStackTrace;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ArgumentError = void 0;\nconst generate_stack_1 = require(\"./utils/generate-stack\");\nconst wrapStackTrace = (error, stack) => `${error.name}: ${error.message}\\n${stack}`;\n/**\n@hidden\n*/\nclass ArgumentError extends Error {\n constructor(message, context, errors = new Map()) {\n super(message);\n Object.defineProperty(this, \"validationErrors\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: void 0\n });\n this.name = 'ArgumentError';\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, context);\n } else {\n this.stack = wrapStackTrace(this, (0, generate_stack_1.generateStackTrace)());\n }\n this.validationErrors = errors;\n }\n}\nexports.ArgumentError = ArgumentError;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = () => Math.random().toString(16).slice(2);","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.not = void 0;\nconst random_id_1 = require(\"../utils/random-id\");\nconst predicate_1 = require(\"../predicates/predicate\");\n/**\nOperator which inverts the following validation.\n\n@hidden\n\n@param predictate - Predicate to wrap inside the operator.\n*/\nconst not = predicate => {\n const originalAddValidator = predicate.addValidator;\n predicate.addValidator = validator => {\n const {\n validator: fn,\n message,\n negatedMessage\n } = validator;\n const placeholder = (0, random_id_1.default)();\n validator.message = (value, label) => negatedMessage ? negatedMessage(value, label) : message(value, placeholder).replace(/ to /, '$¬ ').replace(placeholder, label);\n validator.validator = value => !fn(value);\n predicate[predicate_1.validatorSymbol].push(validator);\n predicate.addValidator = originalAddValidator;\n return predicate;\n };\n return predicate;\n};\nexports.not = not;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isPredicate = exports.testSymbol = void 0;\n/**\n@hidden\n*/\nexports.testSymbol = Symbol('test');\n/**\n@hidden\n*/\nconst isPredicate = value => Boolean(value[exports.testSymbol]);\nexports.isPredicate = isPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.generateArgumentErrorMessage = void 0;\n/**\nGenerates a complete message from all errors generated by predicates.\n\n@param errors - The errors generated by the predicates.\n@param isAny - If this function is called from the any argument.\n@hidden\n*/\nconst generateArgumentErrorMessage = (errors, isAny = false) => {\n const message = [];\n const errorArray = [...errors.entries()];\n const anyErrorWithoutOneItemOnly = errorArray.some(([, array]) => array.size !== 1);\n // If only one error \"key\" is present, enumerate all of those errors only.\n if (errorArray.length === 1) {\n const [, returnedErrors] = errorArray[0];\n if (!isAny && returnedErrors.size === 1) {\n const [errorMessage] = returnedErrors;\n return errorMessage;\n }\n for (const entry of returnedErrors) {\n message.push(`${isAny ? ' - ' : ''}${entry}`);\n }\n return message.join('\\n');\n }\n // If every predicate returns just one error, enumerate them as is.\n if (!anyErrorWithoutOneItemOnly) {\n return errorArray.map(([, [item]]) => ` - ${item}`).join('\\n');\n }\n // Else, iterate through all the errors and enumerate them.\n for (const [key, value] of errorArray) {\n message.push(`Errors from the \"${key}\" predicate:`);\n for (const entry of value) {\n message.push(` - ${entry}`);\n }\n }\n return message.join('\\n');\n};\nexports.generateArgumentErrorMessage = generateArgumentErrorMessage;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Predicate = exports.validatorSymbol = void 0;\nconst is_1 = require(\"@sindresorhus/is\");\nconst argument_error_1 = require(\"../argument-error\");\nconst not_1 = require(\"../operators/not\");\nconst base_predicate_1 = require(\"./base-predicate\");\nconst generate_argument_error_message_1 = require(\"../utils/generate-argument-error-message\");\n/**\n@hidden\n*/\nexports.validatorSymbol = Symbol('validators');\n/**\n@hidden\n*/\nclass Predicate {\n constructor(type, options = {}) {\n Object.defineProperty(this, \"type\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: type\n });\n Object.defineProperty(this, \"options\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: options\n });\n Object.defineProperty(this, \"context\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: {\n validators: []\n }\n });\n this.context = {\n ...this.context,\n ...this.options\n };\n const typeString = this.type.charAt(0).toLowerCase() + this.type.slice(1);\n this.addValidator({\n message: (value, label) => {\n // We do not include type in this label as we do for other messages, because it would be redundant.\n const label_ = label === null || label === void 0 ? void 0 : label.slice(this.type.length + 1);\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n return `Expected ${label_ || 'argument'} to be of type \\`${this.type}\\` but received type \\`${(0, is_1.default)(value)}\\``;\n },\n validator: value => is_1.default[typeString](value)\n });\n }\n /**\n @hidden\n */\n [base_predicate_1.testSymbol](value, main, label, idLabel) {\n // Create a map of labels -> received errors.\n const errors = new Map();\n for (const {\n validator,\n message\n } of this.context.validators) {\n if (this.options.optional === true && value === undefined) {\n continue;\n }\n let result;\n try {\n result = validator(value);\n } catch (error) {\n // Any errors caught means validators couldn't process the input.\n result = error;\n }\n if (result === true) {\n continue;\n }\n const label2 = is_1.default.function_(label) ? label() : label;\n const labelWithTick = label2 && idLabel ? `\\`${label2}\\`` : label2;\n const label_ = labelWithTick ? `${this.type} ${labelWithTick}` : this.type;\n const mapKey = label2 || this.type;\n // Get the current errors encountered for this label.\n const currentErrors = errors.get(mapKey);\n // Pre-generate the error message that will be reported to the user.\n const errorMessage = message(value, label_, result);\n // If we already have any errors for this label.\n if (currentErrors) {\n // If we don't already have this error logged, add it.\n currentErrors.add(errorMessage);\n } else {\n // Set this label and error in the full map.\n errors.set(mapKey, new Set([errorMessage]));\n }\n }\n // If we have any errors to report, throw.\n if (errors.size > 0) {\n // Generate the `error.message` property.\n const message = (0, generate_argument_error_message_1.generateArgumentErrorMessage)(errors);\n throw new argument_error_1.ArgumentError(message, main, errors);\n }\n }\n /**\n @hidden\n */\n get [exports.validatorSymbol]() {\n return this.context.validators;\n }\n /**\n Invert the following validators.\n */\n get not() {\n return (0, not_1.not)(this);\n }\n /**\n Test if the value matches a custom validation function. The validation function should return an object containing a `validator` and `message`. If the `validator` is `false`, the validation fails and the `message` will be used as error message. If the `message` is a function, the function is invoked with the `label` as argument to let you further customize the error message.\n @param customValidator - Custom validation function.\n */\n validate(customValidator) {\n return this.addValidator({\n message: (_, label, error) => typeof error === 'string' ? `(${label}) ${error}` : error(label),\n validator: value => {\n const {\n message,\n validator\n } = customValidator(value);\n if (validator) {\n return true;\n }\n return message;\n }\n });\n }\n /**\n Test if the value matches a custom validation function. The validation function should return `true` if the value passes the function. If the function either returns `false` or a string, the function fails and the string will be used as error message.\n @param validator - Validation function.\n */\n is(validator) {\n return this.addValidator({\n message: (value, label, error) => error ? `(${label}) ${error}` : `Expected ${label} \\`${value}\\` to pass custom validation function`,\n validator\n });\n }\n /**\n Provide a new error message to be thrown when the validation fails.\n @param newMessage - Either a string containing the new message or a function returning the new message.\n @example\n ```\n ow('🌈', 'unicorn', ow.string.equals('🦄').message('Expected unicorn, got rainbow'));\n //=> ArgumentError: Expected unicorn, got rainbow\n ```\n @example\n ```\n ow('🌈', ow.string.minLength(5).message((value, label) => `Expected ${label}, to have a minimum length of 5, got \\`${value}\\``));\n //=> ArgumentError: Expected string, to be have a minimum length of 5, got `🌈`\n ```\n */\n message(newMessage) {\n const {\n validators\n } = this.context;\n validators[validators.length - 1].message = (value, label) => {\n if (typeof newMessage === 'function') {\n return newMessage(value, label);\n }\n return newMessage;\n };\n return this;\n }\n /**\n Register a new validator.\n @param validator - Validator to register.\n */\n addValidator(validator) {\n this.context.validators.push(validator);\n return this;\n }\n}\nexports.Predicate = Predicate;","'use strict';\n\nmodule.exports = function (str) {\n return !isNaN(Date.parse(str));\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.StringPredicate = void 0;\nconst is_1 = require(\"@sindresorhus/is\");\nconst valiDate = require(\"vali-date\");\nconst predicate_1 = require(\"./predicate\");\nclass StringPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('string', options);\n }\n /**\n Test a string to have a specific length.\n @param length - The length of the string.\n */\n length(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have length \\`${length}\\`, got \\`${value}\\``,\n validator: value => value.length === length\n });\n }\n /**\n Test a string to have a minimum length.\n @param length - The minimum length of the string.\n */\n minLength(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a minimum length of \\`${length}\\`, got \\`${value}\\``,\n validator: value => value.length >= length,\n negatedMessage: (value, label) => `Expected ${label} to have a maximum length of \\`${length - 1}\\`, got \\`${value}\\``\n });\n }\n /**\n Test a string to have a maximum length.\n @param length - The maximum length of the string.\n */\n maxLength(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a maximum length of \\`${length}\\`, got \\`${value}\\``,\n validator: value => value.length <= length,\n negatedMessage: (value, label) => `Expected ${label} to have a minimum length of \\`${length + 1}\\`, got \\`${value}\\``\n });\n }\n /**\n Test a string against a regular expression.\n @param regex - The regular expression to match the value with.\n */\n matches(regex) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to match \\`${regex}\\`, got \\`${value}\\``,\n validator: value => regex.test(value)\n });\n }\n /**\n Test a string to start with a specific value.\n @param searchString - The value that should be the start of the string.\n */\n startsWith(searchString) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to start with \\`${searchString}\\`, got \\`${value}\\``,\n validator: value => value.startsWith(searchString)\n });\n }\n /**\n Test a string to end with a specific value.\n @param searchString - The value that should be the end of the string.\n */\n endsWith(searchString) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to end with \\`${searchString}\\`, got \\`${value}\\``,\n validator: value => value.endsWith(searchString)\n });\n }\n /**\n Test a string to include a specific value.\n @param searchString - The value that should be included in the string.\n */\n includes(searchString) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to include \\`${searchString}\\`, got \\`${value}\\``,\n validator: value => value.includes(searchString)\n });\n }\n /**\n Test if the string is an element of the provided list.\n @param list - List of possible values.\n */\n oneOf(list) {\n return this.addValidator({\n message: (value, label) => {\n let printedList = JSON.stringify(list);\n if (list.length > 10) {\n const overflow = list.length - 10;\n printedList = JSON.stringify(list.slice(0, 10)).replace(/]$/, `,…+${overflow} more]`);\n }\n return `Expected ${label} to be one of \\`${printedList}\\`, got \\`${value}\\``;\n },\n validator: value => list.includes(value)\n });\n }\n /**\n Test a string to be empty.\n */\n get empty() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be empty, got \\`${value}\\``,\n validator: value => value === ''\n });\n }\n /**\n Test a string to be not empty.\n */\n get nonEmpty() {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to not be empty`,\n validator: value => value !== ''\n });\n }\n /**\n Test a string to be equal to a specified string.\n @param expected - Expected value to match.\n */\n equals(expected) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be equal to \\`${expected}\\`, got \\`${value}\\``,\n validator: value => value === expected\n });\n }\n /**\n Test a string to be alphanumeric.\n */\n get alphanumeric() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be alphanumeric, got \\`${value}\\``,\n validator: value => /^[a-z\\d]+$/i.test(value)\n });\n }\n /**\n Test a string to be alphabetical.\n */\n get alphabetical() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be alphabetical, got \\`${value}\\``,\n validator: value => /^[a-z]+$/gi.test(value)\n });\n }\n /**\n Test a string to be numeric.\n */\n get numeric() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be numeric, got \\`${value}\\``,\n validator: value => /^[+-]?\\d+$/i.test(value)\n });\n }\n /**\n Test a string to be a valid date.\n */\n get date() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be a date, got \\`${value}\\``,\n validator: valiDate\n });\n }\n /**\n Test a non-empty string to be lowercase. Matching both alphabetical & numbers.\n */\n get lowercase() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be lowercase, got \\`${value}\\``,\n validator: value => value.trim() !== '' && value === value.toLowerCase()\n });\n }\n /**\n Test a non-empty string to be uppercase. Matching both alphabetical & numbers.\n */\n get uppercase() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be uppercase, got \\`${value}\\``,\n validator: value => value.trim() !== '' && value === value.toUpperCase()\n });\n }\n /**\n Test a string to be a valid URL.\n */\n get url() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be a URL, got \\`${value}\\``,\n validator: is_1.default.urlString\n });\n }\n}\nexports.StringPredicate = StringPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.NumberPredicate = void 0;\nconst is_1 = require(\"@sindresorhus/is\");\nconst predicate_1 = require(\"./predicate\");\nclass NumberPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('number', options);\n }\n /**\n Test a number to be in a specified range.\n @param start - Start of the range.\n @param end - End of the range.\n */\n inRange(start, end) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be in range [${start}..${end}], got ${value}`,\n validator: value => is_1.default.inRange(value, [start, end])\n });\n }\n /**\n Test a number to be greater than the provided value.\n @param number - Minimum value.\n */\n greaterThan(number) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be greater than ${number}, got ${value}`,\n validator: value => value > number\n });\n }\n /**\n Test a number to be greater than or equal to the provided value.\n @param number - Minimum value.\n */\n greaterThanOrEqual(number) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be greater than or equal to ${number}, got ${value}`,\n validator: value => value >= number\n });\n }\n /**\n Test a number to be less than the provided value.\n @param number - Maximum value.\n */\n lessThan(number) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be less than ${number}, got ${value}`,\n validator: value => value < number\n });\n }\n /**\n Test a number to be less than or equal to the provided value.\n @param number - Minimum value.\n */\n lessThanOrEqual(number) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be less than or equal to ${number}, got ${value}`,\n validator: value => value <= number\n });\n }\n /**\n Test a number to be equal to a specified number.\n @param expected - Expected value to match.\n */\n equal(expected) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be equal to ${expected}, got ${value}`,\n validator: value => value === expected\n });\n }\n /**\n Test if a number is an element of the provided list.\n @param list - List of possible values.\n */\n oneOf(list) {\n return this.addValidator({\n message: (value, label) => {\n let printedList = JSON.stringify(list);\n if (list.length > 10) {\n const overflow = list.length - 10;\n printedList = JSON.stringify(list.slice(0, 10)).replace(/]$/, `,…+${overflow} more]`);\n }\n return `Expected ${label} to be one of \\`${printedList}\\`, got ${value}`;\n },\n validator: value => list.includes(value)\n });\n }\n /**\n Test a number to be an integer.\n */\n get integer() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be an integer, got ${value}`,\n validator: value => is_1.default.integer(value)\n });\n }\n /**\n Test a number to be finite.\n */\n get finite() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be finite, got ${value}`,\n validator: value => !is_1.default.infinite(value)\n });\n }\n /**\n Test a number to be infinite.\n */\n get infinite() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be infinite, got ${value}`,\n validator: value => is_1.default.infinite(value)\n });\n }\n /**\n Test a number to be positive.\n */\n get positive() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be positive, got ${value}`,\n validator: value => value > 0\n });\n }\n /**\n Test a number to be negative.\n */\n get negative() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be negative, got ${value}`,\n validator: value => value < 0\n });\n }\n /**\n Test a number to be an integer or infinite.\n */\n get integerOrInfinite() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be an integer or infinite, got ${value}`,\n validator: value => is_1.default.integer(value) || is_1.default.infinite(value)\n });\n }\n /**\n Test a number to be in a valid range for a 8-bit unsigned integer.\n */\n get uint8() {\n return this.integer.inRange(0, 255);\n }\n /**\n Test a number to be in a valid range for a 16-bit unsigned integer.\n */\n get uint16() {\n return this.integer.inRange(0, 65535);\n }\n /**\n Test a number to be in a valid range for a 32-bit unsigned integer.\n */\n get uint32() {\n return this.integer.inRange(0, 4294967295);\n }\n /**\n Test a number to be in a valid range for a 8-bit signed integer.\n */\n get int8() {\n return this.integer.inRange(-128, 127);\n }\n /**\n Test a number to be in a valid range for a 16-bit signed integer.\n */\n get int16() {\n return this.integer.inRange(-32768, 32767);\n }\n /**\n Test a number to be in a valid range for a 32-bit signed integer.\n */\n get int32() {\n return this.integer.inRange(-2147483648, 2147483647);\n }\n}\nexports.NumberPredicate = NumberPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.BigIntPredicate = void 0;\nconst predicate_1 = require(\"./predicate\");\nclass BigIntPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('bigint', options);\n }\n}\nexports.BigIntPredicate = BigIntPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.BooleanPredicate = void 0;\nconst predicate_1 = require(\"./predicate\");\nclass BooleanPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('boolean', options);\n }\n /**\n Test a boolean to be true.\n */\n get true() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be true, got ${value}`,\n validator: value => value\n });\n }\n /**\n Test a boolean to be false.\n */\n get false() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be false, got ${value}`,\n validator: value => !value\n });\n }\n}\nexports.BooleanPredicate = BooleanPredicate;","/**\n * Lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]';\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] = typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = typedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] = typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = typedArrayTags[errorTag] = typedArrayTags[funcTag] = typedArrayTags[mapTag] = typedArrayTags[numberTag] = typedArrayTags[objectTag] = typedArrayTags[regexpTag] = typedArrayTags[setTag] = typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = function () {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}();\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function (value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n map.forEach(function (value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function (arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n set.forEach(function (value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = function () {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? 'Symbol(src)_1.' + uid : '';\n}();\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' + funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&').replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$');\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = nativeCreate && value === undefined ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash(),\n 'map': new (Map || ListCache)(),\n 'string': new Hash()\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n this.__data__ = new MapCache();\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache();\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n this.size = data.size;\n return result;\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || pairs.length < LARGE_ARRAY_SIZE - 1) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) && !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n isBuff && (key == 'offset' || key == 'parent') ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset') ||\n // Skip index properties.\n isIndex(key, length)))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return symToStringTag && symToStringTag in Object(value) ? getRawTag(value) : objectToString(value);\n}\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || !isObjectLike(value) && !isObjectLike(other)) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack());\n return objIsArr || isTypedArray(object) ? equalArrays(object, other, bitmask, customizer, equalFunc, stack) : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n stack || (stack = new Stack());\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack());\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = bitmask & COMPARE_UNORDERED_FLAG ? new SetCache() : undefined;\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n if (customizer) {\n var compared = isPartial ? customizer(othValue, arrValue, index, other, array, stack) : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function (othValue, othIndex) {\n if (!cacheHas(seen, othIndex) && (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if (object.byteLength != other.byteLength || object.byteOffset != other.byteOffset) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n case arrayBufferTag:\n if (object.byteLength != other.byteLength || !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n case errorTag:\n return object.name == other.name && object.message == other.message;\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == other + '';\n case mapTag:\n var convert = mapToArray;\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n if (customizer) {\n var compared = isPartial ? customizer(othValue, objValue, key, other, object, stack) : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined ? objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack) : compared)) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor && 'constructor' in object && 'constructor' in other && !(typeof objCtor == 'function' && objCtor instanceof objCtor && typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key) ? data[typeof key == 'string' ? 'string' : 'hash'] : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function (object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function (symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif (DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag || Map && getTag(new Map()) != mapTag || Promise && getTag(Promise.resolve()) != promiseTag || Set && getTag(new Set()) != setTag || WeakMap && getTag(new WeakMap()) != weakMapTag) {\n getTag = function (value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString:\n return dataViewTag;\n case mapCtorString:\n return mapTag;\n case promiseCtorString:\n return promiseTag;\n case setCtorString:\n return setTag;\n case weakMapCtorString:\n return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length && (typeof value == 'number' || reIsUint.test(value)) && value > -1 && value % 1 == 0 && value < length;\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean' ? value !== '__proto__' : value === null;\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && maskSrcKey in func;\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = typeof Ctor == 'function' && Ctor.prototype || objectProto;\n return value === proto;\n}\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return func + '';\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || value !== value && other !== other;\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function () {\n return arguments;\n}()) ? baseIsArguments : function (value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\nmodule.exports = isEqual;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst base_predicate_1 = require(\"./predicates/base-predicate\");\n/**\nValidate the value against the provided predicate.\n\n@hidden\n\n@param value - Value to test.\n@param label - Label which should be used in error messages.\n@param predicate - Predicate to test to value against.\n@param idLabel - If true, the label is a variable or type. Default: true.\n*/\nfunction test(value, label, predicate, idLabel = true) {\n predicate[base_predicate_1.testSymbol](value, test, label, idLabel);\n}\nexports.default = test;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.exact = exports.partial = void 0;\nconst is_1 = require(\"@sindresorhus/is\");\nconst test_1 = require(\"../test\");\nconst base_predicate_1 = require(\"../predicates/base-predicate\");\n/**\nTest if the `object` matches the `shape` partially.\n\n@hidden\n\n@param object - Object to test against the provided shape.\n@param shape - Shape to test the object against.\n@param parent - Name of the parent property.\n*/\nfunction partial(object, shape, parent) {\n try {\n for (const key of Object.keys(shape)) {\n const label = parent ? `${parent}.${key}` : key;\n if ((0, base_predicate_1.isPredicate)(shape[key])) {\n (0, test_1.default)(object[key], label, shape[key]);\n } else if (is_1.default.plainObject(shape[key])) {\n const result = partial(object[key], shape[key], label);\n if (result !== true) {\n return result;\n }\n }\n }\n return true;\n } catch (error) {\n return error.message;\n }\n}\nexports.partial = partial;\n/**\nTest if the `object` matches the `shape` exactly.\n\n@hidden\n\n@param object - Object to test against the provided shape.\n@param shape - Shape to test the object against.\n@param parent - Name of the parent property.\n*/\nfunction exact(object, shape, parent, isArray) {\n try {\n const objectKeys = new Set(Object.keys(object));\n for (const key of Object.keys(shape)) {\n objectKeys.delete(key);\n const label = parent ? `${parent}.${key}` : key;\n if ((0, base_predicate_1.isPredicate)(shape[key])) {\n (0, test_1.default)(object[key], label, shape[key]);\n } else if (is_1.default.plainObject(shape[key])) {\n if (!Object.prototype.hasOwnProperty.call(object, key)) {\n return `Expected \\`${label}\\` to exist`;\n }\n const result = exact(object[key], shape[key], label);\n if (result !== true) {\n return result;\n }\n }\n }\n if (objectKeys.size > 0) {\n const firstKey = [...objectKeys.keys()][0];\n const label = parent ? `${parent}.${firstKey}` : firstKey;\n return `Did not expect ${isArray ? 'element' : 'property'} \\`${label}\\` to exist, got \\`${object[firstKey]}\\``;\n }\n return true;\n } catch (error) {\n return error.message;\n }\n}\nexports.exact = exact;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst test_1 = require(\"../test\");\n/**\nTest all the values in the collection against a provided predicate.\n\n@hidden\n@param source Source collection to test.\n@param name The name to call the collection of values, such as `values` or `keys`.\n@param predicate Predicate to test every item in the source collection against.\n*/\nexports.default = (source, name, predicate) => {\n try {\n for (const item of source) {\n (0, test_1.default)(item, name, predicate, false);\n }\n return true;\n } catch (error) {\n return error.message;\n }\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ArrayPredicate = void 0;\nconst isEqual = require(\"lodash.isequal\");\nconst predicate_1 = require(\"./predicate\");\nconst match_shape_1 = require(\"../utils/match-shape\");\nconst of_type_1 = require(\"../utils/of-type\");\nclass ArrayPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('array', options);\n }\n /**\n Test an array to have a specific length.\n @param length - The length of the array.\n */\n length(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have length \\`${length}\\`, got \\`${value.length}\\``,\n validator: value => value.length === length\n });\n }\n /**\n Test an array to have a minimum length.\n @param length - The minimum length of the array.\n */\n minLength(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a minimum length of \\`${length}\\`, got \\`${value.length}\\``,\n validator: value => value.length >= length,\n negatedMessage: (value, label) => `Expected ${label} to have a maximum length of \\`${length - 1}\\`, got \\`${value.length}\\``\n });\n }\n /**\n Test an array to have a maximum length.\n @param length - The maximum length of the array.\n */\n maxLength(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a maximum length of \\`${length}\\`, got \\`${value.length}\\``,\n validator: value => value.length <= length,\n negatedMessage: (value, label) => `Expected ${label} to have a minimum length of \\`${length + 1}\\`, got \\`${value.length}\\``\n });\n }\n /**\n Test an array to start with a specific value. The value is tested by identity, not structure.\n @param searchElement - The value that should be the start of the array.\n */\n startsWith(searchElement) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to start with \\`${searchElement}\\`, got \\`${value[0]}\\``,\n validator: value => value[0] === searchElement\n });\n }\n /**\n Test an array to end with a specific value. The value is tested by identity, not structure.\n @param searchElement - The value that should be the end of the array.\n */\n endsWith(searchElement) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to end with \\`${searchElement}\\`, got \\`${value[value.length - 1]}\\``,\n validator: value => value[value.length - 1] === searchElement\n });\n }\n /**\n Test an array to include all the provided elements. The values are tested by identity, not structure.\n @param searchElements - The values that should be included in the array.\n */\n includes(...searchElements) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to include all elements of \\`${JSON.stringify(searchElements)}\\`, got \\`${JSON.stringify(value)}\\``,\n validator: value => searchElements.every(element => value.includes(element))\n });\n }\n /**\n Test an array to include any of the provided elements. The values are tested by identity, not structure.\n @param searchElements - The values that should be included in the array.\n */\n includesAny(...searchElements) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to include any element of \\`${JSON.stringify(searchElements)}\\`, got \\`${JSON.stringify(value)}\\``,\n validator: value => searchElements.some(element => value.includes(element))\n });\n }\n /**\n Test an array to be empty.\n */\n get empty() {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be empty, got \\`${JSON.stringify(value)}\\``,\n validator: value => value.length === 0\n });\n }\n /**\n Test an array to be not empty.\n */\n get nonEmpty() {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to not be empty`,\n validator: value => value.length > 0\n });\n }\n /**\n Test an array to be deeply equal to the provided array.\n @param expected - Expected value to match.\n */\n deepEqual(expected) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to be deeply equal to \\`${JSON.stringify(expected)}\\`, got \\`${JSON.stringify(value)}\\``,\n validator: value => isEqual(value, expected)\n });\n }\n /**\n Test all elements in the array to match to provided predicate.\n @param predicate - The predicate that should be applied against every individual item.\n @example\n ```\n ow(['a', 1], ow.array.ofType(ow.any(ow.string, ow.number)));\n ```\n */\n ofType(predicate) {\n // TODO [typescript@>=5] If higher-kinded types are supported natively by typescript, refactor `addValidator` to use them to avoid the usage of `any`. Otherwise, bump or remove this TODO.\n return this.addValidator({\n message: (_, label, error) => `(${label}) ${error}`,\n validator: value => (0, of_type_1.default)(value, 'values', predicate)\n });\n }\n /**\n Test if the elements in the array exactly matches the elements placed at the same indices in the predicates array.\n @param predicates - Predicates to test the array against. Describes what the tested array should look like.\n @example\n ```\n ow(['1', 2], ow.array.exactShape([ow.string, ow.number]));\n ```\n */\n exactShape(predicates) {\n const shape = predicates;\n return this.addValidator({\n message: (_, label, message) => `${message.replace('Expected', 'Expected element')} in ${label}`,\n validator: object => (0, match_shape_1.exact)(object, shape, undefined, true)\n });\n }\n}\nexports.ArrayPredicate = ArrayPredicate;","'use strict';\n\nmodule.exports = value => {\n const type = typeof value;\n return value !== null && (type === 'object' || type === 'function');\n};","'use strict';\n\nconst isObj = require('is-obj');\nconst disallowedKeys = new Set(['__proto__', 'prototype', 'constructor']);\nconst isValidPath = pathSegments => !pathSegments.some(segment => disallowedKeys.has(segment));\nfunction getPathSegments(path) {\n const pathArray = path.split('.');\n const parts = [];\n for (let i = 0; i < pathArray.length; i++) {\n let p = pathArray[i];\n while (p[p.length - 1] === '\\\\' && pathArray[i + 1] !== undefined) {\n p = p.slice(0, -1) + '.';\n p += pathArray[++i];\n }\n parts.push(p);\n }\n if (!isValidPath(parts)) {\n return [];\n }\n return parts;\n}\nmodule.exports = {\n get(object, path, value) {\n if (!isObj(object) || typeof path !== 'string') {\n return value === undefined ? object : value;\n }\n const pathArray = getPathSegments(path);\n if (pathArray.length === 0) {\n return;\n }\n for (let i = 0; i < pathArray.length; i++) {\n object = object[pathArray[i]];\n if (object === undefined || object === null) {\n // `object` is either `undefined` or `null` so we want to stop the loop, and\n // if this is not the last bit of the path, and\n // if it did't return `undefined`\n // it would return `null` if `object` is `null`\n // but we want `get({foo: null}, 'foo.bar')` to equal `undefined`, or the supplied value, not `null`\n if (i !== pathArray.length - 1) {\n return value;\n }\n break;\n }\n }\n return object === undefined ? value : object;\n },\n set(object, path, value) {\n if (!isObj(object) || typeof path !== 'string') {\n return object;\n }\n const root = object;\n const pathArray = getPathSegments(path);\n for (let i = 0; i < pathArray.length; i++) {\n const p = pathArray[i];\n if (!isObj(object[p])) {\n object[p] = {};\n }\n if (i === pathArray.length - 1) {\n object[p] = value;\n }\n object = object[p];\n }\n return root;\n },\n delete(object, path) {\n if (!isObj(object) || typeof path !== 'string') {\n return false;\n }\n const pathArray = getPathSegments(path);\n for (let i = 0; i < pathArray.length; i++) {\n const p = pathArray[i];\n if (i === pathArray.length - 1) {\n delete object[p];\n return true;\n }\n object = object[p];\n if (!isObj(object)) {\n return false;\n }\n }\n },\n has(object, path) {\n if (!isObj(object) || typeof path !== 'string') {\n return false;\n }\n const pathArray = getPathSegments(path);\n if (pathArray.length === 0) {\n return false;\n }\n\n // eslint-disable-next-line unicorn/no-for-loop\n for (let i = 0; i < pathArray.length; i++) {\n if (isObj(object)) {\n if (!(pathArray[i] in object)) {\n return false;\n }\n object = object[pathArray[i]];\n } else {\n return false;\n }\n }\n return true;\n }\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n/**\nRetrieve the missing values in a collection based on an array of items.\n\n@hidden\n\n@param source - Source collection to search through.\n@param items - Items to search for.\n@param maxValues - Maximum number of values after the search process is stopped. Default: 5.\n*/\nexports.default = (source, items, maxValues = 5) => {\n const missingValues = [];\n for (const value of items) {\n if (source.has(value)) {\n continue;\n }\n missingValues.push(value);\n if (missingValues.length === maxValues) {\n return missingValues;\n }\n }\n return missingValues.length === 0 ? true : missingValues;\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst is_1 = require(\"@sindresorhus/is\");\nconst test_1 = require(\"../test\");\nconst ofTypeDeep = (object, predicate) => {\n if (!is_1.default.plainObject(object)) {\n (0, test_1.default)(object, 'deep values', predicate, false);\n return true;\n }\n return Object.values(object).every(value => ofTypeDeep(value, predicate));\n};\n/**\nTest all the values in the object against a provided predicate.\n\n@hidden\n\n@param predicate - Predicate to test every value in the given object against.\n*/\nexports.default = (object, predicate) => {\n try {\n return ofTypeDeep(object, predicate);\n } catch (error) {\n return error.message;\n }\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ObjectPredicate = void 0;\nconst is_1 = require(\"@sindresorhus/is\");\nconst dotProp = require(\"dot-prop\");\nconst isEqual = require(\"lodash.isequal\");\nconst has_items_1 = require(\"../utils/has-items\");\nconst of_type_1 = require(\"../utils/of-type\");\nconst of_type_deep_1 = require(\"../utils/of-type-deep\");\nconst match_shape_1 = require(\"../utils/match-shape\");\nconst predicate_1 = require(\"./predicate\");\nclass ObjectPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('object', options);\n }\n /**\n Test if an Object is a plain object.\n */\n get plain() {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to be a plain object`,\n validator: object => is_1.default.plainObject(object)\n });\n }\n /**\n Test an object to be empty.\n */\n get empty() {\n return this.addValidator({\n message: (object, label) => `Expected ${label} to be empty, got \\`${JSON.stringify(object)}\\``,\n validator: object => Object.keys(object).length === 0\n });\n }\n /**\n Test an object to be not empty.\n */\n get nonEmpty() {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to not be empty`,\n validator: object => Object.keys(object).length > 0\n });\n }\n /**\n Test all the values in the object to match the provided predicate.\n @param predicate - The predicate that should be applied against every value in the object.\n */\n valuesOfType(predicate) {\n return this.addValidator({\n message: (_, label, error) => `(${label}) ${error}`,\n validator: object => (0, of_type_1.default)(Object.values(object), 'values', predicate)\n });\n }\n /**\n Test all the values in the object deeply to match the provided predicate.\n @param predicate - The predicate that should be applied against every value in the object.\n */\n deepValuesOfType(predicate) {\n return this.addValidator({\n message: (_, label, error) => `(${label}) ${error}`,\n validator: object => (0, of_type_deep_1.default)(object, predicate)\n });\n }\n /**\n Test an object to be deeply equal to the provided object.\n @param expected - Expected object to match.\n */\n deepEqual(expected) {\n return this.addValidator({\n message: (object, label) => `Expected ${label} to be deeply equal to \\`${JSON.stringify(expected)}\\`, got \\`${JSON.stringify(object)}\\``,\n validator: object => isEqual(object, expected)\n });\n }\n /**\n Test an object to be of a specific instance type.\n @param instance - The expected instance type of the object.\n */\n instanceOf(instance) {\n return this.addValidator({\n message: (object, label) => {\n var _a;\n let {\n name\n } = (_a = object === null || object === void 0 ? void 0 : object.constructor) !== null && _a !== void 0 ? _a : {};\n if (!name || name === 'Object') {\n name = JSON.stringify(object);\n }\n return `Expected ${label} \\`${name}\\` to be of type \\`${instance.name}\\``;\n },\n validator: object => object instanceof instance\n });\n }\n /**\n Test an object to include all the provided keys. You can use [dot-notation](https://github.com/sindresorhus/dot-prop) in a key to access nested properties.\n @param keys - The keys that should be present in the object.\n */\n hasKeys(...keys) {\n return this.addValidator({\n message: (_, label, missingKeys) => `Expected ${label} to have keys \\`${JSON.stringify(missingKeys)}\\``,\n validator: object => (0, has_items_1.default)({\n has: item => dotProp.has(object, item)\n }, keys)\n });\n }\n /**\n Test an object to include any of the provided keys. You can use [dot-notation](https://github.com/sindresorhus/dot-prop) in a key to access nested properties.\n @param keys - The keys that could be a key in the object.\n */\n hasAnyKeys(...keys) {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to have any key of \\`${JSON.stringify(keys)}\\``,\n validator: object => keys.some(key => dotProp.has(object, key))\n });\n }\n /**\n Test an object to match the `shape` partially. This means that it ignores unexpected properties. The shape comparison is deep.\n The shape is an object which describes how the tested object should look like. The keys are the same as the source object and the values are predicates.\n @param shape - Shape to test the object against.\n @example\n ```\n import ow from 'ow';\n const object = {\n unicorn: '🦄',\n rainbow: '🌈'\n };\n ow(object, ow.object.partialShape({\n unicorn: ow.string\n }));\n ```\n */\n partialShape(shape) {\n return this.addValidator({\n // TODO: Improve this when message handling becomes smarter\n message: (_, label, message) => `${message.replace('Expected', 'Expected property')} in ${label}`,\n validator: object => (0, match_shape_1.partial)(object, shape)\n });\n }\n /**\n Test an object to match the `shape` exactly. This means that will fail if it comes across unexpected properties. The shape comparison is deep.\n The shape is an object which describes how the tested object should look like. The keys are the same as the source object and the values are predicates.\n @param shape - Shape to test the object against.\n @example\n ```\n import ow from 'ow';\n ow({unicorn: '🦄'}, ow.object.exactShape({\n unicorn: ow.string\n }));\n ```\n */\n exactShape(shape) {\n // TODO [typescript@>=5] If higher-kinded types are supported natively by typescript, refactor `addValidator` to use them to avoid the usage of `any`. Otherwise, bump or remove this TODO.\n return this.addValidator({\n // TODO: Improve this when message handling becomes smarter\n message: (_, label, message) => `${message.replace('Expected', 'Expected property')} in ${label}`,\n validator: object => (0, match_shape_1.exact)(object, shape)\n });\n }\n}\nexports.ObjectPredicate = ObjectPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DatePredicate = void 0;\nconst predicate_1 = require(\"./predicate\");\nclass DatePredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('date', options);\n }\n /**\n Test a date to be before another date.\n @param date - Maximum value.\n */\n before(date) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} ${value.toISOString()} to be before ${date.toISOString()}`,\n validator: value => value.getTime() < date.getTime()\n });\n }\n /**\n Test a date to be before another date.\n @param date - Minimum value.\n */\n after(date) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} ${value.toISOString()} to be after ${date.toISOString()}`,\n validator: value => value.getTime() > date.getTime()\n });\n }\n}\nexports.DatePredicate = DatePredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ErrorPredicate = void 0;\nconst predicate_1 = require(\"./predicate\");\nclass ErrorPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('error', options);\n }\n /**\n Test an error to have a specific name.\n @param expected - Expected name of the Error.\n */\n name(expected) {\n return this.addValidator({\n message: (error, label) => `Expected ${label} to have name \\`${expected}\\`, got \\`${error.name}\\``,\n validator: error => error.name === expected\n });\n }\n /**\n Test an error to have a specific message.\n @param expected - Expected message of the Error.\n */\n message(expected) {\n return this.addValidator({\n message: (error, label) => `Expected ${label} message to be \\`${expected}\\`, got \\`${error.message}\\``,\n validator: error => error.message === expected\n });\n }\n /**\n Test the error message to include a specific message.\n @param message - Message that should be included in the error.\n */\n messageIncludes(message) {\n return this.addValidator({\n message: (error, label) => `Expected ${label} message to include \\`${message}\\`, got \\`${error.message}\\``,\n validator: error => error.message.includes(message)\n });\n }\n /**\n Test the error object to have specific keys.\n @param keys - One or more keys which should be part of the error object.\n */\n hasKeys(...keys) {\n return this.addValidator({\n message: (_, label) => `Expected ${label} message to have keys \\`${keys.join('`, `')}\\``,\n validator: error => keys.every(key => Object.prototype.hasOwnProperty.call(error, key))\n });\n }\n /**\n Test an error to be of a specific instance type.\n @param instance - The expected instance type of the error.\n */\n instanceOf(instance) {\n return this.addValidator({\n message: (error, label) => `Expected ${label} \\`${error.name}\\` to be of type \\`${instance.name}\\``,\n validator: error => error instanceof instance\n });\n }\n /**\n Test an Error to be a TypeError.\n */\n get typeError() {\n return this.instanceOf(TypeError);\n }\n /**\n Test an Error to be an EvalError.\n */\n get evalError() {\n return this.instanceOf(EvalError);\n }\n /**\n Test an Error to be a RangeError.\n */\n get rangeError() {\n return this.instanceOf(RangeError);\n }\n /**\n Test an Error to be a ReferenceError.\n */\n get referenceError() {\n return this.instanceOf(ReferenceError);\n }\n /**\n Test an Error to be a SyntaxError.\n */\n get syntaxError() {\n return this.instanceOf(SyntaxError);\n }\n /**\n Test an Error to be a URIError.\n */\n get uriError() {\n return this.instanceOf(URIError);\n }\n}\nexports.ErrorPredicate = ErrorPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.MapPredicate = void 0;\nconst isEqual = require(\"lodash.isequal\");\nconst has_items_1 = require(\"../utils/has-items\");\nconst of_type_1 = require(\"../utils/of-type\");\nconst predicate_1 = require(\"./predicate\");\nclass MapPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('Map', options);\n }\n /**\n Test a Map to have a specific size.\n @param size - The size of the Map.\n */\n size(size) {\n return this.addValidator({\n message: (map, label) => `Expected ${label} to have size \\`${size}\\`, got \\`${map.size}\\``,\n validator: map => map.size === size\n });\n }\n /**\n Test an Map to have a minimum size.\n @param size - The minimum size of the Map.\n */\n minSize(size) {\n return this.addValidator({\n message: (map, label) => `Expected ${label} to have a minimum size of \\`${size}\\`, got \\`${map.size}\\``,\n validator: map => map.size >= size,\n negatedMessage: (map, label) => `Expected ${label} to have a maximum size of \\`${size - 1}\\`, got \\`${map.size}\\``\n });\n }\n /**\n Test an Map to have a maximum size.\n @param size - The maximum size of the Map.\n */\n maxSize(size) {\n return this.addValidator({\n message: (map, label) => `Expected ${label} to have a maximum size of \\`${size}\\`, got \\`${map.size}\\``,\n validator: map => map.size <= size,\n negatedMessage: (map, label) => `Expected ${label} to have a minimum size of \\`${size + 1}\\`, got \\`${map.size}\\``\n });\n }\n /**\n Test a Map to include all the provided keys. The keys are tested by identity, not structure.\n @param keys - The keys that should be a key in the Map.\n */\n hasKeys(...keys) {\n return this.addValidator({\n message: (_, label, missingKeys) => `Expected ${label} to have keys \\`${JSON.stringify(missingKeys)}\\``,\n validator: map => (0, has_items_1.default)(map, keys)\n });\n }\n /**\n Test a Map to include any of the provided keys. The keys are tested by identity, not structure.\n @param keys - The keys that could be a key in the Map.\n */\n hasAnyKeys(...keys) {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to have any key of \\`${JSON.stringify(keys)}\\``,\n validator: map => keys.some(key => map.has(key))\n });\n }\n /**\n Test a Map to include all the provided values. The values are tested by identity, not structure.\n @param values - The values that should be a value in the Map.\n */\n hasValues(...values) {\n return this.addValidator({\n message: (_, label, missingValues) => `Expected ${label} to have values \\`${JSON.stringify(missingValues)}\\``,\n validator: map => (0, has_items_1.default)(new Set(map.values()), values)\n });\n }\n /**\n Test a Map to include any of the provided values. The values are tested by identity, not structure.\n @param values - The values that could be a value in the Map.\n */\n hasAnyValues(...values) {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to have any value of \\`${JSON.stringify(values)}\\``,\n validator: map => {\n const valueSet = new Set(map.values());\n return values.some(key => valueSet.has(key));\n }\n });\n }\n /**\n Test all the keys in the Map to match the provided predicate.\n @param predicate - The predicate that should be applied against every key in the Map.\n */\n keysOfType(predicate) {\n return this.addValidator({\n message: (_, label, error) => `(${label}) ${error}`,\n validator: map => (0, of_type_1.default)(map.keys(), 'keys', predicate)\n });\n }\n /**\n Test all the values in the Map to match the provided predicate.\n @param predicate - The predicate that should be applied against every value in the Map.\n */\n valuesOfType(predicate) {\n return this.addValidator({\n message: (_, label, error) => `(${label}) ${error}`,\n validator: map => (0, of_type_1.default)(map.values(), 'values', predicate)\n });\n }\n /**\n Test a Map to be empty.\n */\n get empty() {\n return this.addValidator({\n message: (map, label) => `Expected ${label} to be empty, got \\`${JSON.stringify([...map])}\\``,\n validator: map => map.size === 0\n });\n }\n /**\n Test a Map to be not empty.\n */\n get nonEmpty() {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to not be empty`,\n validator: map => map.size > 0\n });\n }\n /**\n Test a Map to be deeply equal to the provided Map.\n @param expected - Expected Map to match.\n */\n deepEqual(expected) {\n return this.addValidator({\n message: (map, label) => `Expected ${label} to be deeply equal to \\`${JSON.stringify([...expected])}\\`, got \\`${JSON.stringify([...map])}\\``,\n validator: map => isEqual(map, expected)\n });\n }\n}\nexports.MapPredicate = MapPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.WeakMapPredicate = void 0;\nconst has_items_1 = require(\"../utils/has-items\");\nconst predicate_1 = require(\"./predicate\");\nclass WeakMapPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('WeakMap', options);\n }\n /**\n Test a WeakMap to include all the provided keys. The keys are tested by identity, not structure.\n @param keys - The keys that should be a key in the WeakMap.\n */\n hasKeys(...keys) {\n return this.addValidator({\n message: (_, label, missingKeys) => `Expected ${label} to have keys \\`${JSON.stringify(missingKeys)}\\``,\n validator: map => (0, has_items_1.default)(map, keys)\n });\n }\n /**\n Test a WeakMap to include any of the provided keys. The keys are tested by identity, not structure.\n @param keys - The keys that could be a key in the WeakMap.\n */\n hasAnyKeys(...keys) {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to have any key of \\`${JSON.stringify(keys)}\\``,\n validator: map => keys.some(key => map.has(key))\n });\n }\n}\nexports.WeakMapPredicate = WeakMapPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SetPredicate = void 0;\nconst isEqual = require(\"lodash.isequal\");\nconst has_items_1 = require(\"../utils/has-items\");\nconst of_type_1 = require(\"../utils/of-type\");\nconst predicate_1 = require(\"./predicate\");\nclass SetPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('Set', options);\n }\n /**\n Test a Set to have a specific size.\n @param size - The size of the Set.\n */\n size(size) {\n return this.addValidator({\n message: (set, label) => `Expected ${label} to have size \\`${size}\\`, got \\`${set.size}\\``,\n validator: set => set.size === size\n });\n }\n /**\n Test a Set to have a minimum size.\n @param size - The minimum size of the Set.\n */\n minSize(size) {\n return this.addValidator({\n message: (set, label) => `Expected ${label} to have a minimum size of \\`${size}\\`, got \\`${set.size}\\``,\n validator: set => set.size >= size,\n negatedMessage: (set, label) => `Expected ${label} to have a maximum size of \\`${size - 1}\\`, got \\`${set.size}\\``\n });\n }\n /**\n Test a Set to have a maximum size.\n @param size - The maximum size of the Set.\n */\n maxSize(size) {\n return this.addValidator({\n message: (set, label) => `Expected ${label} to have a maximum size of \\`${size}\\`, got \\`${set.size}\\``,\n validator: set => set.size <= size,\n negatedMessage: (set, label) => `Expected ${label} to have a minimum size of \\`${size + 1}\\`, got \\`${set.size}\\``\n });\n }\n /**\n Test a Set to include all the provided items. The items are tested by identity, not structure.\n @param items - The items that should be a item in the Set.\n */\n has(...items) {\n return this.addValidator({\n message: (_, label, missingItems) => `Expected ${label} to have items \\`${JSON.stringify(missingItems)}\\``,\n validator: set => (0, has_items_1.default)(set, items)\n });\n }\n /**\n Test a Set to include any of the provided items. The items are tested by identity, not structure.\n @param items - The items that could be a item in the Set.\n */\n hasAny(...items) {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to have any item of \\`${JSON.stringify(items)}\\``,\n validator: set => items.some(item => set.has(item))\n });\n }\n /**\n Test all the items in the Set to match the provided predicate.\n @param predicate - The predicate that should be applied against every item in the Set.\n */\n ofType(predicate) {\n return this.addValidator({\n message: (_, label, error) => `(${label}) ${error}`,\n validator: set => (0, of_type_1.default)(set, 'values', predicate)\n });\n }\n /**\n Test a Set to be empty.\n */\n get empty() {\n return this.addValidator({\n message: (set, label) => `Expected ${label} to be empty, got \\`${JSON.stringify([...set])}\\``,\n validator: set => set.size === 0\n });\n }\n /**\n Test a Set to be not empty.\n */\n get nonEmpty() {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to not be empty`,\n validator: set => set.size > 0\n });\n }\n /**\n Test a Set to be deeply equal to the provided Set.\n @param expected - Expected Set to match.\n */\n deepEqual(expected) {\n return this.addValidator({\n message: (set, label) => `Expected ${label} to be deeply equal to \\`${JSON.stringify([...expected])}\\`, got \\`${JSON.stringify([...set])}\\``,\n validator: set => isEqual(set, expected)\n });\n }\n}\nexports.SetPredicate = SetPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.WeakSetPredicate = void 0;\nconst has_items_1 = require(\"../utils/has-items\");\nconst predicate_1 = require(\"./predicate\");\nclass WeakSetPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('WeakSet', options);\n }\n /**\n Test a WeakSet to include all the provided items. The items are tested by identity, not structure.\n @param items - The items that should be a item in the WeakSet.\n */\n has(...items) {\n return this.addValidator({\n message: (_, label, missingItems) => `Expected ${label} to have items \\`${JSON.stringify(missingItems)}\\``,\n validator: set => (0, has_items_1.default)(set, items)\n });\n }\n /**\n Test a WeakSet to include any of the provided items. The items are tested by identity, not structure.\n @param items - The items that could be a item in the WeakSet.\n */\n hasAny(...items) {\n return this.addValidator({\n message: (_, label) => `Expected ${label} to have any item of \\`${JSON.stringify(items)}\\``,\n validator: set => items.some(item => set.has(item))\n });\n }\n}\nexports.WeakSetPredicate = WeakSetPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.TypedArrayPredicate = void 0;\nconst predicate_1 = require(\"./predicate\");\nclass TypedArrayPredicate extends predicate_1.Predicate {\n /**\n Test a typed array to have a specific byte length.\n @param byteLength - The byte length of the typed array.\n */\n byteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength === byteLength\n });\n }\n /**\n Test a typed array to have a minimum byte length.\n @param byteLength - The minimum byte length of the typed array.\n */\n minByteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a minimum byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength >= byteLength,\n negatedMessage: (value, label) => `Expected ${label} to have a maximum byte length of \\`${byteLength - 1}\\`, got \\`${value.byteLength}\\``\n });\n }\n /**\n Test a typed array to have a minimum byte length.\n @param length - The minimum byte length of the typed array.\n */\n maxByteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a maximum byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength <= byteLength,\n negatedMessage: (value, label) => `Expected ${label} to have a minimum byte length of \\`${byteLength + 1}\\`, got \\`${value.byteLength}\\``\n });\n }\n /**\n Test a typed array to have a specific length.\n @param length - The length of the typed array.\n */\n length(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have length \\`${length}\\`, got \\`${value.length}\\``,\n validator: value => value.length === length\n });\n }\n /**\n Test a typed array to have a minimum length.\n @param length - The minimum length of the typed array.\n */\n minLength(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a minimum length of \\`${length}\\`, got \\`${value.length}\\``,\n validator: value => value.length >= length,\n negatedMessage: (value, label) => `Expected ${label} to have a maximum length of \\`${length - 1}\\`, got \\`${value.length}\\``\n });\n }\n /**\n Test a typed array to have a maximum length.\n @param length - The maximum length of the typed array.\n */\n maxLength(length) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a maximum length of \\`${length}\\`, got \\`${value.length}\\``,\n validator: value => value.length <= length,\n negatedMessage: (value, label) => `Expected ${label} to have a minimum length of \\`${length + 1}\\`, got \\`${value.length}\\``\n });\n }\n}\nexports.TypedArrayPredicate = TypedArrayPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ArrayBufferPredicate = void 0;\nconst predicate_1 = require(\"./predicate\");\nclass ArrayBufferPredicate extends predicate_1.Predicate {\n /**\n Test an array buffer to have a specific byte length.\n @param byteLength - The byte length of the array buffer.\n */\n byteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength === byteLength\n });\n }\n /**\n Test an array buffer to have a minimum byte length.\n @param byteLength - The minimum byte length of the array buffer.\n */\n minByteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a minimum byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength >= byteLength,\n negatedMessage: (value, label) => `Expected ${label} to have a maximum byte length of \\`${byteLength - 1}\\`, got \\`${value.byteLength}\\``\n });\n }\n /**\n Test an array buffer to have a minimum byte length.\n @param length - The minimum byte length of the array buffer.\n */\n maxByteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a maximum byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength <= byteLength,\n negatedMessage: (value, label) => `Expected ${label} to have a minimum byte length of \\`${byteLength + 1}\\`, got \\`${value.byteLength}\\``\n });\n }\n}\nexports.ArrayBufferPredicate = ArrayBufferPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DataViewPredicate = void 0;\nconst predicate_1 = require(\"./predicate\");\nclass DataViewPredicate extends predicate_1.Predicate {\n /**\n @hidden\n */\n constructor(options) {\n super('DataView', options);\n }\n /**\n Test a DataView to have a specific byte length.\n @param byteLength - The byte length of the DataView.\n */\n byteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength === byteLength\n });\n }\n /**\n Test a DataView to have a minimum byte length.\n @param byteLength - The minimum byte length of the DataView.\n */\n minByteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a minimum byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength >= byteLength,\n negatedMessage: (value, label) => `Expected ${label} to have a maximum byte length of \\`${byteLength - 1}\\`, got \\`${value.byteLength}\\``\n });\n }\n /**\n Test a DataView to have a minimum byte length.\n @param length - The minimum byte length of the DataView.\n */\n maxByteLength(byteLength) {\n return this.addValidator({\n message: (value, label) => `Expected ${label} to have a maximum byte length of \\`${byteLength}\\`, got \\`${value.byteLength}\\``,\n validator: value => value.byteLength <= byteLength,\n negatedMessage: (value, label) => `Expected ${label} to have a minimum byte length of \\`${byteLength + 1}\\`, got \\`${value.byteLength}\\``\n });\n }\n}\nexports.DataViewPredicate = DataViewPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AnyPredicate = void 0;\nconst argument_error_1 = require(\"../argument-error\");\nconst base_predicate_1 = require(\"./base-predicate\");\nconst generate_argument_error_message_1 = require(\"../utils/generate-argument-error-message\");\n/**\n@hidden\n*/\nclass AnyPredicate {\n constructor(predicates, options = {}) {\n Object.defineProperty(this, \"predicates\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: predicates\n });\n Object.defineProperty(this, \"options\", {\n enumerable: true,\n configurable: true,\n writable: true,\n value: options\n });\n }\n [base_predicate_1.testSymbol](value, main, label, idLabel) {\n const errors = new Map();\n for (const predicate of this.predicates) {\n try {\n main(value, label, predicate, idLabel);\n return;\n } catch (error) {\n if (value === undefined && this.options.optional === true) {\n return;\n }\n // If we received an ArgumentError, then..\n if (error instanceof argument_error_1.ArgumentError) {\n // Iterate through every error reported.\n for (const [key, value] of error.validationErrors.entries()) {\n // Get the current errors set, if any.\n const alreadyPresent = errors.get(key);\n // Add all errors under the same key\n errors.set(key, new Set([...(alreadyPresent !== null && alreadyPresent !== void 0 ? alreadyPresent : []), ...value]));\n }\n }\n }\n }\n if (errors.size > 0) {\n // Generate the `error.message` property.\n const message = (0, generate_argument_error_message_1.generateArgumentErrorMessage)(errors, true);\n throw new argument_error_1.ArgumentError(`Any predicate failed with the following errors:\\n${message}`, main, errors);\n }\n }\n}\nexports.AnyPredicate = AnyPredicate;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AnyPredicate = exports.DataViewPredicate = exports.ArrayBufferPredicate = exports.TypedArrayPredicate = exports.WeakSetPredicate = exports.SetPredicate = exports.WeakMapPredicate = exports.MapPredicate = exports.ErrorPredicate = exports.DatePredicate = exports.ObjectPredicate = exports.ArrayPredicate = exports.BooleanPredicate = exports.BigIntPredicate = exports.NumberPredicate = exports.StringPredicate = void 0;\nconst string_1 = require(\"./predicates/string\");\nObject.defineProperty(exports, \"StringPredicate\", {\n enumerable: true,\n get: function () {\n return string_1.StringPredicate;\n }\n});\nconst number_1 = require(\"./predicates/number\");\nObject.defineProperty(exports, \"NumberPredicate\", {\n enumerable: true,\n get: function () {\n return number_1.NumberPredicate;\n }\n});\nconst bigint_1 = require(\"./predicates/bigint\");\nObject.defineProperty(exports, \"BigIntPredicate\", {\n enumerable: true,\n get: function () {\n return bigint_1.BigIntPredicate;\n }\n});\nconst boolean_1 = require(\"./predicates/boolean\");\nObject.defineProperty(exports, \"BooleanPredicate\", {\n enumerable: true,\n get: function () {\n return boolean_1.BooleanPredicate;\n }\n});\nconst predicate_1 = require(\"./predicates/predicate\");\nconst array_1 = require(\"./predicates/array\");\nObject.defineProperty(exports, \"ArrayPredicate\", {\n enumerable: true,\n get: function () {\n return array_1.ArrayPredicate;\n }\n});\nconst object_1 = require(\"./predicates/object\");\nObject.defineProperty(exports, \"ObjectPredicate\", {\n enumerable: true,\n get: function () {\n return object_1.ObjectPredicate;\n }\n});\nconst date_1 = require(\"./predicates/date\");\nObject.defineProperty(exports, \"DatePredicate\", {\n enumerable: true,\n get: function () {\n return date_1.DatePredicate;\n }\n});\nconst error_1 = require(\"./predicates/error\");\nObject.defineProperty(exports, \"ErrorPredicate\", {\n enumerable: true,\n get: function () {\n return error_1.ErrorPredicate;\n }\n});\nconst map_1 = require(\"./predicates/map\");\nObject.defineProperty(exports, \"MapPredicate\", {\n enumerable: true,\n get: function () {\n return map_1.MapPredicate;\n }\n});\nconst weak_map_1 = require(\"./predicates/weak-map\");\nObject.defineProperty(exports, \"WeakMapPredicate\", {\n enumerable: true,\n get: function () {\n return weak_map_1.WeakMapPredicate;\n }\n});\nconst set_1 = require(\"./predicates/set\");\nObject.defineProperty(exports, \"SetPredicate\", {\n enumerable: true,\n get: function () {\n return set_1.SetPredicate;\n }\n});\nconst weak_set_1 = require(\"./predicates/weak-set\");\nObject.defineProperty(exports, \"WeakSetPredicate\", {\n enumerable: true,\n get: function () {\n return weak_set_1.WeakSetPredicate;\n }\n});\nconst typed_array_1 = require(\"./predicates/typed-array\");\nObject.defineProperty(exports, \"TypedArrayPredicate\", {\n enumerable: true,\n get: function () {\n return typed_array_1.TypedArrayPredicate;\n }\n});\nconst array_buffer_1 = require(\"./predicates/array-buffer\");\nObject.defineProperty(exports, \"ArrayBufferPredicate\", {\n enumerable: true,\n get: function () {\n return array_buffer_1.ArrayBufferPredicate;\n }\n});\nconst data_view_1 = require(\"./predicates/data-view\");\nObject.defineProperty(exports, \"DataViewPredicate\", {\n enumerable: true,\n get: function () {\n return data_view_1.DataViewPredicate;\n }\n});\nconst any_1 = require(\"./predicates/any\");\nObject.defineProperty(exports, \"AnyPredicate\", {\n enumerable: true,\n get: function () {\n return any_1.AnyPredicate;\n }\n});\nexports.default = (object, options) => {\n Object.defineProperties(object, {\n string: {\n get: () => new string_1.StringPredicate(options)\n },\n number: {\n get: () => new number_1.NumberPredicate(options)\n },\n bigint: {\n get: () => new bigint_1.BigIntPredicate(options)\n },\n boolean: {\n get: () => new boolean_1.BooleanPredicate(options)\n },\n undefined: {\n get: () => new predicate_1.Predicate('undefined', options)\n },\n null: {\n get: () => new predicate_1.Predicate('null', options)\n },\n nullOrUndefined: {\n get: () => new predicate_1.Predicate('nullOrUndefined', options)\n },\n nan: {\n get: () => new predicate_1.Predicate('nan', options)\n },\n symbol: {\n get: () => new predicate_1.Predicate('symbol', options)\n },\n array: {\n get: () => new array_1.ArrayPredicate(options)\n },\n object: {\n get: () => new object_1.ObjectPredicate(options)\n },\n date: {\n get: () => new date_1.DatePredicate(options)\n },\n error: {\n get: () => new error_1.ErrorPredicate(options)\n },\n map: {\n get: () => new map_1.MapPredicate(options)\n },\n weakMap: {\n get: () => new weak_map_1.WeakMapPredicate(options)\n },\n set: {\n get: () => new set_1.SetPredicate(options)\n },\n weakSet: {\n get: () => new weak_set_1.WeakSetPredicate(options)\n },\n function: {\n get: () => new predicate_1.Predicate('Function', options)\n },\n buffer: {\n get: () => new predicate_1.Predicate('Buffer', options)\n },\n regExp: {\n get: () => new predicate_1.Predicate('RegExp', options)\n },\n promise: {\n get: () => new predicate_1.Predicate('Promise', options)\n },\n typedArray: {\n get: () => new typed_array_1.TypedArrayPredicate('TypedArray', options)\n },\n int8Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Int8Array', options)\n },\n uint8Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Uint8Array', options)\n },\n uint8ClampedArray: {\n get: () => new typed_array_1.TypedArrayPredicate('Uint8ClampedArray', options)\n },\n int16Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Int16Array', options)\n },\n uint16Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Uint16Array', options)\n },\n int32Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Int32Array', options)\n },\n uint32Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Uint32Array', options)\n },\n float32Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Float32Array', options)\n },\n float64Array: {\n get: () => new typed_array_1.TypedArrayPredicate('Float64Array', options)\n },\n arrayBuffer: {\n get: () => new array_buffer_1.ArrayBufferPredicate('ArrayBuffer', options)\n },\n sharedArrayBuffer: {\n get: () => new array_buffer_1.ArrayBufferPredicate('SharedArrayBuffer', options)\n },\n dataView: {\n get: () => new data_view_1.DataViewPredicate(options)\n },\n iterable: {\n get: () => new predicate_1.Predicate('Iterable', options)\n },\n any: {\n value: (...predicates) => new any_1.AnyPredicate(predicates, options)\n }\n });\n return object;\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst predicates_1 = require(\"./predicates\");\nexports.default = object => {\n Object.defineProperties(object, {\n optional: {\n get: () => (0, predicates_1.default)({}, {\n optional: true\n })\n }\n });\n return object;\n};","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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\", {\n value: true\n});\nexports.ArgumentError = exports.Predicate = void 0;\nconst callsites_1 = require(\"callsites\");\nconst infer_label_1 = require(\"./utils/infer-label\");\nconst predicate_1 = require(\"./predicates/predicate\");\nObject.defineProperty(exports, \"Predicate\", {\n enumerable: true,\n get: function () {\n return predicate_1.Predicate;\n }\n});\nconst base_predicate_1 = require(\"./predicates/base-predicate\");\nconst modifiers_1 = require(\"./modifiers\");\nconst predicates_1 = require(\"./predicates\");\nconst test_1 = require(\"./test\");\nconst ow = (value, labelOrPredicate, predicate) => {\n if (!(0, base_predicate_1.isPredicate)(labelOrPredicate) && typeof labelOrPredicate !== 'string') {\n throw new TypeError(`Expected second argument to be a predicate or a string, got \\`${typeof labelOrPredicate}\\``);\n }\n if ((0, base_predicate_1.isPredicate)(labelOrPredicate)) {\n // If the second argument is a predicate, infer the label\n const stackFrames = (0, callsites_1.default)();\n (0, test_1.default)(value, () => (0, infer_label_1.inferLabel)(stackFrames), labelOrPredicate);\n return;\n }\n (0, test_1.default)(value, labelOrPredicate, predicate);\n};\nObject.defineProperties(ow, {\n isValid: {\n value: (value, predicate) => {\n try {\n (0, test_1.default)(value, '', predicate);\n return true;\n } catch {\n return false;\n }\n }\n },\n create: {\n value: (labelOrPredicate, predicate) => (value, label) => {\n if ((0, base_predicate_1.isPredicate)(labelOrPredicate)) {\n const stackFrames = (0, callsites_1.default)();\n (0, test_1.default)(value, label !== null && label !== void 0 ? label : () => (0, infer_label_1.inferLabel)(stackFrames), labelOrPredicate);\n return;\n }\n (0, test_1.default)(value, label !== null && label !== void 0 ? label : labelOrPredicate, predicate);\n }\n }\n});\n// Can't use `export default predicates(modifiers(ow)) as Ow` because the variable needs a type annotation to avoid a compiler error when used:\n// Assertions require every name in the call target to be declared with an explicit type annotation.ts(2775)\n// See https://github.com/microsoft/TypeScript/issues/36931 for more details.\nconst _ow = (0, predicates_1.default)((0, modifiers_1.default)(ow));\nexports.default = _ow;\n__exportStar(require(\"./predicates\"), exports);\nvar argument_error_1 = require(\"./argument-error\");\nObject.defineProperty(exports, \"ArgumentError\", {\n enumerable: true,\n get: function () {\n return argument_error_1.ArgumentError;\n }\n});","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AuditRequestShape = void 0;\nconst ow_1 = __importDefault(require(\"ow\"));\nexports.AuditRequestShape = {\n signedTx: ow_1.default.string\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RelayTransactionRequestShape = void 0;\nconst ow_1 = __importDefault(require(\"ow\"));\nexports.RelayTransactionRequestShape = {\n relayRequest: {\n request: {\n from: ow_1.default.string,\n to: ow_1.default.string,\n data: ow_1.default.string,\n value: ow_1.default.string,\n nonce: ow_1.default.string,\n gas: ow_1.default.string,\n validUntilTime: ow_1.default.string\n },\n relayData: {\n maxPriorityFeePerGas: ow_1.default.string,\n maxFeePerGas: ow_1.default.string,\n transactionCalldataGasUsed: ow_1.default.string,\n relayWorker: ow_1.default.string,\n paymaster: ow_1.default.string,\n paymasterData: ow_1.default.string,\n clientId: ow_1.default.string,\n forwarder: ow_1.default.string\n }\n },\n metadata: {\n domainSeparatorName: ow_1.default.string,\n relayLastKnownNonce: ow_1.default.number,\n approvalData: ow_1.default.string,\n relayHubAddress: ow_1.default.string,\n relayMaxNonce: ow_1.default.number,\n relayRequestId: ow_1.default.string,\n signature: ow_1.default.string,\n maxAcceptanceBudget: ow_1.default.string\n }\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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\", {\n value: true\n});\n__exportStar(require(\"./AmountRequired\"), exports);\n__exportStar(require(\"./ConfigResponse\"), exports);\n__exportStar(require(\"./Constants\"), exports);\n__exportStar(require(\"./ContractInteractor\"), exports);\n__exportStar(require(\"./environments/Environments\"), exports);\n__exportStar(require(\"./environments/MainnetCalldataGasEstimation\"), exports);\n__exportStar(require(\"./environments/AsyncZeroAddressCalldataGasEstimation\"), exports);\n__exportStar(require(\"./GSNContractsDeployment\"), exports);\n__exportStar(require(\"./HttpClient\"), exports);\n__exportStar(require(\"./HttpWrapper\"), exports);\n__exportStar(require(\"./LightTruffleContract\"), exports);\n__exportStar(require(\"./LoggerInterface\"), exports);\n__exportStar(require(\"./PingResponse\"), exports);\n__exportStar(require(\"./StatsResponse\"), exports);\n__exportStar(require(\"./Utils\"), exports);\n__exportStar(require(\"./Version\"), exports);\n__exportStar(require(\"./VersionsManager\"), exports);\n__exportStar(require(\"./types/Aliases\"), exports);\n__exportStar(require(\"./EIP712/ForwardRequest\"), exports);\n__exportStar(require(\"./EIP712/RelayData\"), exports);\n__exportStar(require(\"./EIP712/RelayRequest\"), exports);\n__exportStar(require(\"./EIP712/TypedRequestData\"), exports);\n__exportStar(require(\"./types/AuditRequest\"), exports);\n__exportStar(require(\"./types/GSNContractsDataTypes\"), exports);\n__exportStar(require(\"./types/GsnTransactionDetails\"), exports);\n__exportStar(require(\"./types/PaymasterConfiguration\"), exports);\n__exportStar(require(\"./types/PenalizerConfiguration\"), exports);\n__exportStar(require(\"./types/RelayFailureInfo\"), exports);\n__exportStar(require(\"./types/RelayHubConfiguration\"), exports);\n__exportStar(require(\"./types/RelayInfo\"), exports);\n__exportStar(require(\"./types/RelayTransactionRequest\"), exports);\n__exportStar(require(\"./types/TransactionType\"), exports);\n__exportStar(require(\"./web3js/FeeHistoryResult\"), exports);\n__exportStar(require(\"./web3js/JsonRpcPayload\"), exports);\n__exportStar(require(\"./web3js/JsonRpcResponse\"), exports);\n__exportStar(require(\"./web3js/Web3JSUtils\"), exports);\n__exportStar(require(\"./web3js/RLPEncodedTransaction\"), exports);\n","'use strict';\n\n// base-x encoding / decoding\n// Copyright (c) 2018 base-x contributors\n// Copyright (c) 2014-2018 The Bitcoin Core developers (base58.cpp)\n// Distributed under the MIT software license, see the accompanying\n// file LICENSE or http://www.opensource.org/licenses/mit-license.php.\n// @ts-ignore\nvar _Buffer = require('safe-buffer').Buffer;\nfunction base(ALPHABET) {\n if (ALPHABET.length >= 255) {\n throw new TypeError('Alphabet too long');\n }\n var BASE_MAP = new Uint8Array(256);\n for (var j = 0; j < BASE_MAP.length; j++) {\n BASE_MAP[j] = 255;\n }\n for (var i = 0; i < ALPHABET.length; i++) {\n var x = ALPHABET.charAt(i);\n var xc = x.charCodeAt(0);\n if (BASE_MAP[xc] !== 255) {\n throw new TypeError(x + ' is ambiguous');\n }\n BASE_MAP[xc] = i;\n }\n var BASE = ALPHABET.length;\n var LEADER = ALPHABET.charAt(0);\n var FACTOR = Math.log(BASE) / Math.log(256); // log(BASE) / log(256), rounded up\n var iFACTOR = Math.log(256) / Math.log(BASE); // log(256) / log(BASE), rounded up\n function encode(source) {\n if (Array.isArray(source) || source instanceof Uint8Array) {\n source = _Buffer.from(source);\n }\n if (!_Buffer.isBuffer(source)) {\n throw new TypeError('Expected Buffer');\n }\n if (source.length === 0) {\n return '';\n }\n // Skip & count leading zeroes.\n var zeroes = 0;\n var length = 0;\n var pbegin = 0;\n var pend = source.length;\n while (pbegin !== pend && source[pbegin] === 0) {\n pbegin++;\n zeroes++;\n }\n // Allocate enough space in big-endian base58 representation.\n var size = (pend - pbegin) * iFACTOR + 1 >>> 0;\n var b58 = new Uint8Array(size);\n // Process the bytes.\n while (pbegin !== pend) {\n var carry = source[pbegin];\n // Apply \"b58 = b58 * 256 + ch\".\n var i = 0;\n for (var it1 = size - 1; (carry !== 0 || i < length) && it1 !== -1; it1--, i++) {\n carry += 256 * b58[it1] >>> 0;\n b58[it1] = carry % BASE >>> 0;\n carry = carry / BASE >>> 0;\n }\n if (carry !== 0) {\n throw new Error('Non-zero carry');\n }\n length = i;\n pbegin++;\n }\n // Skip leading zeroes in base58 result.\n var it2 = size - length;\n while (it2 !== size && b58[it2] === 0) {\n it2++;\n }\n // Translate the result into a string.\n var str = LEADER.repeat(zeroes);\n for (; it2 < size; ++it2) {\n str += ALPHABET.charAt(b58[it2]);\n }\n return str;\n }\n function decodeUnsafe(source) {\n if (typeof source !== 'string') {\n throw new TypeError('Expected String');\n }\n if (source.length === 0) {\n return _Buffer.alloc(0);\n }\n var psz = 0;\n // Skip and count leading '1's.\n var zeroes = 0;\n var length = 0;\n while (source[psz] === LEADER) {\n zeroes++;\n psz++;\n }\n // Allocate enough space in big-endian base256 representation.\n var size = (source.length - psz) * FACTOR + 1 >>> 0; // log(58) / log(256), rounded up.\n var b256 = new Uint8Array(size);\n // Process the characters.\n while (psz < source.length) {\n // Decode character\n var carry = BASE_MAP[source.charCodeAt(psz)];\n // Invalid character\n if (carry === 255) {\n return;\n }\n var i = 0;\n for (var it3 = size - 1; (carry !== 0 || i < length) && it3 !== -1; it3--, i++) {\n carry += BASE * b256[it3] >>> 0;\n b256[it3] = carry % 256 >>> 0;\n carry = carry / 256 >>> 0;\n }\n if (carry !== 0) {\n throw new Error('Non-zero carry');\n }\n length = i;\n psz++;\n }\n // Skip leading zeroes in b256.\n var it4 = size - length;\n while (it4 !== size && b256[it4] === 0) {\n it4++;\n }\n var vch = _Buffer.allocUnsafe(zeroes + (size - it4));\n vch.fill(0x00, 0, zeroes);\n var j = zeroes;\n while (it4 !== size) {\n vch[j++] = b256[it4++];\n }\n return vch;\n }\n function decode(string) {\n var buffer = decodeUnsafe(string);\n if (buffer) {\n return buffer;\n }\n throw new Error('Non-base' + BASE + ' character');\n }\n return {\n encode: encode,\n decodeUnsafe: decodeUnsafe,\n decode: decode\n };\n}\nmodule.exports = base;","var basex = require('base-x');\nvar ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\nmodule.exports = basex(ALPHABET);","'use strict';\n\nvar base58 = require('bs58');\nvar Buffer = require('safe-buffer').Buffer;\nmodule.exports = function (checksumFn) {\n // Encode a buffer as a base58-check encoded string\n function encode(payload) {\n var checksum = checksumFn(payload);\n return base58.encode(Buffer.concat([payload, checksum], payload.length + 4));\n }\n function decodeRaw(buffer) {\n var payload = buffer.slice(0, -4);\n var checksum = buffer.slice(-4);\n var newChecksum = checksumFn(payload);\n if (checksum[0] ^ newChecksum[0] | checksum[1] ^ newChecksum[1] | checksum[2] ^ newChecksum[2] | checksum[3] ^ newChecksum[3]) return;\n return payload;\n }\n\n // Decode a base58-check encoded string to a buffer, no result if checksum is wrong\n function decodeUnsafe(string) {\n var buffer = base58.decodeUnsafe(string);\n if (!buffer) return;\n return decodeRaw(buffer);\n }\n function decode(string) {\n var buffer = base58.decode(string);\n var payload = decodeRaw(buffer, checksumFn);\n if (!payload) throw new Error('Invalid checksum');\n return payload;\n }\n return {\n encode: encode,\n decode: decode,\n decodeUnsafe: decodeUnsafe\n };\n};","'use strict';\n\nvar createHash = require('create-hash');\nvar bs58checkBase = require('./base');\n\n// SHA256(SHA256(buffer))\nfunction sha256x2(buffer) {\n var tmp = createHash('sha256').update(buffer).digest();\n return createHash('sha256').update(tmp).digest();\n}\nmodule.exports = bs58checkBase(sha256x2);","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar Ripemd160 = require(\"hash.js/lib/hash/ripemd\").ripemd160;\nvar hash_utils_1 = require(\"../hash-utils\");\nexports.ripemd160 = hash_utils_1.createHashFunction(function () {\n return new Ripemd160();\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar Sha256Hash = require(\"hash.js/lib/hash/sha/256\");\nvar hash_utils_1 = require(\"../hash-utils\");\nexports.sha256 = hash_utils_1.createHashFunction(function () {\n return new Sha256Hash();\n});\n","'use strict';\n\nvar inherits = require('inherits');\nvar Buffer = require('safe-buffer').Buffer;\nvar Base = require('cipher-base');\nvar ZEROS = Buffer.alloc(128);\nvar blocksize = 64;\nfunction Hmac(alg, key) {\n Base.call(this, 'digest');\n if (typeof key === 'string') {\n key = Buffer.from(key);\n }\n this._alg = alg;\n this._key = key;\n if (key.length > blocksize) {\n key = alg(key);\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize);\n }\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize);\n var opad = this._opad = Buffer.allocUnsafe(blocksize);\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36;\n opad[i] = key[i] ^ 0x5C;\n }\n this._hash = [ipad];\n}\ninherits(Hmac, Base);\nHmac.prototype._update = function (data) {\n this._hash.push(data);\n};\nHmac.prototype._final = function () {\n var h = this._alg(Buffer.concat(this._hash));\n return this._alg(Buffer.concat([this._opad, h]));\n};\nmodule.exports = Hmac;","var MD5 = require('md5.js');\nmodule.exports = function (buffer) {\n return new MD5().update(buffer).digest();\n};","'use strict';\n\nvar inherits = require('inherits');\nvar Legacy = require('./legacy');\nvar Base = require('cipher-base');\nvar Buffer = require('safe-buffer').Buffer;\nvar md5 = require('create-hash/md5');\nvar RIPEMD160 = require('ripemd160');\nvar sha = require('sha.js');\nvar ZEROS = Buffer.alloc(128);\nfunction Hmac(alg, key) {\n Base.call(this, 'digest');\n if (typeof key === 'string') {\n key = Buffer.from(key);\n }\n var blocksize = alg === 'sha512' || alg === 'sha384' ? 128 : 64;\n this._alg = alg;\n this._key = key;\n if (key.length > blocksize) {\n var hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg);\n key = hash.update(key).digest();\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize);\n }\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize);\n var opad = this._opad = Buffer.allocUnsafe(blocksize);\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36;\n opad[i] = key[i] ^ 0x5C;\n }\n this._hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg);\n this._hash.update(ipad);\n}\ninherits(Hmac, Base);\nHmac.prototype._update = function (data) {\n this._hash.update(data);\n};\nHmac.prototype._final = function () {\n var h = this._hash.digest();\n var hash = this._alg === 'rmd160' ? new RIPEMD160() : sha(this._alg);\n return hash.update(this._opad).update(h).digest();\n};\nmodule.exports = function createHmac(alg, key) {\n alg = alg.toLowerCase();\n if (alg === 'rmd160' || alg === 'ripemd160') {\n return new Hmac('rmd160', key);\n }\n if (alg === 'md5') {\n return new Legacy(md5, key);\n }\n return new Hmac(alg, key);\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar ripemd160_1 = require(\"../ripemd160\");\nvar sha256_1 = require(\"../sha256\");\nexports.createHmac = require(\"create-hmac\");\nexports.randomBytes = require(\"randombytes\");\nvar Hash = /** @class */function () {\n function Hash(hashFunction) {\n this.hashFunction = hashFunction;\n this.buffers = [];\n }\n Hash.prototype.update = function (buffer) {\n if (!Buffer.isBuffer(buffer)) {\n throw new Error(\"hdkey-crypto shim is outdated\");\n }\n this.buffers.push(buffer);\n return this;\n };\n Hash.prototype.digest = function (param) {\n if (param) {\n throw new Error(\"hdkey-crypto shim is outdated\");\n }\n return this.hashFunction(Buffer.concat(this.buffers));\n };\n return Hash;\n}();\n// We don't use create-hash here, as it doesn't work well with Rollup\nexports.createHash = function (name) {\n if (name === \"ripemd160\") {\n return new Hash(ripemd160_1.ripemd160);\n }\n if (name === \"sha256\") {\n return new Hash(sha256_1.sha256);\n }\n throw new Error(\"hdkey-crypto shim is outdated\");\n};\n","\"use strict\";\n\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n result[\"default\"] = mod;\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar secp256k1 = __importStar(require(\"secp256k1\"));\nfunction privateKeyVerify(privateKey) {\n return secp256k1.privateKeyVerify(privateKey);\n}\nexports.privateKeyVerify = privateKeyVerify;\nfunction publicKeyCreate(privateKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n return Buffer.from(secp256k1.publicKeyCreate(privateKey, compressed));\n}\nexports.publicKeyCreate = publicKeyCreate;\nfunction publicKeyVerify(publicKey) {\n return secp256k1.publicKeyVerify(publicKey);\n}\nexports.publicKeyVerify = publicKeyVerify;\nfunction publicKeyConvert(publicKey, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n return Buffer.from(secp256k1.publicKeyConvert(publicKey, compressed));\n}\nexports.publicKeyConvert = publicKeyConvert;\nfunction privateKeyTweakAdd(publicKey, tweak) {\n return Buffer.from(secp256k1.privateKeyTweakAdd(Buffer.from(publicKey), tweak));\n}\nexports.privateKeyTweakAdd = privateKeyTweakAdd;\nfunction publicKeyTweakAdd(publicKey, tweak, compressed) {\n if (compressed === void 0) {\n compressed = true;\n }\n return Buffer.from(secp256k1.publicKeyTweakAdd(Buffer.from(publicKey), tweak, compressed));\n}\nexports.publicKeyTweakAdd = publicKeyTweakAdd;\nfunction sign(message, privateKey) {\n var ret = secp256k1.ecdsaSign(message, privateKey);\n return {\n signature: Buffer.from(ret.signature),\n recovery: ret.recid\n };\n}\nexports.sign = sign;\nfunction verify(message, signature, publicKey) {\n return secp256k1.ecdsaVerify(signature, message, publicKey);\n}\nexports.verify = verify;\n","\"use strict\";\n\nfunction __export(m) {\n for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\n}\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n__export(require(\"../../shims/hdkey-secp256k1v3\"));\n","'use strict';\n\nfunction _interopDefault(ex) {\n return ex && typeof ex === 'object' && 'default' in ex ? ex['default'] : ex;\n}\nvar assert = _interopDefault(require('assert'));\nvar safeBuffer = _interopDefault(require('safe-buffer'));\nvar bs58check = _interopDefault(require('bs58check'));\nvar cryptoShim = require(\"../shims/hdkey-crypto\");\nvar secp256k1Shim = require(\"../shims/hdkey-secp256k1v3\");\nvar Buffer = safeBuffer.Buffer;\nvar MASTER_SECRET = Buffer.from('Bitcoin seed', 'utf8');\nvar HARDENED_OFFSET = 0x80000000;\nvar LEN = 78;\n\n// Bitcoin hardcoded by default, can use package `coininfo` for others\nvar BITCOIN_VERSIONS = {\n private: 0x0488ADE4,\n public: 0x0488B21E\n};\nfunction HDKey(versions) {\n this.versions = versions || BITCOIN_VERSIONS;\n this.depth = 0;\n this.index = 0;\n this._privateKey = null;\n this._publicKey = null;\n this.chainCode = null;\n this._fingerprint = 0;\n this.parentFingerprint = 0;\n}\nObject.defineProperty(HDKey.prototype, 'fingerprint', {\n get: function () {\n return this._fingerprint;\n }\n});\nObject.defineProperty(HDKey.prototype, 'identifier', {\n get: function () {\n return this._identifier;\n }\n});\nObject.defineProperty(HDKey.prototype, 'pubKeyHash', {\n get: function () {\n return this.identifier;\n }\n});\nObject.defineProperty(HDKey.prototype, 'privateKey', {\n get: function () {\n return this._privateKey;\n },\n set: function (value) {\n assert.equal(value.length, 32, 'Private key must be 32 bytes.');\n assert(secp256k1Shim.privateKeyVerify(value) === true, 'Invalid private key');\n this._privateKey = value;\n this._publicKey = secp256k1Shim.publicKeyCreate(value, true);\n this._identifier = hash160(this.publicKey);\n this._fingerprint = this._identifier.slice(0, 4).readUInt32BE(0);\n }\n});\nObject.defineProperty(HDKey.prototype, 'publicKey', {\n get: function () {\n return this._publicKey;\n },\n set: function (value) {\n assert(value.length === 33 || value.length === 65, 'Public key must be 33 or 65 bytes.');\n assert(secp256k1Shim.publicKeyVerify(value) === true, 'Invalid public key');\n this._publicKey = secp256k1Shim.publicKeyConvert(value, true); // force compressed point\n this._identifier = hash160(this.publicKey);\n this._fingerprint = this._identifier.slice(0, 4).readUInt32BE(0);\n this._privateKey = null;\n }\n});\nObject.defineProperty(HDKey.prototype, 'privateExtendedKey', {\n get: function () {\n if (this._privateKey) return bs58check.encode(serialize(this, this.versions.private, Buffer.concat([Buffer.alloc(1, 0), this.privateKey])));else return null;\n }\n});\nObject.defineProperty(HDKey.prototype, 'publicExtendedKey', {\n get: function () {\n return bs58check.encode(serialize(this, this.versions.public, this.publicKey));\n }\n});\nHDKey.prototype.derive = function (path) {\n if (path === 'm' || path === 'M' || path === \"m'\" || path === \"M'\") {\n return this;\n }\n var entries = path.split('/');\n var hdkey = this;\n entries.forEach(function (c, i) {\n if (i === 0) {\n assert(/^[mM]{1}/.test(c), 'Path must start with \"m\" or \"M\"');\n return;\n }\n var hardened = c.length > 1 && c[c.length - 1] === \"'\";\n var childIndex = parseInt(c, 10); // & (HARDENED_OFFSET - 1)\n assert(childIndex < HARDENED_OFFSET, 'Invalid index');\n if (hardened) childIndex += HARDENED_OFFSET;\n hdkey = hdkey.deriveChild(childIndex);\n });\n return hdkey;\n};\nHDKey.prototype.deriveChild = function (index) {\n var isHardened = index >= HARDENED_OFFSET;\n var indexBuffer = Buffer.allocUnsafe(4);\n indexBuffer.writeUInt32BE(index, 0);\n var data;\n if (isHardened) {\n // Hardened child\n assert(this.privateKey, 'Could not derive hardened child key');\n var pk = this.privateKey;\n var zb = Buffer.alloc(1, 0);\n pk = Buffer.concat([zb, pk]);\n\n // data = 0x00 || ser256(kpar) || ser32(index)\n data = Buffer.concat([pk, indexBuffer]);\n } else {\n // Normal child\n // data = serP(point(kpar)) || ser32(index)\n // = serP(Kpar) || ser32(index)\n data = Buffer.concat([this.publicKey, indexBuffer]);\n }\n var I = cryptoShim.createHmac('sha512', this.chainCode).update(data).digest();\n var IL = I.slice(0, 32);\n var IR = I.slice(32);\n var hd = new HDKey(this.versions);\n\n // Private parent key -> private child key\n if (this.privateKey) {\n // ki = parse256(IL) + kpar (mod n)\n try {\n hd.privateKey = secp256k1Shim.privateKeyTweakAdd(this.privateKey, IL);\n // throw if IL >= n || (privateKey + IL) === 0\n } catch (err) {\n // In case parse256(IL) >= n or ki == 0, one should proceed with the next value for i\n return this.deriveChild(index + 1);\n }\n // Public parent key -> public child key\n } else {\n // Ki = point(parse256(IL)) + Kpar\n // = G*IL + Kpar\n try {\n hd.publicKey = secp256k1Shim.publicKeyTweakAdd(this.publicKey, IL, true);\n // throw if IL >= n || (g**IL + publicKey) is infinity\n } catch (err) {\n // In case parse256(IL) >= n or Ki is the point at infinity, one should proceed with the next value for i\n return this.deriveChild(index + 1);\n }\n }\n hd.chainCode = IR;\n hd.depth = this.depth + 1;\n hd.parentFingerprint = this.fingerprint; // .readUInt32BE(0)\n hd.index = index;\n return hd;\n};\nHDKey.prototype.sign = function (hash) {\n return secp256k1Shim.sign(hash, this.privateKey).signature;\n};\nHDKey.prototype.verify = function (hash, signature) {\n return secp256k1Shim.verify(hash, signature, this.publicKey);\n};\nHDKey.prototype.wipePrivateData = function () {\n if (this._privateKey) cryptoShim.randomBytes(this._privateKey.length).copy(this._privateKey);\n this._privateKey = null;\n return this;\n};\nHDKey.prototype.toJSON = function () {\n return {\n xpriv: this.privateExtendedKey,\n xpub: this.publicExtendedKey\n };\n};\nHDKey.fromMasterSeed = function (seedBuffer, versions) {\n var I = cryptoShim.createHmac('sha512', MASTER_SECRET).update(seedBuffer).digest();\n var IL = I.slice(0, 32);\n var IR = I.slice(32);\n var hdkey = new HDKey(versions);\n hdkey.chainCode = IR;\n hdkey.privateKey = IL;\n return hdkey;\n};\nHDKey.fromExtendedKey = function (base58key, versions) {\n // => version(4) || depth(1) || fingerprint(4) || index(4) || chain(32) || key(33)\n versions = versions || BITCOIN_VERSIONS;\n var hdkey = new HDKey(versions);\n var keyBuffer = bs58check.decode(base58key);\n var version = keyBuffer.readUInt32BE(0);\n assert(version === versions.private || version === versions.public, 'Version mismatch: does not match private or public');\n hdkey.depth = keyBuffer.readUInt8(4);\n hdkey.parentFingerprint = keyBuffer.readUInt32BE(5);\n hdkey.index = keyBuffer.readUInt32BE(9);\n hdkey.chainCode = keyBuffer.slice(13, 45);\n var key = keyBuffer.slice(45);\n if (key.readUInt8(0) === 0) {\n // private\n assert(version === versions.private, 'Version mismatch: version does not match private');\n hdkey.privateKey = key.slice(1); // cut off first 0x0 byte\n } else {\n assert(version === versions.public, 'Version mismatch: version does not match public');\n hdkey.publicKey = key;\n }\n return hdkey;\n};\nHDKey.fromJSON = function (obj) {\n return HDKey.fromExtendedKey(obj.xpriv);\n};\nfunction serialize(hdkey, version, key) {\n // => version(4) || depth(1) || fingerprint(4) || index(4) || chain(32) || key(33)\n var buffer = Buffer.allocUnsafe(LEN);\n buffer.writeUInt32BE(version, 0);\n buffer.writeUInt8(hdkey.depth, 4);\n var fingerprint = hdkey.depth ? hdkey.parentFingerprint : 0x00000000;\n buffer.writeUInt32BE(fingerprint, 5);\n buffer.writeUInt32BE(hdkey.index, 9);\n hdkey.chainCode.copy(buffer, 13);\n key.copy(buffer, 45);\n return buffer;\n}\nfunction hash160(buf) {\n var sha = cryptoShim.createHash('sha256').update(buf).digest();\n return cryptoShim.createHash('ripemd160').update(sha).digest();\n}\nHDKey.HARDENED_OFFSET = HARDENED_OFFSET;\nvar hdkey = HDKey;\nmodule.exports = hdkey;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar hdkey = require(\"./vendor/hdkey-without-crypto\");\nexports.HDKey = hdkey;\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar index_1 = __importDefault(require(\"./index\"));\nvar hdkey_1 = require(\"ethereum-cryptography/hdkey\");\nvar EthereumHDKey = /** @class */function () {\n function EthereumHDKey(_hdkey) {\n this._hdkey = _hdkey;\n }\n /**\n * Creates an instance based on a seed.\n *\n * For the seed we suggest to use [bip39](https://npmjs.org/package/bip39) to\n * create one from a BIP39 mnemonic.\n */\n EthereumHDKey.fromMasterSeed = function (seedBuffer) {\n return new EthereumHDKey(hdkey_1.HDKey.fromMasterSeed(seedBuffer));\n };\n /**\n * Create an instance based on a BIP32 extended private or public key.\n */\n EthereumHDKey.fromExtendedKey = function (base58Key) {\n return new EthereumHDKey(hdkey_1.HDKey.fromExtendedKey(base58Key));\n };\n /**\n * Returns a BIP32 extended private key (xprv)\n */\n EthereumHDKey.prototype.privateExtendedKey = function () {\n if (!this._hdkey.privateExtendedKey) {\n throw new Error('This is a public key only wallet');\n }\n return this._hdkey.privateExtendedKey;\n };\n /**\n * Return a BIP32 extended public key (xpub)\n */\n EthereumHDKey.prototype.publicExtendedKey = function () {\n return this._hdkey.publicExtendedKey;\n };\n /**\n * Derives a node based on a path (e.g. m/44'/0'/0/1)\n */\n EthereumHDKey.prototype.derivePath = function (path) {\n return new EthereumHDKey(this._hdkey.derive(path));\n };\n /**\n * Derive a node based on a child index\n */\n EthereumHDKey.prototype.deriveChild = function (index) {\n return new EthereumHDKey(this._hdkey.deriveChild(index));\n };\n /**\n * Return a `Wallet` instance as seen above\n */\n EthereumHDKey.prototype.getWallet = function () {\n if (this._hdkey._privateKey) {\n return index_1.default.fromPrivateKey(this._hdkey._privateKey);\n }\n return index_1.default.fromPublicKey(this._hdkey._publicKey, true);\n };\n return EthereumHDKey;\n}();\nexports.default = EthereumHDKey;\n","/*! https://mths.be/utf8js v3.0.0 by @mathias */\n;\n(function (root) {\n var stringFromCharCode = String.fromCharCode;\n\n // Taken from https://mths.be/punycode\n function ucs2decode(string) {\n var output = [];\n var counter = 0;\n var length = string.length;\n var value;\n var extra;\n while (counter < length) {\n value = string.charCodeAt(counter++);\n if (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n // high surrogate, and there is a next character\n extra = string.charCodeAt(counter++);\n if ((extra & 0xFC00) == 0xDC00) {\n // low surrogate\n output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n } else {\n // unmatched surrogate; only append this code unit, in case the next\n // 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 // Taken from https://mths.be/punycode\n function ucs2encode(array) {\n var length = array.length;\n var index = -1;\n var value;\n var output = '';\n while (++index < length) {\n value = array[index];\n if (value > 0xFFFF) {\n value -= 0x10000;\n output += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800);\n value = 0xDC00 | value & 0x3FF;\n }\n output += stringFromCharCode(value);\n }\n return output;\n }\n function checkScalarValue(codePoint) {\n if (codePoint >= 0xD800 && codePoint <= 0xDFFF) {\n throw Error('Lone surrogate U+' + codePoint.toString(16).toUpperCase() + ' is not a scalar value');\n }\n }\n /*--------------------------------------------------------------------------*/\n\n function createByte(codePoint, shift) {\n return stringFromCharCode(codePoint >> shift & 0x3F | 0x80);\n }\n function encodeCodePoint(codePoint) {\n if ((codePoint & 0xFFFFFF80) == 0) {\n // 1-byte sequence\n return stringFromCharCode(codePoint);\n }\n var symbol = '';\n if ((codePoint & 0xFFFFF800) == 0) {\n // 2-byte sequence\n symbol = stringFromCharCode(codePoint >> 6 & 0x1F | 0xC0);\n } else if ((codePoint & 0xFFFF0000) == 0) {\n // 3-byte sequence\n checkScalarValue(codePoint);\n symbol = stringFromCharCode(codePoint >> 12 & 0x0F | 0xE0);\n symbol += createByte(codePoint, 6);\n } else if ((codePoint & 0xFFE00000) == 0) {\n // 4-byte sequence\n symbol = stringFromCharCode(codePoint >> 18 & 0x07 | 0xF0);\n symbol += createByte(codePoint, 12);\n symbol += createByte(codePoint, 6);\n }\n symbol += stringFromCharCode(codePoint & 0x3F | 0x80);\n return symbol;\n }\n function utf8encode(string) {\n var codePoints = ucs2decode(string);\n var length = codePoints.length;\n var index = -1;\n var codePoint;\n var byteString = '';\n while (++index < length) {\n codePoint = codePoints[index];\n byteString += encodeCodePoint(codePoint);\n }\n return byteString;\n }\n\n /*--------------------------------------------------------------------------*/\n\n function readContinuationByte() {\n if (byteIndex >= byteCount) {\n throw Error('Invalid byte index');\n }\n var continuationByte = byteArray[byteIndex] & 0xFF;\n byteIndex++;\n if ((continuationByte & 0xC0) == 0x80) {\n return continuationByte & 0x3F;\n }\n\n // If we end up here, it’s not a continuation byte\n throw Error('Invalid continuation byte');\n }\n function decodeSymbol() {\n var byte1;\n var byte2;\n var byte3;\n var byte4;\n var codePoint;\n if (byteIndex > byteCount) {\n throw Error('Invalid byte index');\n }\n if (byteIndex == byteCount) {\n return false;\n }\n\n // Read first byte\n byte1 = byteArray[byteIndex] & 0xFF;\n byteIndex++;\n\n // 1-byte sequence (no continuation bytes)\n if ((byte1 & 0x80) == 0) {\n return byte1;\n }\n\n // 2-byte sequence\n if ((byte1 & 0xE0) == 0xC0) {\n byte2 = readContinuationByte();\n codePoint = (byte1 & 0x1F) << 6 | byte2;\n if (codePoint >= 0x80) {\n return codePoint;\n } else {\n throw Error('Invalid continuation byte');\n }\n }\n\n // 3-byte sequence (may include unpaired surrogates)\n if ((byte1 & 0xF0) == 0xE0) {\n byte2 = readContinuationByte();\n byte3 = readContinuationByte();\n codePoint = (byte1 & 0x0F) << 12 | byte2 << 6 | byte3;\n if (codePoint >= 0x0800) {\n checkScalarValue(codePoint);\n return codePoint;\n } else {\n throw Error('Invalid continuation byte');\n }\n }\n\n // 4-byte sequence\n if ((byte1 & 0xF8) == 0xF0) {\n byte2 = readContinuationByte();\n byte3 = readContinuationByte();\n byte4 = readContinuationByte();\n codePoint = (byte1 & 0x07) << 0x12 | byte2 << 0x0C | byte3 << 0x06 | byte4;\n if (codePoint >= 0x010000 && codePoint <= 0x10FFFF) {\n return codePoint;\n }\n }\n throw Error('Invalid UTF-8 detected');\n }\n var byteArray;\n var byteCount;\n var byteIndex;\n function utf8decode(byteString) {\n byteArray = ucs2decode(byteString);\n byteCount = byteArray.length;\n byteIndex = 0;\n var codePoints = [];\n var tmp;\n while ((tmp = decodeSymbol()) !== false) {\n codePoints.push(tmp);\n }\n return ucs2encode(codePoints);\n }\n\n /*--------------------------------------------------------------------------*/\n\n root.version = '3.0.0';\n root.encode = utf8encode;\n root.decode = utf8decode;\n})(typeof exports === 'undefined' ? this.utf8 = {} : exports);","/*! MIT License. Copyright 2015-2018 Richard Moore . See LICENSE.txt. */\n(function (root) {\n \"use strict\";\n\n function checkInt(value) {\n return parseInt(value) === value;\n }\n function checkInts(arrayish) {\n if (!checkInt(arrayish.length)) {\n return false;\n }\n for (var i = 0; i < arrayish.length; i++) {\n if (!checkInt(arrayish[i]) || arrayish[i] < 0 || arrayish[i] > 255) {\n return false;\n }\n }\n return true;\n }\n function coerceArray(arg, copy) {\n // ArrayBuffer view\n if (arg.buffer && arg.name === 'Uint8Array') {\n if (copy) {\n if (arg.slice) {\n arg = arg.slice();\n } else {\n arg = Array.prototype.slice.call(arg);\n }\n }\n return arg;\n }\n\n // It's an array; check it is a valid representation of a byte\n if (Array.isArray(arg)) {\n if (!checkInts(arg)) {\n throw new Error('Array contains invalid value: ' + arg);\n }\n return new Uint8Array(arg);\n }\n\n // Something else, but behaves like an array (maybe a Buffer? Arguments?)\n if (checkInt(arg.length) && checkInts(arg)) {\n return new Uint8Array(arg);\n }\n throw new Error('unsupported array-like object');\n }\n function createArray(length) {\n return new Uint8Array(length);\n }\n function copyArray(sourceArray, targetArray, targetStart, sourceStart, sourceEnd) {\n if (sourceStart != null || sourceEnd != null) {\n if (sourceArray.slice) {\n sourceArray = sourceArray.slice(sourceStart, sourceEnd);\n } else {\n sourceArray = Array.prototype.slice.call(sourceArray, sourceStart, sourceEnd);\n }\n }\n targetArray.set(sourceArray, targetStart);\n }\n var convertUtf8 = function () {\n function toBytes(text) {\n var result = [],\n i = 0;\n text = encodeURI(text);\n while (i < text.length) {\n var c = text.charCodeAt(i++);\n\n // if it is a % sign, encode the following 2 bytes as a hex value\n if (c === 37) {\n result.push(parseInt(text.substr(i, 2), 16));\n i += 2;\n\n // otherwise, just the actual byte\n } else {\n result.push(c);\n }\n }\n return coerceArray(result);\n }\n function fromBytes(bytes) {\n var result = [],\n i = 0;\n while (i < bytes.length) {\n var c = bytes[i];\n if (c < 128) {\n result.push(String.fromCharCode(c));\n i++;\n } else if (c > 191 && c < 224) {\n result.push(String.fromCharCode((c & 0x1f) << 6 | bytes[i + 1] & 0x3f));\n i += 2;\n } else {\n result.push(String.fromCharCode((c & 0x0f) << 12 | (bytes[i + 1] & 0x3f) << 6 | bytes[i + 2] & 0x3f));\n i += 3;\n }\n }\n return result.join('');\n }\n return {\n toBytes: toBytes,\n fromBytes: fromBytes\n };\n }();\n var convertHex = function () {\n function toBytes(text) {\n var result = [];\n for (var i = 0; i < text.length; i += 2) {\n result.push(parseInt(text.substr(i, 2), 16));\n }\n return result;\n }\n\n // http://ixti.net/development/javascript/2011/11/11/base64-encodedecode-of-utf8-in-browser-with-js.html\n var Hex = '0123456789abcdef';\n function fromBytes(bytes) {\n var result = [];\n for (var i = 0; i < bytes.length; i++) {\n var v = bytes[i];\n result.push(Hex[(v & 0xf0) >> 4] + Hex[v & 0x0f]);\n }\n return result.join('');\n }\n return {\n toBytes: toBytes,\n fromBytes: fromBytes\n };\n }();\n\n // Number of rounds by keysize\n var numberOfRounds = {\n 16: 10,\n 24: 12,\n 32: 14\n };\n\n // Round constant words\n var rcon = [0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36, 0x6c, 0xd8, 0xab, 0x4d, 0x9a, 0x2f, 0x5e, 0xbc, 0x63, 0xc6, 0x97, 0x35, 0x6a, 0xd4, 0xb3, 0x7d, 0xfa, 0xef, 0xc5, 0x91];\n\n // S-box and Inverse S-box (S is for Substitution)\n var S = [0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76, 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0, 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15, 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75, 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84, 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf, 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8, 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2, 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73, 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb, 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79, 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08, 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a, 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e, 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf, 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16];\n var Si = [0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb, 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb, 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e, 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25, 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92, 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84, 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06, 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b, 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73, 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e, 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b, 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4, 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f, 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef, 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61, 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d];\n\n // Transformations for encryption\n var T1 = [0xc66363a5, 0xf87c7c84, 0xee777799, 0xf67b7b8d, 0xfff2f20d, 0xd66b6bbd, 0xde6f6fb1, 0x91c5c554, 0x60303050, 0x02010103, 0xce6767a9, 0x562b2b7d, 0xe7fefe19, 0xb5d7d762, 0x4dababe6, 0xec76769a, 0x8fcaca45, 0x1f82829d, 0x89c9c940, 0xfa7d7d87, 0xeffafa15, 0xb25959eb, 0x8e4747c9, 0xfbf0f00b, 0x41adadec, 0xb3d4d467, 0x5fa2a2fd, 0x45afafea, 0x239c9cbf, 0x53a4a4f7, 0xe4727296, 0x9bc0c05b, 0x75b7b7c2, 0xe1fdfd1c, 0x3d9393ae, 0x4c26266a, 0x6c36365a, 0x7e3f3f41, 0xf5f7f702, 0x83cccc4f, 0x6834345c, 0x51a5a5f4, 0xd1e5e534, 0xf9f1f108, 0xe2717193, 0xabd8d873, 0x62313153, 0x2a15153f, 0x0804040c, 0x95c7c752, 0x46232365, 0x9dc3c35e, 0x30181828, 0x379696a1, 0x0a05050f, 0x2f9a9ab5, 0x0e070709, 0x24121236, 0x1b80809b, 0xdfe2e23d, 0xcdebeb26, 0x4e272769, 0x7fb2b2cd, 0xea75759f, 0x1209091b, 0x1d83839e, 0x582c2c74, 0x341a1a2e, 0x361b1b2d, 0xdc6e6eb2, 0xb45a5aee, 0x5ba0a0fb, 0xa45252f6, 0x763b3b4d, 0xb7d6d661, 0x7db3b3ce, 0x5229297b, 0xdde3e33e, 0x5e2f2f71, 0x13848497, 0xa65353f5, 0xb9d1d168, 0x00000000, 0xc1eded2c, 0x40202060, 0xe3fcfc1f, 0x79b1b1c8, 0xb65b5bed, 0xd46a6abe, 0x8dcbcb46, 0x67bebed9, 0x7239394b, 0x944a4ade, 0x984c4cd4, 0xb05858e8, 0x85cfcf4a, 0xbbd0d06b, 0xc5efef2a, 0x4faaaae5, 0xedfbfb16, 0x864343c5, 0x9a4d4dd7, 0x66333355, 0x11858594, 0x8a4545cf, 0xe9f9f910, 0x04020206, 0xfe7f7f81, 0xa05050f0, 0x783c3c44, 0x259f9fba, 0x4ba8a8e3, 0xa25151f3, 0x5da3a3fe, 0x804040c0, 0x058f8f8a, 0x3f9292ad, 0x219d9dbc, 0x70383848, 0xf1f5f504, 0x63bcbcdf, 0x77b6b6c1, 0xafdada75, 0x42212163, 0x20101030, 0xe5ffff1a, 0xfdf3f30e, 0xbfd2d26d, 0x81cdcd4c, 0x180c0c14, 0x26131335, 0xc3ecec2f, 0xbe5f5fe1, 0x359797a2, 0x884444cc, 0x2e171739, 0x93c4c457, 0x55a7a7f2, 0xfc7e7e82, 0x7a3d3d47, 0xc86464ac, 0xba5d5de7, 0x3219192b, 0xe6737395, 0xc06060a0, 0x19818198, 0x9e4f4fd1, 0xa3dcdc7f, 0x44222266, 0x542a2a7e, 0x3b9090ab, 0x0b888883, 0x8c4646ca, 0xc7eeee29, 0x6bb8b8d3, 0x2814143c, 0xa7dede79, 0xbc5e5ee2, 0x160b0b1d, 0xaddbdb76, 0xdbe0e03b, 0x64323256, 0x743a3a4e, 0x140a0a1e, 0x924949db, 0x0c06060a, 0x4824246c, 0xb85c5ce4, 0x9fc2c25d, 0xbdd3d36e, 0x43acacef, 0xc46262a6, 0x399191a8, 0x319595a4, 0xd3e4e437, 0xf279798b, 0xd5e7e732, 0x8bc8c843, 0x6e373759, 0xda6d6db7, 0x018d8d8c, 0xb1d5d564, 0x9c4e4ed2, 0x49a9a9e0, 0xd86c6cb4, 0xac5656fa, 0xf3f4f407, 0xcfeaea25, 0xca6565af, 0xf47a7a8e, 0x47aeaee9, 0x10080818, 0x6fbabad5, 0xf0787888, 0x4a25256f, 0x5c2e2e72, 0x381c1c24, 0x57a6a6f1, 0x73b4b4c7, 0x97c6c651, 0xcbe8e823, 0xa1dddd7c, 0xe874749c, 0x3e1f1f21, 0x964b4bdd, 0x61bdbddc, 0x0d8b8b86, 0x0f8a8a85, 0xe0707090, 0x7c3e3e42, 0x71b5b5c4, 0xcc6666aa, 0x904848d8, 0x06030305, 0xf7f6f601, 0x1c0e0e12, 0xc26161a3, 0x6a35355f, 0xae5757f9, 0x69b9b9d0, 0x17868691, 0x99c1c158, 0x3a1d1d27, 0x279e9eb9, 0xd9e1e138, 0xebf8f813, 0x2b9898b3, 0x22111133, 0xd26969bb, 0xa9d9d970, 0x078e8e89, 0x339494a7, 0x2d9b9bb6, 0x3c1e1e22, 0x15878792, 0xc9e9e920, 0x87cece49, 0xaa5555ff, 0x50282878, 0xa5dfdf7a, 0x038c8c8f, 0x59a1a1f8, 0x09898980, 0x1a0d0d17, 0x65bfbfda, 0xd7e6e631, 0x844242c6, 0xd06868b8, 0x824141c3, 0x299999b0, 0x5a2d2d77, 0x1e0f0f11, 0x7bb0b0cb, 0xa85454fc, 0x6dbbbbd6, 0x2c16163a];\n var T2 = [0xa5c66363, 0x84f87c7c, 0x99ee7777, 0x8df67b7b, 0x0dfff2f2, 0xbdd66b6b, 0xb1de6f6f, 0x5491c5c5, 0x50603030, 0x03020101, 0xa9ce6767, 0x7d562b2b, 0x19e7fefe, 0x62b5d7d7, 0xe64dabab, 0x9aec7676, 0x458fcaca, 0x9d1f8282, 0x4089c9c9, 0x87fa7d7d, 0x15effafa, 0xebb25959, 0xc98e4747, 0x0bfbf0f0, 0xec41adad, 0x67b3d4d4, 0xfd5fa2a2, 0xea45afaf, 0xbf239c9c, 0xf753a4a4, 0x96e47272, 0x5b9bc0c0, 0xc275b7b7, 0x1ce1fdfd, 0xae3d9393, 0x6a4c2626, 0x5a6c3636, 0x417e3f3f, 0x02f5f7f7, 0x4f83cccc, 0x5c683434, 0xf451a5a5, 0x34d1e5e5, 0x08f9f1f1, 0x93e27171, 0x73abd8d8, 0x53623131, 0x3f2a1515, 0x0c080404, 0x5295c7c7, 0x65462323, 0x5e9dc3c3, 0x28301818, 0xa1379696, 0x0f0a0505, 0xb52f9a9a, 0x090e0707, 0x36241212, 0x9b1b8080, 0x3ddfe2e2, 0x26cdebeb, 0x694e2727, 0xcd7fb2b2, 0x9fea7575, 0x1b120909, 0x9e1d8383, 0x74582c2c, 0x2e341a1a, 0x2d361b1b, 0xb2dc6e6e, 0xeeb45a5a, 0xfb5ba0a0, 0xf6a45252, 0x4d763b3b, 0x61b7d6d6, 0xce7db3b3, 0x7b522929, 0x3edde3e3, 0x715e2f2f, 0x97138484, 0xf5a65353, 0x68b9d1d1, 0x00000000, 0x2cc1eded, 0x60402020, 0x1fe3fcfc, 0xc879b1b1, 0xedb65b5b, 0xbed46a6a, 0x468dcbcb, 0xd967bebe, 0x4b723939, 0xde944a4a, 0xd4984c4c, 0xe8b05858, 0x4a85cfcf, 0x6bbbd0d0, 0x2ac5efef, 0xe54faaaa, 0x16edfbfb, 0xc5864343, 0xd79a4d4d, 0x55663333, 0x94118585, 0xcf8a4545, 0x10e9f9f9, 0x06040202, 0x81fe7f7f, 0xf0a05050, 0x44783c3c, 0xba259f9f, 0xe34ba8a8, 0xf3a25151, 0xfe5da3a3, 0xc0804040, 0x8a058f8f, 0xad3f9292, 0xbc219d9d, 0x48703838, 0x04f1f5f5, 0xdf63bcbc, 0xc177b6b6, 0x75afdada, 0x63422121, 0x30201010, 0x1ae5ffff, 0x0efdf3f3, 0x6dbfd2d2, 0x4c81cdcd, 0x14180c0c, 0x35261313, 0x2fc3ecec, 0xe1be5f5f, 0xa2359797, 0xcc884444, 0x392e1717, 0x5793c4c4, 0xf255a7a7, 0x82fc7e7e, 0x477a3d3d, 0xacc86464, 0xe7ba5d5d, 0x2b321919, 0x95e67373, 0xa0c06060, 0x98198181, 0xd19e4f4f, 0x7fa3dcdc, 0x66442222, 0x7e542a2a, 0xab3b9090, 0x830b8888, 0xca8c4646, 0x29c7eeee, 0xd36bb8b8, 0x3c281414, 0x79a7dede, 0xe2bc5e5e, 0x1d160b0b, 0x76addbdb, 0x3bdbe0e0, 0x56643232, 0x4e743a3a, 0x1e140a0a, 0xdb924949, 0x0a0c0606, 0x6c482424, 0xe4b85c5c, 0x5d9fc2c2, 0x6ebdd3d3, 0xef43acac, 0xa6c46262, 0xa8399191, 0xa4319595, 0x37d3e4e4, 0x8bf27979, 0x32d5e7e7, 0x438bc8c8, 0x596e3737, 0xb7da6d6d, 0x8c018d8d, 0x64b1d5d5, 0xd29c4e4e, 0xe049a9a9, 0xb4d86c6c, 0xfaac5656, 0x07f3f4f4, 0x25cfeaea, 0xafca6565, 0x8ef47a7a, 0xe947aeae, 0x18100808, 0xd56fbaba, 0x88f07878, 0x6f4a2525, 0x725c2e2e, 0x24381c1c, 0xf157a6a6, 0xc773b4b4, 0x5197c6c6, 0x23cbe8e8, 0x7ca1dddd, 0x9ce87474, 0x213e1f1f, 0xdd964b4b, 0xdc61bdbd, 0x860d8b8b, 0x850f8a8a, 0x90e07070, 0x427c3e3e, 0xc471b5b5, 0xaacc6666, 0xd8904848, 0x05060303, 0x01f7f6f6, 0x121c0e0e, 0xa3c26161, 0x5f6a3535, 0xf9ae5757, 0xd069b9b9, 0x91178686, 0x5899c1c1, 0x273a1d1d, 0xb9279e9e, 0x38d9e1e1, 0x13ebf8f8, 0xb32b9898, 0x33221111, 0xbbd26969, 0x70a9d9d9, 0x89078e8e, 0xa7339494, 0xb62d9b9b, 0x223c1e1e, 0x92158787, 0x20c9e9e9, 0x4987cece, 0xffaa5555, 0x78502828, 0x7aa5dfdf, 0x8f038c8c, 0xf859a1a1, 0x80098989, 0x171a0d0d, 0xda65bfbf, 0x31d7e6e6, 0xc6844242, 0xb8d06868, 0xc3824141, 0xb0299999, 0x775a2d2d, 0x111e0f0f, 0xcb7bb0b0, 0xfca85454, 0xd66dbbbb, 0x3a2c1616];\n var T3 = [0x63a5c663, 0x7c84f87c, 0x7799ee77, 0x7b8df67b, 0xf20dfff2, 0x6bbdd66b, 0x6fb1de6f, 0xc55491c5, 0x30506030, 0x01030201, 0x67a9ce67, 0x2b7d562b, 0xfe19e7fe, 0xd762b5d7, 0xabe64dab, 0x769aec76, 0xca458fca, 0x829d1f82, 0xc94089c9, 0x7d87fa7d, 0xfa15effa, 0x59ebb259, 0x47c98e47, 0xf00bfbf0, 0xadec41ad, 0xd467b3d4, 0xa2fd5fa2, 0xafea45af, 0x9cbf239c, 0xa4f753a4, 0x7296e472, 0xc05b9bc0, 0xb7c275b7, 0xfd1ce1fd, 0x93ae3d93, 0x266a4c26, 0x365a6c36, 0x3f417e3f, 0xf702f5f7, 0xcc4f83cc, 0x345c6834, 0xa5f451a5, 0xe534d1e5, 0xf108f9f1, 0x7193e271, 0xd873abd8, 0x31536231, 0x153f2a15, 0x040c0804, 0xc75295c7, 0x23654623, 0xc35e9dc3, 0x18283018, 0x96a13796, 0x050f0a05, 0x9ab52f9a, 0x07090e07, 0x12362412, 0x809b1b80, 0xe23ddfe2, 0xeb26cdeb, 0x27694e27, 0xb2cd7fb2, 0x759fea75, 0x091b1209, 0x839e1d83, 0x2c74582c, 0x1a2e341a, 0x1b2d361b, 0x6eb2dc6e, 0x5aeeb45a, 0xa0fb5ba0, 0x52f6a452, 0x3b4d763b, 0xd661b7d6, 0xb3ce7db3, 0x297b5229, 0xe33edde3, 0x2f715e2f, 0x84971384, 0x53f5a653, 0xd168b9d1, 0x00000000, 0xed2cc1ed, 0x20604020, 0xfc1fe3fc, 0xb1c879b1, 0x5bedb65b, 0x6abed46a, 0xcb468dcb, 0xbed967be, 0x394b7239, 0x4ade944a, 0x4cd4984c, 0x58e8b058, 0xcf4a85cf, 0xd06bbbd0, 0xef2ac5ef, 0xaae54faa, 0xfb16edfb, 0x43c58643, 0x4dd79a4d, 0x33556633, 0x85941185, 0x45cf8a45, 0xf910e9f9, 0x02060402, 0x7f81fe7f, 0x50f0a050, 0x3c44783c, 0x9fba259f, 0xa8e34ba8, 0x51f3a251, 0xa3fe5da3, 0x40c08040, 0x8f8a058f, 0x92ad3f92, 0x9dbc219d, 0x38487038, 0xf504f1f5, 0xbcdf63bc, 0xb6c177b6, 0xda75afda, 0x21634221, 0x10302010, 0xff1ae5ff, 0xf30efdf3, 0xd26dbfd2, 0xcd4c81cd, 0x0c14180c, 0x13352613, 0xec2fc3ec, 0x5fe1be5f, 0x97a23597, 0x44cc8844, 0x17392e17, 0xc45793c4, 0xa7f255a7, 0x7e82fc7e, 0x3d477a3d, 0x64acc864, 0x5de7ba5d, 0x192b3219, 0x7395e673, 0x60a0c060, 0x81981981, 0x4fd19e4f, 0xdc7fa3dc, 0x22664422, 0x2a7e542a, 0x90ab3b90, 0x88830b88, 0x46ca8c46, 0xee29c7ee, 0xb8d36bb8, 0x143c2814, 0xde79a7de, 0x5ee2bc5e, 0x0b1d160b, 0xdb76addb, 0xe03bdbe0, 0x32566432, 0x3a4e743a, 0x0a1e140a, 0x49db9249, 0x060a0c06, 0x246c4824, 0x5ce4b85c, 0xc25d9fc2, 0xd36ebdd3, 0xacef43ac, 0x62a6c462, 0x91a83991, 0x95a43195, 0xe437d3e4, 0x798bf279, 0xe732d5e7, 0xc8438bc8, 0x37596e37, 0x6db7da6d, 0x8d8c018d, 0xd564b1d5, 0x4ed29c4e, 0xa9e049a9, 0x6cb4d86c, 0x56faac56, 0xf407f3f4, 0xea25cfea, 0x65afca65, 0x7a8ef47a, 0xaee947ae, 0x08181008, 0xbad56fba, 0x7888f078, 0x256f4a25, 0x2e725c2e, 0x1c24381c, 0xa6f157a6, 0xb4c773b4, 0xc65197c6, 0xe823cbe8, 0xdd7ca1dd, 0x749ce874, 0x1f213e1f, 0x4bdd964b, 0xbddc61bd, 0x8b860d8b, 0x8a850f8a, 0x7090e070, 0x3e427c3e, 0xb5c471b5, 0x66aacc66, 0x48d89048, 0x03050603, 0xf601f7f6, 0x0e121c0e, 0x61a3c261, 0x355f6a35, 0x57f9ae57, 0xb9d069b9, 0x86911786, 0xc15899c1, 0x1d273a1d, 0x9eb9279e, 0xe138d9e1, 0xf813ebf8, 0x98b32b98, 0x11332211, 0x69bbd269, 0xd970a9d9, 0x8e89078e, 0x94a73394, 0x9bb62d9b, 0x1e223c1e, 0x87921587, 0xe920c9e9, 0xce4987ce, 0x55ffaa55, 0x28785028, 0xdf7aa5df, 0x8c8f038c, 0xa1f859a1, 0x89800989, 0x0d171a0d, 0xbfda65bf, 0xe631d7e6, 0x42c68442, 0x68b8d068, 0x41c38241, 0x99b02999, 0x2d775a2d, 0x0f111e0f, 0xb0cb7bb0, 0x54fca854, 0xbbd66dbb, 0x163a2c16];\n var T4 = [0x6363a5c6, 0x7c7c84f8, 0x777799ee, 0x7b7b8df6, 0xf2f20dff, 0x6b6bbdd6, 0x6f6fb1de, 0xc5c55491, 0x30305060, 0x01010302, 0x6767a9ce, 0x2b2b7d56, 0xfefe19e7, 0xd7d762b5, 0xababe64d, 0x76769aec, 0xcaca458f, 0x82829d1f, 0xc9c94089, 0x7d7d87fa, 0xfafa15ef, 0x5959ebb2, 0x4747c98e, 0xf0f00bfb, 0xadadec41, 0xd4d467b3, 0xa2a2fd5f, 0xafafea45, 0x9c9cbf23, 0xa4a4f753, 0x727296e4, 0xc0c05b9b, 0xb7b7c275, 0xfdfd1ce1, 0x9393ae3d, 0x26266a4c, 0x36365a6c, 0x3f3f417e, 0xf7f702f5, 0xcccc4f83, 0x34345c68, 0xa5a5f451, 0xe5e534d1, 0xf1f108f9, 0x717193e2, 0xd8d873ab, 0x31315362, 0x15153f2a, 0x04040c08, 0xc7c75295, 0x23236546, 0xc3c35e9d, 0x18182830, 0x9696a137, 0x05050f0a, 0x9a9ab52f, 0x0707090e, 0x12123624, 0x80809b1b, 0xe2e23ddf, 0xebeb26cd, 0x2727694e, 0xb2b2cd7f, 0x75759fea, 0x09091b12, 0x83839e1d, 0x2c2c7458, 0x1a1a2e34, 0x1b1b2d36, 0x6e6eb2dc, 0x5a5aeeb4, 0xa0a0fb5b, 0x5252f6a4, 0x3b3b4d76, 0xd6d661b7, 0xb3b3ce7d, 0x29297b52, 0xe3e33edd, 0x2f2f715e, 0x84849713, 0x5353f5a6, 0xd1d168b9, 0x00000000, 0xeded2cc1, 0x20206040, 0xfcfc1fe3, 0xb1b1c879, 0x5b5bedb6, 0x6a6abed4, 0xcbcb468d, 0xbebed967, 0x39394b72, 0x4a4ade94, 0x4c4cd498, 0x5858e8b0, 0xcfcf4a85, 0xd0d06bbb, 0xefef2ac5, 0xaaaae54f, 0xfbfb16ed, 0x4343c586, 0x4d4dd79a, 0x33335566, 0x85859411, 0x4545cf8a, 0xf9f910e9, 0x02020604, 0x7f7f81fe, 0x5050f0a0, 0x3c3c4478, 0x9f9fba25, 0xa8a8e34b, 0x5151f3a2, 0xa3a3fe5d, 0x4040c080, 0x8f8f8a05, 0x9292ad3f, 0x9d9dbc21, 0x38384870, 0xf5f504f1, 0xbcbcdf63, 0xb6b6c177, 0xdada75af, 0x21216342, 0x10103020, 0xffff1ae5, 0xf3f30efd, 0xd2d26dbf, 0xcdcd4c81, 0x0c0c1418, 0x13133526, 0xecec2fc3, 0x5f5fe1be, 0x9797a235, 0x4444cc88, 0x1717392e, 0xc4c45793, 0xa7a7f255, 0x7e7e82fc, 0x3d3d477a, 0x6464acc8, 0x5d5de7ba, 0x19192b32, 0x737395e6, 0x6060a0c0, 0x81819819, 0x4f4fd19e, 0xdcdc7fa3, 0x22226644, 0x2a2a7e54, 0x9090ab3b, 0x8888830b, 0x4646ca8c, 0xeeee29c7, 0xb8b8d36b, 0x14143c28, 0xdede79a7, 0x5e5ee2bc, 0x0b0b1d16, 0xdbdb76ad, 0xe0e03bdb, 0x32325664, 0x3a3a4e74, 0x0a0a1e14, 0x4949db92, 0x06060a0c, 0x24246c48, 0x5c5ce4b8, 0xc2c25d9f, 0xd3d36ebd, 0xacacef43, 0x6262a6c4, 0x9191a839, 0x9595a431, 0xe4e437d3, 0x79798bf2, 0xe7e732d5, 0xc8c8438b, 0x3737596e, 0x6d6db7da, 0x8d8d8c01, 0xd5d564b1, 0x4e4ed29c, 0xa9a9e049, 0x6c6cb4d8, 0x5656faac, 0xf4f407f3, 0xeaea25cf, 0x6565afca, 0x7a7a8ef4, 0xaeaee947, 0x08081810, 0xbabad56f, 0x787888f0, 0x25256f4a, 0x2e2e725c, 0x1c1c2438, 0xa6a6f157, 0xb4b4c773, 0xc6c65197, 0xe8e823cb, 0xdddd7ca1, 0x74749ce8, 0x1f1f213e, 0x4b4bdd96, 0xbdbddc61, 0x8b8b860d, 0x8a8a850f, 0x707090e0, 0x3e3e427c, 0xb5b5c471, 0x6666aacc, 0x4848d890, 0x03030506, 0xf6f601f7, 0x0e0e121c, 0x6161a3c2, 0x35355f6a, 0x5757f9ae, 0xb9b9d069, 0x86869117, 0xc1c15899, 0x1d1d273a, 0x9e9eb927, 0xe1e138d9, 0xf8f813eb, 0x9898b32b, 0x11113322, 0x6969bbd2, 0xd9d970a9, 0x8e8e8907, 0x9494a733, 0x9b9bb62d, 0x1e1e223c, 0x87879215, 0xe9e920c9, 0xcece4987, 0x5555ffaa, 0x28287850, 0xdfdf7aa5, 0x8c8c8f03, 0xa1a1f859, 0x89898009, 0x0d0d171a, 0xbfbfda65, 0xe6e631d7, 0x4242c684, 0x6868b8d0, 0x4141c382, 0x9999b029, 0x2d2d775a, 0x0f0f111e, 0xb0b0cb7b, 0x5454fca8, 0xbbbbd66d, 0x16163a2c];\n\n // Transformations for decryption\n var T5 = [0x51f4a750, 0x7e416553, 0x1a17a4c3, 0x3a275e96, 0x3bab6bcb, 0x1f9d45f1, 0xacfa58ab, 0x4be30393, 0x2030fa55, 0xad766df6, 0x88cc7691, 0xf5024c25, 0x4fe5d7fc, 0xc52acbd7, 0x26354480, 0xb562a38f, 0xdeb15a49, 0x25ba1b67, 0x45ea0e98, 0x5dfec0e1, 0xc32f7502, 0x814cf012, 0x8d4697a3, 0x6bd3f9c6, 0x038f5fe7, 0x15929c95, 0xbf6d7aeb, 0x955259da, 0xd4be832d, 0x587421d3, 0x49e06929, 0x8ec9c844, 0x75c2896a, 0xf48e7978, 0x99583e6b, 0x27b971dd, 0xbee14fb6, 0xf088ad17, 0xc920ac66, 0x7dce3ab4, 0x63df4a18, 0xe51a3182, 0x97513360, 0x62537f45, 0xb16477e0, 0xbb6bae84, 0xfe81a01c, 0xf9082b94, 0x70486858, 0x8f45fd19, 0x94de6c87, 0x527bf8b7, 0xab73d323, 0x724b02e2, 0xe31f8f57, 0x6655ab2a, 0xb2eb2807, 0x2fb5c203, 0x86c57b9a, 0xd33708a5, 0x302887f2, 0x23bfa5b2, 0x02036aba, 0xed16825c, 0x8acf1c2b, 0xa779b492, 0xf307f2f0, 0x4e69e2a1, 0x65daf4cd, 0x0605bed5, 0xd134621f, 0xc4a6fe8a, 0x342e539d, 0xa2f355a0, 0x058ae132, 0xa4f6eb75, 0x0b83ec39, 0x4060efaa, 0x5e719f06, 0xbd6e1051, 0x3e218af9, 0x96dd063d, 0xdd3e05ae, 0x4de6bd46, 0x91548db5, 0x71c45d05, 0x0406d46f, 0x605015ff, 0x1998fb24, 0xd6bde997, 0x894043cc, 0x67d99e77, 0xb0e842bd, 0x07898b88, 0xe7195b38, 0x79c8eedb, 0xa17c0a47, 0x7c420fe9, 0xf8841ec9, 0x00000000, 0x09808683, 0x322bed48, 0x1e1170ac, 0x6c5a724e, 0xfd0efffb, 0x0f853856, 0x3daed51e, 0x362d3927, 0x0a0fd964, 0x685ca621, 0x9b5b54d1, 0x24362e3a, 0x0c0a67b1, 0x9357e70f, 0xb4ee96d2, 0x1b9b919e, 0x80c0c54f, 0x61dc20a2, 0x5a774b69, 0x1c121a16, 0xe293ba0a, 0xc0a02ae5, 0x3c22e043, 0x121b171d, 0x0e090d0b, 0xf28bc7ad, 0x2db6a8b9, 0x141ea9c8, 0x57f11985, 0xaf75074c, 0xee99ddbb, 0xa37f60fd, 0xf701269f, 0x5c72f5bc, 0x44663bc5, 0x5bfb7e34, 0x8b432976, 0xcb23c6dc, 0xb6edfc68, 0xb8e4f163, 0xd731dcca, 0x42638510, 0x13972240, 0x84c61120, 0x854a247d, 0xd2bb3df8, 0xaef93211, 0xc729a16d, 0x1d9e2f4b, 0xdcb230f3, 0x0d8652ec, 0x77c1e3d0, 0x2bb3166c, 0xa970b999, 0x119448fa, 0x47e96422, 0xa8fc8cc4, 0xa0f03f1a, 0x567d2cd8, 0x223390ef, 0x87494ec7, 0xd938d1c1, 0x8ccaa2fe, 0x98d40b36, 0xa6f581cf, 0xa57ade28, 0xdab78e26, 0x3fadbfa4, 0x2c3a9de4, 0x5078920d, 0x6a5fcc9b, 0x547e4662, 0xf68d13c2, 0x90d8b8e8, 0x2e39f75e, 0x82c3aff5, 0x9f5d80be, 0x69d0937c, 0x6fd52da9, 0xcf2512b3, 0xc8ac993b, 0x10187da7, 0xe89c636e, 0xdb3bbb7b, 0xcd267809, 0x6e5918f4, 0xec9ab701, 0x834f9aa8, 0xe6956e65, 0xaaffe67e, 0x21bccf08, 0xef15e8e6, 0xbae79bd9, 0x4a6f36ce, 0xea9f09d4, 0x29b07cd6, 0x31a4b2af, 0x2a3f2331, 0xc6a59430, 0x35a266c0, 0x744ebc37, 0xfc82caa6, 0xe090d0b0, 0x33a7d815, 0xf104984a, 0x41ecdaf7, 0x7fcd500e, 0x1791f62f, 0x764dd68d, 0x43efb04d, 0xccaa4d54, 0xe49604df, 0x9ed1b5e3, 0x4c6a881b, 0xc12c1fb8, 0x4665517f, 0x9d5eea04, 0x018c355d, 0xfa877473, 0xfb0b412e, 0xb3671d5a, 0x92dbd252, 0xe9105633, 0x6dd64713, 0x9ad7618c, 0x37a10c7a, 0x59f8148e, 0xeb133c89, 0xcea927ee, 0xb761c935, 0xe11ce5ed, 0x7a47b13c, 0x9cd2df59, 0x55f2733f, 0x1814ce79, 0x73c737bf, 0x53f7cdea, 0x5ffdaa5b, 0xdf3d6f14, 0x7844db86, 0xcaaff381, 0xb968c43e, 0x3824342c, 0xc2a3405f, 0x161dc372, 0xbce2250c, 0x283c498b, 0xff0d9541, 0x39a80171, 0x080cb3de, 0xd8b4e49c, 0x6456c190, 0x7bcb8461, 0xd532b670, 0x486c5c74, 0xd0b85742];\n var T6 = [0x5051f4a7, 0x537e4165, 0xc31a17a4, 0x963a275e, 0xcb3bab6b, 0xf11f9d45, 0xabacfa58, 0x934be303, 0x552030fa, 0xf6ad766d, 0x9188cc76, 0x25f5024c, 0xfc4fe5d7, 0xd7c52acb, 0x80263544, 0x8fb562a3, 0x49deb15a, 0x6725ba1b, 0x9845ea0e, 0xe15dfec0, 0x02c32f75, 0x12814cf0, 0xa38d4697, 0xc66bd3f9, 0xe7038f5f, 0x9515929c, 0xebbf6d7a, 0xda955259, 0x2dd4be83, 0xd3587421, 0x2949e069, 0x448ec9c8, 0x6a75c289, 0x78f48e79, 0x6b99583e, 0xdd27b971, 0xb6bee14f, 0x17f088ad, 0x66c920ac, 0xb47dce3a, 0x1863df4a, 0x82e51a31, 0x60975133, 0x4562537f, 0xe0b16477, 0x84bb6bae, 0x1cfe81a0, 0x94f9082b, 0x58704868, 0x198f45fd, 0x8794de6c, 0xb7527bf8, 0x23ab73d3, 0xe2724b02, 0x57e31f8f, 0x2a6655ab, 0x07b2eb28, 0x032fb5c2, 0x9a86c57b, 0xa5d33708, 0xf2302887, 0xb223bfa5, 0xba02036a, 0x5ced1682, 0x2b8acf1c, 0x92a779b4, 0xf0f307f2, 0xa14e69e2, 0xcd65daf4, 0xd50605be, 0x1fd13462, 0x8ac4a6fe, 0x9d342e53, 0xa0a2f355, 0x32058ae1, 0x75a4f6eb, 0x390b83ec, 0xaa4060ef, 0x065e719f, 0x51bd6e10, 0xf93e218a, 0x3d96dd06, 0xaedd3e05, 0x464de6bd, 0xb591548d, 0x0571c45d, 0x6f0406d4, 0xff605015, 0x241998fb, 0x97d6bde9, 0xcc894043, 0x7767d99e, 0xbdb0e842, 0x8807898b, 0x38e7195b, 0xdb79c8ee, 0x47a17c0a, 0xe97c420f, 0xc9f8841e, 0x00000000, 0x83098086, 0x48322bed, 0xac1e1170, 0x4e6c5a72, 0xfbfd0eff, 0x560f8538, 0x1e3daed5, 0x27362d39, 0x640a0fd9, 0x21685ca6, 0xd19b5b54, 0x3a24362e, 0xb10c0a67, 0x0f9357e7, 0xd2b4ee96, 0x9e1b9b91, 0x4f80c0c5, 0xa261dc20, 0x695a774b, 0x161c121a, 0x0ae293ba, 0xe5c0a02a, 0x433c22e0, 0x1d121b17, 0x0b0e090d, 0xadf28bc7, 0xb92db6a8, 0xc8141ea9, 0x8557f119, 0x4caf7507, 0xbbee99dd, 0xfda37f60, 0x9ff70126, 0xbc5c72f5, 0xc544663b, 0x345bfb7e, 0x768b4329, 0xdccb23c6, 0x68b6edfc, 0x63b8e4f1, 0xcad731dc, 0x10426385, 0x40139722, 0x2084c611, 0x7d854a24, 0xf8d2bb3d, 0x11aef932, 0x6dc729a1, 0x4b1d9e2f, 0xf3dcb230, 0xec0d8652, 0xd077c1e3, 0x6c2bb316, 0x99a970b9, 0xfa119448, 0x2247e964, 0xc4a8fc8c, 0x1aa0f03f, 0xd8567d2c, 0xef223390, 0xc787494e, 0xc1d938d1, 0xfe8ccaa2, 0x3698d40b, 0xcfa6f581, 0x28a57ade, 0x26dab78e, 0xa43fadbf, 0xe42c3a9d, 0x0d507892, 0x9b6a5fcc, 0x62547e46, 0xc2f68d13, 0xe890d8b8, 0x5e2e39f7, 0xf582c3af, 0xbe9f5d80, 0x7c69d093, 0xa96fd52d, 0xb3cf2512, 0x3bc8ac99, 0xa710187d, 0x6ee89c63, 0x7bdb3bbb, 0x09cd2678, 0xf46e5918, 0x01ec9ab7, 0xa8834f9a, 0x65e6956e, 0x7eaaffe6, 0x0821bccf, 0xe6ef15e8, 0xd9bae79b, 0xce4a6f36, 0xd4ea9f09, 0xd629b07c, 0xaf31a4b2, 0x312a3f23, 0x30c6a594, 0xc035a266, 0x37744ebc, 0xa6fc82ca, 0xb0e090d0, 0x1533a7d8, 0x4af10498, 0xf741ecda, 0x0e7fcd50, 0x2f1791f6, 0x8d764dd6, 0x4d43efb0, 0x54ccaa4d, 0xdfe49604, 0xe39ed1b5, 0x1b4c6a88, 0xb8c12c1f, 0x7f466551, 0x049d5eea, 0x5d018c35, 0x73fa8774, 0x2efb0b41, 0x5ab3671d, 0x5292dbd2, 0x33e91056, 0x136dd647, 0x8c9ad761, 0x7a37a10c, 0x8e59f814, 0x89eb133c, 0xeecea927, 0x35b761c9, 0xede11ce5, 0x3c7a47b1, 0x599cd2df, 0x3f55f273, 0x791814ce, 0xbf73c737, 0xea53f7cd, 0x5b5ffdaa, 0x14df3d6f, 0x867844db, 0x81caaff3, 0x3eb968c4, 0x2c382434, 0x5fc2a340, 0x72161dc3, 0x0cbce225, 0x8b283c49, 0x41ff0d95, 0x7139a801, 0xde080cb3, 0x9cd8b4e4, 0x906456c1, 0x617bcb84, 0x70d532b6, 0x74486c5c, 0x42d0b857];\n var T7 = [0xa75051f4, 0x65537e41, 0xa4c31a17, 0x5e963a27, 0x6bcb3bab, 0x45f11f9d, 0x58abacfa, 0x03934be3, 0xfa552030, 0x6df6ad76, 0x769188cc, 0x4c25f502, 0xd7fc4fe5, 0xcbd7c52a, 0x44802635, 0xa38fb562, 0x5a49deb1, 0x1b6725ba, 0x0e9845ea, 0xc0e15dfe, 0x7502c32f, 0xf012814c, 0x97a38d46, 0xf9c66bd3, 0x5fe7038f, 0x9c951592, 0x7aebbf6d, 0x59da9552, 0x832dd4be, 0x21d35874, 0x692949e0, 0xc8448ec9, 0x896a75c2, 0x7978f48e, 0x3e6b9958, 0x71dd27b9, 0x4fb6bee1, 0xad17f088, 0xac66c920, 0x3ab47dce, 0x4a1863df, 0x3182e51a, 0x33609751, 0x7f456253, 0x77e0b164, 0xae84bb6b, 0xa01cfe81, 0x2b94f908, 0x68587048, 0xfd198f45, 0x6c8794de, 0xf8b7527b, 0xd323ab73, 0x02e2724b, 0x8f57e31f, 0xab2a6655, 0x2807b2eb, 0xc2032fb5, 0x7b9a86c5, 0x08a5d337, 0x87f23028, 0xa5b223bf, 0x6aba0203, 0x825ced16, 0x1c2b8acf, 0xb492a779, 0xf2f0f307, 0xe2a14e69, 0xf4cd65da, 0xbed50605, 0x621fd134, 0xfe8ac4a6, 0x539d342e, 0x55a0a2f3, 0xe132058a, 0xeb75a4f6, 0xec390b83, 0xefaa4060, 0x9f065e71, 0x1051bd6e, 0x8af93e21, 0x063d96dd, 0x05aedd3e, 0xbd464de6, 0x8db59154, 0x5d0571c4, 0xd46f0406, 0x15ff6050, 0xfb241998, 0xe997d6bd, 0x43cc8940, 0x9e7767d9, 0x42bdb0e8, 0x8b880789, 0x5b38e719, 0xeedb79c8, 0x0a47a17c, 0x0fe97c42, 0x1ec9f884, 0x00000000, 0x86830980, 0xed48322b, 0x70ac1e11, 0x724e6c5a, 0xfffbfd0e, 0x38560f85, 0xd51e3dae, 0x3927362d, 0xd9640a0f, 0xa621685c, 0x54d19b5b, 0x2e3a2436, 0x67b10c0a, 0xe70f9357, 0x96d2b4ee, 0x919e1b9b, 0xc54f80c0, 0x20a261dc, 0x4b695a77, 0x1a161c12, 0xba0ae293, 0x2ae5c0a0, 0xe0433c22, 0x171d121b, 0x0d0b0e09, 0xc7adf28b, 0xa8b92db6, 0xa9c8141e, 0x198557f1, 0x074caf75, 0xddbbee99, 0x60fda37f, 0x269ff701, 0xf5bc5c72, 0x3bc54466, 0x7e345bfb, 0x29768b43, 0xc6dccb23, 0xfc68b6ed, 0xf163b8e4, 0xdccad731, 0x85104263, 0x22401397, 0x112084c6, 0x247d854a, 0x3df8d2bb, 0x3211aef9, 0xa16dc729, 0x2f4b1d9e, 0x30f3dcb2, 0x52ec0d86, 0xe3d077c1, 0x166c2bb3, 0xb999a970, 0x48fa1194, 0x642247e9, 0x8cc4a8fc, 0x3f1aa0f0, 0x2cd8567d, 0x90ef2233, 0x4ec78749, 0xd1c1d938, 0xa2fe8cca, 0x0b3698d4, 0x81cfa6f5, 0xde28a57a, 0x8e26dab7, 0xbfa43fad, 0x9de42c3a, 0x920d5078, 0xcc9b6a5f, 0x4662547e, 0x13c2f68d, 0xb8e890d8, 0xf75e2e39, 0xaff582c3, 0x80be9f5d, 0x937c69d0, 0x2da96fd5, 0x12b3cf25, 0x993bc8ac, 0x7da71018, 0x636ee89c, 0xbb7bdb3b, 0x7809cd26, 0x18f46e59, 0xb701ec9a, 0x9aa8834f, 0x6e65e695, 0xe67eaaff, 0xcf0821bc, 0xe8e6ef15, 0x9bd9bae7, 0x36ce4a6f, 0x09d4ea9f, 0x7cd629b0, 0xb2af31a4, 0x23312a3f, 0x9430c6a5, 0x66c035a2, 0xbc37744e, 0xcaa6fc82, 0xd0b0e090, 0xd81533a7, 0x984af104, 0xdaf741ec, 0x500e7fcd, 0xf62f1791, 0xd68d764d, 0xb04d43ef, 0x4d54ccaa, 0x04dfe496, 0xb5e39ed1, 0x881b4c6a, 0x1fb8c12c, 0x517f4665, 0xea049d5e, 0x355d018c, 0x7473fa87, 0x412efb0b, 0x1d5ab367, 0xd25292db, 0x5633e910, 0x47136dd6, 0x618c9ad7, 0x0c7a37a1, 0x148e59f8, 0x3c89eb13, 0x27eecea9, 0xc935b761, 0xe5ede11c, 0xb13c7a47, 0xdf599cd2, 0x733f55f2, 0xce791814, 0x37bf73c7, 0xcdea53f7, 0xaa5b5ffd, 0x6f14df3d, 0xdb867844, 0xf381caaf, 0xc43eb968, 0x342c3824, 0x405fc2a3, 0xc372161d, 0x250cbce2, 0x498b283c, 0x9541ff0d, 0x017139a8, 0xb3de080c, 0xe49cd8b4, 0xc1906456, 0x84617bcb, 0xb670d532, 0x5c74486c, 0x5742d0b8];\n var T8 = [0xf4a75051, 0x4165537e, 0x17a4c31a, 0x275e963a, 0xab6bcb3b, 0x9d45f11f, 0xfa58abac, 0xe303934b, 0x30fa5520, 0x766df6ad, 0xcc769188, 0x024c25f5, 0xe5d7fc4f, 0x2acbd7c5, 0x35448026, 0x62a38fb5, 0xb15a49de, 0xba1b6725, 0xea0e9845, 0xfec0e15d, 0x2f7502c3, 0x4cf01281, 0x4697a38d, 0xd3f9c66b, 0x8f5fe703, 0x929c9515, 0x6d7aebbf, 0x5259da95, 0xbe832dd4, 0x7421d358, 0xe0692949, 0xc9c8448e, 0xc2896a75, 0x8e7978f4, 0x583e6b99, 0xb971dd27, 0xe14fb6be, 0x88ad17f0, 0x20ac66c9, 0xce3ab47d, 0xdf4a1863, 0x1a3182e5, 0x51336097, 0x537f4562, 0x6477e0b1, 0x6bae84bb, 0x81a01cfe, 0x082b94f9, 0x48685870, 0x45fd198f, 0xde6c8794, 0x7bf8b752, 0x73d323ab, 0x4b02e272, 0x1f8f57e3, 0x55ab2a66, 0xeb2807b2, 0xb5c2032f, 0xc57b9a86, 0x3708a5d3, 0x2887f230, 0xbfa5b223, 0x036aba02, 0x16825ced, 0xcf1c2b8a, 0x79b492a7, 0x07f2f0f3, 0x69e2a14e, 0xdaf4cd65, 0x05bed506, 0x34621fd1, 0xa6fe8ac4, 0x2e539d34, 0xf355a0a2, 0x8ae13205, 0xf6eb75a4, 0x83ec390b, 0x60efaa40, 0x719f065e, 0x6e1051bd, 0x218af93e, 0xdd063d96, 0x3e05aedd, 0xe6bd464d, 0x548db591, 0xc45d0571, 0x06d46f04, 0x5015ff60, 0x98fb2419, 0xbde997d6, 0x4043cc89, 0xd99e7767, 0xe842bdb0, 0x898b8807, 0x195b38e7, 0xc8eedb79, 0x7c0a47a1, 0x420fe97c, 0x841ec9f8, 0x00000000, 0x80868309, 0x2bed4832, 0x1170ac1e, 0x5a724e6c, 0x0efffbfd, 0x8538560f, 0xaed51e3d, 0x2d392736, 0x0fd9640a, 0x5ca62168, 0x5b54d19b, 0x362e3a24, 0x0a67b10c, 0x57e70f93, 0xee96d2b4, 0x9b919e1b, 0xc0c54f80, 0xdc20a261, 0x774b695a, 0x121a161c, 0x93ba0ae2, 0xa02ae5c0, 0x22e0433c, 0x1b171d12, 0x090d0b0e, 0x8bc7adf2, 0xb6a8b92d, 0x1ea9c814, 0xf1198557, 0x75074caf, 0x99ddbbee, 0x7f60fda3, 0x01269ff7, 0x72f5bc5c, 0x663bc544, 0xfb7e345b, 0x4329768b, 0x23c6dccb, 0xedfc68b6, 0xe4f163b8, 0x31dccad7, 0x63851042, 0x97224013, 0xc6112084, 0x4a247d85, 0xbb3df8d2, 0xf93211ae, 0x29a16dc7, 0x9e2f4b1d, 0xb230f3dc, 0x8652ec0d, 0xc1e3d077, 0xb3166c2b, 0x70b999a9, 0x9448fa11, 0xe9642247, 0xfc8cc4a8, 0xf03f1aa0, 0x7d2cd856, 0x3390ef22, 0x494ec787, 0x38d1c1d9, 0xcaa2fe8c, 0xd40b3698, 0xf581cfa6, 0x7ade28a5, 0xb78e26da, 0xadbfa43f, 0x3a9de42c, 0x78920d50, 0x5fcc9b6a, 0x7e466254, 0x8d13c2f6, 0xd8b8e890, 0x39f75e2e, 0xc3aff582, 0x5d80be9f, 0xd0937c69, 0xd52da96f, 0x2512b3cf, 0xac993bc8, 0x187da710, 0x9c636ee8, 0x3bbb7bdb, 0x267809cd, 0x5918f46e, 0x9ab701ec, 0x4f9aa883, 0x956e65e6, 0xffe67eaa, 0xbccf0821, 0x15e8e6ef, 0xe79bd9ba, 0x6f36ce4a, 0x9f09d4ea, 0xb07cd629, 0xa4b2af31, 0x3f23312a, 0xa59430c6, 0xa266c035, 0x4ebc3774, 0x82caa6fc, 0x90d0b0e0, 0xa7d81533, 0x04984af1, 0xecdaf741, 0xcd500e7f, 0x91f62f17, 0x4dd68d76, 0xefb04d43, 0xaa4d54cc, 0x9604dfe4, 0xd1b5e39e, 0x6a881b4c, 0x2c1fb8c1, 0x65517f46, 0x5eea049d, 0x8c355d01, 0x877473fa, 0x0b412efb, 0x671d5ab3, 0xdbd25292, 0x105633e9, 0xd647136d, 0xd7618c9a, 0xa10c7a37, 0xf8148e59, 0x133c89eb, 0xa927eece, 0x61c935b7, 0x1ce5ede1, 0x47b13c7a, 0xd2df599c, 0xf2733f55, 0x14ce7918, 0xc737bf73, 0xf7cdea53, 0xfdaa5b5f, 0x3d6f14df, 0x44db8678, 0xaff381ca, 0x68c43eb9, 0x24342c38, 0xa3405fc2, 0x1dc37216, 0xe2250cbc, 0x3c498b28, 0x0d9541ff, 0xa8017139, 0x0cb3de08, 0xb4e49cd8, 0x56c19064, 0xcb84617b, 0x32b670d5, 0x6c5c7448, 0xb85742d0];\n\n // Transformations for decryption key expansion\n var U1 = [0x00000000, 0x0e090d0b, 0x1c121a16, 0x121b171d, 0x3824342c, 0x362d3927, 0x24362e3a, 0x2a3f2331, 0x70486858, 0x7e416553, 0x6c5a724e, 0x62537f45, 0x486c5c74, 0x4665517f, 0x547e4662, 0x5a774b69, 0xe090d0b0, 0xee99ddbb, 0xfc82caa6, 0xf28bc7ad, 0xd8b4e49c, 0xd6bde997, 0xc4a6fe8a, 0xcaaff381, 0x90d8b8e8, 0x9ed1b5e3, 0x8ccaa2fe, 0x82c3aff5, 0xa8fc8cc4, 0xa6f581cf, 0xb4ee96d2, 0xbae79bd9, 0xdb3bbb7b, 0xd532b670, 0xc729a16d, 0xc920ac66, 0xe31f8f57, 0xed16825c, 0xff0d9541, 0xf104984a, 0xab73d323, 0xa57ade28, 0xb761c935, 0xb968c43e, 0x9357e70f, 0x9d5eea04, 0x8f45fd19, 0x814cf012, 0x3bab6bcb, 0x35a266c0, 0x27b971dd, 0x29b07cd6, 0x038f5fe7, 0x0d8652ec, 0x1f9d45f1, 0x119448fa, 0x4be30393, 0x45ea0e98, 0x57f11985, 0x59f8148e, 0x73c737bf, 0x7dce3ab4, 0x6fd52da9, 0x61dc20a2, 0xad766df6, 0xa37f60fd, 0xb16477e0, 0xbf6d7aeb, 0x955259da, 0x9b5b54d1, 0x894043cc, 0x87494ec7, 0xdd3e05ae, 0xd33708a5, 0xc12c1fb8, 0xcf2512b3, 0xe51a3182, 0xeb133c89, 0xf9082b94, 0xf701269f, 0x4de6bd46, 0x43efb04d, 0x51f4a750, 0x5ffdaa5b, 0x75c2896a, 0x7bcb8461, 0x69d0937c, 0x67d99e77, 0x3daed51e, 0x33a7d815, 0x21bccf08, 0x2fb5c203, 0x058ae132, 0x0b83ec39, 0x1998fb24, 0x1791f62f, 0x764dd68d, 0x7844db86, 0x6a5fcc9b, 0x6456c190, 0x4e69e2a1, 0x4060efaa, 0x527bf8b7, 0x5c72f5bc, 0x0605bed5, 0x080cb3de, 0x1a17a4c3, 0x141ea9c8, 0x3e218af9, 0x302887f2, 0x223390ef, 0x2c3a9de4, 0x96dd063d, 0x98d40b36, 0x8acf1c2b, 0x84c61120, 0xaef93211, 0xa0f03f1a, 0xb2eb2807, 0xbce2250c, 0xe6956e65, 0xe89c636e, 0xfa877473, 0xf48e7978, 0xdeb15a49, 0xd0b85742, 0xc2a3405f, 0xccaa4d54, 0x41ecdaf7, 0x4fe5d7fc, 0x5dfec0e1, 0x53f7cdea, 0x79c8eedb, 0x77c1e3d0, 0x65daf4cd, 0x6bd3f9c6, 0x31a4b2af, 0x3fadbfa4, 0x2db6a8b9, 0x23bfa5b2, 0x09808683, 0x07898b88, 0x15929c95, 0x1b9b919e, 0xa17c0a47, 0xaf75074c, 0xbd6e1051, 0xb3671d5a, 0x99583e6b, 0x97513360, 0x854a247d, 0x8b432976, 0xd134621f, 0xdf3d6f14, 0xcd267809, 0xc32f7502, 0xe9105633, 0xe7195b38, 0xf5024c25, 0xfb0b412e, 0x9ad7618c, 0x94de6c87, 0x86c57b9a, 0x88cc7691, 0xa2f355a0, 0xacfa58ab, 0xbee14fb6, 0xb0e842bd, 0xea9f09d4, 0xe49604df, 0xf68d13c2, 0xf8841ec9, 0xd2bb3df8, 0xdcb230f3, 0xcea927ee, 0xc0a02ae5, 0x7a47b13c, 0x744ebc37, 0x6655ab2a, 0x685ca621, 0x42638510, 0x4c6a881b, 0x5e719f06, 0x5078920d, 0x0a0fd964, 0x0406d46f, 0x161dc372, 0x1814ce79, 0x322bed48, 0x3c22e043, 0x2e39f75e, 0x2030fa55, 0xec9ab701, 0xe293ba0a, 0xf088ad17, 0xfe81a01c, 0xd4be832d, 0xdab78e26, 0xc8ac993b, 0xc6a59430, 0x9cd2df59, 0x92dbd252, 0x80c0c54f, 0x8ec9c844, 0xa4f6eb75, 0xaaffe67e, 0xb8e4f163, 0xb6edfc68, 0x0c0a67b1, 0x02036aba, 0x10187da7, 0x1e1170ac, 0x342e539d, 0x3a275e96, 0x283c498b, 0x26354480, 0x7c420fe9, 0x724b02e2, 0x605015ff, 0x6e5918f4, 0x44663bc5, 0x4a6f36ce, 0x587421d3, 0x567d2cd8, 0x37a10c7a, 0x39a80171, 0x2bb3166c, 0x25ba1b67, 0x0f853856, 0x018c355d, 0x13972240, 0x1d9e2f4b, 0x47e96422, 0x49e06929, 0x5bfb7e34, 0x55f2733f, 0x7fcd500e, 0x71c45d05, 0x63df4a18, 0x6dd64713, 0xd731dcca, 0xd938d1c1, 0xcb23c6dc, 0xc52acbd7, 0xef15e8e6, 0xe11ce5ed, 0xf307f2f0, 0xfd0efffb, 0xa779b492, 0xa970b999, 0xbb6bae84, 0xb562a38f, 0x9f5d80be, 0x91548db5, 0x834f9aa8, 0x8d4697a3];\n var U2 = [0x00000000, 0x0b0e090d, 0x161c121a, 0x1d121b17, 0x2c382434, 0x27362d39, 0x3a24362e, 0x312a3f23, 0x58704868, 0x537e4165, 0x4e6c5a72, 0x4562537f, 0x74486c5c, 0x7f466551, 0x62547e46, 0x695a774b, 0xb0e090d0, 0xbbee99dd, 0xa6fc82ca, 0xadf28bc7, 0x9cd8b4e4, 0x97d6bde9, 0x8ac4a6fe, 0x81caaff3, 0xe890d8b8, 0xe39ed1b5, 0xfe8ccaa2, 0xf582c3af, 0xc4a8fc8c, 0xcfa6f581, 0xd2b4ee96, 0xd9bae79b, 0x7bdb3bbb, 0x70d532b6, 0x6dc729a1, 0x66c920ac, 0x57e31f8f, 0x5ced1682, 0x41ff0d95, 0x4af10498, 0x23ab73d3, 0x28a57ade, 0x35b761c9, 0x3eb968c4, 0x0f9357e7, 0x049d5eea, 0x198f45fd, 0x12814cf0, 0xcb3bab6b, 0xc035a266, 0xdd27b971, 0xd629b07c, 0xe7038f5f, 0xec0d8652, 0xf11f9d45, 0xfa119448, 0x934be303, 0x9845ea0e, 0x8557f119, 0x8e59f814, 0xbf73c737, 0xb47dce3a, 0xa96fd52d, 0xa261dc20, 0xf6ad766d, 0xfda37f60, 0xe0b16477, 0xebbf6d7a, 0xda955259, 0xd19b5b54, 0xcc894043, 0xc787494e, 0xaedd3e05, 0xa5d33708, 0xb8c12c1f, 0xb3cf2512, 0x82e51a31, 0x89eb133c, 0x94f9082b, 0x9ff70126, 0x464de6bd, 0x4d43efb0, 0x5051f4a7, 0x5b5ffdaa, 0x6a75c289, 0x617bcb84, 0x7c69d093, 0x7767d99e, 0x1e3daed5, 0x1533a7d8, 0x0821bccf, 0x032fb5c2, 0x32058ae1, 0x390b83ec, 0x241998fb, 0x2f1791f6, 0x8d764dd6, 0x867844db, 0x9b6a5fcc, 0x906456c1, 0xa14e69e2, 0xaa4060ef, 0xb7527bf8, 0xbc5c72f5, 0xd50605be, 0xde080cb3, 0xc31a17a4, 0xc8141ea9, 0xf93e218a, 0xf2302887, 0xef223390, 0xe42c3a9d, 0x3d96dd06, 0x3698d40b, 0x2b8acf1c, 0x2084c611, 0x11aef932, 0x1aa0f03f, 0x07b2eb28, 0x0cbce225, 0x65e6956e, 0x6ee89c63, 0x73fa8774, 0x78f48e79, 0x49deb15a, 0x42d0b857, 0x5fc2a340, 0x54ccaa4d, 0xf741ecda, 0xfc4fe5d7, 0xe15dfec0, 0xea53f7cd, 0xdb79c8ee, 0xd077c1e3, 0xcd65daf4, 0xc66bd3f9, 0xaf31a4b2, 0xa43fadbf, 0xb92db6a8, 0xb223bfa5, 0x83098086, 0x8807898b, 0x9515929c, 0x9e1b9b91, 0x47a17c0a, 0x4caf7507, 0x51bd6e10, 0x5ab3671d, 0x6b99583e, 0x60975133, 0x7d854a24, 0x768b4329, 0x1fd13462, 0x14df3d6f, 0x09cd2678, 0x02c32f75, 0x33e91056, 0x38e7195b, 0x25f5024c, 0x2efb0b41, 0x8c9ad761, 0x8794de6c, 0x9a86c57b, 0x9188cc76, 0xa0a2f355, 0xabacfa58, 0xb6bee14f, 0xbdb0e842, 0xd4ea9f09, 0xdfe49604, 0xc2f68d13, 0xc9f8841e, 0xf8d2bb3d, 0xf3dcb230, 0xeecea927, 0xe5c0a02a, 0x3c7a47b1, 0x37744ebc, 0x2a6655ab, 0x21685ca6, 0x10426385, 0x1b4c6a88, 0x065e719f, 0x0d507892, 0x640a0fd9, 0x6f0406d4, 0x72161dc3, 0x791814ce, 0x48322bed, 0x433c22e0, 0x5e2e39f7, 0x552030fa, 0x01ec9ab7, 0x0ae293ba, 0x17f088ad, 0x1cfe81a0, 0x2dd4be83, 0x26dab78e, 0x3bc8ac99, 0x30c6a594, 0x599cd2df, 0x5292dbd2, 0x4f80c0c5, 0x448ec9c8, 0x75a4f6eb, 0x7eaaffe6, 0x63b8e4f1, 0x68b6edfc, 0xb10c0a67, 0xba02036a, 0xa710187d, 0xac1e1170, 0x9d342e53, 0x963a275e, 0x8b283c49, 0x80263544, 0xe97c420f, 0xe2724b02, 0xff605015, 0xf46e5918, 0xc544663b, 0xce4a6f36, 0xd3587421, 0xd8567d2c, 0x7a37a10c, 0x7139a801, 0x6c2bb316, 0x6725ba1b, 0x560f8538, 0x5d018c35, 0x40139722, 0x4b1d9e2f, 0x2247e964, 0x2949e069, 0x345bfb7e, 0x3f55f273, 0x0e7fcd50, 0x0571c45d, 0x1863df4a, 0x136dd647, 0xcad731dc, 0xc1d938d1, 0xdccb23c6, 0xd7c52acb, 0xe6ef15e8, 0xede11ce5, 0xf0f307f2, 0xfbfd0eff, 0x92a779b4, 0x99a970b9, 0x84bb6bae, 0x8fb562a3, 0xbe9f5d80, 0xb591548d, 0xa8834f9a, 0xa38d4697];\n var U3 = [0x00000000, 0x0d0b0e09, 0x1a161c12, 0x171d121b, 0x342c3824, 0x3927362d, 0x2e3a2436, 0x23312a3f, 0x68587048, 0x65537e41, 0x724e6c5a, 0x7f456253, 0x5c74486c, 0x517f4665, 0x4662547e, 0x4b695a77, 0xd0b0e090, 0xddbbee99, 0xcaa6fc82, 0xc7adf28b, 0xe49cd8b4, 0xe997d6bd, 0xfe8ac4a6, 0xf381caaf, 0xb8e890d8, 0xb5e39ed1, 0xa2fe8cca, 0xaff582c3, 0x8cc4a8fc, 0x81cfa6f5, 0x96d2b4ee, 0x9bd9bae7, 0xbb7bdb3b, 0xb670d532, 0xa16dc729, 0xac66c920, 0x8f57e31f, 0x825ced16, 0x9541ff0d, 0x984af104, 0xd323ab73, 0xde28a57a, 0xc935b761, 0xc43eb968, 0xe70f9357, 0xea049d5e, 0xfd198f45, 0xf012814c, 0x6bcb3bab, 0x66c035a2, 0x71dd27b9, 0x7cd629b0, 0x5fe7038f, 0x52ec0d86, 0x45f11f9d, 0x48fa1194, 0x03934be3, 0x0e9845ea, 0x198557f1, 0x148e59f8, 0x37bf73c7, 0x3ab47dce, 0x2da96fd5, 0x20a261dc, 0x6df6ad76, 0x60fda37f, 0x77e0b164, 0x7aebbf6d, 0x59da9552, 0x54d19b5b, 0x43cc8940, 0x4ec78749, 0x05aedd3e, 0x08a5d337, 0x1fb8c12c, 0x12b3cf25, 0x3182e51a, 0x3c89eb13, 0x2b94f908, 0x269ff701, 0xbd464de6, 0xb04d43ef, 0xa75051f4, 0xaa5b5ffd, 0x896a75c2, 0x84617bcb, 0x937c69d0, 0x9e7767d9, 0xd51e3dae, 0xd81533a7, 0xcf0821bc, 0xc2032fb5, 0xe132058a, 0xec390b83, 0xfb241998, 0xf62f1791, 0xd68d764d, 0xdb867844, 0xcc9b6a5f, 0xc1906456, 0xe2a14e69, 0xefaa4060, 0xf8b7527b, 0xf5bc5c72, 0xbed50605, 0xb3de080c, 0xa4c31a17, 0xa9c8141e, 0x8af93e21, 0x87f23028, 0x90ef2233, 0x9de42c3a, 0x063d96dd, 0x0b3698d4, 0x1c2b8acf, 0x112084c6, 0x3211aef9, 0x3f1aa0f0, 0x2807b2eb, 0x250cbce2, 0x6e65e695, 0x636ee89c, 0x7473fa87, 0x7978f48e, 0x5a49deb1, 0x5742d0b8, 0x405fc2a3, 0x4d54ccaa, 0xdaf741ec, 0xd7fc4fe5, 0xc0e15dfe, 0xcdea53f7, 0xeedb79c8, 0xe3d077c1, 0xf4cd65da, 0xf9c66bd3, 0xb2af31a4, 0xbfa43fad, 0xa8b92db6, 0xa5b223bf, 0x86830980, 0x8b880789, 0x9c951592, 0x919e1b9b, 0x0a47a17c, 0x074caf75, 0x1051bd6e, 0x1d5ab367, 0x3e6b9958, 0x33609751, 0x247d854a, 0x29768b43, 0x621fd134, 0x6f14df3d, 0x7809cd26, 0x7502c32f, 0x5633e910, 0x5b38e719, 0x4c25f502, 0x412efb0b, 0x618c9ad7, 0x6c8794de, 0x7b9a86c5, 0x769188cc, 0x55a0a2f3, 0x58abacfa, 0x4fb6bee1, 0x42bdb0e8, 0x09d4ea9f, 0x04dfe496, 0x13c2f68d, 0x1ec9f884, 0x3df8d2bb, 0x30f3dcb2, 0x27eecea9, 0x2ae5c0a0, 0xb13c7a47, 0xbc37744e, 0xab2a6655, 0xa621685c, 0x85104263, 0x881b4c6a, 0x9f065e71, 0x920d5078, 0xd9640a0f, 0xd46f0406, 0xc372161d, 0xce791814, 0xed48322b, 0xe0433c22, 0xf75e2e39, 0xfa552030, 0xb701ec9a, 0xba0ae293, 0xad17f088, 0xa01cfe81, 0x832dd4be, 0x8e26dab7, 0x993bc8ac, 0x9430c6a5, 0xdf599cd2, 0xd25292db, 0xc54f80c0, 0xc8448ec9, 0xeb75a4f6, 0xe67eaaff, 0xf163b8e4, 0xfc68b6ed, 0x67b10c0a, 0x6aba0203, 0x7da71018, 0x70ac1e11, 0x539d342e, 0x5e963a27, 0x498b283c, 0x44802635, 0x0fe97c42, 0x02e2724b, 0x15ff6050, 0x18f46e59, 0x3bc54466, 0x36ce4a6f, 0x21d35874, 0x2cd8567d, 0x0c7a37a1, 0x017139a8, 0x166c2bb3, 0x1b6725ba, 0x38560f85, 0x355d018c, 0x22401397, 0x2f4b1d9e, 0x642247e9, 0x692949e0, 0x7e345bfb, 0x733f55f2, 0x500e7fcd, 0x5d0571c4, 0x4a1863df, 0x47136dd6, 0xdccad731, 0xd1c1d938, 0xc6dccb23, 0xcbd7c52a, 0xe8e6ef15, 0xe5ede11c, 0xf2f0f307, 0xfffbfd0e, 0xb492a779, 0xb999a970, 0xae84bb6b, 0xa38fb562, 0x80be9f5d, 0x8db59154, 0x9aa8834f, 0x97a38d46];\n var U4 = [0x00000000, 0x090d0b0e, 0x121a161c, 0x1b171d12, 0x24342c38, 0x2d392736, 0x362e3a24, 0x3f23312a, 0x48685870, 0x4165537e, 0x5a724e6c, 0x537f4562, 0x6c5c7448, 0x65517f46, 0x7e466254, 0x774b695a, 0x90d0b0e0, 0x99ddbbee, 0x82caa6fc, 0x8bc7adf2, 0xb4e49cd8, 0xbde997d6, 0xa6fe8ac4, 0xaff381ca, 0xd8b8e890, 0xd1b5e39e, 0xcaa2fe8c, 0xc3aff582, 0xfc8cc4a8, 0xf581cfa6, 0xee96d2b4, 0xe79bd9ba, 0x3bbb7bdb, 0x32b670d5, 0x29a16dc7, 0x20ac66c9, 0x1f8f57e3, 0x16825ced, 0x0d9541ff, 0x04984af1, 0x73d323ab, 0x7ade28a5, 0x61c935b7, 0x68c43eb9, 0x57e70f93, 0x5eea049d, 0x45fd198f, 0x4cf01281, 0xab6bcb3b, 0xa266c035, 0xb971dd27, 0xb07cd629, 0x8f5fe703, 0x8652ec0d, 0x9d45f11f, 0x9448fa11, 0xe303934b, 0xea0e9845, 0xf1198557, 0xf8148e59, 0xc737bf73, 0xce3ab47d, 0xd52da96f, 0xdc20a261, 0x766df6ad, 0x7f60fda3, 0x6477e0b1, 0x6d7aebbf, 0x5259da95, 0x5b54d19b, 0x4043cc89, 0x494ec787, 0x3e05aedd, 0x3708a5d3, 0x2c1fb8c1, 0x2512b3cf, 0x1a3182e5, 0x133c89eb, 0x082b94f9, 0x01269ff7, 0xe6bd464d, 0xefb04d43, 0xf4a75051, 0xfdaa5b5f, 0xc2896a75, 0xcb84617b, 0xd0937c69, 0xd99e7767, 0xaed51e3d, 0xa7d81533, 0xbccf0821, 0xb5c2032f, 0x8ae13205, 0x83ec390b, 0x98fb2419, 0x91f62f17, 0x4dd68d76, 0x44db8678, 0x5fcc9b6a, 0x56c19064, 0x69e2a14e, 0x60efaa40, 0x7bf8b752, 0x72f5bc5c, 0x05bed506, 0x0cb3de08, 0x17a4c31a, 0x1ea9c814, 0x218af93e, 0x2887f230, 0x3390ef22, 0x3a9de42c, 0xdd063d96, 0xd40b3698, 0xcf1c2b8a, 0xc6112084, 0xf93211ae, 0xf03f1aa0, 0xeb2807b2, 0xe2250cbc, 0x956e65e6, 0x9c636ee8, 0x877473fa, 0x8e7978f4, 0xb15a49de, 0xb85742d0, 0xa3405fc2, 0xaa4d54cc, 0xecdaf741, 0xe5d7fc4f, 0xfec0e15d, 0xf7cdea53, 0xc8eedb79, 0xc1e3d077, 0xdaf4cd65, 0xd3f9c66b, 0xa4b2af31, 0xadbfa43f, 0xb6a8b92d, 0xbfa5b223, 0x80868309, 0x898b8807, 0x929c9515, 0x9b919e1b, 0x7c0a47a1, 0x75074caf, 0x6e1051bd, 0x671d5ab3, 0x583e6b99, 0x51336097, 0x4a247d85, 0x4329768b, 0x34621fd1, 0x3d6f14df, 0x267809cd, 0x2f7502c3, 0x105633e9, 0x195b38e7, 0x024c25f5, 0x0b412efb, 0xd7618c9a, 0xde6c8794, 0xc57b9a86, 0xcc769188, 0xf355a0a2, 0xfa58abac, 0xe14fb6be, 0xe842bdb0, 0x9f09d4ea, 0x9604dfe4, 0x8d13c2f6, 0x841ec9f8, 0xbb3df8d2, 0xb230f3dc, 0xa927eece, 0xa02ae5c0, 0x47b13c7a, 0x4ebc3774, 0x55ab2a66, 0x5ca62168, 0x63851042, 0x6a881b4c, 0x719f065e, 0x78920d50, 0x0fd9640a, 0x06d46f04, 0x1dc37216, 0x14ce7918, 0x2bed4832, 0x22e0433c, 0x39f75e2e, 0x30fa5520, 0x9ab701ec, 0x93ba0ae2, 0x88ad17f0, 0x81a01cfe, 0xbe832dd4, 0xb78e26da, 0xac993bc8, 0xa59430c6, 0xd2df599c, 0xdbd25292, 0xc0c54f80, 0xc9c8448e, 0xf6eb75a4, 0xffe67eaa, 0xe4f163b8, 0xedfc68b6, 0x0a67b10c, 0x036aba02, 0x187da710, 0x1170ac1e, 0x2e539d34, 0x275e963a, 0x3c498b28, 0x35448026, 0x420fe97c, 0x4b02e272, 0x5015ff60, 0x5918f46e, 0x663bc544, 0x6f36ce4a, 0x7421d358, 0x7d2cd856, 0xa10c7a37, 0xa8017139, 0xb3166c2b, 0xba1b6725, 0x8538560f, 0x8c355d01, 0x97224013, 0x9e2f4b1d, 0xe9642247, 0xe0692949, 0xfb7e345b, 0xf2733f55, 0xcd500e7f, 0xc45d0571, 0xdf4a1863, 0xd647136d, 0x31dccad7, 0x38d1c1d9, 0x23c6dccb, 0x2acbd7c5, 0x15e8e6ef, 0x1ce5ede1, 0x07f2f0f3, 0x0efffbfd, 0x79b492a7, 0x70b999a9, 0x6bae84bb, 0x62a38fb5, 0x5d80be9f, 0x548db591, 0x4f9aa883, 0x4697a38d];\n function convertToInt32(bytes) {\n var result = [];\n for (var i = 0; i < bytes.length; i += 4) {\n result.push(bytes[i] << 24 | bytes[i + 1] << 16 | bytes[i + 2] << 8 | bytes[i + 3]);\n }\n return result;\n }\n var AES = function (key) {\n if (!(this instanceof AES)) {\n throw Error('AES must be instanitated with `new`');\n }\n Object.defineProperty(this, 'key', {\n value: coerceArray(key, true)\n });\n this._prepare();\n };\n AES.prototype._prepare = function () {\n var rounds = numberOfRounds[this.key.length];\n if (rounds == null) {\n throw new Error('invalid key size (must be 16, 24 or 32 bytes)');\n }\n\n // encryption round keys\n this._Ke = [];\n\n // decryption round keys\n this._Kd = [];\n for (var i = 0; i <= rounds; i++) {\n this._Ke.push([0, 0, 0, 0]);\n this._Kd.push([0, 0, 0, 0]);\n }\n var roundKeyCount = (rounds + 1) * 4;\n var KC = this.key.length / 4;\n\n // convert the key into ints\n var tk = convertToInt32(this.key);\n\n // copy values into round key arrays\n var index;\n for (var i = 0; i < KC; i++) {\n index = i >> 2;\n this._Ke[index][i % 4] = tk[i];\n this._Kd[rounds - index][i % 4] = tk[i];\n }\n\n // key expansion (fips-197 section 5.2)\n var rconpointer = 0;\n var t = KC,\n tt;\n while (t < roundKeyCount) {\n tt = tk[KC - 1];\n tk[0] ^= S[tt >> 16 & 0xFF] << 24 ^ S[tt >> 8 & 0xFF] << 16 ^ S[tt & 0xFF] << 8 ^ S[tt >> 24 & 0xFF] ^ rcon[rconpointer] << 24;\n rconpointer += 1;\n\n // key expansion (for non-256 bit)\n if (KC != 8) {\n for (var i = 1; i < KC; i++) {\n tk[i] ^= tk[i - 1];\n }\n\n // key expansion for 256-bit keys is \"slightly different\" (fips-197)\n } else {\n for (var i = 1; i < KC / 2; i++) {\n tk[i] ^= tk[i - 1];\n }\n tt = tk[KC / 2 - 1];\n tk[KC / 2] ^= S[tt & 0xFF] ^ S[tt >> 8 & 0xFF] << 8 ^ S[tt >> 16 & 0xFF] << 16 ^ S[tt >> 24 & 0xFF] << 24;\n for (var i = KC / 2 + 1; i < KC; i++) {\n tk[i] ^= tk[i - 1];\n }\n }\n\n // copy values into round key arrays\n var i = 0,\n r,\n c;\n while (i < KC && t < roundKeyCount) {\n r = t >> 2;\n c = t % 4;\n this._Ke[r][c] = tk[i];\n this._Kd[rounds - r][c] = tk[i++];\n t++;\n }\n }\n\n // inverse-cipher-ify the decryption round key (fips-197 section 5.3)\n for (var r = 1; r < rounds; r++) {\n for (var c = 0; c < 4; c++) {\n tt = this._Kd[r][c];\n this._Kd[r][c] = U1[tt >> 24 & 0xFF] ^ U2[tt >> 16 & 0xFF] ^ U3[tt >> 8 & 0xFF] ^ U4[tt & 0xFF];\n }\n }\n };\n AES.prototype.encrypt = function (plaintext) {\n if (plaintext.length != 16) {\n throw new Error('invalid plaintext size (must be 16 bytes)');\n }\n var rounds = this._Ke.length - 1;\n var a = [0, 0, 0, 0];\n\n // convert plaintext to (ints ^ key)\n var t = convertToInt32(plaintext);\n for (var i = 0; i < 4; i++) {\n t[i] ^= this._Ke[0][i];\n }\n\n // apply round transforms\n for (var r = 1; r < rounds; r++) {\n for (var i = 0; i < 4; i++) {\n a[i] = T1[t[i] >> 24 & 0xff] ^ T2[t[(i + 1) % 4] >> 16 & 0xff] ^ T3[t[(i + 2) % 4] >> 8 & 0xff] ^ T4[t[(i + 3) % 4] & 0xff] ^ this._Ke[r][i];\n }\n t = a.slice();\n }\n\n // the last round is special\n var result = createArray(16),\n tt;\n for (var i = 0; i < 4; i++) {\n tt = this._Ke[rounds][i];\n result[4 * i] = (S[t[i] >> 24 & 0xff] ^ tt >> 24) & 0xff;\n result[4 * i + 1] = (S[t[(i + 1) % 4] >> 16 & 0xff] ^ tt >> 16) & 0xff;\n result[4 * i + 2] = (S[t[(i + 2) % 4] >> 8 & 0xff] ^ tt >> 8) & 0xff;\n result[4 * i + 3] = (S[t[(i + 3) % 4] & 0xff] ^ tt) & 0xff;\n }\n return result;\n };\n AES.prototype.decrypt = function (ciphertext) {\n if (ciphertext.length != 16) {\n throw new Error('invalid ciphertext size (must be 16 bytes)');\n }\n var rounds = this._Kd.length - 1;\n var a = [0, 0, 0, 0];\n\n // convert plaintext to (ints ^ key)\n var t = convertToInt32(ciphertext);\n for (var i = 0; i < 4; i++) {\n t[i] ^= this._Kd[0][i];\n }\n\n // apply round transforms\n for (var r = 1; r < rounds; r++) {\n for (var i = 0; i < 4; i++) {\n a[i] = T5[t[i] >> 24 & 0xff] ^ T6[t[(i + 3) % 4] >> 16 & 0xff] ^ T7[t[(i + 2) % 4] >> 8 & 0xff] ^ T8[t[(i + 1) % 4] & 0xff] ^ this._Kd[r][i];\n }\n t = a.slice();\n }\n\n // the last round is special\n var result = createArray(16),\n tt;\n for (var i = 0; i < 4; i++) {\n tt = this._Kd[rounds][i];\n result[4 * i] = (Si[t[i] >> 24 & 0xff] ^ tt >> 24) & 0xff;\n result[4 * i + 1] = (Si[t[(i + 3) % 4] >> 16 & 0xff] ^ tt >> 16) & 0xff;\n result[4 * i + 2] = (Si[t[(i + 2) % 4] >> 8 & 0xff] ^ tt >> 8) & 0xff;\n result[4 * i + 3] = (Si[t[(i + 1) % 4] & 0xff] ^ tt) & 0xff;\n }\n return result;\n };\n\n /**\n * Mode Of Operation - Electonic Codebook (ECB)\n */\n var ModeOfOperationECB = function (key) {\n if (!(this instanceof ModeOfOperationECB)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Electronic Code Block\";\n this.name = \"ecb\";\n this._aes = new AES(key);\n };\n ModeOfOperationECB.prototype.encrypt = function (plaintext) {\n plaintext = coerceArray(plaintext);\n if (plaintext.length % 16 !== 0) {\n throw new Error('invalid plaintext size (must be multiple of 16 bytes)');\n }\n var ciphertext = createArray(plaintext.length);\n var block = createArray(16);\n for (var i = 0; i < plaintext.length; i += 16) {\n copyArray(plaintext, block, 0, i, i + 16);\n block = this._aes.encrypt(block);\n copyArray(block, ciphertext, i);\n }\n return ciphertext;\n };\n ModeOfOperationECB.prototype.decrypt = function (ciphertext) {\n ciphertext = coerceArray(ciphertext);\n if (ciphertext.length % 16 !== 0) {\n throw new Error('invalid ciphertext size (must be multiple of 16 bytes)');\n }\n var plaintext = createArray(ciphertext.length);\n var block = createArray(16);\n for (var i = 0; i < ciphertext.length; i += 16) {\n copyArray(ciphertext, block, 0, i, i + 16);\n block = this._aes.decrypt(block);\n copyArray(block, plaintext, i);\n }\n return plaintext;\n };\n\n /**\n * Mode Of Operation - Cipher Block Chaining (CBC)\n */\n var ModeOfOperationCBC = function (key, iv) {\n if (!(this instanceof ModeOfOperationCBC)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Cipher Block Chaining\";\n this.name = \"cbc\";\n if (!iv) {\n iv = createArray(16);\n } else if (iv.length != 16) {\n throw new Error('invalid initialation vector size (must be 16 bytes)');\n }\n this._lastCipherblock = coerceArray(iv, true);\n this._aes = new AES(key);\n };\n ModeOfOperationCBC.prototype.encrypt = function (plaintext) {\n plaintext = coerceArray(plaintext);\n if (plaintext.length % 16 !== 0) {\n throw new Error('invalid plaintext size (must be multiple of 16 bytes)');\n }\n var ciphertext = createArray(plaintext.length);\n var block = createArray(16);\n for (var i = 0; i < plaintext.length; i += 16) {\n copyArray(plaintext, block, 0, i, i + 16);\n for (var j = 0; j < 16; j++) {\n block[j] ^= this._lastCipherblock[j];\n }\n this._lastCipherblock = this._aes.encrypt(block);\n copyArray(this._lastCipherblock, ciphertext, i);\n }\n return ciphertext;\n };\n ModeOfOperationCBC.prototype.decrypt = function (ciphertext) {\n ciphertext = coerceArray(ciphertext);\n if (ciphertext.length % 16 !== 0) {\n throw new Error('invalid ciphertext size (must be multiple of 16 bytes)');\n }\n var plaintext = createArray(ciphertext.length);\n var block = createArray(16);\n for (var i = 0; i < ciphertext.length; i += 16) {\n copyArray(ciphertext, block, 0, i, i + 16);\n block = this._aes.decrypt(block);\n for (var j = 0; j < 16; j++) {\n plaintext[i + j] = block[j] ^ this._lastCipherblock[j];\n }\n copyArray(ciphertext, this._lastCipherblock, 0, i, i + 16);\n }\n return plaintext;\n };\n\n /**\n * Mode Of Operation - Cipher Feedback (CFB)\n */\n var ModeOfOperationCFB = function (key, iv, segmentSize) {\n if (!(this instanceof ModeOfOperationCFB)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Cipher Feedback\";\n this.name = \"cfb\";\n if (!iv) {\n iv = createArray(16);\n } else if (iv.length != 16) {\n throw new Error('invalid initialation vector size (must be 16 size)');\n }\n if (!segmentSize) {\n segmentSize = 1;\n }\n this.segmentSize = segmentSize;\n this._shiftRegister = coerceArray(iv, true);\n this._aes = new AES(key);\n };\n ModeOfOperationCFB.prototype.encrypt = function (plaintext) {\n if (plaintext.length % this.segmentSize != 0) {\n throw new Error('invalid plaintext size (must be segmentSize bytes)');\n }\n var encrypted = coerceArray(plaintext, true);\n var xorSegment;\n for (var i = 0; i < encrypted.length; i += this.segmentSize) {\n xorSegment = this._aes.encrypt(this._shiftRegister);\n for (var j = 0; j < this.segmentSize; j++) {\n encrypted[i + j] ^= xorSegment[j];\n }\n\n // Shift the register\n copyArray(this._shiftRegister, this._shiftRegister, 0, this.segmentSize);\n copyArray(encrypted, this._shiftRegister, 16 - this.segmentSize, i, i + this.segmentSize);\n }\n return encrypted;\n };\n ModeOfOperationCFB.prototype.decrypt = function (ciphertext) {\n if (ciphertext.length % this.segmentSize != 0) {\n throw new Error('invalid ciphertext size (must be segmentSize bytes)');\n }\n var plaintext = coerceArray(ciphertext, true);\n var xorSegment;\n for (var i = 0; i < plaintext.length; i += this.segmentSize) {\n xorSegment = this._aes.encrypt(this._shiftRegister);\n for (var j = 0; j < this.segmentSize; j++) {\n plaintext[i + j] ^= xorSegment[j];\n }\n\n // Shift the register\n copyArray(this._shiftRegister, this._shiftRegister, 0, this.segmentSize);\n copyArray(ciphertext, this._shiftRegister, 16 - this.segmentSize, i, i + this.segmentSize);\n }\n return plaintext;\n };\n\n /**\n * Mode Of Operation - Output Feedback (OFB)\n */\n var ModeOfOperationOFB = function (key, iv) {\n if (!(this instanceof ModeOfOperationOFB)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Output Feedback\";\n this.name = \"ofb\";\n if (!iv) {\n iv = createArray(16);\n } else if (iv.length != 16) {\n throw new Error('invalid initialation vector size (must be 16 bytes)');\n }\n this._lastPrecipher = coerceArray(iv, true);\n this._lastPrecipherIndex = 16;\n this._aes = new AES(key);\n };\n ModeOfOperationOFB.prototype.encrypt = function (plaintext) {\n var encrypted = coerceArray(plaintext, true);\n for (var i = 0; i < encrypted.length; i++) {\n if (this._lastPrecipherIndex === 16) {\n this._lastPrecipher = this._aes.encrypt(this._lastPrecipher);\n this._lastPrecipherIndex = 0;\n }\n encrypted[i] ^= this._lastPrecipher[this._lastPrecipherIndex++];\n }\n return encrypted;\n };\n\n // Decryption is symetric\n ModeOfOperationOFB.prototype.decrypt = ModeOfOperationOFB.prototype.encrypt;\n\n /**\n * Counter object for CTR common mode of operation\n */\n var Counter = function (initialValue) {\n if (!(this instanceof Counter)) {\n throw Error('Counter must be instanitated with `new`');\n }\n\n // We allow 0, but anything false-ish uses the default 1\n if (initialValue !== 0 && !initialValue) {\n initialValue = 1;\n }\n if (typeof initialValue === 'number') {\n this._counter = createArray(16);\n this.setValue(initialValue);\n } else {\n this.setBytes(initialValue);\n }\n };\n Counter.prototype.setValue = function (value) {\n if (typeof value !== 'number' || parseInt(value) != value) {\n throw new Error('invalid counter value (must be an integer)');\n }\n\n // We cannot safely handle numbers beyond the safe range for integers\n if (value > Number.MAX_SAFE_INTEGER) {\n throw new Error('integer value out of safe range');\n }\n for (var index = 15; index >= 0; --index) {\n this._counter[index] = value % 256;\n value = parseInt(value / 256);\n }\n };\n Counter.prototype.setBytes = function (bytes) {\n bytes = coerceArray(bytes, true);\n if (bytes.length != 16) {\n throw new Error('invalid counter bytes size (must be 16 bytes)');\n }\n this._counter = bytes;\n };\n Counter.prototype.increment = function () {\n for (var i = 15; i >= 0; i--) {\n if (this._counter[i] === 255) {\n this._counter[i] = 0;\n } else {\n this._counter[i]++;\n break;\n }\n }\n };\n\n /**\n * Mode Of Operation - Counter (CTR)\n */\n var ModeOfOperationCTR = function (key, counter) {\n if (!(this instanceof ModeOfOperationCTR)) {\n throw Error('AES must be instanitated with `new`');\n }\n this.description = \"Counter\";\n this.name = \"ctr\";\n if (!(counter instanceof Counter)) {\n counter = new Counter(counter);\n }\n this._counter = counter;\n this._remainingCounter = null;\n this._remainingCounterIndex = 16;\n this._aes = new AES(key);\n };\n ModeOfOperationCTR.prototype.encrypt = function (plaintext) {\n var encrypted = coerceArray(plaintext, true);\n for (var i = 0; i < encrypted.length; i++) {\n if (this._remainingCounterIndex === 16) {\n this._remainingCounter = this._aes.encrypt(this._counter._counter);\n this._remainingCounterIndex = 0;\n this._counter.increment();\n }\n encrypted[i] ^= this._remainingCounter[this._remainingCounterIndex++];\n }\n return encrypted;\n };\n\n // Decryption is symetric\n ModeOfOperationCTR.prototype.decrypt = ModeOfOperationCTR.prototype.encrypt;\n\n ///////////////////////\n // Padding\n\n // See:https://tools.ietf.org/html/rfc2315\n function pkcs7pad(data) {\n data = coerceArray(data, true);\n var padder = 16 - data.length % 16;\n var result = createArray(data.length + padder);\n copyArray(data, result);\n for (var i = data.length; i < result.length; i++) {\n result[i] = padder;\n }\n return result;\n }\n function pkcs7strip(data) {\n data = coerceArray(data, true);\n if (data.length < 16) {\n throw new Error('PKCS#7 invalid length');\n }\n var padder = data[data.length - 1];\n if (padder > 16) {\n throw new Error('PKCS#7 padding byte out of range');\n }\n var length = data.length - padder;\n for (var i = 0; i < padder; i++) {\n if (data[length + i] !== padder) {\n throw new Error('PKCS#7 invalid padding byte');\n }\n }\n var result = createArray(length);\n copyArray(data, result, 0, 0, length);\n return result;\n }\n\n ///////////////////////\n // Exporting\n\n // The block cipher\n var aesjs = {\n AES: AES,\n Counter: Counter,\n ModeOfOperation: {\n ecb: ModeOfOperationECB,\n cbc: ModeOfOperationCBC,\n cfb: ModeOfOperationCFB,\n ofb: ModeOfOperationOFB,\n ctr: ModeOfOperationCTR\n },\n utils: {\n hex: convertHex,\n utf8: convertUtf8\n },\n padding: {\n pkcs7: {\n pad: pkcs7pad,\n strip: pkcs7strip\n }\n },\n _arrayTest: {\n coerceArray: coerceArray,\n createArray: createArray,\n copyArray: copyArray\n }\n };\n\n // node.js\n if (typeof exports !== 'undefined') {\n module.exports = aesjs;\n\n // RequireJS/AMD\n // http://www.requirejs.org/docs/api.html\n // https://github.com/amdjs/amdjs-api/wiki/AMD\n } else if (typeof define === 'function' && define.amd) {\n define([], function () {\n return aesjs;\n });\n\n // Web Browsers\n } else {\n // If there was an existing library at \"aesjs\" make sure it's still available\n if (root.aesjs) {\n aesjs._aesjs = root.aesjs;\n }\n root.aesjs = aesjs;\n }\n})(this);","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\n} : function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\nvar __setModuleDefault = this && this.__setModuleDefault || (Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = this && this.__generator || function (thisArg, body) {\n var _ = {\n label: 0,\n sent: function () {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n },\n f,\n y,\n t,\n g;\n return g = {\n next: verb(0),\n \"throw\": verb(1),\n \"return\": verb(2)\n }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function () {\n return this;\n }), g;\n function verb(n) {\n return function (v) {\n return step([n, v]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [0];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [6, e];\n y = 0;\n } finally {\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n};\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.fromQuorumWallet = exports.fromKryptoKit = exports.fromEtherCamp = exports.fromEtherWallet = void 0;\nvar crypto = __importStar(require(\"crypto\"));\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar scrypt_js_1 = require(\"scrypt-js\");\nvar index_1 = __importDefault(require(\"./index\"));\nvar utf8 = require('utf8');\nvar aesjs = require('aes-js');\nfunction runCipherBuffer(cipher, data) {\n return Buffer.concat([cipher.update(data), cipher.final()]);\n}\nvar evpKdfDefaults = {\n count: 1,\n keysize: 16,\n ivsize: 16,\n digest: 'md5'\n};\nfunction mergeEvpKdfOptsWithDefaults(opts) {\n if (!opts) {\n return evpKdfDefaults;\n }\n return {\n count: opts.count || evpKdfDefaults.count,\n keysize: opts.keysize || evpKdfDefaults.keysize,\n ivsize: opts.ivsize || evpKdfDefaults.ivsize,\n digest: opts.digest || evpKdfDefaults.digest\n };\n}\n/*\n * opts:\n * - digest - digest algorithm, defaults to md5\n * - count - hash iterations\n * - keysize - desired key size\n * - ivsize - desired IV size\n *\n * Algorithm form https://www.openssl.org/docs/manmaster/crypto/EVP_BytesToKey.html\n *\n * FIXME: not optimised at all\n */\nfunction evp_kdf(data, salt, opts) {\n var params = mergeEvpKdfOptsWithDefaults(opts);\n // A single EVP iteration, returns `D_i`, where block equlas to `D_(i-1)`\n function iter(block) {\n var hash = crypto.createHash(params.digest);\n hash.update(block);\n hash.update(data);\n hash.update(salt);\n block = hash.digest();\n for (var i_1 = 1, len = params.count; i_1 < len; i_1++) {\n hash = crypto.createHash(params.digest);\n hash.update(block);\n block = hash.digest();\n }\n return block;\n }\n var ret = [];\n var i = 0;\n while (Buffer.concat(ret).length < params.keysize + params.ivsize) {\n ret[i] = iter(i === 0 ? Buffer.alloc(0) : ret[i - 1]);\n i++;\n }\n var tmp = Buffer.concat(ret);\n return {\n key: tmp.slice(0, params.keysize),\n iv: tmp.slice(params.keysize, params.keysize + params.ivsize)\n };\n}\n// http://stackoverflow.com/questions/25288311/cryptojs-aes-pattern-always-ends-with\nfunction decodeCryptojsSalt(input) {\n var ciphertext = Buffer.from(input, 'base64');\n if (ciphertext.slice(0, 8).toString() === 'Salted__') {\n return {\n salt: ciphertext.slice(8, 16),\n ciphertext: ciphertext.slice(16)\n };\n }\n return {\n ciphertext: ciphertext\n };\n}\n/*\n * Third Party API: Import a wallet generated by EtherWallet\n * This wallet format is created by https://github.com/SilentCicero/ethereumjs-accounts\n * and used on https://www.myetherwallet.com/\n */\nfunction fromEtherWallet(input, password) {\n var json = typeof input === 'object' ? input : JSON.parse(input);\n var privateKey;\n if (!json.locked) {\n if (json.private.length !== 64) {\n throw new Error('Invalid private key length');\n }\n privateKey = Buffer.from(json.private, 'hex');\n } else {\n if (typeof password !== 'string') {\n throw new Error('Password required');\n }\n if (password.length < 7) {\n throw new Error('Password must be at least 7 characters');\n }\n // the \"encrypted\" version has the low 4 bytes\n // of the hash of the address appended\n var hash = json.encrypted ? json.private.slice(0, 128) : json.private;\n // decode openssl ciphertext + salt encoding\n var cipher = decodeCryptojsSalt(hash);\n if (!cipher.salt) {\n throw new Error('Unsupported EtherWallet key format');\n }\n // derive key/iv using OpenSSL EVP as implemented in CryptoJS\n var evp = evp_kdf(Buffer.from(password), cipher.salt, {\n keysize: 32,\n ivsize: 16\n });\n var decipher = crypto.createDecipheriv('aes-256-cbc', evp.key, evp.iv);\n privateKey = runCipherBuffer(decipher, Buffer.from(cipher.ciphertext));\n // NOTE: yes, they've run it through UTF8\n privateKey = Buffer.from(utf8.decode(privateKey.toString()), 'hex');\n }\n var wallet = new index_1.default(privateKey);\n if (wallet.getAddressString() !== json.address) {\n throw new Error('Invalid private key or address');\n }\n return wallet;\n}\nexports.fromEtherWallet = fromEtherWallet;\n/**\n * Third Party API: Import a brain wallet used by Ether.Camp\n */\nfunction fromEtherCamp(passphrase) {\n return new index_1.default((0, ethereumjs_util_1.keccak256)(Buffer.from(passphrase)));\n}\nexports.fromEtherCamp = fromEtherCamp;\n/**\n * Third Party API: Import a wallet from a KryptoKit seed\n */\nfunction fromKryptoKit(entropy, password) {\n return __awaiter(this, void 0, void 0, function () {\n function kryptoKitBrokenScryptSeed(buf) {\n // js-scrypt calls `Buffer.from(String(salt), 'utf8')` on the seed even though it is a buffer\n //\n // The `buffer`` implementation used does the below transformation (doesn't matches the current version):\n // https://github.com/feross/buffer/blob/67c61181b938b17d10dbfc0a545f713b8bd59de8/index.js\n function decodeUtf8Char(str) {\n try {\n return decodeURIComponent(str);\n } catch (err) {\n return String.fromCharCode(0xfffd); // UTF 8 invalid char\n }\n }\n var res = '',\n tmp = '';\n for (var i = 0; i < buf.length; i++) {\n if (buf[i] <= 0x7f) {\n res += decodeUtf8Char(tmp) + String.fromCharCode(buf[i]);\n tmp = '';\n } else {\n tmp += '%' + buf[i].toString(16);\n }\n }\n return Buffer.from(res + decodeUtf8Char(tmp));\n }\n var type, privateKey, encryptedSeed, checksum, salt, aesKey, decipher;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (entropy[0] === '#') {\n entropy = entropy.slice(1);\n }\n type = entropy[0];\n entropy = entropy.slice(1);\n if (!(type === 'd')) return [3 /*break*/, 1];\n privateKey = (0, ethereumjs_util_1.sha256)((0, ethereumjs_util_1.toBuffer)(entropy));\n return [3 /*break*/, 4];\n case 1:\n if (!(type === 'q')) return [3 /*break*/, 3];\n if (typeof password !== 'string') {\n throw new Error('Password required');\n }\n encryptedSeed = (0, ethereumjs_util_1.sha256)(Buffer.from(entropy.slice(0, 30)));\n checksum = entropy.slice(30, 46);\n salt = kryptoKitBrokenScryptSeed(encryptedSeed);\n return [4 /*yield*/, (0, scrypt_js_1.scrypt)(Buffer.from(password, 'utf8'), salt, 16384, 8, 1, 32)\n /* FIXME: try to use `crypto` instead of `aesjs`\n // NOTE: ECB doesn't use the IV, so it can be anything\n var decipher = crypto.createDecipheriv(\"aes-256-ecb\", aesKey, Buffer.from(0))\n // FIXME: this is a clear abuse, but seems to match how ECB in aesjs works\n privKey = Buffer.concat([\n decipher.update(encryptedSeed).slice(0, 16),\n decipher.update(encryptedSeed).slice(0, 16),\n ])\n */];\n case 2:\n aesKey = _a.sent();\n decipher = new aesjs.ModeOfOperation.ecb(aesKey);\n /* decrypt returns an Uint8Array, perhaps there is a better way to concatenate */\n privateKey = Buffer.concat([Buffer.from(decipher.decrypt(encryptedSeed.slice(0, 16))), Buffer.from(decipher.decrypt(encryptedSeed.slice(16, 32)))]);\n if (checksum.length > 0) {\n if (checksum !== (0, ethereumjs_util_1.sha256)((0, ethereumjs_util_1.sha256)(privateKey)).slice(0, 8).toString('hex')) {\n throw new Error('Failed to decrypt input - possibly invalid passphrase');\n }\n }\n return [3 /*break*/, 4];\n case 3:\n throw new Error('Unsupported or invalid entropy type');\n case 4:\n return [2 /*return*/, new index_1.default(privateKey)];\n }\n });\n });\n}\nexports.fromKryptoKit = fromKryptoKit;\n/**\n * Third Party API: Import a brain wallet used by Quorum Wallet\n */\nfunction fromQuorumWallet(passphrase, userid) {\n if (passphrase.length < 10) {\n throw new Error('Passphrase must be at least 10 characters');\n }\n if (userid.length < 10) {\n throw new Error('User id must be at least 10 characters');\n }\n var merged = passphrase + userid;\n var seed = crypto.pbkdf2Sync(merged, merged, 2000, 32, 'sha256');\n return new index_1.default(seed);\n}\nexports.fromQuorumWallet = fromQuorumWallet;\nvar Thirdparty = {\n fromEtherWallet: fromEtherWallet,\n fromEtherCamp: fromEtherCamp,\n fromKryptoKit: fromKryptoKit,\n fromQuorumWallet: fromQuorumWallet\n};\nexports.default = Thirdparty;\n","// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\nvar getRandomValues;\nvar rnds8 = new Uint8Array(16);\nexport default function rng() {\n // lazy load so that environments that need to polyfill have a chance to do so\n if (!getRandomValues) {\n // getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation. Also,\n // find the complete implementation of crypto (msCrypto) on IE11.\n getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto !== 'undefined' && typeof msCrypto.getRandomValues === 'function' && msCrypto.getRandomValues.bind(msCrypto);\n if (!getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n }\n return getRandomValues(rnds8);\n}","export default /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;","import REGEX from './regex.js';\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\nexport default validate;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nvar byteToHex = [];\nfor (var i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).substr(1));\n}\nfunction stringify(arr) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n var uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;","import rng from './rng.js';\nimport stringify from './stringify.js'; // **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\nvar _clockseq; // Previous uuid creation time\n\nvar _lastMSecs = 0;\nvar _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details\n\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || new Array(16);\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n\n if (node == null || clockseq == null) {\n var seedBytes = options.random || (options.rng || rng)();\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];\n }\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n } // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n\n var msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)\n\n var dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression\n\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n } // Per 4.2.1.2 Throw error if too many uuids are requested\n\n if (nsecs >= 10000) {\n throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\");\n }\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n\n msecs += 12219292800000; // `time_low`\n\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff; // `time_mid`\n\n var tmh = msecs / 0x100000000 * 10000 & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff; // `time_high_and_version`\n\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n\n b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n\n b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`\n\n b[i++] = clockseq & 0xff; // `node`\n\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n return buf || stringify(b);\n}\nexport default v1;","import validate from './validate.js';\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n var v;\n var arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\nexport default parse;","import stringify from './stringify.js';\nimport parse from './parse.js';\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n var bytes = [];\n for (var i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n return bytes;\n}\nexport var DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport var URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function (name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n if (namespace.length !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n var bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n if (buf) {\n offset = offset || 0;\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n return buf;\n }\n return stringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","/*\n * Browser-compatible JavaScript MD5\n *\n * Modification of JavaScript MD5\n * https://github.com/blueimp/JavaScript-MD5\n *\n * Copyright 2011, Sebastian Tschan\n * https://blueimp.net\n *\n * Licensed under the MIT license:\n * https://opensource.org/licenses/MIT\n *\n * Based on\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.2 Copyright (C) Paul Johnston 1999 - 2009\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\nfunction md5(bytes) {\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = new Uint8Array(msg.length);\n for (var i = 0; i < msg.length; ++i) {\n bytes[i] = msg.charCodeAt(i);\n }\n }\n return md5ToHexEncodedArray(wordsToMd5(bytesToWords(bytes), bytes.length * 8));\n}\n/*\n * Convert an array of little-endian words to an array of bytes\n */\n\nfunction md5ToHexEncodedArray(input) {\n var output = [];\n var length32 = input.length * 32;\n var hexTab = '0123456789abcdef';\n for (var i = 0; i < length32; i += 8) {\n var x = input[i >> 5] >>> i % 32 & 0xff;\n var hex = parseInt(hexTab.charAt(x >>> 4 & 0x0f) + hexTab.charAt(x & 0x0f), 16);\n output.push(hex);\n }\n return output;\n}\n/**\n * Calculate output length with padding and bit length\n */\n\nfunction getOutputLength(inputLength8) {\n return (inputLength8 + 64 >>> 9 << 4) + 14 + 1;\n}\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length.\n */\n\nfunction wordsToMd5(x, len) {\n /* append padding */\n x[len >> 5] |= 0x80 << len % 32;\n x[getOutputLength(len) - 1] = len;\n var a = 1732584193;\n var b = -271733879;\n var c = -1732584194;\n var d = 271733878;\n for (var i = 0; i < x.length; i += 16) {\n var olda = a;\n var oldb = b;\n var oldc = c;\n var oldd = d;\n a = md5ff(a, b, c, d, x[i], 7, -680876936);\n d = md5ff(d, a, b, c, x[i + 1], 12, -389564586);\n c = md5ff(c, d, a, b, x[i + 2], 17, 606105819);\n b = md5ff(b, c, d, a, x[i + 3], 22, -1044525330);\n a = md5ff(a, b, c, d, x[i + 4], 7, -176418897);\n d = md5ff(d, a, b, c, x[i + 5], 12, 1200080426);\n c = md5ff(c, d, a, b, x[i + 6], 17, -1473231341);\n b = md5ff(b, c, d, a, x[i + 7], 22, -45705983);\n a = md5ff(a, b, c, d, x[i + 8], 7, 1770035416);\n d = md5ff(d, a, b, c, x[i + 9], 12, -1958414417);\n c = md5ff(c, d, a, b, x[i + 10], 17, -42063);\n b = md5ff(b, c, d, a, x[i + 11], 22, -1990404162);\n a = md5ff(a, b, c, d, x[i + 12], 7, 1804603682);\n d = md5ff(d, a, b, c, x[i + 13], 12, -40341101);\n c = md5ff(c, d, a, b, x[i + 14], 17, -1502002290);\n b = md5ff(b, c, d, a, x[i + 15], 22, 1236535329);\n a = md5gg(a, b, c, d, x[i + 1], 5, -165796510);\n d = md5gg(d, a, b, c, x[i + 6], 9, -1069501632);\n c = md5gg(c, d, a, b, x[i + 11], 14, 643717713);\n b = md5gg(b, c, d, a, x[i], 20, -373897302);\n a = md5gg(a, b, c, d, x[i + 5], 5, -701558691);\n d = md5gg(d, a, b, c, x[i + 10], 9, 38016083);\n c = md5gg(c, d, a, b, x[i + 15], 14, -660478335);\n b = md5gg(b, c, d, a, x[i + 4], 20, -405537848);\n a = md5gg(a, b, c, d, x[i + 9], 5, 568446438);\n d = md5gg(d, a, b, c, x[i + 14], 9, -1019803690);\n c = md5gg(c, d, a, b, x[i + 3], 14, -187363961);\n b = md5gg(b, c, d, a, x[i + 8], 20, 1163531501);\n a = md5gg(a, b, c, d, x[i + 13], 5, -1444681467);\n d = md5gg(d, a, b, c, x[i + 2], 9, -51403784);\n c = md5gg(c, d, a, b, x[i + 7], 14, 1735328473);\n b = md5gg(b, c, d, a, x[i + 12], 20, -1926607734);\n a = md5hh(a, b, c, d, x[i + 5], 4, -378558);\n d = md5hh(d, a, b, c, x[i + 8], 11, -2022574463);\n c = md5hh(c, d, a, b, x[i + 11], 16, 1839030562);\n b = md5hh(b, c, d, a, x[i + 14], 23, -35309556);\n a = md5hh(a, b, c, d, x[i + 1], 4, -1530992060);\n d = md5hh(d, a, b, c, x[i + 4], 11, 1272893353);\n c = md5hh(c, d, a, b, x[i + 7], 16, -155497632);\n b = md5hh(b, c, d, a, x[i + 10], 23, -1094730640);\n a = md5hh(a, b, c, d, x[i + 13], 4, 681279174);\n d = md5hh(d, a, b, c, x[i], 11, -358537222);\n c = md5hh(c, d, a, b, x[i + 3], 16, -722521979);\n b = md5hh(b, c, d, a, x[i + 6], 23, 76029189);\n a = md5hh(a, b, c, d, x[i + 9], 4, -640364487);\n d = md5hh(d, a, b, c, x[i + 12], 11, -421815835);\n c = md5hh(c, d, a, b, x[i + 15], 16, 530742520);\n b = md5hh(b, c, d, a, x[i + 2], 23, -995338651);\n a = md5ii(a, b, c, d, x[i], 6, -198630844);\n d = md5ii(d, a, b, c, x[i + 7], 10, 1126891415);\n c = md5ii(c, d, a, b, x[i + 14], 15, -1416354905);\n b = md5ii(b, c, d, a, x[i + 5], 21, -57434055);\n a = md5ii(a, b, c, d, x[i + 12], 6, 1700485571);\n d = md5ii(d, a, b, c, x[i + 3], 10, -1894986606);\n c = md5ii(c, d, a, b, x[i + 10], 15, -1051523);\n b = md5ii(b, c, d, a, x[i + 1], 21, -2054922799);\n a = md5ii(a, b, c, d, x[i + 8], 6, 1873313359);\n d = md5ii(d, a, b, c, x[i + 15], 10, -30611744);\n c = md5ii(c, d, a, b, x[i + 6], 15, -1560198380);\n b = md5ii(b, c, d, a, x[i + 13], 21, 1309151649);\n a = md5ii(a, b, c, d, x[i + 4], 6, -145523070);\n d = md5ii(d, a, b, c, x[i + 11], 10, -1120210379);\n c = md5ii(c, d, a, b, x[i + 2], 15, 718787259);\n b = md5ii(b, c, d, a, x[i + 9], 21, -343485551);\n a = safeAdd(a, olda);\n b = safeAdd(b, oldb);\n c = safeAdd(c, oldc);\n d = safeAdd(d, oldd);\n }\n return [a, b, c, d];\n}\n/*\n * Convert an array bytes to an array of little-endian words\n * Characters >255 have their high-byte silently ignored.\n */\n\nfunction bytesToWords(input) {\n if (input.length === 0) {\n return [];\n }\n var length8 = input.length * 8;\n var output = new Uint32Array(getOutputLength(length8));\n for (var i = 0; i < length8; i += 8) {\n output[i >> 5] |= (input[i / 8] & 0xff) << i % 32;\n }\n return output;\n}\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\n\nfunction safeAdd(x, y) {\n var lsw = (x & 0xffff) + (y & 0xffff);\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return msw << 16 | lsw & 0xffff;\n}\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\n\nfunction bitRotateLeft(num, cnt) {\n return num << cnt | num >>> 32 - cnt;\n}\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\n\nfunction md5cmn(q, a, b, x, s, t) {\n return safeAdd(bitRotateLeft(safeAdd(safeAdd(a, q), safeAdd(x, t)), s), b);\n}\nfunction md5ff(a, b, c, d, x, s, t) {\n return md5cmn(b & c | ~b & d, a, b, x, s, t);\n}\nfunction md5gg(a, b, c, d, x, s, t) {\n return md5cmn(b & d | c & ~d, a, b, x, s, t);\n}\nfunction md5hh(a, b, c, d, x, s, t) {\n return md5cmn(b ^ c ^ d, a, b, x, s, t);\n}\nfunction md5ii(a, b, c, d, x, s, t) {\n return md5cmn(c ^ (b | ~d), a, b, x, s, t);\n}\nexport default md5;","import v35 from './v35.js';\nimport md5 from './md5.js';\nvar v3 = v35('v3', 0x30, md5);\nexport default v3;","import rng from './rng.js';\nimport stringify from './stringify.js';\nfunction v4(options, buf, offset) {\n options = options || {};\n var rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return stringify(rnds);\n}\nexport default v4;","// Adapted from Chris Veness' SHA1 code at\n// http://www.movable-type.co.uk/scripts/sha1.html\nfunction f(s, x, y, z) {\n switch (s) {\n case 0:\n return x & y ^ ~x & z;\n case 1:\n return x ^ y ^ z;\n case 2:\n return x & y ^ x & z ^ y & z;\n case 3:\n return x ^ y ^ z;\n }\n}\nfunction ROTL(x, n) {\n return x << n | x >>> 32 - n;\n}\nfunction sha1(bytes) {\n var K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6];\n var H = [0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0];\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = [];\n for (var i = 0; i < msg.length; ++i) {\n bytes.push(msg.charCodeAt(i));\n }\n } else if (!Array.isArray(bytes)) {\n // Convert Array-like to Array\n bytes = Array.prototype.slice.call(bytes);\n }\n bytes.push(0x80);\n var l = bytes.length / 4 + 2;\n var N = Math.ceil(l / 16);\n var M = new Array(N);\n for (var _i = 0; _i < N; ++_i) {\n var arr = new Uint32Array(16);\n for (var j = 0; j < 16; ++j) {\n arr[j] = bytes[_i * 64 + j * 4] << 24 | bytes[_i * 64 + j * 4 + 1] << 16 | bytes[_i * 64 + j * 4 + 2] << 8 | bytes[_i * 64 + j * 4 + 3];\n }\n M[_i] = arr;\n }\n M[N - 1][14] = (bytes.length - 1) * 8 / Math.pow(2, 32);\n M[N - 1][14] = Math.floor(M[N - 1][14]);\n M[N - 1][15] = (bytes.length - 1) * 8 & 0xffffffff;\n for (var _i2 = 0; _i2 < N; ++_i2) {\n var W = new Uint32Array(80);\n for (var t = 0; t < 16; ++t) {\n W[t] = M[_i2][t];\n }\n for (var _t = 16; _t < 80; ++_t) {\n W[_t] = ROTL(W[_t - 3] ^ W[_t - 8] ^ W[_t - 14] ^ W[_t - 16], 1);\n }\n var a = H[0];\n var b = H[1];\n var c = H[2];\n var d = H[3];\n var e = H[4];\n for (var _t2 = 0; _t2 < 80; ++_t2) {\n var s = Math.floor(_t2 / 20);\n var T = ROTL(a, 5) + f(s, b, c, d) + e + K[s] + W[_t2] >>> 0;\n e = d;\n d = c;\n c = ROTL(b, 30) >>> 0;\n b = a;\n a = T;\n }\n H[0] = H[0] + a >>> 0;\n H[1] = H[1] + b >>> 0;\n H[2] = H[2] + c >>> 0;\n H[3] = H[3] + d >>> 0;\n H[4] = H[4] + e >>> 0;\n }\n return [H[0] >> 24 & 0xff, H[0] >> 16 & 0xff, H[0] >> 8 & 0xff, H[0] & 0xff, H[1] >> 24 & 0xff, H[1] >> 16 & 0xff, H[1] >> 8 & 0xff, H[1] & 0xff, H[2] >> 24 & 0xff, H[2] >> 16 & 0xff, H[2] >> 8 & 0xff, H[2] & 0xff, H[3] >> 24 & 0xff, H[3] >> 16 & 0xff, H[3] >> 8 & 0xff, H[3] & 0xff, H[4] >> 24 & 0xff, H[4] >> 16 & 0xff, H[4] >> 8 & 0xff, H[4] & 0xff];\n}\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nvar v5 = v35('v5', 0x50, sha1);\nexport default v5;","export default '00000000-0000-0000-0000-000000000000';","import validate from './validate.js';\nfunction version(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n return parseInt(uuid.substr(14, 1), 16);\n}\nexport default version;","export { default as v1 } from './v1.js';\nexport { default as v3 } from './v3.js';\nexport { default as v4 } from './v4.js';\nexport { default as v5 } from './v5.js';\nexport { default as NIL } from './nil.js';\nexport { default as version } from './version.js';\nexport { default as validate } from './validate.js';\nexport { default as stringify } from './stringify.js';\nexport { default as parse } from './parse.js';","\"use strict\";\n\nvar __assign = this && this.__assign || function () {\n __assign = Object.assign || function (t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\n} : function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\nvar __setModuleDefault = this && this.__setModuleDefault || (Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = this && this.__generator || function (thisArg, body) {\n var _ = {\n label: 0,\n sent: function () {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n },\n f,\n y,\n t,\n g;\n return g = {\n next: verb(0),\n \"throw\": verb(1),\n \"return\": verb(2)\n }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function () {\n return this;\n }), g;\n function verb(n) {\n return function (v) {\n return step([n, v]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [0];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [6, e];\n y = 0;\n } finally {\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n};\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.thirdparty = exports.hdkey = void 0;\nvar crypto = __importStar(require(\"crypto\"));\nvar ethereumjs_util_1 = require(\"ethereumjs-util\");\nvar scrypt_js_1 = require(\"scrypt-js\");\nvar hdkey_1 = require(\"./hdkey\");\nObject.defineProperty(exports, \"hdkey\", {\n enumerable: true,\n get: function () {\n return __importDefault(hdkey_1).default;\n }\n});\nvar thirdparty_1 = require(\"./thirdparty\");\nObject.defineProperty(exports, \"thirdparty\", {\n enumerable: true,\n get: function () {\n return __importDefault(thirdparty_1).default;\n }\n});\nvar bs58check = require('bs58check');\nvar randomBytes = require('randombytes');\nvar uuidv4 = require('uuid').v4;\nfunction validateHexString(paramName, str, length) {\n if (str.toLowerCase().startsWith('0x')) {\n str = str.slice(2);\n }\n if (!str && !length) {\n return str;\n }\n if (length % 2) {\n throw new Error(\"Invalid length argument, must be an even number\");\n }\n if (typeof length === 'number' && str.length !== length) {\n throw new Error(\"Invalid \" + paramName + \", string must be \" + length + \" hex characters\");\n }\n if (!/^([0-9a-f]{2})+$/i.test(str)) {\n var howMany = typeof length === 'number' ? length : 'empty or a non-zero even number of';\n throw new Error(\"Invalid \" + paramName + \", string must be \" + howMany + \" hex characters\");\n }\n return str;\n}\nfunction validateBuffer(paramName, buff, length) {\n if (!Buffer.isBuffer(buff)) {\n var howManyHex = typeof length === 'number' ? \"\" + length * 2 : 'empty or a non-zero even number of';\n var howManyBytes = typeof length === 'number' ? \" (\" + length + \" bytes)\" : '';\n throw new Error(\"Invalid \" + paramName + \", must be a string (\" + howManyHex + \" hex characters) or buffer\" + howManyBytes);\n }\n if (typeof length === 'number' && buff.length !== length) {\n throw new Error(\"Invalid \" + paramName + \", buffer must be \" + length + \" bytes\");\n }\n return buff;\n}\nfunction mergeToV3ParamsWithDefaults(params) {\n var v3Defaults = {\n cipher: 'aes-128-ctr',\n kdf: 'scrypt',\n salt: randomBytes(32),\n iv: randomBytes(16),\n uuid: randomBytes(16),\n dklen: 32,\n c: 262144,\n n: 262144,\n r: 8,\n p: 1\n };\n if (!params) {\n return v3Defaults;\n }\n if (typeof params.salt === 'string') {\n params.salt = Buffer.from(validateHexString('salt', params.salt), 'hex');\n }\n if (typeof params.iv === 'string') {\n params.iv = Buffer.from(validateHexString('iv', params.iv, 32), 'hex');\n }\n if (typeof params.uuid === 'string') {\n params.uuid = Buffer.from(validateHexString('uuid', params.uuid, 32), 'hex');\n }\n if (params.salt) {\n validateBuffer('salt', params.salt);\n }\n if (params.iv) {\n validateBuffer('iv', params.iv, 16);\n }\n if (params.uuid) {\n validateBuffer('uuid', params.uuid, 16);\n }\n return __assign(__assign({}, v3Defaults), params);\n}\nfunction kdfParamsForPBKDF(opts) {\n return {\n dklen: opts.dklen,\n salt: opts.salt,\n c: opts.c,\n prf: 'hmac-sha256'\n };\n}\nfunction kdfParamsForScrypt(opts) {\n return {\n dklen: opts.dklen,\n salt: opts.salt,\n n: opts.n,\n r: opts.r,\n p: opts.p\n };\n}\n// wallet implementation\nvar Wallet = /** @class */function () {\n function Wallet(privateKey, publicKey) {\n if (publicKey === void 0) {\n publicKey = undefined;\n }\n this.privateKey = privateKey;\n this.publicKey = publicKey;\n if (privateKey && publicKey) {\n throw new Error('Cannot supply both a private and a public key to the constructor');\n }\n if (privateKey && !(0, ethereumjs_util_1.isValidPrivate)(privateKey)) {\n throw new Error('Private key does not satisfy the curve requirements (ie. it is invalid)');\n }\n if (publicKey && !(0, ethereumjs_util_1.isValidPublic)(publicKey)) {\n throw new Error('Invalid public key');\n }\n }\n // static methods\n /**\n * Create an instance based on a new random key.\n *\n * @param icapDirect setting this to `true` will generate an address suitable for the `ICAP Direct mode`\n */\n Wallet.generate = function (icapDirect) {\n if (icapDirect === void 0) {\n icapDirect = false;\n }\n if (icapDirect) {\n var max = new ethereumjs_util_1.BN('088f924eeceeda7fe92e1f5b0fffffffffffffff', 16);\n while (true) {\n var privateKey = randomBytes(32);\n if (new ethereumjs_util_1.BN((0, ethereumjs_util_1.privateToAddress)(privateKey)).lte(max)) {\n return new Wallet(privateKey);\n }\n }\n } else {\n return new Wallet(randomBytes(32));\n }\n };\n /**\n * Create an instance where the address is valid against the supplied pattern (**this will be very slow**)\n */\n Wallet.generateVanityAddress = function (pattern) {\n if (!(pattern instanceof RegExp)) {\n pattern = new RegExp(pattern);\n }\n while (true) {\n var privateKey = randomBytes(32);\n var address = (0, ethereumjs_util_1.privateToAddress)(privateKey);\n if (pattern.test(address.toString('hex'))) {\n return new Wallet(privateKey);\n }\n }\n };\n /**\n * Create an instance based on a public key (certain methods will not be available)\n *\n * This method only accepts uncompressed Ethereum-style public keys, unless\n * the `nonStrict` flag is set to true.\n */\n Wallet.fromPublicKey = function (publicKey, nonStrict) {\n if (nonStrict === void 0) {\n nonStrict = false;\n }\n if (nonStrict) {\n publicKey = (0, ethereumjs_util_1.importPublic)(publicKey);\n }\n return new Wallet(undefined, publicKey);\n };\n /**\n * Create an instance based on a BIP32 extended public key (xpub)\n */\n Wallet.fromExtendedPublicKey = function (extendedPublicKey) {\n if (extendedPublicKey.slice(0, 4) !== 'xpub') {\n throw new Error('Not an extended public key');\n }\n var publicKey = bs58check.decode(extendedPublicKey).slice(45);\n // Convert to an Ethereum public key\n return Wallet.fromPublicKey(publicKey, true);\n };\n /**\n * Create an instance based on a raw private key\n */\n Wallet.fromPrivateKey = function (privateKey) {\n return new Wallet(privateKey);\n };\n /**\n * Create an instance based on a BIP32 extended private key (xprv)\n */\n Wallet.fromExtendedPrivateKey = function (extendedPrivateKey) {\n if (extendedPrivateKey.slice(0, 4) !== 'xprv') {\n throw new Error('Not an extended private key');\n }\n var tmp = bs58check.decode(extendedPrivateKey);\n if (tmp[45] !== 0) {\n throw new Error('Invalid extended private key');\n }\n return Wallet.fromPrivateKey(tmp.slice(46));\n };\n /**\n * Import a wallet (Version 1 of the Ethereum wallet format).\n *\n * @param input A JSON serialized string, or an object representing V1 Keystore.\n * @param password The keystore password.\n */\n Wallet.fromV1 = function (input, password) {\n return __awaiter(this, void 0, void 0, function () {\n var json, kdfparams, derivedKey, ciphertext, mac, decipher, seed;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n json = typeof input === 'object' ? input : JSON.parse(input);\n if (json.Version !== '1') {\n throw new Error('Not a V1 Wallet');\n }\n if (json.Crypto.KeyHeader.Kdf !== 'scrypt') {\n throw new Error('Unsupported key derivation scheme');\n }\n kdfparams = json.Crypto.KeyHeader.KdfParams;\n return [4 /*yield*/, (0, scrypt_js_1.scrypt)(Buffer.from(password), Buffer.from(json.Crypto.Salt, 'hex'), kdfparams.N, kdfparams.R, kdfparams.P, kdfparams.DkLen)];\n case 1:\n derivedKey = _a.sent();\n ciphertext = Buffer.from(json.Crypto.CipherText, 'hex');\n mac = (0, ethereumjs_util_1.keccak256)(Buffer.concat([derivedKey.slice(16, 32), ciphertext]));\n if (mac.toString('hex') !== json.Crypto.MAC) {\n throw new Error('Key derivation failed - possibly wrong passphrase');\n }\n decipher = crypto.createDecipheriv('aes-128-cbc', (0, ethereumjs_util_1.keccak256)(derivedKey.slice(0, 16)).slice(0, 16), Buffer.from(json.Crypto.IV, 'hex'));\n seed = runCipherBuffer(decipher, ciphertext);\n return [2 /*return*/, new Wallet(seed)];\n }\n });\n });\n };\n /**\n * Import a wallet (Version 3 of the Ethereum wallet format). Set `nonStrict` true to accept files with mixed-caps.\n *\n * @param input A JSON serialized string, or an object representing V3 Keystore.\n * @param password The keystore password.\n */\n Wallet.fromV3 = function (input, password, nonStrict) {\n if (nonStrict === void 0) {\n nonStrict = false;\n }\n return __awaiter(this, void 0, void 0, function () {\n var json, derivedKey, kdfparams, ciphertext, mac, decipher, seed;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n json = typeof input === 'object' ? input : JSON.parse(nonStrict ? input.toLowerCase() : input);\n if (json.version !== 3) {\n throw new Error('Not a V3 wallet');\n }\n if (!(json.crypto.kdf === 'scrypt')) return [3 /*break*/, 2];\n kdfparams = json.crypto.kdfparams;\n return [4 /*yield*/, (0, scrypt_js_1.scrypt)(Buffer.from(password), Buffer.from(kdfparams.salt, 'hex'), kdfparams.n, kdfparams.r, kdfparams.p, kdfparams.dklen)];\n case 1:\n // FIXME: support progress reporting callback\n derivedKey = _a.sent();\n return [3 /*break*/, 3];\n case 2:\n if (json.crypto.kdf === 'pbkdf2') {\n kdfparams = json.crypto.kdfparams;\n if (kdfparams.prf !== 'hmac-sha256') {\n throw new Error('Unsupported parameters to PBKDF2');\n }\n derivedKey = crypto.pbkdf2Sync(Buffer.from(password), Buffer.from(kdfparams.salt, 'hex'), kdfparams.c, kdfparams.dklen, 'sha256');\n } else {\n throw new Error('Unsupported key derivation scheme');\n }\n _a.label = 3;\n case 3:\n ciphertext = Buffer.from(json.crypto.ciphertext, 'hex');\n mac = (0, ethereumjs_util_1.keccak256)(Buffer.concat([Buffer.from(derivedKey.slice(16, 32)), ciphertext]));\n if (mac.toString('hex') !== json.crypto.mac) {\n throw new Error('Key derivation failed - possibly wrong passphrase');\n }\n decipher = crypto.createDecipheriv(json.crypto.cipher, derivedKey.slice(0, 16), Buffer.from(json.crypto.cipherparams.iv, 'hex'));\n seed = runCipherBuffer(decipher, ciphertext);\n return [2 /*return*/, new Wallet(seed)];\n }\n });\n });\n };\n /*\n * Import an Ethereum Pre Sale wallet.\n * Based on https://github.com/ethereum/pyethsaletool/blob/master/pyethsaletool.py\n * JSON fields: encseed, ethaddr, btcaddr, email\n *\n * @param input A JSON serialized string, or an object representing EthSale Keystore.\n * @param password The keystore password.\n */\n Wallet.fromEthSale = function (input, password) {\n var json = typeof input === 'object' ? input : JSON.parse(input);\n var encseed = Buffer.from(json.encseed, 'hex');\n // key derivation\n var derivedKey = crypto.pbkdf2Sync(password, password, 2000, 32, 'sha256').slice(0, 16);\n // seed decoding (IV is first 16 bytes)\n // NOTE: crypto (derived from openssl) when used with aes-*-cbc will handle PKCS#7 padding internally\n // see also http://stackoverflow.com/a/31614770/4964819\n var decipher = crypto.createDecipheriv('aes-128-cbc', derivedKey, encseed.slice(0, 16));\n var seed = runCipherBuffer(decipher, encseed.slice(16));\n var wallet = new Wallet((0, ethereumjs_util_1.keccak256)(seed));\n if (wallet.getAddress().toString('hex') !== json.ethaddr) {\n throw new Error('Decoded key mismatch - possibly wrong passphrase');\n }\n return wallet;\n };\n Object.defineProperty(Wallet.prototype, \"pubKey\", {\n // private getters\n /**\n * Returns the wallet's public key.\n */\n get: function () {\n if (!keyExists(this.publicKey)) {\n this.publicKey = (0, ethereumjs_util_1.privateToPublic)(this.privateKey);\n }\n return this.publicKey;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(Wallet.prototype, \"privKey\", {\n /**\n * Returns the wallet's private key.\n */\n get: function () {\n if (!keyExists(this.privateKey)) {\n throw new Error('This is a public key only wallet');\n }\n return this.privateKey;\n },\n enumerable: false,\n configurable: true\n });\n // public instance methods\n /**\n * Returns the wallet's private key.\n *\n */\n // tslint:disable-next-line\n Wallet.prototype.getPrivateKey = function () {\n return this.privKey;\n };\n Wallet.prototype.getPrivateKeyString = function () {\n return (0, ethereumjs_util_1.bufferToHex)(this.privKey);\n };\n /**\n * Returns the wallet's public key.\n */\n // tslint:disable-next-line\n Wallet.prototype.getPublicKey = function () {\n return this.pubKey;\n };\n /**\n * Returns the wallet's public key as a \"0x\" prefixed hex string\n */\n Wallet.prototype.getPublicKeyString = function () {\n return (0, ethereumjs_util_1.bufferToHex)(this.getPublicKey());\n };\n /**\n * Returns the wallet's address.\n */\n Wallet.prototype.getAddress = function () {\n return (0, ethereumjs_util_1.publicToAddress)(this.pubKey);\n };\n /**\n * Returns the wallet's address as a \"0x\" prefixed hex string\n */\n Wallet.prototype.getAddressString = function () {\n return (0, ethereumjs_util_1.bufferToHex)(this.getAddress());\n };\n /**\n * Returns the wallet's private key as a \"0x\" prefixed hex string checksummed\n * according to [EIP 55](https://github.com/ethereum/EIPs/issues/55).\n */\n Wallet.prototype.getChecksumAddressString = function () {\n return (0, ethereumjs_util_1.toChecksumAddress)(this.getAddressString());\n };\n /**\n * Returns an Etherem Version 3 Keystore Format object representing the wallet\n *\n * @param password The password used to encrypt the Keystore.\n * @param opts The options for the keystore. See [its spec](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) for more info.\n */\n Wallet.prototype.toV3 = function (password, opts) {\n return __awaiter(this, void 0, void 0, function () {\n var v3Params, kdfParams, derivedKey, _a, cipher, ciphertext, mac;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n if (!keyExists(this.privateKey)) {\n throw new Error('This is a public key only wallet');\n }\n v3Params = mergeToV3ParamsWithDefaults(opts);\n _a = v3Params.kdf;\n switch (_a) {\n case \"pbkdf2\" /* PBKDF */:\n return [3 /*break*/, 1];\n case \"scrypt\" /* Scrypt */:\n return [3 /*break*/, 2];\n }\n return [3 /*break*/, 4];\n case 1:\n kdfParams = kdfParamsForPBKDF(v3Params);\n derivedKey = crypto.pbkdf2Sync(Buffer.from(password), kdfParams.salt, kdfParams.c, kdfParams.dklen, 'sha256');\n return [3 /*break*/, 5];\n case 2:\n kdfParams = kdfParamsForScrypt(v3Params);\n return [4 /*yield*/, (0, scrypt_js_1.scrypt)(Buffer.from(password), kdfParams.salt, kdfParams.n, kdfParams.r, kdfParams.p, kdfParams.dklen)];\n case 3:\n // FIXME: support progress reporting callback\n derivedKey = _b.sent();\n return [3 /*break*/, 5];\n case 4:\n throw new Error('Unsupported kdf');\n case 5:\n cipher = crypto.createCipheriv(v3Params.cipher, derivedKey.slice(0, 16), v3Params.iv);\n if (!cipher) {\n throw new Error('Unsupported cipher');\n }\n ciphertext = runCipherBuffer(cipher, this.privKey);\n mac = (0, ethereumjs_util_1.keccak256)(Buffer.concat([Buffer.from(derivedKey.slice(16, 32)), Buffer.from(ciphertext)]));\n return [2 /*return*/, {\n version: 3,\n id: uuidv4({\n random: v3Params.uuid\n }),\n // @ts-ignore - the official V3 keystore spec omits the address key\n address: this.getAddress().toString('hex'),\n crypto: {\n ciphertext: ciphertext.toString('hex'),\n cipherparams: {\n iv: v3Params.iv.toString('hex')\n },\n cipher: v3Params.cipher,\n kdf: v3Params.kdf,\n kdfparams: __assign(__assign({}, kdfParams), {\n salt: kdfParams.salt.toString('hex')\n }),\n mac: mac.toString('hex')\n }\n }];\n }\n });\n });\n };\n /**\n * Return the suggested filename for V3 keystores.\n */\n Wallet.prototype.getV3Filename = function (timestamp) {\n /*\n * We want a timestamp like 2016-03-15T17-11-33.007598288Z. Date formatting\n * is a pain in Javascript, everbody knows that. We could use moment.js,\n * but decide to do it manually in order to save space.\n *\n * toJSON() returns a pretty close version, so let's use it. It is not UTC though,\n * but does it really matter?\n *\n * Alternative manual way with padding and Date fields: http://stackoverflow.com/a/7244288/4964819\n *\n */\n var ts = timestamp ? new Date(timestamp) : new Date();\n return ['UTC--', ts.toJSON().replace(/:/g, '-'), '--', this.getAddress().toString('hex')].join('');\n };\n Wallet.prototype.toV3String = function (password, opts) {\n return __awaiter(this, void 0, void 0, function () {\n var _a, _b;\n return __generator(this, function (_c) {\n switch (_c.label) {\n case 0:\n _b = (_a = JSON).stringify;\n return [4 /*yield*/, this.toV3(password, opts)];\n case 1:\n return [2 /*return*/, _b.apply(_a, [_c.sent()])];\n }\n });\n });\n };\n return Wallet;\n}();\nexports.default = Wallet;\n// helpers\nfunction runCipherBuffer(cipher, data) {\n return Buffer.concat([cipher.update(data), cipher.final()]);\n}\nfunction keyExists(k) {\n return k !== undefined && k !== null;\n}\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AccountManager = void 0;\n// @ts-ignore\nconst ethereumjs_wallet_1 = __importDefault(require(\"ethereumjs-wallet\"));\nconst tx_1 = require(\"@ethereumjs/tx\");\nconst eth_sig_util_1 = require(\"@metamask/eth-sig-util\");\nconst common_1 = require(\"@opengsn/common\");\nfunction toAddress(privateKey) {\n const wallet = ethereumjs_wallet_1.default.fromPrivateKey(Buffer.from((0, common_1.removeHexPrefix)(privateKey), 'hex'));\n return wallet.getChecksumAddressString();\n}\nclass AccountManager {\n constructor(provider, chainId, config) {\n this.accounts = [];\n this.provider = provider;\n this.chainId = chainId;\n this.config = config;\n }\n addAccount(privateKey) {\n // TODO: backwards-compatibility 101 - remove on next version bump\n // addAccount used to accept AccountKeypair with Buffer in it\n // @ts-ignore\n // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions\n if (privateKey.privateKey) {\n console.error('ERROR: addAccount accepts a private key as a prefixed hex string now!');\n // @ts-ignore\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n privateKey = `0x${privateKey.privateKey.toString('hex')}`;\n }\n const address = toAddress(privateKey);\n const keypair = {\n privateKey,\n address\n };\n this.accounts.push(keypair);\n return keypair;\n }\n newAccount() {\n const a = ethereumjs_wallet_1.default.generate();\n const privateKey = a.getPrivateKeyString();\n this.addAccount(privateKey);\n const address = toAddress(privateKey);\n return {\n privateKey,\n address\n };\n }\n signMessage(message, from) {\n const keypair = this.accounts.find(account => (0, common_1.isSameAddress)(account.address, from));\n if (keypair == null) {\n throw new Error(`Account ${from} not found`);\n }\n const privateKey = Buffer.from((0, common_1.removeHexPrefix)(keypair.privateKey), 'hex');\n return (0, eth_sig_util_1.personalSign)({\n privateKey,\n data: message\n });\n }\n signTransaction(transactionConfig, from) {\n let transaction;\n if (transactionConfig.chainId != null && transactionConfig.chainId !== this.chainId) {\n throw new Error(`This provider is initialized for chainId ${this.chainId} but transaction targets chainId ${transactionConfig.chainId}`);\n }\n const commonTxOptions = (0, common_1.getRawTxOptions)(this.chainId, 0);\n const fixGasLimitName = Object.assign(Object.assign({}, transactionConfig), {\n gasLimit: transactionConfig.gas\n });\n if (transactionConfig.gasPrice != null) {\n // annoying - '@ethereumjs/tx' imports BN.js@^4.x.x while we use ^5.x.x\n // @ts-ignore\n transaction = new tx_1.Transaction(fixGasLimitName, commonTxOptions);\n } else {\n // @ts-ignore\n transaction = new tx_1.FeeMarketEIP1559Transaction(fixGasLimitName, commonTxOptions);\n }\n const privateKeyBuf = Buffer.from((0, common_1.removeHexPrefix)(this.findPrivateKey(from)), 'hex');\n const raw = '0x' + transaction.sign(privateKeyBuf).serialize().toString('hex');\n // even more annoying is that 'RLPEncodedTransaction', which is expected return type here, is not yet 1559-ready\n // @ts-ignore\n return {\n raw,\n tx: transaction\n };\n }\n findPrivateKey(from) {\n const keypair = this.accounts.find(account => (0, common_1.isSameAddress)(account.address, from));\n if (keypair == null) {\n throw new Error(`Account ${from} not found`);\n }\n return keypair.privateKey;\n }\n signTypedData(typedMessage, from) {\n return this._signWithControlledKey(this.findPrivateKey(from), typedMessage);\n }\n async sign(domainSeparatorName, relayRequest) {\n let signature;\n const forwarder = relayRequest.relayData.forwarder;\n const cloneRequest = Object.assign({}, relayRequest);\n const signedData = new common_1.TypedRequestData(domainSeparatorName, this.chainId, forwarder, cloneRequest);\n const keypair = this.accounts.find(account => (0, common_1.isSameAddress)(account.address, relayRequest.request.from));\n let rec;\n try {\n if (keypair != null) {\n signature = this._signWithControlledKey(keypair.privateKey, signedData);\n } else {\n signature = await this._signWithProvider(signedData);\n }\n // Sanity check only\n rec = (0, eth_sig_util_1.recoverTypedSignature)({\n data: signedData,\n signature,\n version: eth_sig_util_1.SignTypedDataVersion.V4\n });\n } catch (error) {\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n throw new Error(`Failed to sign relayed transaction for ${relayRequest.request.from}: ${error}`);\n }\n if (!(0, common_1.isSameAddress)(relayRequest.request.from.toLowerCase(), rec)) {\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n throw new Error(`Internal RelayClient exception: signature is not correct: sender=${relayRequest.request.from}, recovered=${rec}`);\n }\n return signature;\n }\n // These methods are extracted to\n // a) allow different implementations in the future, and\n // b) allow spying on Account Manager in tests\n async _signWithProvider(signedData) {\n return await (0, common_1.getEip712Signature)(this.provider, signedData, this.config.methodSuffix, this.config.jsonStringifyRequest);\n }\n _signWithControlledKey(privateKey, signedData) {\n return (0, eth_sig_util_1.signTypedData)({\n privateKey: Buffer.from((0, common_1.removeHexPrefix)(privateKey), 'hex'),\n data: signedData,\n version: eth_sig_util_1.SignTypedDataVersion.V4\n });\n }\n getAccounts() {\n return this.accounts.map(it => it.address);\n }\n}\nexports.AccountManager = AccountManager;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.defaultGsnConfig = exports.defaultLoggerConfiguration = void 0;\nconst common_1 = require(\"@opengsn/common\");\nconst GAS_PRICE_PERCENT = 20;\nconst GAS_PRICE_SLACK_PERCENT = 80;\nconst MAX_RELAY_NONCE_GAP = 3;\nconst DEFAULT_RELAY_TIMEOUT_GRACE_SEC = 1800;\nexports.defaultLoggerConfiguration = {\n logLevel: 'info'\n};\nexports.defaultGsnConfig = {\n calldataEstimationSlackFactor: 1,\n preferredRelays: [],\n blacklistedRelays: [],\n pastEventsQueryMaxPageSize: Number.MAX_SAFE_INTEGER,\n pastEventsQueryMaxPageCount: 20,\n gasPriceFactorPercent: GAS_PRICE_PERCENT,\n gasPriceSlackPercent: GAS_PRICE_SLACK_PERCENT,\n getGasFeesBlocks: 5,\n getGasFeesPercentile: 50,\n gasPriceOracleUrl: '',\n gasPriceOraclePath: '',\n minMaxPriorityFeePerGas: 1e9,\n maxRelayNonceGap: MAX_RELAY_NONCE_GAP,\n relayTimeoutGrace: DEFAULT_RELAY_TIMEOUT_GRACE_SEC,\n methodSuffix: '_v4',\n requiredVersionRange: common_1.gsnRequiredVersion,\n jsonStringifyRequest: true,\n auditorsCount: 0,\n skipErc165Check: false,\n clientId: '1',\n requestValidSeconds: 172800,\n maxViewableGasLimit: '12000000',\n minViewableGasLimit: '300000',\n environment: common_1.defaultEnvironment,\n maxApprovalDataLength: 0,\n maxPaymasterDataLength: 0,\n clientDefaultConfigUrl: `https://client-config.opengsn.org/${common_1.gsnRuntimeVersion}/client-config.json`,\n useClientDefaultConfigUrl: true,\n performDryRunViewRelayCall: true,\n performEstimateGasFromRealSender: false,\n tokenPaymasterAddress: '',\n tokenPaymasterDomainSeparators: {},\n waitForSuccessSliceSize: 3,\n waitForSuccessPingGrace: 3000,\n domainSeparatorName: 'GSN Relayed Transaction'\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.GsnRelayerResponseEvent = exports.GsnSendToRelayerEvent = exports.GsnValidateRequestEvent = exports.GsnSignRequestEvent = exports.GsnNextRelayEvent = exports.GsnDoneRefreshRelaysEvent = exports.GsnRefreshRelaysEvent = exports.GsnInitEvent = exports.GsnEvent = void 0;\n/**\n * base export class for all events fired by RelayClient.\n * for \"progress\" report, it is enough to test the base export class only.\n * subclasses contain some extra information about the events.\n * Last event is when we receive response from relayer that event was sent - now we should wait for mining..\n */\nconst TOTAL_EVENTS = 7;\nclass GsnEvent {\n constructor(event, step) {\n this.event = event;\n this.step = step;\n this.total = TOTAL_EVENTS;\n }\n}\nexports.GsnEvent = GsnEvent;\n// initialize client (should be done before all requests. not counted in \"total\")\nclass GsnInitEvent extends GsnEvent {\n constructor() {\n super('init', 0);\n }\n}\nexports.GsnInitEvent = GsnInitEvent;\nclass GsnRefreshRelaysEvent extends GsnEvent {\n constructor() {\n super('refresh-relays', 1);\n }\n}\nexports.GsnRefreshRelaysEvent = GsnRefreshRelaysEvent;\nclass GsnDoneRefreshRelaysEvent extends GsnEvent {\n constructor(relaysCount) {\n super('refreshed-relays', 2);\n this.relaysCount = relaysCount;\n }\n}\nexports.GsnDoneRefreshRelaysEvent = GsnDoneRefreshRelaysEvent;\nclass GsnNextRelayEvent extends GsnEvent {\n constructor(relayUrl) {\n super('next-relay', 3);\n this.relayUrl = relayUrl;\n }\n}\nexports.GsnNextRelayEvent = GsnNextRelayEvent;\nclass GsnSignRequestEvent extends GsnEvent {\n constructor() {\n super('sign-request', 4);\n }\n}\nexports.GsnSignRequestEvent = GsnSignRequestEvent;\n// before sending the request to the relayer, the client attempt to verify it will succeed.\n// validation may fail if the paymaster rejects the request\nclass GsnValidateRequestEvent extends GsnEvent {\n constructor() {\n super('validate-request', 5);\n }\n}\nexports.GsnValidateRequestEvent = GsnValidateRequestEvent;\nclass GsnSendToRelayerEvent extends GsnEvent {\n constructor(relayUrl) {\n super('send-to-relayer', 6);\n this.relayUrl = relayUrl;\n }\n}\nexports.GsnSendToRelayerEvent = GsnSendToRelayerEvent;\nclass GsnRelayerResponseEvent extends GsnEvent {\n constructor(success) {\n super('relayer-response', 7);\n this.success = success;\n }\n}\nexports.GsnRelayerResponseEvent = GsnRelayerResponseEvent;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.KnownRelaysManager = exports.DefaultRelayFilter = void 0;\nconst common_1 = require(\"@opengsn/common\");\nconst DefaultRelayFilter = function (registrarRelayInfo) {\n return true;\n};\nexports.DefaultRelayFilter = DefaultRelayFilter;\nclass KnownRelaysManager {\n constructor(contractInteractor, logger, config, relayFilter) {\n this.relayFailures = new Map();\n this.preferredRelayers = [];\n this.allRelayers = [];\n this.config = config;\n this.logger = logger;\n this.relayFilter = relayFilter !== null && relayFilter !== void 0 ? relayFilter : exports.DefaultRelayFilter;\n this.contractInteractor = contractInteractor;\n }\n async refresh() {\n this._refreshFailures();\n this.preferredRelayers = this.config.preferredRelays.map(relayUrl => {\n return {\n relayUrl\n };\n });\n this.allRelayers = await this.getRelayInfoForManagers();\n }\n getRelayInfoForManager(address) {\n return this.allRelayers.find(info => (0, common_1.isSameAddress)(info.relayManager, address));\n }\n async getRelayInfoForManagers() {\n const relayInfos = await this.contractInteractor.getRegisteredRelays();\n this.logger.info(`fetchRelaysAdded: found ${relayInfos.length} relays`);\n const blacklistFilteredRelayInfos = relayInfos.filter(info => {\n const isHostBlacklisted = this.config.blacklistedRelays.find(relay => info.relayUrl.toLowerCase().includes(relay.toLowerCase())) != null;\n const isManagerBlacklisted = this.config.blacklistedRelays.find(relay => (0, common_1.isSameAddress)(info.relayManager, relay)) != null;\n return !(isHostBlacklisted || isManagerBlacklisted);\n });\n const filteredRelayInfos = blacklistFilteredRelayInfos.filter(this.relayFilter);\n if (filteredRelayInfos.length !== relayInfos.length) {\n this.logger.warn(`RelayFilter: removing ${relayInfos.length - filteredRelayInfos.length} relays from results`);\n }\n return filteredRelayInfos;\n }\n _refreshFailures() {\n const newMap = new Map();\n this.relayFailures.forEach((value, key) => {\n newMap.set(key, value.filter(failure => {\n const elapsed = (new Date().getTime() - failure.lastErrorTime) / 1000;\n return elapsed < this.config.relayTimeoutGrace;\n }));\n });\n this.relayFailures = newMap;\n }\n async getRelaysShuffledForTransaction() {\n const sortedRelays = [];\n // preferred relays are copied as-is, unsorted (we don't have any info about them anyway to sort)\n sortedRelays[0] = Array.from(this.preferredRelayers);\n const hasFailure = it => {\n return this.relayFailures.get(it.relayUrl) != null;\n };\n const relaysWithFailures = this.allRelayers.filter(hasFailure);\n const relaysWithoutFailures = this.allRelayers.filter(it => {\n return !hasFailure(it);\n });\n sortedRelays[1] = (0, common_1.shuffle)(relaysWithoutFailures);\n sortedRelays[2] = (0, common_1.shuffle)(relaysWithFailures);\n for (let i = 0; i < sortedRelays.length; i++) {\n const queriedRelaysSize = sortedRelays[i].length;\n sortedRelays[i] = sortedRelays[i].filter(it => (0, common_1.validateRelayUrl)(it.relayUrl));\n if (sortedRelays[i].length < queriedRelaysSize) {\n this.logger.info(`getRelaysShuffledForTransaction (${i}): filtered out ${queriedRelaysSize - sortedRelays[i].length} relays without a public URL or a public URL that is not valid`);\n }\n }\n return sortedRelays;\n }\n getAuditors(excludeUrls) {\n if (this.config.auditorsCount === 0) {\n this.logger.debug('skipping audit step as \"auditorsCount\" config parameter is set to 0');\n return [];\n }\n const indexes = [];\n const auditors = [];\n const flatRelayers = [...this.preferredRelayers, ...this.allRelayers].map(it => it.relayUrl).filter(it => !excludeUrls.includes(it)).filter((value, index, self) => {\n return self.indexOf(value) === index;\n });\n if (flatRelayers.length <= this.config.auditorsCount) {\n if (flatRelayers.length < this.config.auditorsCount) {\n this.logger.warn(`Not enough auditors: request ${this.config.auditorsCount} but only have ${flatRelayers.length}`);\n }\n return flatRelayers;\n }\n do {\n const index = Math.floor(Math.random() * flatRelayers.length);\n if (!indexes.includes(index)) {\n auditors.push(flatRelayers[index]);\n indexes.push(index);\n }\n } while (auditors.length < this.config.auditorsCount);\n return auditors;\n }\n saveRelayFailure(lastErrorTime, relayManager, relayUrl) {\n const relayFailures = this.relayFailures.get(relayUrl);\n const newFailureInfo = {\n lastErrorTime,\n relayManager,\n relayUrl\n };\n if (relayFailures == null) {\n this.relayFailures.set(relayUrl, [newFailureInfo]);\n } else {\n relayFailures.push(newFailureInfo);\n }\n }\n isPreferred(relayUrl) {\n return this.preferredRelayers.find(it => it.relayUrl.toLowerCase() === relayUrl.toLowerCase()) != null;\n }\n}\nexports.KnownRelaysManager = KnownRelaysManager;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RelaySelectionManager = void 0;\nconst ErrorReplacerJSON_1 = require(\"@opengsn/common/dist/ErrorReplacerJSON\");\nconst common_1 = require(\"@opengsn/common\");\nclass RelaySelectionManager {\n constructor(gsnTransactionDetails, knownRelaysManager, httpClient, pingFilter, logger, config) {\n this.remainingRelays = [];\n this.isInitialized = false;\n this.errors = new Map();\n this.gsnTransactionDetails = gsnTransactionDetails;\n this.knownRelaysManager = knownRelaysManager;\n this.httpClient = httpClient;\n this.pingFilter = pingFilter;\n this.config = config;\n this.logger = logger;\n }\n /**\n * Ping those relays that were not pinged yet, and remove both the returned relay or relays re from {@link remainingRelays}\n * @returns the first relay to respond to a ping message. Note: will never return the same relay twice.\n */\n async selectNextRelay(relayHub, paymaster) {\n while (true) {\n const slice = this._getNextSlice();\n let relayInfo;\n if (slice.length > 0) {\n relayInfo = await this._nextRelayInternal(slice, relayHub, paymaster);\n if (relayInfo == null) {\n continue;\n }\n }\n return relayInfo;\n }\n }\n async _nextRelayInternal(relays, relayHub, paymaster) {\n this.logger.info('nextRelay: find fastest relay from: ' + JSON.stringify(relays));\n const allPingResults = await this._waitForSuccess(relays, relayHub, paymaster);\n this.logger.info(`race finished with a result: ${JSON.stringify(allPingResults, ErrorReplacerJSON_1.replaceErrors)}`);\n const {\n winner,\n skippedRelays\n } = this.selectWinnerFromResult(allPingResults);\n this._handleWaitForSuccessResults(allPingResults, skippedRelays, winner === null || winner === void 0 ? void 0 : winner.relayInfo);\n if (winner == null) {\n return;\n }\n if ((0, common_1.isInfoFromEvent)(winner.relayInfo.relayInfo)) {\n return {\n relayInfo: winner.relayInfo,\n updatedGasFees: winner.updatedGasFees,\n maxDeltaPercent: winner.maxDeltaPercent\n };\n } else {\n const managerAddress = winner.relayInfo.pingResponse.relayManagerAddress;\n this.logger.debug(`finding relay register info for manager address: ${managerAddress}; known info: ${JSON.stringify(winner.relayInfo)}`);\n const event = await this.knownRelaysManager.getRelayInfoForManager(managerAddress);\n if (event == null) {\n this.logger.error('Could not find registration info in the RelayRegistrar for the selected preferred relay');\n return undefined;\n }\n // as preferred relay URL is not guaranteed to match the advertised one for the same manager, preserve URL\n const relayInfo = Object.assign({}, event);\n relayInfo.relayUrl = winner.relayInfo.relayInfo.relayUrl;\n return {\n relayInfo: {\n pingResponse: winner.relayInfo.pingResponse,\n relayInfo\n },\n updatedGasFees: winner.updatedGasFees,\n maxDeltaPercent: winner.maxDeltaPercent\n };\n }\n }\n async init() {\n this.remainingRelays = await this.knownRelaysManager.getRelaysShuffledForTransaction();\n this.isInitialized = true;\n return this;\n }\n // relays left to try\n // (note that some edge-cases (like duplicate urls) are not filtered out)\n relaysLeft() {\n return this.remainingRelays.flatMap(list => list);\n }\n _getNextSlice() {\n if (!this.isInitialized) {\n throw new Error('init() not called');\n }\n for (const relays of this.remainingRelays) {\n const bulkSize = Math.min(this.config.waitForSuccessSliceSize, relays.length);\n const slice = relays.slice(0, bulkSize);\n if (slice.length === 0) {\n continue;\n }\n return slice;\n }\n return [];\n }\n /**\n * @returns JSON response from the relay server, but adds the requested URL to it :'-(\n */\n async _getRelayAddressPing(relayInfo, relayHub, paymaster) {\n this.logger.info(`getRelayAddressPing URL: ${relayInfo.relayUrl}`);\n const pingResponse = await this.httpClient.getPingResponse(relayInfo.relayUrl, paymaster);\n if (!pingResponse.ready) {\n throw new Error(`Relay not ready ${JSON.stringify(pingResponse)}`);\n }\n if (!(0, common_1.isSameAddress)(relayHub, pingResponse.relayHubAddress)) {\n throw new Error(`Client is using RelayHub ${relayHub} while the server responded with RelayHub address ${pingResponse.relayHubAddress}`);\n }\n this.pingFilter(pingResponse, this.gsnTransactionDetails);\n return {\n pingResponse,\n relayInfo\n };\n }\n async _waitForSuccess(relays, relayHub, paymaster) {\n // go through a Map to remove duplicates\n const asMap = new Map();\n relays.forEach(it => {\n asMap.set(it.relayUrl, it);\n });\n const asArray = Array.from(asMap.values());\n if (asArray.length !== relays.length) {\n this.logger.info(`waitForSuccess: Removed ${relays.length - asArray.length} duplicate Relay Server URLs from `);\n }\n const promises = asArray.map(async relay => {\n return await this._getRelayAddressPing(relay, relayHub, paymaster);\n });\n const errorKeys = asArray.map(it => {\n return it.relayUrl;\n });\n return await (0, common_1.waitForSuccess)(promises, errorKeys, this.config.waitForSuccessPingGrace);\n }\n _handleWaitForSuccessResults(raceResult, skippedRelays, winner) {\n if (!this.isInitialized) {\n throw new Error('init() not called');\n }\n this.errors = new Map([...this.errors, ...raceResult.errors]);\n const totalRemainingRelaysBefore = this.remainingRelays.map(relays => {\n return relays.length;\n }).reduce((a, b) => {\n return a + b;\n }, 0);\n function notWinner(eventInfo) {\n if (winner == null) {\n return true;\n }\n const eventUrl = new URL(eventInfo.relayUrl).toString();\n const winnerUrl = new URL(winner.relayInfo.relayUrl).toString();\n return eventUrl !== winnerUrl;\n }\n function notError(eventInfo) {\n const urls = Array.from(raceResult.errors.keys()).map(it => new URL(it).toString());\n return !urls.includes(new URL(eventInfo.relayUrl).toString());\n }\n function notSkipped(eventInfo) {\n // remove relays skipped (due to gas fees being wrong)\n return !skippedRelays.map(it => new URL(it).toString()).includes(new URL(eventInfo.relayUrl).toString());\n }\n this.remainingRelays = this.remainingRelays.map(relays => relays.filter(notWinner).filter(notError).filter(notSkipped));\n const totalRemainingRelaysAfter = this.remainingRelays.map(relays => {\n return relays.length;\n }).reduce((a, b) => {\n return a + b;\n }, 0);\n const touched = raceResult.errors.size + (winner != null ? 1 : raceResult.results.length);\n this.logger.debug(`_handleWaitForSuccessResults info ${totalRemainingRelaysBefore} ${totalRemainingRelaysAfter} ${touched}`);\n }\n selectWinnerFromResult(allPingResults) {\n if (allPingResults.results.length === 0) {\n return {\n skippedRelays: []\n };\n }\n const winner = this.selectWinnerWithoutAdjustingFees(allPingResults);\n if (winner != null) {\n return {\n winner,\n skippedRelays: []\n };\n }\n this.logger.debug('No relay with suitable gas fees found in current slice. Adjusting request...');\n return this.selectWinnerByAdjustingFees(allPingResults);\n }\n /**\n * Pick a random relay among those that satisfy the original client gas fees parameters.\n */\n selectWinnerWithoutAdjustingFees(allPingResults) {\n const relaysWithSatisfyingFees = allPingResults.results.filter(it => {\n return parseInt(it.pingResponse.maxMaxFeePerGas) >= parseInt(this.gsnTransactionDetails.maxFeePerGas) && parseInt(it.pingResponse.minMaxFeePerGas) <= parseInt(this.gsnTransactionDetails.maxFeePerGas) && parseInt(it.pingResponse.minMaxPriorityFeePerGas) <= parseInt(this.gsnTransactionDetails.maxPriorityFeePerGas);\n });\n this.logger.debug(`selectWinnerWithoutAdjustingFees: allPingResults length: (${allPingResults.results.length}) relaysWithSatisfyingFees length: (${relaysWithSatisfyingFees.length})`);\n if (relaysWithSatisfyingFees.length === 0) {\n return;\n }\n return {\n relayInfo: (0, common_1.pickRandomElementFromArray)(relaysWithSatisfyingFees),\n updatedGasFees: this.gsnTransactionDetails,\n maxDeltaPercent: 0\n };\n }\n /**\n * Here we attempt to save the Relay Request attempt and avoid raising an exception in the client code.\n * As these Relay Servers did not agree to our suggested gas fees, we cannot rely on Random to pick a winner.\n * Pick Relay Servers deterministically with the closest gas fees instead.\n */\n selectWinnerByAdjustingFees(allPingResults) {\n const skippedRelays = [];\n const adjustedArray = allPingResults.results.map(it => {\n return (0, common_1.adjustRelayRequestForPingResponse)(this.gsnTransactionDetails, it);\n }).filter(it => {\n const isGasPriceWithinSlack = it.maxDeltaPercent <= this.config.gasPriceSlackPercent;\n if (!isGasPriceWithinSlack) {\n const skippedRelayUrl = it.relayInfo.relayInfo.relayUrl;\n this.logger.debug(`\nSkipping relay (${skippedRelayUrl}) due to gas fees being higher than allowed by ${it.maxDeltaPercent}%.\nThere are many reasons a Relay Server may want a higher price. See our FAQ page: https://docs.opengsn.org/faq/troubleshooting.html\nTLDR: you can set 'gasPriceSlackPercent' to ${it.maxDeltaPercent} or more to make this relay acceptable for now.\nValue currently configured is: ${this.config.gasPriceSlackPercent}%`);\n skippedRelays.push(skippedRelayUrl);\n }\n return isGasPriceWithinSlack;\n }).sort((a, b) => {\n return a.maxDeltaPercent - b.maxDeltaPercent;\n });\n const winner = adjustedArray[0];\n if (winner != null) {\n this.logger.debug(`Adjusting RelayRequest to use Relay Server (${winner.relayInfo.relayInfo.relayUrl}) with fees ${JSON.stringify(winner.updatedGasFees)}`);\n }\n return {\n winner,\n skippedRelays\n };\n }\n}\nexports.RelaySelectionManager = RelaySelectionManager;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createVerifierApprovalDataCallback = exports.DEFAULT_VERIFIER_SERVER_APPROVAL_DATA_LENGTH = exports.DEFAULT_VERIFIER_SERVER_URL = void 0;\nconst common_1 = require(\"@opengsn/common\");\n// TODO: replace with production URL before release\nexports.DEFAULT_VERIFIER_SERVER_URL = 'https://staging-api.opengsn.org';\nexports.DEFAULT_VERIFIER_SERVER_APPROVAL_DATA_LENGTH = 65;\nfunction createVerifierApprovalDataCallback(httpWrapper, logger, domainSeparatorName, chainId, apiKey, verifierUrl) {\n return async function defaultVerifierApprovalDataCallback(relayRequest, relayRequestId) {\n const approvalRequest = {\n apiKey,\n chainId,\n domainSeparatorName,\n relayRequest,\n relayRequestId\n };\n const signRelayRequestResponse = await httpWrapper.sendPromise(new URL('signRelayRequest', (0, common_1.appendSlashTrim)(verifierUrl)), approvalRequest);\n logger.info(`signRelayRequest response: ${JSON.stringify(signRelayRequestResponse)}`);\n return signRelayRequestResponse.signature;\n };\n}\nexports.createVerifierApprovalDataCallback = createVerifierApprovalDataCallback;\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RelayedTransactionValidator = exports.isTransactionValid = void 0;\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst tx_1 = require(\"@ethereumjs/tx\");\nconst abi_1 = require(\"@ethersproject/abi\");\nconst IRelayHub_json_1 = __importDefault(require(\"@opengsn/common/dist/interfaces/IRelayHub.json\"));\nconst common_1 = require(\"@opengsn/common\");\nfunction isTransactionValid(result) {\n const isValid1559GasFee = result.gasPriceValidationResult.isFeeMarket1559Transaction && result.gasPriceValidationResult.isMaxFeePerGasValid && result.gasPriceValidationResult.isMaxPriorityFeePerGasValid;\n const isGasPriceValid = result.gasPriceValidationResult.isTransactionTypeValid && (result.gasPriceValidationResult.isLegacyGasPriceValid || isValid1559GasFee);\n // this call is 'recursive' but transactions inside nonce gap have empty arrays here and function is not called\n const isNonceGapFilled = !result.nonceGapFilledValidationResult.map(it => isTransactionValid(it)).includes(false);\n return isGasPriceValid && isNonceGapFilled && result.isTransactionTargetValid && result.isTransactionSenderValid && result.isTransactionContentValid && result.isNonceGapFilledSizeValid && result.isTransactionNonceValid;\n}\nexports.isTransactionValid = isTransactionValid;\nclass RelayedTransactionValidator {\n constructor(contractInteractor, logger, config) {\n this.contractInteractor = contractInteractor;\n this.config = config;\n this.logger = logger;\n }\n /**\n * Decode the signed transaction returned from the Relay Server, compare it to the\n * requested transaction and validate its signature.\n * @returns true if relay response is valid, false otherwise\n */\n validateTransactionInNonceGap(request, transaction, expectedNonce) {\n const isTransactionSenderValid = this._validateTransactionSender(request, transaction);\n const isTransactionTargetValid = this.validateTransactionTarget(transaction);\n const isTransactionContentValid = this._validateTransactionMethodSignature(transaction);\n const gasPriceValidationResult = this._validateNonceGapGasPrice(request, transaction);\n const isTransactionNonceValid = parseInt(transaction.nonce.toString()) === expectedNonce;\n return {\n nonceGapFilledValidationResult: [],\n isNonceGapFilledSizeValid: true,\n isTransactionTargetValid,\n isTransactionSenderValid,\n isTransactionContentValid,\n gasPriceValidationResult,\n isTransactionNonceValid\n };\n }\n validateRelayResponse(request, returnedTx, nonceGapFilled) {\n const transaction = tx_1.TransactionFactory.fromSerializedData((0, ethereumjs_util_1.toBuffer)(returnedTx), this.contractInteractor.getRawTxOptions());\n this.logger.debug(`returnedTx: ${JSON.stringify(transaction.toJSON(), null, 2)}`);\n const nonce = parseInt(transaction.nonce.toString());\n const expectedNonceGapLength = nonce - request.metadata.relayLastKnownNonce;\n const isNonceGapFilledSizeValid = Object.keys(nonceGapFilled).length === expectedNonceGapLength;\n const isTransactionTargetValid = this.validateTransactionTarget(transaction);\n const isTransactionSenderValid = this._validateTransactionSender(request, transaction);\n const isTransactionContentValid = this._validateTransactionContent(request, transaction);\n const gasPriceValidationResult = this._validateGasPrice(request, transaction);\n const isTransactionNonceValid = nonce <= request.metadata.relayMaxNonce;\n const nonceGapFilledValidationResult = this._validateNonceGapFilled(request, nonceGapFilled);\n return {\n gasPriceValidationResult,\n isTransactionTargetValid,\n isTransactionSenderValid,\n isTransactionContentValid,\n isTransactionNonceValid,\n isNonceGapFilledSizeValid,\n nonceGapFilledValidationResult\n };\n }\n validateTransactionTarget(transaction) {\n const relayHubAddress = this.contractInteractor.getDeployment().relayHubAddress;\n return transaction.to != null && relayHubAddress != null && (0, common_1.isSameAddress)(transaction.to.toString(), relayHubAddress);\n }\n _validateTransactionSender(request, transaction) {\n const signer = transaction.getSenderAddress().toString();\n return (0, common_1.isSameAddress)(request.relayRequest.relayData.relayWorker, signer);\n }\n /**\n * For transactions that are filling the nonce gap, we only check that the transaction is not penalizable.\n */\n _validateTransactionMethodSignature(transaction) {\n const iface = new abi_1.Interface(IRelayHub_json_1.default);\n const relayCallSignature = iface.getSighash('relayCall');\n return (0, ethereumjs_util_1.bufferToHex)(transaction.data).startsWith(relayCallSignature);\n }\n _validateTransactionContent(request, transaction) {\n const relayRequestAbiEncode = this.contractInteractor.encodeABI({\n domainSeparatorName: request.metadata.domainSeparatorName,\n relayRequest: request.relayRequest,\n signature: request.metadata.signature,\n approvalData: request.metadata.approvalData,\n maxAcceptanceBudget: request.metadata.maxAcceptanceBudget\n });\n return relayRequestAbiEncode === (0, ethereumjs_util_1.bufferToHex)(transaction.data);\n }\n _validateNonceGapGasPrice(_request, _transaction) {\n // TODO: implement logic for verifying gas price is valid for transactions in the nonce gap\n this.logger.debug('not checking gas prices for transaction in nonce gap - not implemented');\n return {\n isTransactionTypeValid: true,\n isFeeMarket1559Transaction: true,\n isLegacyGasPriceValid: true,\n isMaxFeePerGasValid: true,\n isMaxPriorityFeePerGasValid: true\n };\n }\n _validateGasPrice(request, transaction) {\n let isTransactionTypeValid = true;\n let isFeeMarket1559Transaction = false;\n let isLegacyGasPriceValid = false;\n let isMaxFeePerGasValid = false;\n let isMaxPriorityFeePerGasValid = false;\n if (transaction instanceof tx_1.Transaction) {\n isLegacyGasPriceValid = transaction.gasPrice.gte((0, common_1.toBN)(request.relayRequest.relayData.maxFeePerGas));\n } else if (transaction instanceof tx_1.FeeMarketEIP1559Transaction) {\n isFeeMarket1559Transaction = true;\n isMaxPriorityFeePerGasValid = transaction.maxPriorityFeePerGas.gte((0, common_1.toBN)(request.relayRequest.relayData.maxPriorityFeePerGas));\n isMaxFeePerGasValid = transaction.maxFeePerGas.gte((0, common_1.toBN)(request.relayRequest.relayData.maxFeePerGas));\n } else {\n isTransactionTypeValid = false;\n }\n return {\n isTransactionTypeValid,\n isFeeMarket1559Transaction,\n isLegacyGasPriceValid,\n isMaxFeePerGasValid,\n isMaxPriorityFeePerGasValid\n };\n }\n _validateNonceGapFilled(request, transactionsInGap) {\n const result = [];\n let expectedNonce = request.metadata.relayLastKnownNonce;\n for (const rawTransaction of Object.values(transactionsInGap)) {\n const transaction = tx_1.TransactionFactory.fromSerializedData((0, ethereumjs_util_1.toBuffer)(rawTransaction), this.contractInteractor.getRawTxOptions());\n const validationResult = this.validateTransactionInNonceGap(request, transaction, expectedNonce);\n result.push(validationResult);\n expectedNonce++;\n }\n return result;\n }\n}\nexports.RelayedTransactionValidator = RelayedTransactionValidator;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports._dumpRelayingResult = exports.RelayClient = exports.GasPricePingFilter = exports.EmptyDataCallback = void 0;\nconst events_1 = require(\"events\");\nconst tx_1 = require(\"@ethereumjs/tx\");\nconst ethereumjs_util_1 = require(\"ethereumjs-util\");\nconst common_1 = require(\"@opengsn/common\");\nconst AccountManager_1 = require(\"./AccountManager\");\nconst KnownRelaysManager_1 = require(\"./KnownRelaysManager\");\nconst RelaySelectionManager_1 = require(\"./RelaySelectionManager\");\nconst VerifierUtils_1 = require(\"./VerifierUtils\");\nconst RelayedTransactionValidator_1 = require(\"./RelayedTransactionValidator\");\nconst GSNConfigurator_1 = require(\"./GSNConfigurator\");\nconst GsnEvents_1 = require(\"./GsnEvents\");\n// forwarder requests are signed with expiration time.\n// generate \"approvalData\" and \"paymasterData\" for a request.\n// both are bytes arrays. paymasterData is part of the client request.\n// approvalData is created after request is filled and signed.\nconst EmptyDataCallback = async (...args) => {\n return '0x';\n};\nexports.EmptyDataCallback = EmptyDataCallback;\n/**\n * Warning: if providing custom 'PingFilter' it is important to call this one as well.\n * The MaxMaxFeePerGas parameter only exists on the Relay Server for the sanity check (i.e. not paying 1 ETH per gas).\n * We do not adjust a request for the MaxMaxFeePerGas, proposing gas prices above it is a sure misconfiguration.\n */\nconst GasPricePingFilter = (pingResponse, gsnTransactionDetails) => {\n if (parseInt(pingResponse.minMaxFeePerGas) >= parseInt(pingResponse.maxMaxFeePerGas)) {\n throw new Error(`Misconfigured relay: relay's configured maxMaxFeePerGas: ${pingResponse.maxMaxFeePerGas} relay's minMaxFeePerGas: ${pingResponse.minMaxFeePerGas}`);\n }\n if (parseInt(gsnTransactionDetails.maxFeePerGas) > parseInt(pingResponse.maxMaxFeePerGas)) {\n throw new Error(`Proposed fee per gas: ${parseInt(gsnTransactionDetails.maxFeePerGas)}; relay's configured maxMaxFeePerGas: ${pingResponse.maxMaxFeePerGas}`);\n }\n};\nexports.GasPricePingFilter = GasPricePingFilter;\nclass RelayClient {\n constructor(rawConstructorInput) {\n var _a, _b;\n this.emitter = new events_1.EventEmitter();\n this.initialized = false;\n // TODO: backwards-compatibility 102 - remove on next version bump\n if (arguments[0] == null || arguments[0].send != null || arguments[2] != null) {\n throw new Error('Sorry, but the constructor parameters of the RelayClient class have changed. See \"GSNUnresolvedConstructorInput\" interface for details.');\n }\n this.rawConstructorInput = rawConstructorInput;\n this.logger = (_b = (_a = rawConstructorInput.overrideDependencies) === null || _a === void 0 ? void 0 : _a.logger) !== null && _b !== void 0 ? _b : console;\n }\n async init(useTokenPaymaster = false) {\n if (this.initialized) {\n throw new Error('init() already called');\n }\n this.initializingPromise = this._initInternal(useTokenPaymaster);\n await this.initializingPromise;\n this.initialized = true;\n return this;\n }\n async _initInternal(useTokenPaymaster = false) {\n this.emit(new GsnEvents_1.GsnInitEvent());\n this.config = await this._resolveConfiguration(this.rawConstructorInput);\n if (useTokenPaymaster && this.config.tokenPaymasterAddress !== '') {\n this.logger.debug(`Using token paymaster ${this.config.tokenPaymasterAddress}`);\n this.config.paymasterAddress = this.config.tokenPaymasterAddress;\n }\n this.dependencies = await this._resolveDependencies({\n config: this.config,\n provider: this.getUnderlyingProvider(),\n overrideDependencies: this.rawConstructorInput.overrideDependencies\n });\n if (!this.config.skipErc165Check) {\n await this.dependencies.contractInteractor._validateERC165InterfacesClient();\n }\n }\n /**\n * register a listener for GSN events\n * @see GsnEvent and its subclasses for emitted events\n * @param handler callback function to handle events\n */\n registerEventListener(handler) {\n this.emitter.on('gsn', handler);\n }\n /**\n * unregister previously registered event listener\n * @param handler callback function to unregister\n */\n unregisterEventListener(handler) {\n this.emitter.off('gsn', handler);\n }\n emit(event) {\n this.emitter.emit('gsn', event);\n }\n /**\n * In case Relay Server does not broadcast the signed transaction to the network,\n * client also broadcasts the same transaction. If the transaction fails with nonce\n * error, it indicates Relay may have signed multiple transactions with same nonce,\n * causing a DoS attack.\n *\n * @param {*} transaction - actual Ethereum transaction, signed by a relay\n */\n async _broadcastRawTx(transaction) {\n const rawTx = '0x' + transaction.serialize().toString('hex');\n const txHash = '0x' + transaction.hash().toString('hex');\n try {\n if (await this._isAlreadySubmitted(txHash)) {\n this.logger.debug('Not broadcasting raw transaction as our RPC endpoint already sees it');\n return {\n hasReceipt: true\n };\n }\n this.logger.info(`Broadcasting raw transaction signed by relay. TxHash: ${txHash}\\nNote: this may cause a \"transaction already known\" error to appear in the logs. It is not a problem, please ignore that error.`);\n // can't find the TX in the mempool. broadcast it ourselves.\n await this.dependencies.contractInteractor.sendSignedTransaction(rawTx);\n return {\n hasReceipt: true\n };\n } catch (broadcastError) {\n // don't display error for the known-good cases\n if ((broadcastError === null || broadcastError === void 0 ? void 0 : broadcastError.message.match(/the tx doesn't have the correct nonce|known transaction/)) != null) {\n return {\n hasReceipt: false,\n wrongNonce: true,\n broadcastError\n };\n }\n return {\n hasReceipt: false,\n broadcastError\n };\n }\n }\n async _isAlreadySubmitted(txHash) {\n const [txMinedReceipt, pendingBlock] = await Promise.all([this.dependencies.contractInteractor.provider.getTransactionReceipt(txHash),\n // mempool transactions\n // ethers.js does not really support 'pending' block yet\n this.dependencies.contractInteractor.provider.send('eth_getBlockByNumber', ['pending', false])]);\n if (txMinedReceipt != null) {\n return true;\n }\n return pendingBlock.transactions.includes(txHash);\n }\n async relayTransaction(_gsnTransactionDetails) {\n var _a, _b, _c;\n if (!this.initialized) {\n if (this.initializingPromise == null) {\n this._warn('suggestion: call RelayProvider.init()/RelayClient.init() in advance (to make first request faster)');\n }\n await this.init();\n }\n const gsnTransactionDetails = Object.assign({}, _gsnTransactionDetails);\n // TODO: should have a better strategy to decide how often to refresh known relays\n this.emit(new GsnEvents_1.GsnRefreshRelaysEvent());\n await this.dependencies.knownRelaysManager.refresh();\n gsnTransactionDetails.maxFeePerGas = (0, common_1.toHex)(gsnTransactionDetails.maxFeePerGas);\n gsnTransactionDetails.maxPriorityFeePerGas = (0, common_1.toHex)(gsnTransactionDetails.maxPriorityFeePerGas);\n if (gsnTransactionDetails.gas == null) {\n // in order to avoid using less gas in '_msgSender()', make an 'estimateGas' call from the Forwarder address\n let from = this.dependencies.contractInteractor.getDeployment().forwarderAddress;\n let data = gsnTransactionDetails.data + gsnTransactionDetails.from.replace('0x', '');\n if (this.config.performEstimateGasFromRealSender) {\n // use only in case making an 'estimateGas' from Forwarder address causes exceptions\n from = gsnTransactionDetails.from;\n data = gsnTransactionDetails.data;\n }\n const value = '0';\n const txDetailsFromForwarder = Object.assign({}, gsnTransactionDetails, {\n from,\n data,\n value\n });\n const estimated = await this.dependencies.contractInteractor.estimateInnerCallGasLimit(txDetailsFromForwarder);\n gsnTransactionDetails.gas = `0x${estimated.toString(16)}`;\n }\n const relayingErrors = new Map();\n const auditPromises = [];\n let relayRequest;\n try {\n relayRequest = await this._prepareRelayRequest(gsnTransactionDetails);\n } catch (error) {\n relayingErrors.set(common_1.constants.DRY_RUN_KEY, error);\n return {\n relayingErrors,\n auditPromises,\n pingErrors: new Map()\n };\n }\n if (this.config.performDryRunViewRelayCall) {\n const dryRunError = await this._verifyDryRunSuccessful(relayRequest);\n if (dryRunError != null) {\n relayingErrors.set(common_1.constants.DRY_RUN_KEY, dryRunError);\n return {\n relayingErrors,\n auditPromises,\n pingErrors: new Map()\n };\n }\n }\n const relaySelectionManager = await new RelaySelectionManager_1.RelaySelectionManager(gsnTransactionDetails, this.dependencies.knownRelaysManager, this.dependencies.httpClient, this.dependencies.pingFilter, this.logger, this.config).init();\n const count = relaySelectionManager.relaysLeft().length;\n this.emit(new GsnEvents_1.GsnDoneRefreshRelaysEvent(count));\n if (count === 0) {\n throw new Error('no registered relayers');\n }\n const paymaster = this.dependencies.contractInteractor.getDeployment().paymasterAddress;\n // approximate block height when relaying began is used to look up relayed events\n const submissionBlock = await this.dependencies.contractInteractor.getBlockNumberRightNow();\n while (true) {\n let relayingAttempt;\n const relayHub = (_a = this.dependencies.contractInteractor.getDeployment().relayHubAddress) !== null && _a !== void 0 ? _a : '';\n const relaySelectionResult = await relaySelectionManager.selectNextRelay(relayHub, paymaster);\n const activeRelay = relaySelectionResult === null || relaySelectionResult === void 0 ? void 0 : relaySelectionResult.relayInfo; // safe to cast as R.S.M. looks up missing details internally\n if (activeRelay != null) {\n if (relaySelectionResult != null) {\n // adjust relay request fees for the selected relay if necessary\n relayRequest.relayData.maxFeePerGas = (0, common_1.toHex)(relaySelectionResult.updatedGasFees.maxFeePerGas);\n relayRequest.relayData.maxPriorityFeePerGas = (0, common_1.toHex)(relaySelectionResult.updatedGasFees.maxPriorityFeePerGas);\n }\n this.emit(new GsnEvents_1.GsnNextRelayEvent(activeRelay.relayInfo.relayUrl));\n relayingAttempt = await this._attemptRelay(activeRelay, relayRequest).catch(error => ({\n error\n }));\n if (relayingAttempt.auditPromise != null) {\n auditPromises.push(relayingAttempt.auditPromise);\n }\n if (relayingAttempt.transaction == null) {\n relayingErrors.set(activeRelay.relayInfo.relayUrl, (_b = relayingAttempt.error) !== null && _b !== void 0 ? _b : new Error('No error reason was given'));\n if ((_c = relayingAttempt.isRelayError) !== null && _c !== void 0 ? _c : false) {\n // continue with next relayer\n continue;\n }\n }\n }\n return {\n relayRequestID: relayingAttempt === null || relayingAttempt === void 0 ? void 0 : relayingAttempt.relayRequestID,\n submissionBlock,\n validUntilTime: relayingAttempt === null || relayingAttempt === void 0 ? void 0 : relayingAttempt.validUntilTime,\n transaction: relayingAttempt === null || relayingAttempt === void 0 ? void 0 : relayingAttempt.transaction,\n relayingErrors,\n auditPromises,\n pingErrors: relaySelectionManager.errors\n };\n }\n }\n _warn(msg) {\n this.logger.warn(msg);\n }\n async calculateGasFees() {\n const pct = this.config.gasPriceFactorPercent;\n const gasFees = await this.dependencies.contractInteractor.getGasFees(this.config.getGasFeesBlocks, this.config.getGasFeesPercentile);\n let priorityFee = Math.round(parseInt(gasFees.priorityFeePerGas) * (pct + 100) / 100);\n if (this.config.minMaxPriorityFeePerGas != null && priorityFee < this.config.minMaxPriorityFeePerGas) {\n priorityFee = this.config.minMaxPriorityFeePerGas;\n }\n const maxPriorityFeePerGas = `0x${priorityFee.toString(16)}`;\n let maxFeePerGas = `0x${Math.round((parseInt(gasFees.baseFeePerGas) + priorityFee) * (pct + 100) / 100).toString(16)}`;\n if (parseInt(maxFeePerGas) === 0) {\n maxFeePerGas = maxPriorityFeePerGas;\n }\n return {\n maxFeePerGas,\n maxPriorityFeePerGas\n };\n }\n async _attemptRelay(relayInfo, relayRequest) {\n this.logger.info(`attempting relay: ${JSON.stringify(relayInfo)} transaction: ${JSON.stringify(relayRequest)}`);\n await this.fillRelayInfo(relayRequest, relayInfo);\n const httpRequest = await this._prepareRelayHttpRequest(relayRequest, relayInfo);\n this.emit(new GsnEvents_1.GsnValidateRequestEvent());\n const viewCallGasLimit = await this.dependencies.contractInteractor.calculateDryRunCallGasLimit(relayRequest.relayData.paymaster, relayRequest.relayData.relayWorker, (0, common_1.toBN)(relayRequest.relayData.maxFeePerGas), (0, common_1.toBN)(this.config.maxViewableGasLimit), (0, common_1.toBN)(this.config.minViewableGasLimit));\n const error = await this._verifyViewCallSuccessful(relayInfo, (0, common_1.asRelayCallAbi)(httpRequest), viewCallGasLimit, false);\n if (error != null) {\n return {\n error\n };\n }\n let signedTx;\n let nonceGapFilled;\n let transaction;\n let auditPromise;\n this.emit(new GsnEvents_1.GsnSendToRelayerEvent(relayInfo.relayInfo.relayUrl));\n try {\n ({\n signedTx,\n nonceGapFilled\n } = await this.dependencies.httpClient.relayTransaction(relayInfo.relayInfo.relayUrl, httpRequest));\n transaction = tx_1.TransactionFactory.fromSerializedData((0, ethereumjs_util_1.toBuffer)(signedTx), this.dependencies.contractInteractor.getRawTxOptions());\n auditPromise = this.auditTransaction(signedTx, relayInfo.relayInfo.relayUrl).then(penalizeResponse => {\n if (penalizeResponse.commitTxHash != null) {\n const txHash = (0, ethereumjs_util_1.bufferToHex)(transaction.hash());\n this.logger.error(`The transaction with id: ${txHash} was penalized! Penalization commitment tx id: ${penalizeResponse.commitTxHash}`);\n }\n return penalizeResponse;\n });\n } catch (error) {\n if ((error === null || error === void 0 ? void 0 : error.message) == null || error.message.indexOf('timeout') !== -1) {\n this.dependencies.knownRelaysManager.saveRelayFailure(new Date().getTime(), relayInfo.relayInfo.relayManager, relayInfo.relayInfo.relayUrl);\n }\n this.logger.info(`relayTransaction: ${JSON.stringify(httpRequest)}`);\n return {\n error,\n isRelayError: true\n };\n }\n const validationResponse = this.dependencies.transactionValidator.validateRelayResponse(httpRequest, signedTx, nonceGapFilled);\n const isValid = (0, RelayedTransactionValidator_1.isTransactionValid)(validationResponse);\n if (!isValid) {\n this.emit(new GsnEvents_1.GsnRelayerResponseEvent(false));\n this.dependencies.knownRelaysManager.saveRelayFailure(new Date().getTime(), relayInfo.relayInfo.relayManager, relayInfo.relayInfo.relayUrl);\n return {\n auditPromise,\n isRelayError: true,\n // TODO: return human-readable error messages\n error: new Error(`Transaction response verification failed. Validation results: ${JSON.stringify(validationResponse)}`)\n };\n }\n this.emit(new GsnEvents_1.GsnRelayerResponseEvent(true));\n await this._broadcastRawTx(transaction);\n return {\n relayRequestID: httpRequest.metadata.relayRequestId,\n validUntilTime: httpRequest.relayRequest.request.validUntilTime,\n auditPromise,\n transaction\n };\n }\n // noinspection JSMethodCanBeStatic\n _getRelayRequestID(relayRequest, signature) {\n return (0, common_1.getRelayRequestID)(relayRequest, signature);\n }\n async _prepareRelayRequest(gsnTransactionDetails) {\n var _a;\n const relayHubAddress = this.dependencies.contractInteractor.getDeployment().relayHubAddress;\n const forwarder = this.dependencies.contractInteractor.getDeployment().forwarderAddress;\n const paymaster = this.dependencies.contractInteractor.getDeployment().paymasterAddress;\n if (relayHubAddress == null || paymaster == null || forwarder == null) {\n throw new Error('Contract addresses are not initialized!');\n }\n const senderNonce = await this.dependencies.contractInteractor.getSenderNonce(gsnTransactionDetails.from, forwarder);\n const maxFeePerGasHex = gsnTransactionDetails.maxFeePerGas;\n const maxPriorityFeePerGasHex = gsnTransactionDetails.maxPriorityFeePerGas;\n const gasLimitHex = gsnTransactionDetails.gas;\n if (maxFeePerGasHex == null || maxPriorityFeePerGasHex == null || gasLimitHex == null) {\n throw new Error('RelayClient internal exception. gas fees or gas limit still not calculated. Cannot happen.');\n }\n if (maxFeePerGasHex.indexOf('0x') !== 0) {\n throw new Error(`Invalid maxFeePerGas hex string: ${maxFeePerGasHex}`);\n }\n if (maxPriorityFeePerGasHex.indexOf('0x') !== 0) {\n throw new Error(`Invalid maxPriorityFeePerGas hex string: ${maxPriorityFeePerGasHex}`);\n }\n if (gasLimitHex.indexOf('0x') !== 0) {\n throw new Error(`Invalid gasLimit hex string: ${gasLimitHex}`);\n }\n const gasLimit = parseInt(gasLimitHex, 16).toString();\n const maxFeePerGas = parseInt(maxFeePerGasHex, 16).toString();\n const maxPriorityFeePerGas = parseInt(maxPriorityFeePerGasHex, 16).toString();\n const value = (_a = gsnTransactionDetails.value) !== null && _a !== void 0 ? _a : '0';\n const secondsNow = Math.round(Date.now() / 1000);\n const validUntilTime = (secondsNow + this.config.requestValidSeconds).toString();\n const relayRequest = {\n request: {\n to: gsnTransactionDetails.to,\n data: gsnTransactionDetails.data,\n from: gsnTransactionDetails.from,\n value: value,\n nonce: senderNonce,\n gas: gasLimit,\n validUntilTime\n },\n relayData: {\n // temp values. filled in by 'fillRelayInfo'\n relayWorker: '',\n transactionCalldataGasUsed: '',\n paymasterData: '',\n maxFeePerGas,\n maxPriorityFeePerGas,\n paymaster,\n clientId: this.config.clientId,\n forwarder\n }\n };\n // put paymasterData into struct before signing\n relayRequest.relayData.paymasterData = await this.dependencies.asyncPaymasterData(relayRequest);\n return relayRequest;\n }\n async fillRelayInfo(relayRequest, relayInfo) {\n relayRequest.relayData.relayWorker = relayInfo.pingResponse.relayWorkerAddress;\n // cannot estimate before relay info is filled in\n relayRequest.relayData.transactionCalldataGasUsed = await this.dependencies.contractInteractor.estimateCalldataCostForRequest(relayRequest, this.config);\n }\n async _prepareRelayHttpRequest(relayRequest, relayInfo) {\n var _a;\n this.emit(new GsnEvents_1.GsnSignRequestEvent());\n const signature = await this.dependencies.accountManager.sign(this.config.domainSeparatorName, relayRequest);\n const relayRequestId = this._getRelayRequestID(relayRequest, signature);\n const approvalData = await this.dependencies.asyncApprovalData(relayRequest, relayRequestId);\n if ((0, ethereumjs_util_1.toBuffer)(relayRequest.relayData.paymasterData).length > this.config.maxPaymasterDataLength) {\n throw new Error('actual paymasterData larger than maxPaymasterDataLength');\n }\n if ((0, ethereumjs_util_1.toBuffer)(approvalData).length > this.config.maxApprovalDataLength) {\n throw new Error('actual approvalData larger than maxApprovalDataLength');\n }\n // max nonce is not signed, as contracts cannot access addresses' nonces.\n const relayLastKnownNonce = await this.dependencies.contractInteractor.getTransactionCount(relayInfo.pingResponse.relayWorkerAddress);\n const relayMaxNonce = relayLastKnownNonce + this.config.maxRelayNonceGap;\n const relayHubAddress = (_a = this.dependencies.contractInteractor.getDeployment().relayHubAddress) !== null && _a !== void 0 ? _a : '';\n const metadata = {\n domainSeparatorName: this.config.domainSeparatorName,\n maxAcceptanceBudget: relayInfo.pingResponse.maxAcceptanceBudget,\n relayHubAddress,\n relayRequestId,\n signature,\n approvalData,\n relayMaxNonce,\n relayLastKnownNonce\n };\n const httpRequest = {\n relayRequest,\n metadata\n };\n this.logger.info(`Created HTTP relay request: ${JSON.stringify(httpRequest)}`);\n return httpRequest;\n }\n newAccount() {\n this._verifyInitialized();\n return this.dependencies.accountManager.newAccount();\n }\n addAccount(privateKey) {\n this._verifyInitialized();\n return this.dependencies.accountManager.addAccount(privateKey);\n }\n _verifyInitialized() {\n if (!this.initialized) {\n throw new Error('not initialized. must call RelayClient.init()');\n }\n }\n async auditTransaction(hexTransaction, sourceRelayUrl) {\n const auditors = this.dependencies.knownRelaysManager.getAuditors([sourceRelayUrl]);\n let failedAuditorsCount = 0;\n for (const auditor of auditors) {\n try {\n const penalizeResponse = await this.dependencies.httpClient.auditTransaction(auditor, hexTransaction);\n if (penalizeResponse.commitTxHash != null) {\n return penalizeResponse;\n }\n } catch (e) {\n failedAuditorsCount++;\n this.logger.info(`Audit call failed for relay at URL: ${auditor}. Failed audit calls: ${failedAuditorsCount}/${auditors.length}`);\n }\n }\n if (auditors.length === failedAuditorsCount && failedAuditorsCount !== 0) {\n this.logger.error('All auditors failed!');\n }\n return {\n message: `Transaction was not audited. Failed audit calls: ${failedAuditorsCount}/${auditors.length}`\n };\n }\n getUnderlyingProvider() {\n return (0, common_1.wrapWeb3JsProvider)(this.rawConstructorInput.provider);\n }\n async _resolveConfiguration({\n config = {}\n }) {\n var _a;\n let configFromServer = {};\n const network = await this.getUnderlyingProvider().getNetwork();\n const chainId = network.chainId;\n const useClientDefaultConfigUrl = (_a = config.useClientDefaultConfigUrl) !== null && _a !== void 0 ? _a : GSNConfigurator_1.defaultGsnConfig.useClientDefaultConfigUrl;\n if (useClientDefaultConfigUrl) {\n this.logger.debug(`Reading default client config for chainId ${chainId.toString()}`);\n configFromServer = await this._resolveConfigurationFromServer(chainId, GSNConfigurator_1.defaultGsnConfig.clientDefaultConfigUrl);\n }\n await this._resolveVerifierConfig(config, chainId);\n return Object.assign(Object.assign(Object.assign({}, GSNConfigurator_1.defaultGsnConfig), configFromServer), (0, common_1.removeNullValues)(config));\n }\n async _resolveVerifyingPaymasterAddress(verifierUrl, chainId) {\n try {\n const httpClient = new common_1.HttpClient(new common_1.HttpWrapper(), this.logger);\n return await httpClient.getVerifyingPaymasterAddress(verifierUrl, chainId);\n } catch (e) {\n this.logger.error(`Could not fetch VerifyingPaymaster address: ${e.message}`);\n return common_1.constants.ZERO_ADDRESS;\n }\n }\n async _resolveVerifierConfig(config, chainId) {\n var _a;\n if (config.verifierServerApiKey == null || config.verifierServerApiKey.length === 0) {\n return;\n }\n if (config.maxApprovalDataLength == null || config.maxApprovalDataLength === 0) {\n this.logger.info('Verifier server API Key is set - setting maxApprovalDataLength');\n config.maxApprovalDataLength = VerifierUtils_1.DEFAULT_VERIFIER_SERVER_APPROVAL_DATA_LENGTH;\n } else {\n this.logger.warn('Verifier server API Key and \"maxApprovalDataLength\" are both set. Make sure they match!');\n }\n config.verifierServerUrl = (_a = config.verifierServerUrl) !== null && _a !== void 0 ? _a : VerifierUtils_1.DEFAULT_VERIFIER_SERVER_URL;\n this.logger.info(`Verifier server API Key is set - setting verifierServerUrl to ${config.verifierServerUrl}`);\n if (config.paymasterAddress == null) {\n config.paymasterAddress = await this._resolveVerifyingPaymasterAddress(config.verifierServerUrl, chainId);\n }\n }\n async _resolveConfigurationFromServer(chainId, clientDefaultConfigUrl) {\n try {\n const httpClient = new common_1.HttpClient(new common_1.HttpWrapper(), this.logger);\n const jsonConfig = await httpClient.getNetworkConfiguration(clientDefaultConfigUrl);\n if (jsonConfig.networks[chainId] == null) {\n return {};\n }\n return jsonConfig.networks[chainId].gsnConfig;\n } catch (e) {\n this.logger.error(`Could not fetch default configuration: ${e.message}`);\n return {};\n }\n }\n async _resolveDependencies({\n provider,\n config,\n overrideDependencies = {}\n }) {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j;\n const versionManager = new common_1.VersionsManager(common_1.gsnRuntimeVersion, (_a = config.requiredVersionRange) !== null && _a !== void 0 ? _a : common_1.gsnRequiredVersion);\n const contractInteractor = (_b = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.contractInteractor) !== null && _b !== void 0 ? _b : await new common_1.ContractInteractor({\n provider,\n versionManager,\n logger: this.logger,\n maxPageSize: this.config.pastEventsQueryMaxPageSize,\n maxPageCount: this.config.pastEventsQueryMaxPageCount,\n environment: this.config.environment,\n domainSeparatorName: this.config.domainSeparatorName,\n calldataEstimationSlackFactor: this.config.calldataEstimationSlackFactor,\n deployment: {\n paymasterAddress: config === null || config === void 0 ? void 0 : config.paymasterAddress\n }\n }).init();\n const chainId = contractInteractor.chainId;\n const accountManager = (_c = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.accountManager) !== null && _c !== void 0 ? _c : new AccountManager_1.AccountManager(provider, chainId, this.config);\n // TODO: accept HttpWrapper as a dependency - calling 'new' here is breaking the init flow.\n const httpWrapper = new common_1.HttpWrapper();\n const httpClient = (_d = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.httpClient) !== null && _d !== void 0 ? _d : new common_1.HttpClient(httpWrapper, this.logger);\n const pingFilter = (_e = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.pingFilter) !== null && _e !== void 0 ? _e : exports.GasPricePingFilter;\n const relayFilter = (_f = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.relayFilter) !== null && _f !== void 0 ? _f : KnownRelaysManager_1.DefaultRelayFilter;\n const asyncApprovalData = await this._resolveVerifierApprovalDataCallback(config, httpWrapper, chainId, overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.asyncApprovalData);\n const asyncPaymasterData = (_g = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.asyncPaymasterData) !== null && _g !== void 0 ? _g : exports.EmptyDataCallback;\n const asyncSignTypedData = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.asyncSignTypedData;\n const knownRelaysManager = (_h = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.knownRelaysManager) !== null && _h !== void 0 ? _h : new KnownRelaysManager_1.KnownRelaysManager(contractInteractor, this.logger, this.config, relayFilter);\n const transactionValidator = (_j = overrideDependencies === null || overrideDependencies === void 0 ? void 0 : overrideDependencies.transactionValidator) !== null && _j !== void 0 ? _j : new RelayedTransactionValidator_1.RelayedTransactionValidator(contractInteractor, this.logger, this.config);\n return {\n logger: this.logger,\n httpClient,\n contractInteractor,\n knownRelaysManager,\n accountManager,\n transactionValidator,\n pingFilter,\n relayFilter,\n asyncApprovalData,\n asyncPaymasterData,\n asyncSignTypedData\n };\n }\n async _resolveVerifierApprovalDataCallback(config, httpWrapper, chainId, asyncApprovalData) {\n if (config.verifierServerApiKey == null || config.verifierServerApiKey.length === 0) {\n return asyncApprovalData !== null && asyncApprovalData !== void 0 ? asyncApprovalData : exports.EmptyDataCallback;\n }\n if (asyncApprovalData != null) {\n throw new Error('Passing both verifierServerApiKey and asyncApprovalData params is unsupported.');\n }\n if (config.verifierServerUrl == null) {\n throw new Error('The \"verifierServerUrl\" is not initialized but \"verifierServerApiKey\" is set.');\n }\n return (0, VerifierUtils_1.createVerifierApprovalDataCallback)(httpWrapper, this.logger, config.domainSeparatorName, chainId, config.verifierServerApiKey, config.verifierServerUrl);\n }\n async _verifyDryRunSuccessful(relayRequest) {\n // TODO: only 3 fields are needed, extract fields instead of building stub object\n const relayWorkerAddress = common_1.constants.DRY_RUN_ADDRESS;\n const maxMaxFeePerGas = '0';\n const dryRunRelayInfo = {\n relayInfo: {\n lastSeenTimestamp: (0, common_1.toBN)(0),\n lastSeenBlockNumber: (0, common_1.toBN)(0),\n firstSeenTimestamp: (0, common_1.toBN)(0),\n firstSeenBlockNumber: (0, common_1.toBN)(0),\n relayManager: '',\n relayUrl: ''\n },\n pingResponse: {\n relayWorkerAddress,\n relayManagerAddress: common_1.constants.ZERO_ADDRESS,\n relayHubAddress: common_1.constants.ZERO_ADDRESS,\n ownerAddress: common_1.constants.ZERO_ADDRESS,\n maxMaxFeePerGas,\n minMaxFeePerGas: '0',\n minMaxPriorityFeePerGas: '0',\n maxAcceptanceBudget: '0',\n ready: true,\n version: ''\n }\n };\n // TODO: clone?\n await this.fillRelayInfo(relayRequest, dryRunRelayInfo);\n const paymasterLimits = await this.dependencies.contractInteractor.getGasAndDataLimitsFromPaymaster(relayRequest.relayData.paymaster);\n const maxAcceptanceBudget = paymasterLimits.acceptanceBudget;\n const viewCallGasLimit = await this.dependencies.contractInteractor.calculateDryRunCallGasLimit(relayRequest.relayData.paymaster, relayWorkerAddress, (0, common_1.toBN)(relayRequest.relayData.maxFeePerGas), (0, common_1.toBN)(this.config.maxViewableGasLimit), (0, common_1.toBN)(this.config.minViewableGasLimit));\n // note that here 'maxAcceptanceBudget' is set to the entire transaction 'maxViewableGasLimit'\n const relayCallABI = {\n domainSeparatorName: this.config.domainSeparatorName,\n relayRequest,\n signature: '0x',\n approvalData: '0x',\n maxAcceptanceBudget: maxAcceptanceBudget.toString()\n };\n return await this._verifyViewCallSuccessful(dryRunRelayInfo, relayCallABI, viewCallGasLimit, true);\n }\n async _verifyViewCallSuccessful(relayInfo, relayCallABI, viewCallGasLimit, isDryRun) {\n const acceptRelayCallResult = await this.dependencies.contractInteractor.validateRelayCall(relayCallABI, viewCallGasLimit, isDryRun);\n if (!acceptRelayCallResult.paymasterAccepted || acceptRelayCallResult.recipientReverted) {\n let message;\n if (acceptRelayCallResult.relayHubReverted) {\n message = `${isDryRun ? 'DRY-RUN' : 'local'} view call to 'relayCall()' reverted`;\n } else if (acceptRelayCallResult.recipientReverted) {\n message = `paymaster accepted but recipient reverted in ${isDryRun ? 'DRY-RUN' : 'local'} view call to 'relayCall()'`;\n } else {\n message = `paymaster rejected in ${isDryRun ? 'DRY-RUN' : 'local'} view call to 'relayCall()'`;\n }\n if (isDryRun) {\n message += '\\n(You can set \\'performDryRunViewRelayCall\\' to \\'false\\' if your want to skip the DRY-RUN step)\\nReported reason: ';\n }\n return new Error(`${message}: ${(0, common_1.decodeRevertReason)(acceptRelayCallResult.returnValue)}`);\n }\n }\n}\nexports.RelayClient = RelayClient;\nfunction _dumpRelayingResult(relayingResult) {\n let str = '';\n if (relayingResult.pingErrors.size > 0) {\n str += `Ping errors (${relayingResult.pingErrors.size}):`;\n Array.from(relayingResult.pingErrors.keys()).forEach(e => {\n var _a, _b;\n const err = relayingResult.pingErrors.get(e);\n // eslint-disable-next-line @typescript-eslint/no-base-to-string\n const error = (_b = (_a = err === null || err === void 0 ? void 0 : err.message) !== null && _a !== void 0 ? _a : err === null || err === void 0 ? void 0 : err.toString()) !== null && _b !== void 0 ? _b : '';\n str += `\\n${e} => ${error} stack:${err === null || err === void 0 ? void 0 : err.stack}\\n`;\n });\n }\n if (relayingResult.relayingErrors.size > 0) {\n str += `Relaying errors (${relayingResult.relayingErrors.size}):\\n`;\n Array.from(relayingResult.relayingErrors.keys()).forEach(e => {\n var _a, _b;\n const err = relayingResult.relayingErrors.get(e);\n // eslint-disable-next-line @typescript-eslint/no-base-to-string\n const error = (_b = (_a = err === null || err === void 0 ? void 0 : err.message) !== null && _a !== void 0 ? _a : err === null || err === void 0 ? void 0 : err.toString()) !== null && _b !== void 0 ? _b : '';\n str += `${e} => ${error} stack:${err === null || err === void 0 ? void 0 : err.stack}`;\n });\n }\n return str;\n}\nexports._dumpRelayingResult = _dumpRelayingResult;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.output = exports.exists = exports.hash = exports.bytes = exports.bool = exports.number = exports.isBytes = void 0;\nfunction number(n) {\n if (!Number.isSafeInteger(n) || n < 0) throw new Error(`positive integer expected, not ${n}`);\n}\nexports.number = number;\nfunction bool(b) {\n if (typeof b !== 'boolean') throw new Error(`boolean expected, not ${b}`);\n}\nexports.bool = bool;\n// copied from utils\nfunction isBytes(a) {\n return a instanceof Uint8Array || a != null && typeof a === 'object' && a.constructor.name === 'Uint8Array';\n}\nexports.isBytes = isBytes;\nfunction bytes(b, ...lengths) {\n if (!isBytes(b)) throw new Error('Uint8Array expected');\n if (lengths.length > 0 && !lengths.includes(b.length)) throw new Error(`Uint8Array expected of length ${lengths}, not of length=${b.length}`);\n}\nexports.bytes = bytes;\nfunction hash(h) {\n if (typeof h !== 'function' || typeof h.create !== 'function') throw new Error('Hash should be wrapped by utils.wrapConstructor');\n number(h.outputLen);\n number(h.blockLen);\n}\nexports.hash = hash;\nfunction exists(instance, checkFinished = true) {\n if (instance.destroyed) throw new Error('Hash instance has been destroyed');\n if (checkFinished && instance.finished) throw new Error('Hash#digest() has already been called');\n}\nexports.exists = exists;\nfunction output(out, instance) {\n bytes(out);\n const min = instance.outputLen;\n if (out.length < min) {\n throw new Error(`digestInto() expects output buffer of length at least ${min}`);\n }\n}\nexports.output = output;\nconst assert = {\n number,\n bool,\n bytes,\n hash,\n exists,\n output\n};\nexports.default = assert;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.crypto = void 0;\nexports.crypto = typeof globalThis === 'object' && 'crypto' in globalThis ? globalThis.crypto : undefined;\n","\"use strict\";\n\n/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomBytes = exports.wrapXOFConstructorWithOpts = exports.wrapConstructorWithOpts = exports.wrapConstructor = exports.checkOpts = exports.Hash = exports.concatBytes = exports.toBytes = exports.utf8ToBytes = exports.asyncLoop = exports.nextTick = exports.hexToBytes = exports.bytesToHex = exports.byteSwap32 = exports.byteSwapIfBE = exports.byteSwap = exports.isLE = exports.rotl = exports.rotr = exports.createView = exports.u32 = exports.u8 = exports.isBytes = void 0;\n// We use WebCrypto aka globalThis.crypto, which exists in browsers and node.js 16+.\n// node.js versions earlier than v19 don't declare it in global scope.\n// For node.js, package.json#exports field mapping rewrites import\n// from `crypto` to `cryptoNode`, which imports native module.\n// Makes the utils un-importable in browsers without a bundler.\n// Once node.js 18 is deprecated (2025-04-30), we can just drop the import.\nconst crypto_1 = require(\"@noble/hashes/crypto\");\nconst _assert_js_1 = require(\"./_assert.js\");\n// export { isBytes } from './_assert.js';\n// We can't reuse isBytes from _assert, because somehow this causes huge perf issues\nfunction isBytes(a) {\n return a instanceof Uint8Array || a != null && typeof a === 'object' && a.constructor.name === 'Uint8Array';\n}\nexports.isBytes = isBytes;\n// Cast array to different type\nconst u8 = arr => new Uint8Array(arr.buffer, arr.byteOffset, arr.byteLength);\nexports.u8 = u8;\nconst u32 = arr => new Uint32Array(arr.buffer, arr.byteOffset, Math.floor(arr.byteLength / 4));\nexports.u32 = u32;\n// Cast array to view\nconst createView = arr => new DataView(arr.buffer, arr.byteOffset, arr.byteLength);\nexports.createView = createView;\n// The rotate right (circular right shift) operation for uint32\nconst rotr = (word, shift) => word << 32 - shift | word >>> shift;\nexports.rotr = rotr;\n// The rotate left (circular left shift) operation for uint32\nconst rotl = (word, shift) => word << shift | word >>> 32 - shift >>> 0;\nexports.rotl = rotl;\nexports.isLE = new Uint8Array(new Uint32Array([0x11223344]).buffer)[0] === 0x44;\n// The byte swap operation for uint32\nconst byteSwap = word => word << 24 & 0xff000000 | word << 8 & 0xff0000 | word >>> 8 & 0xff00 | word >>> 24 & 0xff;\nexports.byteSwap = byteSwap;\n// Conditionally byte swap if on a big-endian platform\nexports.byteSwapIfBE = exports.isLE ? n => n : n => (0, exports.byteSwap)(n);\n// In place byte swap for Uint32Array\nfunction byteSwap32(arr) {\n for (let i = 0; i < arr.length; i++) {\n arr[i] = (0, exports.byteSwap)(arr[i]);\n }\n}\nexports.byteSwap32 = byteSwap32;\n// Array where index 0xf0 (240) is mapped to string 'f0'\nconst hexes = /* @__PURE__ */Array.from({\n length: 256\n}, (_, i) => i.toString(16).padStart(2, '0'));\n/**\n * @example bytesToHex(Uint8Array.from([0xca, 0xfe, 0x01, 0x23])) // 'cafe0123'\n */\nfunction bytesToHex(bytes) {\n (0, _assert_js_1.bytes)(bytes);\n // pre-caching improves the speed 6x\n let hex = '';\n for (let i = 0; i < bytes.length; i++) {\n hex += hexes[bytes[i]];\n }\n return hex;\n}\nexports.bytesToHex = bytesToHex;\n// We use optimized technique to convert hex string to byte array\nconst asciis = {\n _0: 48,\n _9: 57,\n _A: 65,\n _F: 70,\n _a: 97,\n _f: 102\n};\nfunction asciiToBase16(char) {\n if (char >= asciis._0 && char <= asciis._9) return char - asciis._0;\n if (char >= asciis._A && char <= asciis._F) return char - (asciis._A - 10);\n if (char >= asciis._a && char <= asciis._f) return char - (asciis._a - 10);\n return;\n}\n/**\n * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])\n */\nfunction hexToBytes(hex) {\n if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);\n const hl = hex.length;\n const al = hl / 2;\n if (hl % 2) throw new Error('padded hex string expected, got unpadded hex of length ' + hl);\n const array = new Uint8Array(al);\n for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {\n const n1 = asciiToBase16(hex.charCodeAt(hi));\n const n2 = asciiToBase16(hex.charCodeAt(hi + 1));\n if (n1 === undefined || n2 === undefined) {\n const char = hex[hi] + hex[hi + 1];\n throw new Error('hex string expected, got non-hex character \"' + char + '\" at index ' + hi);\n }\n array[ai] = n1 * 16 + n2;\n }\n return array;\n}\nexports.hexToBytes = hexToBytes;\n// There is no setImmediate in browser and setTimeout is slow.\n// call of async fn will return Promise, which will be fullfiled only on\n// next scheduler queue processing step and this is exactly what we need.\nconst nextTick = async () => {};\nexports.nextTick = nextTick;\n// Returns control to thread each 'tick' ms to avoid blocking\nasync function asyncLoop(iters, tick, cb) {\n let ts = Date.now();\n for (let i = 0; i < iters; i++) {\n cb(i);\n // Date.now() is not monotonic, so in case if clock goes backwards we return return control too\n const diff = Date.now() - ts;\n if (diff >= 0 && diff < tick) continue;\n await (0, exports.nextTick)();\n ts += diff;\n }\n}\nexports.asyncLoop = asyncLoop;\n/**\n * @example utf8ToBytes('abc') // new Uint8Array([97, 98, 99])\n */\nfunction utf8ToBytes(str) {\n if (typeof str !== 'string') throw new Error(`utf8ToBytes expected string, got ${typeof str}`);\n return new Uint8Array(new TextEncoder().encode(str)); // https://bugzil.la/1681809\n}\nexports.utf8ToBytes = utf8ToBytes;\n/**\n * Normalizes (non-hex) string or Uint8Array to Uint8Array.\n * Warning: when Uint8Array is passed, it would NOT get copied.\n * Keep in mind for future mutable operations.\n */\nfunction toBytes(data) {\n if (typeof data === 'string') data = utf8ToBytes(data);\n (0, _assert_js_1.bytes)(data);\n return data;\n}\nexports.toBytes = toBytes;\n/**\n * Copies several Uint8Arrays into one.\n */\nfunction concatBytes(...arrays) {\n let sum = 0;\n for (let i = 0; i < arrays.length; i++) {\n const a = arrays[i];\n (0, _assert_js_1.bytes)(a);\n sum += a.length;\n }\n const res = new Uint8Array(sum);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const a = arrays[i];\n res.set(a, pad);\n pad += a.length;\n }\n return res;\n}\nexports.concatBytes = concatBytes;\n// For runtime check if class implements interface\nclass Hash {\n // Safe version that clones internal state\n clone() {\n return this._cloneInto();\n }\n}\nexports.Hash = Hash;\nconst toStr = {}.toString;\nfunction checkOpts(defaults, opts) {\n if (opts !== undefined && toStr.call(opts) !== '[object Object]') throw new Error('Options should be object or undefined');\n const merged = Object.assign(defaults, opts);\n return merged;\n}\nexports.checkOpts = checkOpts;\nfunction wrapConstructor(hashCons) {\n const hashC = msg => hashCons().update(toBytes(msg)).digest();\n const tmp = hashCons();\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = () => hashCons();\n return hashC;\n}\nexports.wrapConstructor = wrapConstructor;\nfunction wrapConstructorWithOpts(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = opts => hashCons(opts);\n return hashC;\n}\nexports.wrapConstructorWithOpts = wrapConstructorWithOpts;\nfunction wrapXOFConstructorWithOpts(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = opts => hashCons(opts);\n return hashC;\n}\nexports.wrapXOFConstructorWithOpts = wrapXOFConstructorWithOpts;\n/**\n * Secure PRNG. Uses `crypto.getRandomValues`, which defers to OS.\n */\nfunction randomBytes(bytesLength = 32) {\n if (crypto_1.crypto && typeof crypto_1.crypto.getRandomValues === 'function') {\n return crypto_1.crypto.getRandomValues(new Uint8Array(bytesLength));\n }\n throw new Error('crypto.getRandomValues must be defined');\n}\nexports.randomBytes = randomBytes;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HashMD = exports.Maj = exports.Chi = void 0;\nconst _assert_js_1 = require(\"./_assert.js\");\nconst utils_js_1 = require(\"./utils.js\");\n// Polyfill for Safari 14\nfunction setBigUint64(view, byteOffset, value, isLE) {\n if (typeof view.setBigUint64 === 'function') return view.setBigUint64(byteOffset, value, isLE);\n const _32n = BigInt(32);\n const _u32_max = BigInt(0xffffffff);\n const wh = Number(value >> _32n & _u32_max);\n const wl = Number(value & _u32_max);\n const h = isLE ? 4 : 0;\n const l = isLE ? 0 : 4;\n view.setUint32(byteOffset + h, wh, isLE);\n view.setUint32(byteOffset + l, wl, isLE);\n}\n// Choice: a ? b : c\nconst Chi = (a, b, c) => a & b ^ ~a & c;\nexports.Chi = Chi;\n// Majority function, true if any two inpust is true\nconst Maj = (a, b, c) => a & b ^ a & c ^ b & c;\nexports.Maj = Maj;\n/**\n * Merkle-Damgard hash construction base class.\n * Could be used to create MD5, RIPEMD, SHA1, SHA2.\n */\nclass HashMD extends utils_js_1.Hash {\n constructor(blockLen, outputLen, padOffset, isLE) {\n super();\n this.blockLen = blockLen;\n this.outputLen = outputLen;\n this.padOffset = padOffset;\n this.isLE = isLE;\n this.finished = false;\n this.length = 0;\n this.pos = 0;\n this.destroyed = false;\n this.buffer = new Uint8Array(blockLen);\n this.view = (0, utils_js_1.createView)(this.buffer);\n }\n update(data) {\n (0, _assert_js_1.exists)(this);\n const {\n view,\n buffer,\n blockLen\n } = this;\n data = (0, utils_js_1.toBytes)(data);\n const len = data.length;\n for (let pos = 0; pos < len;) {\n const take = Math.min(blockLen - this.pos, len - pos);\n // Fast path: we have at least one block in input, cast it to view and process\n if (take === blockLen) {\n const dataView = (0, utils_js_1.createView)(data);\n for (; blockLen <= len - pos; pos += blockLen) this.process(dataView, pos);\n continue;\n }\n buffer.set(data.subarray(pos, pos + take), this.pos);\n this.pos += take;\n pos += take;\n if (this.pos === blockLen) {\n this.process(view, 0);\n this.pos = 0;\n }\n }\n this.length += data.length;\n this.roundClean();\n return this;\n }\n digestInto(out) {\n (0, _assert_js_1.exists)(this);\n (0, _assert_js_1.output)(out, this);\n this.finished = true;\n // Padding\n // We can avoid allocation of buffer for padding completely if it\n // was previously not allocated here. But it won't change performance.\n const {\n buffer,\n view,\n blockLen,\n isLE\n } = this;\n let {\n pos\n } = this;\n // append the bit '1' to the message\n buffer[pos++] = 0b10000000;\n this.buffer.subarray(pos).fill(0);\n // we have less than padOffset left in buffer, so we cannot put length in\n // current block, need process it and pad again\n if (this.padOffset > blockLen - pos) {\n this.process(view, 0);\n pos = 0;\n }\n // Pad until full block byte with zeros\n for (let i = pos; i < blockLen; i++) buffer[i] = 0;\n // Note: sha512 requires length to be 128bit integer, but length in JS will overflow before that\n // You need to write around 2 exabytes (u64_max / 8 / (1024**6)) for this to happen.\n // So we just write lowest 64 bits of that value.\n setBigUint64(view, blockLen - 8, BigInt(this.length * 8), isLE);\n this.process(view, 0);\n const oview = (0, utils_js_1.createView)(out);\n const len = this.outputLen;\n // NOTE: we do division by 4 later, which should be fused in single op with modulo by JIT\n if (len % 4) throw new Error('_sha2: outputLen should be aligned to 32bit');\n const outLen = len / 4;\n const state = this.get();\n if (outLen > state.length) throw new Error('_sha2: outputLen bigger than state');\n for (let i = 0; i < outLen; i++) oview.setUint32(4 * i, state[i], isLE);\n }\n digest() {\n const {\n buffer,\n outputLen\n } = this;\n this.digestInto(buffer);\n const res = buffer.slice(0, outputLen);\n this.destroy();\n return res;\n }\n _cloneInto(to) {\n to || (to = new this.constructor());\n to.set(...this.get());\n const {\n blockLen,\n buffer,\n length,\n finished,\n destroyed,\n pos\n } = this;\n to.length = length;\n to.pos = pos;\n to.finished = finished;\n to.destroyed = destroyed;\n if (length % blockLen) to.buffer.set(buffer);\n return to;\n }\n}\nexports.HashMD = HashMD;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.sha224 = exports.sha256 = void 0;\nconst _md_js_1 = require(\"./_md.js\");\nconst utils_js_1 = require(\"./utils.js\");\n// SHA2-256 need to try 2^128 hashes to execute birthday attack.\n// BTC network is doing 2^67 hashes/sec as per early 2023.\n// Round constants:\n// first 32 bits of the fractional parts of the cube roots of the first 64 primes 2..311)\n// prettier-ignore\nconst SHA256_K = /* @__PURE__ */new Uint32Array([0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2]);\n// Initial state:\n// first 32 bits of the fractional parts of the square roots of the first 8 primes 2..19\n// prettier-ignore\nconst SHA256_IV = /* @__PURE__ */new Uint32Array([0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a, 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19]);\n// Temporary buffer, not used to store anything between runs\n// Named this way because it matches specification.\nconst SHA256_W = /* @__PURE__ */new Uint32Array(64);\nclass SHA256 extends _md_js_1.HashMD {\n constructor() {\n super(64, 32, 8, false);\n // We cannot use array here since array allows indexing by variable\n // which means optimizer/compiler cannot use registers.\n this.A = SHA256_IV[0] | 0;\n this.B = SHA256_IV[1] | 0;\n this.C = SHA256_IV[2] | 0;\n this.D = SHA256_IV[3] | 0;\n this.E = SHA256_IV[4] | 0;\n this.F = SHA256_IV[5] | 0;\n this.G = SHA256_IV[6] | 0;\n this.H = SHA256_IV[7] | 0;\n }\n get() {\n const {\n A,\n B,\n C,\n D,\n E,\n F,\n G,\n H\n } = this;\n return [A, B, C, D, E, F, G, H];\n }\n // prettier-ignore\n set(A, B, C, D, E, F, G, H) {\n this.A = A | 0;\n this.B = B | 0;\n this.C = C | 0;\n this.D = D | 0;\n this.E = E | 0;\n this.F = F | 0;\n this.G = G | 0;\n this.H = H | 0;\n }\n process(view, offset) {\n // Extend the first 16 words into the remaining 48 words w[16..63] of the message schedule array\n for (let i = 0; i < 16; i++, offset += 4) SHA256_W[i] = view.getUint32(offset, false);\n for (let i = 16; i < 64; i++) {\n const W15 = SHA256_W[i - 15];\n const W2 = SHA256_W[i - 2];\n const s0 = (0, utils_js_1.rotr)(W15, 7) ^ (0, utils_js_1.rotr)(W15, 18) ^ W15 >>> 3;\n const s1 = (0, utils_js_1.rotr)(W2, 17) ^ (0, utils_js_1.rotr)(W2, 19) ^ W2 >>> 10;\n SHA256_W[i] = s1 + SHA256_W[i - 7] + s0 + SHA256_W[i - 16] | 0;\n }\n // Compression function main loop, 64 rounds\n let {\n A,\n B,\n C,\n D,\n E,\n F,\n G,\n H\n } = this;\n for (let i = 0; i < 64; i++) {\n const sigma1 = (0, utils_js_1.rotr)(E, 6) ^ (0, utils_js_1.rotr)(E, 11) ^ (0, utils_js_1.rotr)(E, 25);\n const T1 = H + sigma1 + (0, _md_js_1.Chi)(E, F, G) + SHA256_K[i] + SHA256_W[i] | 0;\n const sigma0 = (0, utils_js_1.rotr)(A, 2) ^ (0, utils_js_1.rotr)(A, 13) ^ (0, utils_js_1.rotr)(A, 22);\n const T2 = sigma0 + (0, _md_js_1.Maj)(A, B, C) | 0;\n H = G;\n G = F;\n F = E;\n E = D + T1 | 0;\n D = C;\n C = B;\n B = A;\n A = T1 + T2 | 0;\n }\n // Add the compressed chunk to the current hash value\n A = A + this.A | 0;\n B = B + this.B | 0;\n C = C + this.C | 0;\n D = D + this.D | 0;\n E = E + this.E | 0;\n F = F + this.F | 0;\n G = G + this.G | 0;\n H = H + this.H | 0;\n this.set(A, B, C, D, E, F, G, H);\n }\n roundClean() {\n SHA256_W.fill(0);\n }\n destroy() {\n this.set(0, 0, 0, 0, 0, 0, 0, 0);\n this.buffer.fill(0);\n }\n}\n// Constants from https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.180-4.pdf\nclass SHA224 extends SHA256 {\n constructor() {\n super();\n this.A = 0xc1059ed8 | 0;\n this.B = 0x367cd507 | 0;\n this.C = 0x3070dd17 | 0;\n this.D = 0xf70e5939 | 0;\n this.E = 0xffc00b31 | 0;\n this.F = 0x68581511 | 0;\n this.G = 0x64f98fa7 | 0;\n this.H = 0xbefa4fa4 | 0;\n this.outputLen = 28;\n }\n}\n/**\n * SHA2-256 hash function\n * @param message - data that would be hashed\n */\nexports.sha256 = (0, utils_js_1.wrapConstructor)(() => new SHA256());\nexports.sha224 = (0, utils_js_1.wrapConstructor)(() => new SHA224());\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hmac = exports.HMAC = void 0;\nconst _assert_js_1 = require(\"./_assert.js\");\nconst utils_js_1 = require(\"./utils.js\");\n// HMAC (RFC 2104)\nclass HMAC extends utils_js_1.Hash {\n constructor(hash, _key) {\n super();\n this.finished = false;\n this.destroyed = false;\n (0, _assert_js_1.hash)(hash);\n const key = (0, utils_js_1.toBytes)(_key);\n this.iHash = hash.create();\n if (typeof this.iHash.update !== 'function') throw new Error('Expected instance of class which extends utils.Hash');\n this.blockLen = this.iHash.blockLen;\n this.outputLen = this.iHash.outputLen;\n const blockLen = this.blockLen;\n const pad = new Uint8Array(blockLen);\n // blockLen can be bigger than outputLen\n pad.set(key.length > blockLen ? hash.create().update(key).digest() : key);\n for (let i = 0; i < pad.length; i++) pad[i] ^= 0x36;\n this.iHash.update(pad);\n // By doing update (processing of first block) of outer hash here we can re-use it between multiple calls via clone\n this.oHash = hash.create();\n // Undo internal XOR && apply outer XOR\n for (let i = 0; i < pad.length; i++) pad[i] ^= 0x36 ^ 0x5c;\n this.oHash.update(pad);\n pad.fill(0);\n }\n update(buf) {\n (0, _assert_js_1.exists)(this);\n this.iHash.update(buf);\n return this;\n }\n digestInto(out) {\n (0, _assert_js_1.exists)(this);\n (0, _assert_js_1.bytes)(out, this.outputLen);\n this.finished = true;\n this.iHash.digestInto(out);\n this.oHash.update(out);\n this.oHash.digestInto(out);\n this.destroy();\n }\n digest() {\n const out = new Uint8Array(this.oHash.outputLen);\n this.digestInto(out);\n return out;\n }\n _cloneInto(to) {\n // Create new instance without calling constructor since key already in state and we don't know it.\n to || (to = Object.create(Object.getPrototypeOf(this), {}));\n const {\n oHash,\n iHash,\n finished,\n destroyed,\n blockLen,\n outputLen\n } = this;\n to = to;\n to.finished = finished;\n to.destroyed = destroyed;\n to.blockLen = blockLen;\n to.outputLen = outputLen;\n to.oHash = oHash._cloneInto(to.oHash);\n to.iHash = iHash._cloneInto(to.iHash);\n return to;\n }\n destroy() {\n this.destroyed = true;\n this.oHash.destroy();\n this.iHash.destroy();\n }\n}\nexports.HMAC = HMAC;\n/**\n * HMAC: RFC2104 message authentication code.\n * @param hash - function that would be used e.g. sha256\n * @param key - message key\n * @param message - message data\n */\nconst hmac = (hash, key, message) => new HMAC(hash, key).update(message).digest();\nexports.hmac = hmac;\nexports.hmac.create = (hash, key) => new HMAC(hash, key);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bitMask = void 0;\nexports.isBytes = isBytes;\nexports.abytes = abytes;\nexports.bytesToHex = bytesToHex;\nexports.numberToHexUnpadded = numberToHexUnpadded;\nexports.hexToNumber = hexToNumber;\nexports.hexToBytes = hexToBytes;\nexports.bytesToNumberBE = bytesToNumberBE;\nexports.bytesToNumberLE = bytesToNumberLE;\nexports.numberToBytesBE = numberToBytesBE;\nexports.numberToBytesLE = numberToBytesLE;\nexports.numberToVarBytesBE = numberToVarBytesBE;\nexports.ensureBytes = ensureBytes;\nexports.concatBytes = concatBytes;\nexports.equalBytes = equalBytes;\nexports.utf8ToBytes = utf8ToBytes;\nexports.bitLen = bitLen;\nexports.bitGet = bitGet;\nexports.bitSet = bitSet;\nexports.createHmacDrbg = createHmacDrbg;\nexports.validateObject = validateObject;\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\n// 100 lines of code in the file are duplicated from noble-hashes (utils).\n// This is OK: `abstract` directory does not use noble-hashes.\n// User may opt-in into using different hashing library. This way, noble-hashes\n// won't be included into their bundle.\nconst _0n = /* @__PURE__ */BigInt(0);\nconst _1n = /* @__PURE__ */BigInt(1);\nconst _2n = /* @__PURE__ */BigInt(2);\nfunction isBytes(a) {\n return a instanceof Uint8Array || a != null && typeof a === 'object' && a.constructor.name === 'Uint8Array';\n}\nfunction abytes(item) {\n if (!isBytes(item)) throw new Error('Uint8Array expected');\n}\n// Array where index 0xf0 (240) is mapped to string 'f0'\nconst hexes = /* @__PURE__ */Array.from({\n length: 256\n}, (_, i) => i.toString(16).padStart(2, '0'));\n/**\n * @example bytesToHex(Uint8Array.from([0xca, 0xfe, 0x01, 0x23])) // 'cafe0123'\n */\nfunction bytesToHex(bytes) {\n abytes(bytes);\n // pre-caching improves the speed 6x\n let hex = '';\n for (let i = 0; i < bytes.length; i++) {\n hex += hexes[bytes[i]];\n }\n return hex;\n}\nfunction numberToHexUnpadded(num) {\n const hex = num.toString(16);\n return hex.length & 1 ? `0${hex}` : hex;\n}\nfunction hexToNumber(hex) {\n if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);\n // Big Endian\n return BigInt(hex === '' ? '0' : `0x${hex}`);\n}\n// We use optimized technique to convert hex string to byte array\nconst asciis = {\n _0: 48,\n _9: 57,\n _A: 65,\n _F: 70,\n _a: 97,\n _f: 102\n};\nfunction asciiToBase16(char) {\n if (char >= asciis._0 && char <= asciis._9) return char - asciis._0;\n if (char >= asciis._A && char <= asciis._F) return char - (asciis._A - 10);\n if (char >= asciis._a && char <= asciis._f) return char - (asciis._a - 10);\n return;\n}\n/**\n * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])\n */\nfunction hexToBytes(hex) {\n if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);\n const hl = hex.length;\n const al = hl / 2;\n if (hl % 2) throw new Error('padded hex string expected, got unpadded hex of length ' + hl);\n const array = new Uint8Array(al);\n for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {\n const n1 = asciiToBase16(hex.charCodeAt(hi));\n const n2 = asciiToBase16(hex.charCodeAt(hi + 1));\n if (n1 === undefined || n2 === undefined) {\n const char = hex[hi] + hex[hi + 1];\n throw new Error('hex string expected, got non-hex character \"' + char + '\" at index ' + hi);\n }\n array[ai] = n1 * 16 + n2;\n }\n return array;\n}\n// BE: Big Endian, LE: Little Endian\nfunction bytesToNumberBE(bytes) {\n return hexToNumber(bytesToHex(bytes));\n}\nfunction bytesToNumberLE(bytes) {\n abytes(bytes);\n return hexToNumber(bytesToHex(Uint8Array.from(bytes).reverse()));\n}\nfunction numberToBytesBE(n, len) {\n return hexToBytes(n.toString(16).padStart(len * 2, '0'));\n}\nfunction numberToBytesLE(n, len) {\n return numberToBytesBE(n, len).reverse();\n}\n// Unpadded, rarely used\nfunction numberToVarBytesBE(n) {\n return hexToBytes(numberToHexUnpadded(n));\n}\n/**\n * Takes hex string or Uint8Array, converts to Uint8Array.\n * Validates output length.\n * Will throw error for other types.\n * @param title descriptive title for an error e.g. 'private key'\n * @param hex hex string or Uint8Array\n * @param expectedLength optional, will compare to result array's length\n * @returns\n */\nfunction ensureBytes(title, hex, expectedLength) {\n let res;\n if (typeof hex === 'string') {\n try {\n res = hexToBytes(hex);\n } catch (e) {\n throw new Error(`${title} must be valid hex string, got \"${hex}\". Cause: ${e}`);\n }\n } else if (isBytes(hex)) {\n // Uint8Array.from() instead of hash.slice() because node.js Buffer\n // is instance of Uint8Array, and its slice() creates **mutable** copy\n res = Uint8Array.from(hex);\n } else {\n throw new Error(`${title} must be hex string or Uint8Array`);\n }\n const len = res.length;\n if (typeof expectedLength === 'number' && len !== expectedLength) throw new Error(`${title} expected ${expectedLength} bytes, got ${len}`);\n return res;\n}\n/**\n * Copies several Uint8Arrays into one.\n */\nfunction concatBytes(...arrays) {\n let sum = 0;\n for (let i = 0; i < arrays.length; i++) {\n const a = arrays[i];\n abytes(a);\n sum += a.length;\n }\n const res = new Uint8Array(sum);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const a = arrays[i];\n res.set(a, pad);\n pad += a.length;\n }\n return res;\n}\n// Compares 2 u8a-s in kinda constant time\nfunction equalBytes(a, b) {\n if (a.length !== b.length) return false;\n let diff = 0;\n for (let i = 0; i < a.length; i++) diff |= a[i] ^ b[i];\n return diff === 0;\n}\n/**\n * @example utf8ToBytes('abc') // new Uint8Array([97, 98, 99])\n */\nfunction utf8ToBytes(str) {\n if (typeof str !== 'string') throw new Error(`utf8ToBytes expected string, got ${typeof str}`);\n return new Uint8Array(new TextEncoder().encode(str)); // https://bugzil.la/1681809\n}\n// Bit operations\n/**\n * Calculates amount of bits in a bigint.\n * Same as `n.toString(2).length`\n */\nfunction bitLen(n) {\n let len;\n for (len = 0; n > _0n; n >>= _1n, len += 1);\n return len;\n}\n/**\n * Gets single bit at position.\n * NOTE: first bit position is 0 (same as arrays)\n * Same as `!!+Array.from(n.toString(2)).reverse()[pos]`\n */\nfunction bitGet(n, pos) {\n return n >> BigInt(pos) & _1n;\n}\n/**\n * Sets single bit at position.\n */\nfunction bitSet(n, pos, value) {\n return n | (value ? _1n : _0n) << BigInt(pos);\n}\n/**\n * Calculate mask for N bits. Not using ** operator with bigints because of old engines.\n * Same as BigInt(`0b${Array(i).fill('1').join('')}`)\n */\nconst bitMask = n => (_2n << BigInt(n - 1)) - _1n;\nexports.bitMask = bitMask;\n// DRBG\nconst u8n = data => new Uint8Array(data); // creates Uint8Array\nconst u8fr = arr => Uint8Array.from(arr); // another shortcut\n/**\n * Minimal HMAC-DRBG from NIST 800-90 for RFC6979 sigs.\n * @returns function that will call DRBG until 2nd arg returns something meaningful\n * @example\n * const drbg = createHmacDRBG(32, 32, hmac);\n * drbg(seed, bytesToKey); // bytesToKey must return Key or undefined\n */\nfunction createHmacDrbg(hashLen, qByteLen, hmacFn) {\n if (typeof hashLen !== 'number' || hashLen < 2) throw new Error('hashLen must be a number');\n if (typeof qByteLen !== 'number' || qByteLen < 2) throw new Error('qByteLen must be a number');\n if (typeof hmacFn !== 'function') throw new Error('hmacFn must be a function');\n // Step B, Step C: set hashLen to 8*ceil(hlen/8)\n let v = u8n(hashLen); // Minimal non-full-spec HMAC-DRBG from NIST 800-90 for RFC6979 sigs.\n let k = u8n(hashLen); // Steps B and C of RFC6979 3.2: set hashLen, in our case always same\n let i = 0; // Iterations counter, will throw when over 1000\n const reset = () => {\n v.fill(1);\n k.fill(0);\n i = 0;\n };\n const h = (...b) => hmacFn(k, v, ...b); // hmac(k)(v, ...values)\n const reseed = (seed = u8n()) => {\n // HMAC-DRBG reseed() function. Steps D-G\n k = h(u8fr([0x00]), seed); // k = hmac(k || v || 0x00 || seed)\n v = h(); // v = hmac(k || v)\n if (seed.length === 0) return;\n k = h(u8fr([0x01]), seed); // k = hmac(k || v || 0x01 || seed)\n v = h(); // v = hmac(k || v)\n };\n const gen = () => {\n // HMAC-DRBG generate() function\n if (i++ >= 1000) throw new Error('drbg: tried 1000 values');\n let len = 0;\n const out = [];\n while (len < qByteLen) {\n v = h();\n const sl = v.slice();\n out.push(sl);\n len += v.length;\n }\n return concatBytes(...out);\n };\n const genUntil = (seed, pred) => {\n reset();\n reseed(seed); // Steps D-G\n let res = undefined; // Step H: grind until k is in [1..n-1]\n while (!(res = pred(gen()))) reseed();\n reset();\n return res;\n };\n return genUntil;\n}\n// Validating curves and fields\nconst validatorFns = {\n bigint: val => typeof val === 'bigint',\n function: val => typeof val === 'function',\n boolean: val => typeof val === 'boolean',\n string: val => typeof val === 'string',\n stringOrUint8Array: val => typeof val === 'string' || isBytes(val),\n isSafeInteger: val => Number.isSafeInteger(val),\n array: val => Array.isArray(val),\n field: (val, object) => object.Fp.isValid(val),\n hash: val => typeof val === 'function' && Number.isSafeInteger(val.outputLen)\n};\n// type Record = { [P in K]: T; }\nfunction validateObject(object, validators, optValidators = {}) {\n const checkField = (fieldName, type, isOptional) => {\n const checkVal = validatorFns[type];\n if (typeof checkVal !== 'function') throw new Error(`Invalid validator \"${type}\", expected function`);\n const val = object[fieldName];\n if (isOptional && val === undefined) return;\n if (!checkVal(val, object)) {\n throw new Error(`Invalid param ${String(fieldName)}=${val} (${typeof val}), expected ${type}`);\n }\n };\n for (const [fieldName, type] of Object.entries(validators)) checkField(fieldName, type, false);\n for (const [fieldName, type] of Object.entries(optValidators)) checkField(fieldName, type, true);\n return object;\n}\n// validate type tests\n// const o: { a: number; b: number; c: number } = { a: 1, b: 5, c: 6 };\n// const z0 = validateObject(o, { a: 'isSafeInteger' }, { c: 'bigint' }); // Ok!\n// // Should fail type-check\n// const z1 = validateObject(o, { a: 'tmp' }, { c: 'zz' });\n// const z2 = validateObject(o, { a: 'isSafeInteger' }, { c: 'zz' });\n// const z3 = validateObject(o, { test: 'boolean', z: 'bug' });\n// const z4 = validateObject(o, { a: 'boolean', z: 'bug' });\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isNegativeLE = void 0;\nexports.mod = mod;\nexports.pow = pow;\nexports.pow2 = pow2;\nexports.invert = invert;\nexports.tonelliShanks = tonelliShanks;\nexports.FpSqrt = FpSqrt;\nexports.validateField = validateField;\nexports.FpPow = FpPow;\nexports.FpInvertBatch = FpInvertBatch;\nexports.FpDiv = FpDiv;\nexports.FpIsSquare = FpIsSquare;\nexports.nLength = nLength;\nexports.Field = Field;\nexports.FpSqrtOdd = FpSqrtOdd;\nexports.FpSqrtEven = FpSqrtEven;\nexports.hashToPrivateScalar = hashToPrivateScalar;\nexports.getFieldBytesLength = getFieldBytesLength;\nexports.getMinHashLength = getMinHashLength;\nexports.mapHashToField = mapHashToField;\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\n// Utilities for modular arithmetics and finite fields\nconst utils_js_1 = require(\"./utils.js\");\n// prettier-ignore\nconst _0n = BigInt(0),\n _1n = BigInt(1),\n _2n = BigInt(2),\n _3n = BigInt(3);\n// prettier-ignore\nconst _4n = BigInt(4),\n _5n = BigInt(5),\n _8n = BigInt(8);\n// prettier-ignore\nconst _9n = BigInt(9),\n _16n = BigInt(16);\n// Calculates a modulo b\nfunction mod(a, b) {\n const result = a % b;\n return result >= _0n ? result : b + result;\n}\n/**\n * Efficiently raise num to power and do modular division.\n * Unsafe in some contexts: uses ladder, so can expose bigint bits.\n * @example\n * pow(2n, 6n, 11n) // 64n % 11n == 9n\n */\n// TODO: use field version && remove\nfunction pow(num, power, modulo) {\n if (modulo <= _0n || power < _0n) throw new Error('Expected power/modulo > 0');\n if (modulo === _1n) return _0n;\n let res = _1n;\n while (power > _0n) {\n if (power & _1n) res = res * num % modulo;\n num = num * num % modulo;\n power >>= _1n;\n }\n return res;\n}\n// Does x ^ (2 ^ power) mod p. pow2(30, 4) == 30 ^ (2 ^ 4)\nfunction pow2(x, power, modulo) {\n let res = x;\n while (power-- > _0n) {\n res *= res;\n res %= modulo;\n }\n return res;\n}\n// Inverses number over modulo\nfunction invert(number, modulo) {\n if (number === _0n || modulo <= _0n) {\n throw new Error(`invert: expected positive integers, got n=${number} mod=${modulo}`);\n }\n // Euclidean GCD https://brilliant.org/wiki/extended-euclidean-algorithm/\n // Fermat's little theorem \"CT-like\" version inv(n) = n^(m-2) mod m is 30x slower.\n let a = mod(number, modulo);\n let b = modulo;\n // prettier-ignore\n let x = _0n,\n y = _1n,\n u = _1n,\n v = _0n;\n while (a !== _0n) {\n // JIT applies optimization if those two lines follow each other\n const q = b / a;\n const r = b % a;\n const m = x - u * q;\n const n = y - v * q;\n // prettier-ignore\n b = a, a = r, x = u, y = v, u = m, v = n;\n }\n const gcd = b;\n if (gcd !== _1n) throw new Error('invert: does not exist');\n return mod(x, modulo);\n}\n/**\n * Tonelli-Shanks square root search algorithm.\n * 1. https://eprint.iacr.org/2012/685.pdf (page 12)\n * 2. Square Roots from 1; 24, 51, 10 to Dan Shanks\n * Will start an infinite loop if field order P is not prime.\n * @param P field order\n * @returns function that takes field Fp (created from P) and number n\n */\nfunction tonelliShanks(P) {\n // Legendre constant: used to calculate Legendre symbol (a | p),\n // which denotes the value of a^((p-1)/2) (mod p).\n // (a | p) ≡ 1 if a is a square (mod p)\n // (a | p) ≡ -1 if a is not a square (mod p)\n // (a | p) ≡ 0 if a ≡ 0 (mod p)\n const legendreC = (P - _1n) / _2n;\n let Q, S, Z;\n // Step 1: By factoring out powers of 2 from p - 1,\n // find q and s such that p - 1 = q*(2^s) with q odd\n for (Q = P - _1n, S = 0; Q % _2n === _0n; Q /= _2n, S++);\n // Step 2: Select a non-square z such that (z | p) ≡ -1 and set c ≡ zq\n for (Z = _2n; Z < P && pow(Z, legendreC, P) !== P - _1n; Z++);\n // Fast-path\n if (S === 1) {\n const p1div4 = (P + _1n) / _4n;\n return function tonelliFast(Fp, n) {\n const root = Fp.pow(n, p1div4);\n if (!Fp.eql(Fp.sqr(root), n)) throw new Error('Cannot find square root');\n return root;\n };\n }\n // Slow-path\n const Q1div2 = (Q + _1n) / _2n;\n return function tonelliSlow(Fp, n) {\n // Step 0: Check that n is indeed a square: (n | p) should not be ≡ -1\n if (Fp.pow(n, legendreC) === Fp.neg(Fp.ONE)) throw new Error('Cannot find square root');\n let r = S;\n // TODO: will fail at Fp2/etc\n let g = Fp.pow(Fp.mul(Fp.ONE, Z), Q); // will update both x and b\n let x = Fp.pow(n, Q1div2); // first guess at the square root\n let b = Fp.pow(n, Q); // first guess at the fudge factor\n while (!Fp.eql(b, Fp.ONE)) {\n if (Fp.eql(b, Fp.ZERO)) return Fp.ZERO; // https://en.wikipedia.org/wiki/Tonelli%E2%80%93Shanks_algorithm (4. If t = 0, return r = 0)\n // Find m such b^(2^m)==1\n let m = 1;\n for (let t2 = Fp.sqr(b); m < r; m++) {\n if (Fp.eql(t2, Fp.ONE)) break;\n t2 = Fp.sqr(t2); // t2 *= t2\n }\n // NOTE: r-m-1 can be bigger than 32, need to convert to bigint before shift, otherwise there will be overflow\n const ge = Fp.pow(g, _1n << BigInt(r - m - 1)); // ge = 2^(r-m-1)\n g = Fp.sqr(ge); // g = ge * ge\n x = Fp.mul(x, ge); // x *= ge\n b = Fp.mul(b, g); // b *= g\n r = m;\n }\n return x;\n };\n}\nfunction FpSqrt(P) {\n // NOTE: different algorithms can give different roots, it is up to user to decide which one they want.\n // For example there is FpSqrtOdd/FpSqrtEven to choice root based on oddness (used for hash-to-curve).\n // P ≡ 3 (mod 4)\n // √n = n^((P+1)/4)\n if (P % _4n === _3n) {\n // Not all roots possible!\n // const ORDER =\n // 0x1a0111ea397fe69a4b1ba7b6434bacd764774b84f38512bf6730d2a0f6b0f6241eabfffeb153ffffb9feffffffffaaabn;\n // const NUM = 72057594037927816n;\n const p1div4 = (P + _1n) / _4n;\n return function sqrt3mod4(Fp, n) {\n const root = Fp.pow(n, p1div4);\n // Throw if root**2 != n\n if (!Fp.eql(Fp.sqr(root), n)) throw new Error('Cannot find square root');\n return root;\n };\n }\n // Atkin algorithm for q ≡ 5 (mod 8), https://eprint.iacr.org/2012/685.pdf (page 10)\n if (P % _8n === _5n) {\n const c1 = (P - _5n) / _8n;\n return function sqrt5mod8(Fp, n) {\n const n2 = Fp.mul(n, _2n);\n const v = Fp.pow(n2, c1);\n const nv = Fp.mul(n, v);\n const i = Fp.mul(Fp.mul(nv, _2n), v);\n const root = Fp.mul(nv, Fp.sub(i, Fp.ONE));\n if (!Fp.eql(Fp.sqr(root), n)) throw new Error('Cannot find square root');\n return root;\n };\n }\n // P ≡ 9 (mod 16)\n if (P % _16n === _9n) {\n // NOTE: tonelli is too slow for bls-Fp2 calculations even on start\n // Means we cannot use sqrt for constants at all!\n //\n // const c1 = Fp.sqrt(Fp.negate(Fp.ONE)); // 1. c1 = sqrt(-1) in F, i.e., (c1^2) == -1 in F\n // const c2 = Fp.sqrt(c1); // 2. c2 = sqrt(c1) in F, i.e., (c2^2) == c1 in F\n // const c3 = Fp.sqrt(Fp.negate(c1)); // 3. c3 = sqrt(-c1) in F, i.e., (c3^2) == -c1 in F\n // const c4 = (P + _7n) / _16n; // 4. c4 = (q + 7) / 16 # Integer arithmetic\n // sqrt = (x) => {\n // let tv1 = Fp.pow(x, c4); // 1. tv1 = x^c4\n // let tv2 = Fp.mul(c1, tv1); // 2. tv2 = c1 * tv1\n // const tv3 = Fp.mul(c2, tv1); // 3. tv3 = c2 * tv1\n // let tv4 = Fp.mul(c3, tv1); // 4. tv4 = c3 * tv1\n // const e1 = Fp.equals(Fp.square(tv2), x); // 5. e1 = (tv2^2) == x\n // const e2 = Fp.equals(Fp.square(tv3), x); // 6. e2 = (tv3^2) == x\n // tv1 = Fp.cmov(tv1, tv2, e1); // 7. tv1 = CMOV(tv1, tv2, e1) # Select tv2 if (tv2^2) == x\n // tv2 = Fp.cmov(tv4, tv3, e2); // 8. tv2 = CMOV(tv4, tv3, e2) # Select tv3 if (tv3^2) == x\n // const e3 = Fp.equals(Fp.square(tv2), x); // 9. e3 = (tv2^2) == x\n // return Fp.cmov(tv1, tv2, e3); // 10. z = CMOV(tv1, tv2, e3) # Select the sqrt from tv1 and tv2\n // }\n }\n // Other cases: Tonelli-Shanks algorithm\n return tonelliShanks(P);\n}\n// Little-endian check for first LE bit (last BE bit);\nconst isNegativeLE = (num, modulo) => (mod(num, modulo) & _1n) === _1n;\nexports.isNegativeLE = isNegativeLE;\n// prettier-ignore\nconst FIELD_FIELDS = ['create', 'isValid', 'is0', 'neg', 'inv', 'sqrt', 'sqr', 'eql', 'add', 'sub', 'mul', 'pow', 'div', 'addN', 'subN', 'mulN', 'sqrN'];\nfunction validateField(field) {\n const initial = {\n ORDER: 'bigint',\n MASK: 'bigint',\n BYTES: 'isSafeInteger',\n BITS: 'isSafeInteger'\n };\n const opts = FIELD_FIELDS.reduce((map, val) => {\n map[val] = 'function';\n return map;\n }, initial);\n return (0, utils_js_1.validateObject)(field, opts);\n}\n// Generic field functions\n/**\n * Same as `pow` but for Fp: non-constant-time.\n * Unsafe in some contexts: uses ladder, so can expose bigint bits.\n */\nfunction FpPow(f, num, power) {\n // Should have same speed as pow for bigints\n // TODO: benchmark!\n if (power < _0n) throw new Error('Expected power > 0');\n if (power === _0n) return f.ONE;\n if (power === _1n) return num;\n let p = f.ONE;\n let d = num;\n while (power > _0n) {\n if (power & _1n) p = f.mul(p, d);\n d = f.sqr(d);\n power >>= _1n;\n }\n return p;\n}\n/**\n * Efficiently invert an array of Field elements.\n * `inv(0)` will return `undefined` here: make sure to throw an error.\n */\nfunction FpInvertBatch(f, nums) {\n const tmp = new Array(nums.length);\n // Walk from first to last, multiply them by each other MOD p\n const lastMultiplied = nums.reduce((acc, num, i) => {\n if (f.is0(num)) return acc;\n tmp[i] = acc;\n return f.mul(acc, num);\n }, f.ONE);\n // Invert last element\n const inverted = f.inv(lastMultiplied);\n // Walk from last to first, multiply them by inverted each other MOD p\n nums.reduceRight((acc, num, i) => {\n if (f.is0(num)) return acc;\n tmp[i] = f.mul(acc, tmp[i]);\n return f.mul(acc, num);\n }, inverted);\n return tmp;\n}\nfunction FpDiv(f, lhs, rhs) {\n return f.mul(lhs, typeof rhs === 'bigint' ? invert(rhs, f.ORDER) : f.inv(rhs));\n}\n// This function returns True whenever the value x is a square in the field F.\nfunction FpIsSquare(f) {\n const legendreConst = (f.ORDER - _1n) / _2n; // Integer arithmetic\n return x => {\n const p = f.pow(x, legendreConst);\n return f.eql(p, f.ZERO) || f.eql(p, f.ONE);\n };\n}\n// CURVE.n lengths\nfunction nLength(n, nBitLength) {\n // Bit size, byte size of CURVE.n\n const _nBitLength = nBitLength !== undefined ? nBitLength : n.toString(2).length;\n const nByteLength = Math.ceil(_nBitLength / 8);\n return {\n nBitLength: _nBitLength,\n nByteLength\n };\n}\n/**\n * Initializes a finite field over prime. **Non-primes are not supported.**\n * Do not init in loop: slow. Very fragile: always run a benchmark on a change.\n * Major performance optimizations:\n * * a) denormalized operations like mulN instead of mul\n * * b) same object shape: never add or remove keys\n * * c) Object.freeze\n * @param ORDER prime positive bigint\n * @param bitLen how many bits the field consumes\n * @param isLE (def: false) if encoding / decoding should be in little-endian\n * @param redef optional faster redefinitions of sqrt and other methods\n */\nfunction Field(ORDER, bitLen, isLE = false, redef = {}) {\n if (ORDER <= _0n) throw new Error(`Expected Field ORDER > 0, got ${ORDER}`);\n const {\n nBitLength: BITS,\n nByteLength: BYTES\n } = nLength(ORDER, bitLen);\n if (BYTES > 2048) throw new Error('Field lengths over 2048 bytes are not supported');\n const sqrtP = FpSqrt(ORDER);\n const f = Object.freeze({\n ORDER,\n BITS,\n BYTES,\n MASK: (0, utils_js_1.bitMask)(BITS),\n ZERO: _0n,\n ONE: _1n,\n create: num => mod(num, ORDER),\n isValid: num => {\n if (typeof num !== 'bigint') throw new Error(`Invalid field element: expected bigint, got ${typeof num}`);\n return _0n <= num && num < ORDER; // 0 is valid element, but it's not invertible\n },\n is0: num => num === _0n,\n isOdd: num => (num & _1n) === _1n,\n neg: num => mod(-num, ORDER),\n eql: (lhs, rhs) => lhs === rhs,\n sqr: num => mod(num * num, ORDER),\n add: (lhs, rhs) => mod(lhs + rhs, ORDER),\n sub: (lhs, rhs) => mod(lhs - rhs, ORDER),\n mul: (lhs, rhs) => mod(lhs * rhs, ORDER),\n pow: (num, power) => FpPow(f, num, power),\n div: (lhs, rhs) => mod(lhs * invert(rhs, ORDER), ORDER),\n // Same as above, but doesn't normalize\n sqrN: num => num * num,\n addN: (lhs, rhs) => lhs + rhs,\n subN: (lhs, rhs) => lhs - rhs,\n mulN: (lhs, rhs) => lhs * rhs,\n inv: num => invert(num, ORDER),\n sqrt: redef.sqrt || (n => sqrtP(f, n)),\n invertBatch: lst => FpInvertBatch(f, lst),\n // TODO: do we really need constant cmov?\n // We don't have const-time bigints anyway, so probably will be not very useful\n cmov: (a, b, c) => c ? b : a,\n toBytes: num => isLE ? (0, utils_js_1.numberToBytesLE)(num, BYTES) : (0, utils_js_1.numberToBytesBE)(num, BYTES),\n fromBytes: bytes => {\n if (bytes.length !== BYTES) throw new Error(`Fp.fromBytes: expected ${BYTES}, got ${bytes.length}`);\n return isLE ? (0, utils_js_1.bytesToNumberLE)(bytes) : (0, utils_js_1.bytesToNumberBE)(bytes);\n }\n });\n return Object.freeze(f);\n}\nfunction FpSqrtOdd(Fp, elm) {\n if (!Fp.isOdd) throw new Error(`Field doesn't have isOdd`);\n const root = Fp.sqrt(elm);\n return Fp.isOdd(root) ? root : Fp.neg(root);\n}\nfunction FpSqrtEven(Fp, elm) {\n if (!Fp.isOdd) throw new Error(`Field doesn't have isOdd`);\n const root = Fp.sqrt(elm);\n return Fp.isOdd(root) ? Fp.neg(root) : root;\n}\n/**\n * \"Constant-time\" private key generation utility.\n * Same as mapKeyToField, but accepts less bytes (40 instead of 48 for 32-byte field).\n * Which makes it slightly more biased, less secure.\n * @deprecated use mapKeyToField instead\n */\nfunction hashToPrivateScalar(hash, groupOrder, isLE = false) {\n hash = (0, utils_js_1.ensureBytes)('privateHash', hash);\n const hashLen = hash.length;\n const minLen = nLength(groupOrder).nByteLength + 8;\n if (minLen < 24 || hashLen < minLen || hashLen > 1024) throw new Error(`hashToPrivateScalar: expected ${minLen}-1024 bytes of input, got ${hashLen}`);\n const num = isLE ? (0, utils_js_1.bytesToNumberLE)(hash) : (0, utils_js_1.bytesToNumberBE)(hash);\n return mod(num, groupOrder - _1n) + _1n;\n}\n/**\n * Returns total number of bytes consumed by the field element.\n * For example, 32 bytes for usual 256-bit weierstrass curve.\n * @param fieldOrder number of field elements, usually CURVE.n\n * @returns byte length of field\n */\nfunction getFieldBytesLength(fieldOrder) {\n if (typeof fieldOrder !== 'bigint') throw new Error('field order must be bigint');\n const bitLength = fieldOrder.toString(2).length;\n return Math.ceil(bitLength / 8);\n}\n/**\n * Returns minimal amount of bytes that can be safely reduced\n * by field order.\n * Should be 2^-128 for 128-bit curve such as P256.\n * @param fieldOrder number of field elements, usually CURVE.n\n * @returns byte length of target hash\n */\nfunction getMinHashLength(fieldOrder) {\n const length = getFieldBytesLength(fieldOrder);\n return length + Math.ceil(length / 2);\n}\n/**\n * \"Constant-time\" private key generation utility.\n * Can take (n + n/2) or more bytes of uniform input e.g. from CSPRNG or KDF\n * and convert them into private scalar, with the modulo bias being negligible.\n * Needs at least 48 bytes of input for 32-byte private key.\n * https://research.kudelskisecurity.com/2020/07/28/the-definitive-guide-to-modulo-bias-and-how-to-avoid-it/\n * FIPS 186-5, A.2 https://csrc.nist.gov/publications/detail/fips/186/5/final\n * RFC 9380, https://www.rfc-editor.org/rfc/rfc9380#section-5\n * @param hash hash output from SHA3 or a similar function\n * @param groupOrder size of subgroup - (e.g. secp256k1.CURVE.n)\n * @param isLE interpret hash bytes as LE num\n * @returns valid private scalar\n */\nfunction mapHashToField(key, fieldOrder, isLE = false) {\n const len = key.length;\n const fieldLen = getFieldBytesLength(fieldOrder);\n const minLen = getMinHashLength(fieldOrder);\n // No small numbers: need to understand bias story. No huge numbers: easier to detect JS timings.\n if (len < 16 || len < minLen || len > 1024) throw new Error(`expected ${minLen}-1024 bytes of input, got ${len}`);\n const num = isLE ? (0, utils_js_1.bytesToNumberBE)(key) : (0, utils_js_1.bytesToNumberLE)(key);\n // `mod(x, 11)` can sometimes produce 0. `mod(x, 10) + 1` is the same, but no 0\n const reduced = mod(num, fieldOrder - _1n) + _1n;\n return isLE ? (0, utils_js_1.numberToBytesLE)(reduced, fieldLen) : (0, utils_js_1.numberToBytesBE)(reduced, fieldLen);\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.wNAF = wNAF;\nexports.validateBasic = validateBasic;\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\n// Abelian group utilities\nconst modular_js_1 = require(\"./modular.js\");\nconst utils_js_1 = require(\"./utils.js\");\nconst _0n = BigInt(0);\nconst _1n = BigInt(1);\n// Elliptic curve multiplication of Point by scalar. Fragile.\n// Scalars should always be less than curve order: this should be checked inside of a curve itself.\n// Creates precomputation tables for fast multiplication:\n// - private scalar is split by fixed size windows of W bits\n// - every window point is collected from window's table & added to accumulator\n// - since windows are different, same point inside tables won't be accessed more than once per calc\n// - each multiplication is 'Math.ceil(CURVE_ORDER / 𝑊) + 1' point additions (fixed for any scalar)\n// - +1 window is neccessary for wNAF\n// - wNAF reduces table size: 2x less memory + 2x faster generation, but 10% slower multiplication\n// TODO: Research returning 2d JS array of windows, instead of a single window. This would allow\n// windows to be in different memory locations\nfunction wNAF(c, bits) {\n const constTimeNegate = (condition, item) => {\n const neg = item.negate();\n return condition ? neg : item;\n };\n const opts = W => {\n const windows = Math.ceil(bits / W) + 1; // +1, because\n const windowSize = 2 ** (W - 1); // -1 because we skip zero\n return {\n windows,\n windowSize\n };\n };\n return {\n constTimeNegate,\n // non-const time multiplication ladder\n unsafeLadder(elm, n) {\n let p = c.ZERO;\n let d = elm;\n while (n > _0n) {\n if (n & _1n) p = p.add(d);\n d = d.double();\n n >>= _1n;\n }\n return p;\n },\n /**\n * Creates a wNAF precomputation window. Used for caching.\n * Default window size is set by `utils.precompute()` and is equal to 8.\n * Number of precomputed points depends on the curve size:\n * 2^(𝑊−1) * (Math.ceil(𝑛 / 𝑊) + 1), where:\n * - 𝑊 is the window size\n * - 𝑛 is the bitlength of the curve order.\n * For a 256-bit curve and window size 8, the number of precomputed points is 128 * 33 = 4224.\n * @returns precomputed point tables flattened to a single array\n */\n precomputeWindow(elm, W) {\n const {\n windows,\n windowSize\n } = opts(W);\n const points = [];\n let p = elm;\n let base = p;\n for (let window = 0; window < windows; window++) {\n base = p;\n points.push(base);\n // =1, because we skip zero\n for (let i = 1; i < windowSize; i++) {\n base = base.add(p);\n points.push(base);\n }\n p = base.double();\n }\n return points;\n },\n /**\n * Implements ec multiplication using precomputed tables and w-ary non-adjacent form.\n * @param W window size\n * @param precomputes precomputed tables\n * @param n scalar (we don't check here, but should be less than curve order)\n * @returns real and fake (for const-time) points\n */\n wNAF(W, precomputes, n) {\n // TODO: maybe check that scalar is less than group order? wNAF behavious is undefined otherwise\n // But need to carefully remove other checks before wNAF. ORDER == bits here\n const {\n windows,\n windowSize\n } = opts(W);\n let p = c.ZERO;\n let f = c.BASE;\n const mask = BigInt(2 ** W - 1); // Create mask with W ones: 0b1111 for W=4 etc.\n const maxNumber = 2 ** W;\n const shiftBy = BigInt(W);\n for (let window = 0; window < windows; window++) {\n const offset = window * windowSize;\n // Extract W bits.\n let wbits = Number(n & mask);\n // Shift number by W bits.\n n >>= shiftBy;\n // If the bits are bigger than max size, we'll split those.\n // +224 => 256 - 32\n if (wbits > windowSize) {\n wbits -= maxNumber;\n n += _1n;\n }\n // This code was first written with assumption that 'f' and 'p' will never be infinity point:\n // since each addition is multiplied by 2 ** W, it cannot cancel each other. However,\n // there is negate now: it is possible that negated element from low value\n // would be the same as high element, which will create carry into next window.\n // It's not obvious how this can fail, but still worth investigating later.\n // Check if we're onto Zero point.\n // Add random point inside current window to f.\n const offset1 = offset;\n const offset2 = offset + Math.abs(wbits) - 1; // -1 because we skip zero\n const cond1 = window % 2 !== 0;\n const cond2 = wbits < 0;\n if (wbits === 0) {\n // The most important part for const-time getPublicKey\n f = f.add(constTimeNegate(cond1, precomputes[offset1]));\n } else {\n p = p.add(constTimeNegate(cond2, precomputes[offset2]));\n }\n }\n // JIT-compiler should not eliminate f here, since it will later be used in normalizeZ()\n // Even if the variable is still unused, there are some checks which will\n // throw an exception, so compiler needs to prove they won't happen, which is hard.\n // At this point there is a way to F be infinity-point even if p is not,\n // which makes it less const-time: around 1 bigint multiply.\n return {\n p,\n f\n };\n },\n wNAFCached(P, precomputesMap, n, transform) {\n // @ts-ignore\n const W = P._WINDOW_SIZE || 1;\n // Calculate precomputes on a first run, reuse them after\n let comp = precomputesMap.get(P);\n if (!comp) {\n comp = this.precomputeWindow(P, W);\n if (W !== 1) {\n precomputesMap.set(P, transform(comp));\n }\n }\n return this.wNAF(W, comp, n);\n }\n };\n}\nfunction validateBasic(curve) {\n (0, modular_js_1.validateField)(curve.Fp);\n (0, utils_js_1.validateObject)(curve, {\n n: 'bigint',\n h: 'bigint',\n Gx: 'field',\n Gy: 'field'\n }, {\n nBitLength: 'isSafeInteger',\n nByteLength: 'isSafeInteger'\n });\n // Set defaults\n return Object.freeze({\n ...(0, modular_js_1.nLength)(curve.n, curve.nBitLength),\n ...curve,\n ...{\n p: curve.Fp.ORDER\n }\n });\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DER = void 0;\nexports.weierstrassPoints = weierstrassPoints;\nexports.weierstrass = weierstrass;\nexports.SWUFpSqrtRatio = SWUFpSqrtRatio;\nexports.mapToCurveSimpleSWU = mapToCurveSimpleSWU;\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\n// Short Weierstrass curve. The formula is: y² = x³ + ax + b\nconst curve_js_1 = require(\"./curve.js\");\nconst mod = require(\"./modular.js\");\nconst ut = require(\"./utils.js\");\nconst utils_js_1 = require(\"./utils.js\");\nfunction validatePointOpts(curve) {\n const opts = (0, curve_js_1.validateBasic)(curve);\n ut.validateObject(opts, {\n a: 'field',\n b: 'field'\n }, {\n allowedPrivateKeyLengths: 'array',\n wrapPrivateKey: 'boolean',\n isTorsionFree: 'function',\n clearCofactor: 'function',\n allowInfinityPoint: 'boolean',\n fromBytes: 'function',\n toBytes: 'function'\n });\n const {\n endo,\n Fp,\n a\n } = opts;\n if (endo) {\n if (!Fp.eql(a, Fp.ZERO)) {\n throw new Error('Endomorphism can only be defined for Koblitz curves that have a=0');\n }\n if (typeof endo !== 'object' || typeof endo.beta !== 'bigint' || typeof endo.splitScalar !== 'function') {\n throw new Error('Expected endomorphism with beta: bigint and splitScalar: function');\n }\n }\n return Object.freeze({\n ...opts\n });\n}\n// ASN.1 DER encoding utilities\nconst {\n bytesToNumberBE: b2n,\n hexToBytes: h2b\n} = ut;\nexports.DER = {\n // asn.1 DER encoding utils\n Err: class DERErr extends Error {\n constructor(m = '') {\n super(m);\n }\n },\n _parseInt(data) {\n const {\n Err: E\n } = exports.DER;\n if (data.length < 2 || data[0] !== 0x02) throw new E('Invalid signature integer tag');\n const len = data[1];\n const res = data.subarray(2, len + 2);\n if (!len || res.length !== len) throw new E('Invalid signature integer: wrong length');\n // https://crypto.stackexchange.com/a/57734 Leftmost bit of first byte is 'negative' flag,\n // since we always use positive integers here. It must always be empty:\n // - add zero byte if exists\n // - if next byte doesn't have a flag, leading zero is not allowed (minimal encoding)\n if (res[0] & 0b10000000) throw new E('Invalid signature integer: negative');\n if (res[0] === 0x00 && !(res[1] & 0b10000000)) throw new E('Invalid signature integer: unnecessary leading zero');\n return {\n d: b2n(res),\n l: data.subarray(len + 2)\n }; // d is data, l is left\n },\n toSig(hex) {\n // parse DER signature\n const {\n Err: E\n } = exports.DER;\n const data = typeof hex === 'string' ? h2b(hex) : hex;\n ut.abytes(data);\n let l = data.length;\n if (l < 2 || data[0] != 0x30) throw new E('Invalid signature tag');\n if (data[1] !== l - 2) throw new E('Invalid signature: incorrect length');\n const {\n d: r,\n l: sBytes\n } = exports.DER._parseInt(data.subarray(2));\n const {\n d: s,\n l: rBytesLeft\n } = exports.DER._parseInt(sBytes);\n if (rBytesLeft.length) throw new E('Invalid signature: left bytes after parsing');\n return {\n r,\n s\n };\n },\n hexFromSig(sig) {\n // Add leading zero if first byte has negative bit enabled. More details in '_parseInt'\n const slice = s => Number.parseInt(s[0], 16) & 0b1000 ? '00' + s : s;\n const h = num => {\n const hex = num.toString(16);\n return hex.length & 1 ? `0${hex}` : hex;\n };\n const s = slice(h(sig.s));\n const r = slice(h(sig.r));\n const shl = s.length / 2;\n const rhl = r.length / 2;\n const sl = h(shl);\n const rl = h(rhl);\n return `30${h(rhl + shl + 4)}02${rl}${r}02${sl}${s}`;\n }\n};\n// Be friendly to bad ECMAScript parsers by not using bigint literals\n// prettier-ignore\nconst _0n = BigInt(0),\n _1n = BigInt(1),\n _2n = BigInt(2),\n _3n = BigInt(3),\n _4n = BigInt(4);\nfunction weierstrassPoints(opts) {\n const CURVE = validatePointOpts(opts);\n const {\n Fp\n } = CURVE; // All curves has same field / group length as for now, but they can differ\n const toBytes = CURVE.toBytes || ((_c, point, _isCompressed) => {\n const a = point.toAffine();\n return ut.concatBytes(Uint8Array.from([0x04]), Fp.toBytes(a.x), Fp.toBytes(a.y));\n });\n const fromBytes = CURVE.fromBytes || (bytes => {\n // const head = bytes[0];\n const tail = bytes.subarray(1);\n // if (head !== 0x04) throw new Error('Only non-compressed encoding is supported');\n const x = Fp.fromBytes(tail.subarray(0, Fp.BYTES));\n const y = Fp.fromBytes(tail.subarray(Fp.BYTES, 2 * Fp.BYTES));\n return {\n x,\n y\n };\n });\n /**\n * y² = x³ + ax + b: Short weierstrass curve formula\n * @returns y²\n */\n function weierstrassEquation(x) {\n const {\n a,\n b\n } = CURVE;\n const x2 = Fp.sqr(x); // x * x\n const x3 = Fp.mul(x2, x); // x2 * x\n return Fp.add(Fp.add(x3, Fp.mul(x, a)), b); // x3 + a * x + b\n }\n // Validate whether the passed curve params are valid.\n // We check if curve equation works for generator point.\n // `assertValidity()` won't work: `isTorsionFree()` is not available at this point in bls12-381.\n // ProjectivePoint class has not been initialized yet.\n if (!Fp.eql(Fp.sqr(CURVE.Gy), weierstrassEquation(CURVE.Gx))) throw new Error('bad generator point: equation left != right');\n // Valid group elements reside in range 1..n-1\n function isWithinCurveOrder(num) {\n return typeof num === 'bigint' && _0n < num && num < CURVE.n;\n }\n function assertGE(num) {\n if (!isWithinCurveOrder(num)) throw new Error('Expected valid bigint: 0 < bigint < curve.n');\n }\n // Validates if priv key is valid and converts it to bigint.\n // Supports options allowedPrivateKeyLengths and wrapPrivateKey.\n function normPrivateKeyToScalar(key) {\n const {\n allowedPrivateKeyLengths: lengths,\n nByteLength,\n wrapPrivateKey,\n n\n } = CURVE;\n if (lengths && typeof key !== 'bigint') {\n if (ut.isBytes(key)) key = ut.bytesToHex(key);\n // Normalize to hex string, pad. E.g. P521 would norm 130-132 char hex to 132-char bytes\n if (typeof key !== 'string' || !lengths.includes(key.length)) throw new Error('Invalid key');\n key = key.padStart(nByteLength * 2, '0');\n }\n let num;\n try {\n num = typeof key === 'bigint' ? key : ut.bytesToNumberBE((0, utils_js_1.ensureBytes)('private key', key, nByteLength));\n } catch (error) {\n throw new Error(`private key must be ${nByteLength} bytes, hex or bigint, not ${typeof key}`);\n }\n if (wrapPrivateKey) num = mod.mod(num, n); // disabled by default, enabled for BLS\n assertGE(num); // num in range [1..N-1]\n return num;\n }\n const pointPrecomputes = new Map();\n function assertPrjPoint(other) {\n if (!(other instanceof Point)) throw new Error('ProjectivePoint expected');\n }\n /**\n * Projective Point works in 3d / projective (homogeneous) coordinates: (x, y, z) ∋ (x=x/z, y=y/z)\n * Default Point works in 2d / affine coordinates: (x, y)\n * We're doing calculations in projective, because its operations don't require costly inversion.\n */\n class Point {\n constructor(px, py, pz) {\n this.px = px;\n this.py = py;\n this.pz = pz;\n if (px == null || !Fp.isValid(px)) throw new Error('x required');\n if (py == null || !Fp.isValid(py)) throw new Error('y required');\n if (pz == null || !Fp.isValid(pz)) throw new Error('z required');\n }\n // Does not validate if the point is on-curve.\n // Use fromHex instead, or call assertValidity() later.\n static fromAffine(p) {\n const {\n x,\n y\n } = p || {};\n if (!p || !Fp.isValid(x) || !Fp.isValid(y)) throw new Error('invalid affine point');\n if (p instanceof Point) throw new Error('projective point not allowed');\n const is0 = i => Fp.eql(i, Fp.ZERO);\n // fromAffine(x:0, y:0) would produce (x:0, y:0, z:1), but we need (x:0, y:1, z:0)\n if (is0(x) && is0(y)) return Point.ZERO;\n return new Point(x, y, Fp.ONE);\n }\n get x() {\n return this.toAffine().x;\n }\n get y() {\n return this.toAffine().y;\n }\n /**\n * Takes a bunch of Projective Points but executes only one\n * inversion on all of them. Inversion is very slow operation,\n * so this improves performance massively.\n * Optimization: converts a list of projective points to a list of identical points with Z=1.\n */\n static normalizeZ(points) {\n const toInv = Fp.invertBatch(points.map(p => p.pz));\n return points.map((p, i) => p.toAffine(toInv[i])).map(Point.fromAffine);\n }\n /**\n * Converts hash string or Uint8Array to Point.\n * @param hex short/long ECDSA hex\n */\n static fromHex(hex) {\n const P = Point.fromAffine(fromBytes((0, utils_js_1.ensureBytes)('pointHex', hex)));\n P.assertValidity();\n return P;\n }\n // Multiplies generator point by privateKey.\n static fromPrivateKey(privateKey) {\n return Point.BASE.multiply(normPrivateKeyToScalar(privateKey));\n }\n // \"Private method\", don't use it directly\n _setWindowSize(windowSize) {\n this._WINDOW_SIZE = windowSize;\n pointPrecomputes.delete(this);\n }\n // A point on curve is valid if it conforms to equation.\n assertValidity() {\n if (this.is0()) {\n // (0, 1, 0) aka ZERO is invalid in most contexts.\n // In BLS, ZERO can be serialized, so we allow it.\n // (0, 0, 0) is wrong representation of ZERO and is always invalid.\n if (CURVE.allowInfinityPoint && !Fp.is0(this.py)) return;\n throw new Error('bad point: ZERO');\n }\n // Some 3rd-party test vectors require different wording between here & `fromCompressedHex`\n const {\n x,\n y\n } = this.toAffine();\n // Check if x, y are valid field elements\n if (!Fp.isValid(x) || !Fp.isValid(y)) throw new Error('bad point: x or y not FE');\n const left = Fp.sqr(y); // y²\n const right = weierstrassEquation(x); // x³ + ax + b\n if (!Fp.eql(left, right)) throw new Error('bad point: equation left != right');\n if (!this.isTorsionFree()) throw new Error('bad point: not in prime-order subgroup');\n }\n hasEvenY() {\n const {\n y\n } = this.toAffine();\n if (Fp.isOdd) return !Fp.isOdd(y);\n throw new Error(\"Field doesn't support isOdd\");\n }\n /**\n * Compare one point to another.\n */\n equals(other) {\n assertPrjPoint(other);\n const {\n px: X1,\n py: Y1,\n pz: Z1\n } = this;\n const {\n px: X2,\n py: Y2,\n pz: Z2\n } = other;\n const U1 = Fp.eql(Fp.mul(X1, Z2), Fp.mul(X2, Z1));\n const U2 = Fp.eql(Fp.mul(Y1, Z2), Fp.mul(Y2, Z1));\n return U1 && U2;\n }\n /**\n * Flips point to one corresponding to (x, -y) in Affine coordinates.\n */\n negate() {\n return new Point(this.px, Fp.neg(this.py), this.pz);\n }\n // Renes-Costello-Batina exception-free doubling formula.\n // There is 30% faster Jacobian formula, but it is not complete.\n // https://eprint.iacr.org/2015/1060, algorithm 3\n // Cost: 8M + 3S + 3*a + 2*b3 + 15add.\n double() {\n const {\n a,\n b\n } = CURVE;\n const b3 = Fp.mul(b, _3n);\n const {\n px: X1,\n py: Y1,\n pz: Z1\n } = this;\n let X3 = Fp.ZERO,\n Y3 = Fp.ZERO,\n Z3 = Fp.ZERO; // prettier-ignore\n let t0 = Fp.mul(X1, X1); // step 1\n let t1 = Fp.mul(Y1, Y1);\n let t2 = Fp.mul(Z1, Z1);\n let t3 = Fp.mul(X1, Y1);\n t3 = Fp.add(t3, t3); // step 5\n Z3 = Fp.mul(X1, Z1);\n Z3 = Fp.add(Z3, Z3);\n X3 = Fp.mul(a, Z3);\n Y3 = Fp.mul(b3, t2);\n Y3 = Fp.add(X3, Y3); // step 10\n X3 = Fp.sub(t1, Y3);\n Y3 = Fp.add(t1, Y3);\n Y3 = Fp.mul(X3, Y3);\n X3 = Fp.mul(t3, X3);\n Z3 = Fp.mul(b3, Z3); // step 15\n t2 = Fp.mul(a, t2);\n t3 = Fp.sub(t0, t2);\n t3 = Fp.mul(a, t3);\n t3 = Fp.add(t3, Z3);\n Z3 = Fp.add(t0, t0); // step 20\n t0 = Fp.add(Z3, t0);\n t0 = Fp.add(t0, t2);\n t0 = Fp.mul(t0, t3);\n Y3 = Fp.add(Y3, t0);\n t2 = Fp.mul(Y1, Z1); // step 25\n t2 = Fp.add(t2, t2);\n t0 = Fp.mul(t2, t3);\n X3 = Fp.sub(X3, t0);\n Z3 = Fp.mul(t2, t1);\n Z3 = Fp.add(Z3, Z3); // step 30\n Z3 = Fp.add(Z3, Z3);\n return new Point(X3, Y3, Z3);\n }\n // Renes-Costello-Batina exception-free addition formula.\n // There is 30% faster Jacobian formula, but it is not complete.\n // https://eprint.iacr.org/2015/1060, algorithm 1\n // Cost: 12M + 0S + 3*a + 3*b3 + 23add.\n add(other) {\n assertPrjPoint(other);\n const {\n px: X1,\n py: Y1,\n pz: Z1\n } = this;\n const {\n px: X2,\n py: Y2,\n pz: Z2\n } = other;\n let X3 = Fp.ZERO,\n Y3 = Fp.ZERO,\n Z3 = Fp.ZERO; // prettier-ignore\n const a = CURVE.a;\n const b3 = Fp.mul(CURVE.b, _3n);\n let t0 = Fp.mul(X1, X2); // step 1\n let t1 = Fp.mul(Y1, Y2);\n let t2 = Fp.mul(Z1, Z2);\n let t3 = Fp.add(X1, Y1);\n let t4 = Fp.add(X2, Y2); // step 5\n t3 = Fp.mul(t3, t4);\n t4 = Fp.add(t0, t1);\n t3 = Fp.sub(t3, t4);\n t4 = Fp.add(X1, Z1);\n let t5 = Fp.add(X2, Z2); // step 10\n t4 = Fp.mul(t4, t5);\n t5 = Fp.add(t0, t2);\n t4 = Fp.sub(t4, t5);\n t5 = Fp.add(Y1, Z1);\n X3 = Fp.add(Y2, Z2); // step 15\n t5 = Fp.mul(t5, X3);\n X3 = Fp.add(t1, t2);\n t5 = Fp.sub(t5, X3);\n Z3 = Fp.mul(a, t4);\n X3 = Fp.mul(b3, t2); // step 20\n Z3 = Fp.add(X3, Z3);\n X3 = Fp.sub(t1, Z3);\n Z3 = Fp.add(t1, Z3);\n Y3 = Fp.mul(X3, Z3);\n t1 = Fp.add(t0, t0); // step 25\n t1 = Fp.add(t1, t0);\n t2 = Fp.mul(a, t2);\n t4 = Fp.mul(b3, t4);\n t1 = Fp.add(t1, t2);\n t2 = Fp.sub(t0, t2); // step 30\n t2 = Fp.mul(a, t2);\n t4 = Fp.add(t4, t2);\n t0 = Fp.mul(t1, t4);\n Y3 = Fp.add(Y3, t0);\n t0 = Fp.mul(t5, t4); // step 35\n X3 = Fp.mul(t3, X3);\n X3 = Fp.sub(X3, t0);\n t0 = Fp.mul(t3, t1);\n Z3 = Fp.mul(t5, Z3);\n Z3 = Fp.add(Z3, t0); // step 40\n return new Point(X3, Y3, Z3);\n }\n subtract(other) {\n return this.add(other.negate());\n }\n is0() {\n return this.equals(Point.ZERO);\n }\n wNAF(n) {\n return wnaf.wNAFCached(this, pointPrecomputes, n, comp => {\n const toInv = Fp.invertBatch(comp.map(p => p.pz));\n return comp.map((p, i) => p.toAffine(toInv[i])).map(Point.fromAffine);\n });\n }\n /**\n * Non-constant-time multiplication. Uses double-and-add algorithm.\n * It's faster, but should only be used when you don't care about\n * an exposed private key e.g. sig verification, which works over *public* keys.\n */\n multiplyUnsafe(n) {\n const I = Point.ZERO;\n if (n === _0n) return I;\n assertGE(n); // Will throw on 0\n if (n === _1n) return this;\n const {\n endo\n } = CURVE;\n if (!endo) return wnaf.unsafeLadder(this, n);\n // Apply endomorphism\n let {\n k1neg,\n k1,\n k2neg,\n k2\n } = endo.splitScalar(n);\n let k1p = I;\n let k2p = I;\n let d = this;\n while (k1 > _0n || k2 > _0n) {\n if (k1 & _1n) k1p = k1p.add(d);\n if (k2 & _1n) k2p = k2p.add(d);\n d = d.double();\n k1 >>= _1n;\n k2 >>= _1n;\n }\n if (k1neg) k1p = k1p.negate();\n if (k2neg) k2p = k2p.negate();\n k2p = new Point(Fp.mul(k2p.px, endo.beta), k2p.py, k2p.pz);\n return k1p.add(k2p);\n }\n /**\n * Constant time multiplication.\n * Uses wNAF method. Windowed method may be 10% faster,\n * but takes 2x longer to generate and consumes 2x memory.\n * Uses precomputes when available.\n * Uses endomorphism for Koblitz curves.\n * @param scalar by which the point would be multiplied\n * @returns New point\n */\n multiply(scalar) {\n assertGE(scalar);\n let n = scalar;\n let point, fake; // Fake point is used to const-time mult\n const {\n endo\n } = CURVE;\n if (endo) {\n const {\n k1neg,\n k1,\n k2neg,\n k2\n } = endo.splitScalar(n);\n let {\n p: k1p,\n f: f1p\n } = this.wNAF(k1);\n let {\n p: k2p,\n f: f2p\n } = this.wNAF(k2);\n k1p = wnaf.constTimeNegate(k1neg, k1p);\n k2p = wnaf.constTimeNegate(k2neg, k2p);\n k2p = new Point(Fp.mul(k2p.px, endo.beta), k2p.py, k2p.pz);\n point = k1p.add(k2p);\n fake = f1p.add(f2p);\n } else {\n const {\n p,\n f\n } = this.wNAF(n);\n point = p;\n fake = f;\n }\n // Normalize `z` for both points, but return only real one\n return Point.normalizeZ([point, fake])[0];\n }\n /**\n * Efficiently calculate `aP + bQ`. Unsafe, can expose private key, if used incorrectly.\n * Not using Strauss-Shamir trick: precomputation tables are faster.\n * The trick could be useful if both P and Q are not G (not in our case).\n * @returns non-zero affine point\n */\n multiplyAndAddUnsafe(Q, a, b) {\n const G = Point.BASE; // No Strauss-Shamir trick: we have 10% faster G precomputes\n const mul = (P, a // Select faster multiply() method\n ) => a === _0n || a === _1n || !P.equals(G) ? P.multiplyUnsafe(a) : P.multiply(a);\n const sum = mul(this, a).add(mul(Q, b));\n return sum.is0() ? undefined : sum;\n }\n // Converts Projective point to affine (x, y) coordinates.\n // Can accept precomputed Z^-1 - for example, from invertBatch.\n // (x, y, z) ∋ (x=x/z, y=y/z)\n toAffine(iz) {\n const {\n px: x,\n py: y,\n pz: z\n } = this;\n const is0 = this.is0();\n // If invZ was 0, we return zero point. However we still want to execute\n // all operations, so we replace invZ with a random number, 1.\n if (iz == null) iz = is0 ? Fp.ONE : Fp.inv(z);\n const ax = Fp.mul(x, iz);\n const ay = Fp.mul(y, iz);\n const zz = Fp.mul(z, iz);\n if (is0) return {\n x: Fp.ZERO,\n y: Fp.ZERO\n };\n if (!Fp.eql(zz, Fp.ONE)) throw new Error('invZ was invalid');\n return {\n x: ax,\n y: ay\n };\n }\n isTorsionFree() {\n const {\n h: cofactor,\n isTorsionFree\n } = CURVE;\n if (cofactor === _1n) return true; // No subgroups, always torsion-free\n if (isTorsionFree) return isTorsionFree(Point, this);\n throw new Error('isTorsionFree() has not been declared for the elliptic curve');\n }\n clearCofactor() {\n const {\n h: cofactor,\n clearCofactor\n } = CURVE;\n if (cofactor === _1n) return this; // Fast-path\n if (clearCofactor) return clearCofactor(Point, this);\n return this.multiplyUnsafe(CURVE.h);\n }\n toRawBytes(isCompressed = true) {\n this.assertValidity();\n return toBytes(Point, this, isCompressed);\n }\n toHex(isCompressed = true) {\n return ut.bytesToHex(this.toRawBytes(isCompressed));\n }\n }\n Point.BASE = new Point(CURVE.Gx, CURVE.Gy, Fp.ONE);\n Point.ZERO = new Point(Fp.ZERO, Fp.ONE, Fp.ZERO);\n const _bits = CURVE.nBitLength;\n const wnaf = (0, curve_js_1.wNAF)(Point, CURVE.endo ? Math.ceil(_bits / 2) : _bits);\n // Validate if generator point is on curve\n return {\n CURVE,\n ProjectivePoint: Point,\n normPrivateKeyToScalar,\n weierstrassEquation,\n isWithinCurveOrder\n };\n}\nfunction validateOpts(curve) {\n const opts = (0, curve_js_1.validateBasic)(curve);\n ut.validateObject(opts, {\n hash: 'hash',\n hmac: 'function',\n randomBytes: 'function'\n }, {\n bits2int: 'function',\n bits2int_modN: 'function',\n lowS: 'boolean'\n });\n return Object.freeze({\n lowS: true,\n ...opts\n });\n}\nfunction weierstrass(curveDef) {\n const CURVE = validateOpts(curveDef);\n const {\n Fp,\n n: CURVE_ORDER\n } = CURVE;\n const compressedLen = Fp.BYTES + 1; // e.g. 33 for 32\n const uncompressedLen = 2 * Fp.BYTES + 1; // e.g. 65 for 32\n function isValidFieldElement(num) {\n return _0n < num && num < Fp.ORDER; // 0 is banned since it's not invertible FE\n }\n function modN(a) {\n return mod.mod(a, CURVE_ORDER);\n }\n function invN(a) {\n return mod.invert(a, CURVE_ORDER);\n }\n const {\n ProjectivePoint: Point,\n normPrivateKeyToScalar,\n weierstrassEquation,\n isWithinCurveOrder\n } = weierstrassPoints({\n ...CURVE,\n toBytes(_c, point, isCompressed) {\n const a = point.toAffine();\n const x = Fp.toBytes(a.x);\n const cat = ut.concatBytes;\n if (isCompressed) {\n return cat(Uint8Array.from([point.hasEvenY() ? 0x02 : 0x03]), x);\n } else {\n return cat(Uint8Array.from([0x04]), x, Fp.toBytes(a.y));\n }\n },\n fromBytes(bytes) {\n const len = bytes.length;\n const head = bytes[0];\n const tail = bytes.subarray(1);\n // this.assertValidity() is done inside of fromHex\n if (len === compressedLen && (head === 0x02 || head === 0x03)) {\n const x = ut.bytesToNumberBE(tail);\n if (!isValidFieldElement(x)) throw new Error('Point is not on curve');\n const y2 = weierstrassEquation(x); // y² = x³ + ax + b\n let y;\n try {\n y = Fp.sqrt(y2); // y = y² ^ (p+1)/4\n } catch (sqrtError) {\n const suffix = sqrtError instanceof Error ? ': ' + sqrtError.message : '';\n throw new Error('Point is not on curve' + suffix);\n }\n const isYOdd = (y & _1n) === _1n;\n // ECDSA\n const isHeadOdd = (head & 1) === 1;\n if (isHeadOdd !== isYOdd) y = Fp.neg(y);\n return {\n x,\n y\n };\n } else if (len === uncompressedLen && head === 0x04) {\n const x = Fp.fromBytes(tail.subarray(0, Fp.BYTES));\n const y = Fp.fromBytes(tail.subarray(Fp.BYTES, 2 * Fp.BYTES));\n return {\n x,\n y\n };\n } else {\n throw new Error(`Point of length ${len} was invalid. Expected ${compressedLen} compressed bytes or ${uncompressedLen} uncompressed bytes`);\n }\n }\n });\n const numToNByteStr = num => ut.bytesToHex(ut.numberToBytesBE(num, CURVE.nByteLength));\n function isBiggerThanHalfOrder(number) {\n const HALF = CURVE_ORDER >> _1n;\n return number > HALF;\n }\n function normalizeS(s) {\n return isBiggerThanHalfOrder(s) ? modN(-s) : s;\n }\n // slice bytes num\n const slcNum = (b, from, to) => ut.bytesToNumberBE(b.slice(from, to));\n /**\n * ECDSA signature with its (r, s) properties. Supports DER & compact representations.\n */\n class Signature {\n constructor(r, s, recovery) {\n this.r = r;\n this.s = s;\n this.recovery = recovery;\n this.assertValidity();\n }\n // pair (bytes of r, bytes of s)\n static fromCompact(hex) {\n const l = CURVE.nByteLength;\n hex = (0, utils_js_1.ensureBytes)('compactSignature', hex, l * 2);\n return new Signature(slcNum(hex, 0, l), slcNum(hex, l, 2 * l));\n }\n // DER encoded ECDSA signature\n // https://bitcoin.stackexchange.com/questions/57644/what-are-the-parts-of-a-bitcoin-transaction-input-script\n static fromDER(hex) {\n const {\n r,\n s\n } = exports.DER.toSig((0, utils_js_1.ensureBytes)('DER', hex));\n return new Signature(r, s);\n }\n assertValidity() {\n // can use assertGE here\n if (!isWithinCurveOrder(this.r)) throw new Error('r must be 0 < r < CURVE.n');\n if (!isWithinCurveOrder(this.s)) throw new Error('s must be 0 < s < CURVE.n');\n }\n addRecoveryBit(recovery) {\n return new Signature(this.r, this.s, recovery);\n }\n recoverPublicKey(msgHash) {\n const {\n r,\n s,\n recovery: rec\n } = this;\n const h = bits2int_modN((0, utils_js_1.ensureBytes)('msgHash', msgHash)); // Truncate hash\n if (rec == null || ![0, 1, 2, 3].includes(rec)) throw new Error('recovery id invalid');\n const radj = rec === 2 || rec === 3 ? r + CURVE.n : r;\n if (radj >= Fp.ORDER) throw new Error('recovery id 2 or 3 invalid');\n const prefix = (rec & 1) === 0 ? '02' : '03';\n const R = Point.fromHex(prefix + numToNByteStr(radj));\n const ir = invN(radj); // r^-1\n const u1 = modN(-h * ir); // -hr^-1\n const u2 = modN(s * ir); // sr^-1\n const Q = Point.BASE.multiplyAndAddUnsafe(R, u1, u2); // (sr^-1)R-(hr^-1)G = -(hr^-1)G + (sr^-1)\n if (!Q) throw new Error('point at infinify'); // unsafe is fine: no priv data leaked\n Q.assertValidity();\n return Q;\n }\n // Signatures should be low-s, to prevent malleability.\n hasHighS() {\n return isBiggerThanHalfOrder(this.s);\n }\n normalizeS() {\n return this.hasHighS() ? new Signature(this.r, modN(-this.s), this.recovery) : this;\n }\n // DER-encoded\n toDERRawBytes() {\n return ut.hexToBytes(this.toDERHex());\n }\n toDERHex() {\n return exports.DER.hexFromSig({\n r: this.r,\n s: this.s\n });\n }\n // padded bytes of r, then padded bytes of s\n toCompactRawBytes() {\n return ut.hexToBytes(this.toCompactHex());\n }\n toCompactHex() {\n return numToNByteStr(this.r) + numToNByteStr(this.s);\n }\n }\n const utils = {\n isValidPrivateKey(privateKey) {\n try {\n normPrivateKeyToScalar(privateKey);\n return true;\n } catch (error) {\n return false;\n }\n },\n normPrivateKeyToScalar: normPrivateKeyToScalar,\n /**\n * Produces cryptographically secure private key from random of size\n * (groupLen + ceil(groupLen / 2)) with modulo bias being negligible.\n */\n randomPrivateKey: () => {\n const length = mod.getMinHashLength(CURVE.n);\n return mod.mapHashToField(CURVE.randomBytes(length), CURVE.n);\n },\n /**\n * Creates precompute table for an arbitrary EC point. Makes point \"cached\".\n * Allows to massively speed-up `point.multiply(scalar)`.\n * @returns cached point\n * @example\n * const fast = utils.precompute(8, ProjectivePoint.fromHex(someonesPubKey));\n * fast.multiply(privKey); // much faster ECDH now\n */\n precompute(windowSize = 8, point = Point.BASE) {\n point._setWindowSize(windowSize);\n point.multiply(BigInt(3)); // 3 is arbitrary, just need any number here\n return point;\n }\n };\n /**\n * Computes public key for a private key. Checks for validity of the private key.\n * @param privateKey private key\n * @param isCompressed whether to return compact (default), or full key\n * @returns Public key, full when isCompressed=false; short when isCompressed=true\n */\n function getPublicKey(privateKey, isCompressed = true) {\n return Point.fromPrivateKey(privateKey).toRawBytes(isCompressed);\n }\n /**\n * Quick and dirty check for item being public key. Does not validate hex, or being on-curve.\n */\n function isProbPub(item) {\n const arr = ut.isBytes(item);\n const str = typeof item === 'string';\n const len = (arr || str) && item.length;\n if (arr) return len === compressedLen || len === uncompressedLen;\n if (str) return len === 2 * compressedLen || len === 2 * uncompressedLen;\n if (item instanceof Point) return true;\n return false;\n }\n /**\n * ECDH (Elliptic Curve Diffie Hellman).\n * Computes shared public key from private key and public key.\n * Checks: 1) private key validity 2) shared key is on-curve.\n * Does NOT hash the result.\n * @param privateA private key\n * @param publicB different public key\n * @param isCompressed whether to return compact (default), or full key\n * @returns shared public key\n */\n function getSharedSecret(privateA, publicB, isCompressed = true) {\n if (isProbPub(privateA)) throw new Error('first arg must be private key');\n if (!isProbPub(publicB)) throw new Error('second arg must be public key');\n const b = Point.fromHex(publicB); // check for being on-curve\n return b.multiply(normPrivateKeyToScalar(privateA)).toRawBytes(isCompressed);\n }\n // RFC6979: ensure ECDSA msg is X bytes and < N. RFC suggests optional truncating via bits2octets.\n // FIPS 186-4 4.6 suggests the leftmost min(nBitLen, outLen) bits, which matches bits2int.\n // bits2int can produce res>N, we can do mod(res, N) since the bitLen is the same.\n // int2octets can't be used; pads small msgs with 0: unacceptatble for trunc as per RFC vectors\n const bits2int = CURVE.bits2int || function (bytes) {\n // For curves with nBitLength % 8 !== 0: bits2octets(bits2octets(m)) !== bits2octets(m)\n // for some cases, since bytes.length * 8 is not actual bitLength.\n const num = ut.bytesToNumberBE(bytes); // check for == u8 done here\n const delta = bytes.length * 8 - CURVE.nBitLength; // truncate to nBitLength leftmost bits\n return delta > 0 ? num >> BigInt(delta) : num;\n };\n const bits2int_modN = CURVE.bits2int_modN || function (bytes) {\n return modN(bits2int(bytes)); // can't use bytesToNumberBE here\n };\n // NOTE: pads output with zero as per spec\n const ORDER_MASK = ut.bitMask(CURVE.nBitLength);\n /**\n * Converts to bytes. Checks if num in `[0..ORDER_MASK-1]` e.g.: `[0..2^256-1]`.\n */\n function int2octets(num) {\n if (typeof num !== 'bigint') throw new Error('bigint expected');\n if (!(_0n <= num && num < ORDER_MASK)) throw new Error(`bigint expected < 2^${CURVE.nBitLength}`);\n // works with order, can have different size than numToField!\n return ut.numberToBytesBE(num, CURVE.nByteLength);\n }\n // Steps A, D of RFC6979 3.2\n // Creates RFC6979 seed; converts msg/privKey to numbers.\n // Used only in sign, not in verify.\n // NOTE: we cannot assume here that msgHash has same amount of bytes as curve order, this will be wrong at least for P521.\n // Also it can be bigger for P224 + SHA256\n function prepSig(msgHash, privateKey, opts = defaultSigOpts) {\n if (['recovered', 'canonical'].some(k => k in opts)) throw new Error('sign() legacy options not supported');\n const {\n hash,\n randomBytes\n } = CURVE;\n let {\n lowS,\n prehash,\n extraEntropy: ent\n } = opts; // generates low-s sigs by default\n if (lowS == null) lowS = true; // RFC6979 3.2: we skip step A, because we already provide hash\n msgHash = (0, utils_js_1.ensureBytes)('msgHash', msgHash);\n if (prehash) msgHash = (0, utils_js_1.ensureBytes)('prehashed msgHash', hash(msgHash));\n // We can't later call bits2octets, since nested bits2int is broken for curves\n // with nBitLength % 8 !== 0. Because of that, we unwrap it here as int2octets call.\n // const bits2octets = (bits) => int2octets(bits2int_modN(bits))\n const h1int = bits2int_modN(msgHash);\n const d = normPrivateKeyToScalar(privateKey); // validate private key, convert to bigint\n const seedArgs = [int2octets(d), int2octets(h1int)];\n // extraEntropy. RFC6979 3.6: additional k' (optional).\n if (ent != null && ent !== false) {\n // K = HMAC_K(V || 0x00 || int2octets(x) || bits2octets(h1) || k')\n const e = ent === true ? randomBytes(Fp.BYTES) : ent; // generate random bytes OR pass as-is\n seedArgs.push((0, utils_js_1.ensureBytes)('extraEntropy', e)); // check for being bytes\n }\n const seed = ut.concatBytes(...seedArgs); // Step D of RFC6979 3.2\n const m = h1int; // NOTE: no need to call bits2int second time here, it is inside truncateHash!\n // Converts signature params into point w r/s, checks result for validity.\n function k2sig(kBytes) {\n // RFC 6979 Section 3.2, step 3: k = bits2int(T)\n const k = bits2int(kBytes); // Cannot use fields methods, since it is group element\n if (!isWithinCurveOrder(k)) return; // Important: all mod() calls here must be done over N\n const ik = invN(k); // k^-1 mod n\n const q = Point.BASE.multiply(k).toAffine(); // q = Gk\n const r = modN(q.x); // r = q.x mod n\n if (r === _0n) return;\n // Can use scalar blinding b^-1(bm + bdr) where b ∈ [1,q−1] according to\n // https://tches.iacr.org/index.php/TCHES/article/view/7337/6509. We've decided against it:\n // a) dependency on CSPRNG b) 15% slowdown c) doesn't really help since bigints are not CT\n const s = modN(ik * modN(m + r * d)); // Not using blinding here\n if (s === _0n) return;\n let recovery = (q.x === r ? 0 : 2) | Number(q.y & _1n); // recovery bit (2 or 3, when q.x > n)\n let normS = s;\n if (lowS && isBiggerThanHalfOrder(s)) {\n normS = normalizeS(s); // if lowS was passed, ensure s is always\n recovery ^= 1; // // in the bottom half of N\n }\n return new Signature(r, normS, recovery); // use normS, not s\n }\n return {\n seed,\n k2sig\n };\n }\n const defaultSigOpts = {\n lowS: CURVE.lowS,\n prehash: false\n };\n const defaultVerOpts = {\n lowS: CURVE.lowS,\n prehash: false\n };\n /**\n * Signs message hash with a private key.\n * ```\n * sign(m, d, k) where\n * (x, y) = G × k\n * r = x mod n\n * s = (m + dr)/k mod n\n * ```\n * @param msgHash NOT message. msg needs to be hashed to `msgHash`, or use `prehash`.\n * @param privKey private key\n * @param opts lowS for non-malleable sigs. extraEntropy for mixing randomness into k. prehash will hash first arg.\n * @returns signature with recovery param\n */\n function sign(msgHash, privKey, opts = defaultSigOpts) {\n const {\n seed,\n k2sig\n } = prepSig(msgHash, privKey, opts); // Steps A, D of RFC6979 3.2.\n const C = CURVE;\n const drbg = ut.createHmacDrbg(C.hash.outputLen, C.nByteLength, C.hmac);\n return drbg(seed, k2sig); // Steps B, C, D, E, F, G\n }\n // Enable precomputes. Slows down first publicKey computation by 20ms.\n Point.BASE._setWindowSize(8);\n // utils.precompute(8, ProjectivePoint.BASE)\n /**\n * Verifies a signature against message hash and public key.\n * Rejects lowS signatures by default: to override,\n * specify option `{lowS: false}`. Implements section 4.1.4 from https://www.secg.org/sec1-v2.pdf:\n *\n * ```\n * verify(r, s, h, P) where\n * U1 = hs^-1 mod n\n * U2 = rs^-1 mod n\n * R = U1⋅G - U2⋅P\n * mod(R.x, n) == r\n * ```\n */\n function verify(signature, msgHash, publicKey, opts = defaultVerOpts) {\n const sg = signature;\n msgHash = (0, utils_js_1.ensureBytes)('msgHash', msgHash);\n publicKey = (0, utils_js_1.ensureBytes)('publicKey', publicKey);\n if ('strict' in opts) throw new Error('options.strict was renamed to lowS');\n const {\n lowS,\n prehash\n } = opts;\n let _sig = undefined;\n let P;\n try {\n if (typeof sg === 'string' || ut.isBytes(sg)) {\n // Signature can be represented in 2 ways: compact (2*nByteLength) & DER (variable-length).\n // Since DER can also be 2*nByteLength bytes, we check for it first.\n try {\n _sig = Signature.fromDER(sg);\n } catch (derError) {\n if (!(derError instanceof exports.DER.Err)) throw derError;\n _sig = Signature.fromCompact(sg);\n }\n } else if (typeof sg === 'object' && typeof sg.r === 'bigint' && typeof sg.s === 'bigint') {\n const {\n r,\n s\n } = sg;\n _sig = new Signature(r, s);\n } else {\n throw new Error('PARSE');\n }\n P = Point.fromHex(publicKey);\n } catch (error) {\n if (error.message === 'PARSE') throw new Error(`signature must be Signature instance, Uint8Array or hex string`);\n return false;\n }\n if (lowS && _sig.hasHighS()) return false;\n if (prehash) msgHash = CURVE.hash(msgHash);\n const {\n r,\n s\n } = _sig;\n const h = bits2int_modN(msgHash); // Cannot use fields methods, since it is group element\n const is = invN(s); // s^-1\n const u1 = modN(h * is); // u1 = hs^-1 mod n\n const u2 = modN(r * is); // u2 = rs^-1 mod n\n const R = Point.BASE.multiplyAndAddUnsafe(P, u1, u2)?.toAffine(); // R = u1⋅G + u2⋅P\n if (!R) return false;\n const v = modN(R.x);\n return v === r;\n }\n return {\n CURVE,\n getPublicKey,\n getSharedSecret,\n sign,\n verify,\n ProjectivePoint: Point,\n Signature,\n utils\n };\n}\n/**\n * Implementation of the Shallue and van de Woestijne method for any weierstrass curve.\n * TODO: check if there is a way to merge this with uvRatio in Edwards; move to modular.\n * b = True and y = sqrt(u / v) if (u / v) is square in F, and\n * b = False and y = sqrt(Z * (u / v)) otherwise.\n * @param Fp\n * @param Z\n * @returns\n */\nfunction SWUFpSqrtRatio(Fp, Z) {\n // Generic implementation\n const q = Fp.ORDER;\n let l = _0n;\n for (let o = q - _1n; o % _2n === _0n; o /= _2n) l += _1n;\n const c1 = l; // 1. c1, the largest integer such that 2^c1 divides q - 1.\n // We need 2n ** c1 and 2n ** (c1-1). We can't use **; but we can use <<.\n // 2n ** c1 == 2n << (c1-1)\n const _2n_pow_c1_1 = _2n << c1 - _1n - _1n;\n const _2n_pow_c1 = _2n_pow_c1_1 * _2n;\n const c2 = (q - _1n) / _2n_pow_c1; // 2. c2 = (q - 1) / (2^c1) # Integer arithmetic\n const c3 = (c2 - _1n) / _2n; // 3. c3 = (c2 - 1) / 2 # Integer arithmetic\n const c4 = _2n_pow_c1 - _1n; // 4. c4 = 2^c1 - 1 # Integer arithmetic\n const c5 = _2n_pow_c1_1; // 5. c5 = 2^(c1 - 1) # Integer arithmetic\n const c6 = Fp.pow(Z, c2); // 6. c6 = Z^c2\n const c7 = Fp.pow(Z, (c2 + _1n) / _2n); // 7. c7 = Z^((c2 + 1) / 2)\n let sqrtRatio = (u, v) => {\n let tv1 = c6; // 1. tv1 = c6\n let tv2 = Fp.pow(v, c4); // 2. tv2 = v^c4\n let tv3 = Fp.sqr(tv2); // 3. tv3 = tv2^2\n tv3 = Fp.mul(tv3, v); // 4. tv3 = tv3 * v\n let tv5 = Fp.mul(u, tv3); // 5. tv5 = u * tv3\n tv5 = Fp.pow(tv5, c3); // 6. tv5 = tv5^c3\n tv5 = Fp.mul(tv5, tv2); // 7. tv5 = tv5 * tv2\n tv2 = Fp.mul(tv5, v); // 8. tv2 = tv5 * v\n tv3 = Fp.mul(tv5, u); // 9. tv3 = tv5 * u\n let tv4 = Fp.mul(tv3, tv2); // 10. tv4 = tv3 * tv2\n tv5 = Fp.pow(tv4, c5); // 11. tv5 = tv4^c5\n let isQR = Fp.eql(tv5, Fp.ONE); // 12. isQR = tv5 == 1\n tv2 = Fp.mul(tv3, c7); // 13. tv2 = tv3 * c7\n tv5 = Fp.mul(tv4, tv1); // 14. tv5 = tv4 * tv1\n tv3 = Fp.cmov(tv2, tv3, isQR); // 15. tv3 = CMOV(tv2, tv3, isQR)\n tv4 = Fp.cmov(tv5, tv4, isQR); // 16. tv4 = CMOV(tv5, tv4, isQR)\n // 17. for i in (c1, c1 - 1, ..., 2):\n for (let i = c1; i > _1n; i--) {\n let tv5 = i - _2n; // 18. tv5 = i - 2\n tv5 = _2n << tv5 - _1n; // 19. tv5 = 2^tv5\n let tvv5 = Fp.pow(tv4, tv5); // 20. tv5 = tv4^tv5\n const e1 = Fp.eql(tvv5, Fp.ONE); // 21. e1 = tv5 == 1\n tv2 = Fp.mul(tv3, tv1); // 22. tv2 = tv3 * tv1\n tv1 = Fp.mul(tv1, tv1); // 23. tv1 = tv1 * tv1\n tvv5 = Fp.mul(tv4, tv1); // 24. tv5 = tv4 * tv1\n tv3 = Fp.cmov(tv2, tv3, e1); // 25. tv3 = CMOV(tv2, tv3, e1)\n tv4 = Fp.cmov(tvv5, tv4, e1); // 26. tv4 = CMOV(tv5, tv4, e1)\n }\n return {\n isValid: isQR,\n value: tv3\n };\n };\n if (Fp.ORDER % _4n === _3n) {\n // sqrt_ratio_3mod4(u, v)\n const c1 = (Fp.ORDER - _3n) / _4n; // 1. c1 = (q - 3) / 4 # Integer arithmetic\n const c2 = Fp.sqrt(Fp.neg(Z)); // 2. c2 = sqrt(-Z)\n sqrtRatio = (u, v) => {\n let tv1 = Fp.sqr(v); // 1. tv1 = v^2\n const tv2 = Fp.mul(u, v); // 2. tv2 = u * v\n tv1 = Fp.mul(tv1, tv2); // 3. tv1 = tv1 * tv2\n let y1 = Fp.pow(tv1, c1); // 4. y1 = tv1^c1\n y1 = Fp.mul(y1, tv2); // 5. y1 = y1 * tv2\n const y2 = Fp.mul(y1, c2); // 6. y2 = y1 * c2\n const tv3 = Fp.mul(Fp.sqr(y1), v); // 7. tv3 = y1^2; 8. tv3 = tv3 * v\n const isQR = Fp.eql(tv3, u); // 9. isQR = tv3 == u\n let y = Fp.cmov(y2, y1, isQR); // 10. y = CMOV(y2, y1, isQR)\n return {\n isValid: isQR,\n value: y\n }; // 11. return (isQR, y) isQR ? y : y*c2\n };\n }\n // No curves uses that\n // if (Fp.ORDER % _8n === _5n) // sqrt_ratio_5mod8\n return sqrtRatio;\n}\n/**\n * Simplified Shallue-van de Woestijne-Ulas Method\n * https://www.rfc-editor.org/rfc/rfc9380#section-6.6.2\n */\nfunction mapToCurveSimpleSWU(Fp, opts) {\n mod.validateField(Fp);\n if (!Fp.isValid(opts.A) || !Fp.isValid(opts.B) || !Fp.isValid(opts.Z)) throw new Error('mapToCurveSimpleSWU: invalid opts');\n const sqrtRatio = SWUFpSqrtRatio(Fp, opts.Z);\n if (!Fp.isOdd) throw new Error('Fp.isOdd is not implemented!');\n // Input: u, an element of F.\n // Output: (x, y), a point on E.\n return u => {\n // prettier-ignore\n let tv1, tv2, tv3, tv4, tv5, tv6, x, y;\n tv1 = Fp.sqr(u); // 1. tv1 = u^2\n tv1 = Fp.mul(tv1, opts.Z); // 2. tv1 = Z * tv1\n tv2 = Fp.sqr(tv1); // 3. tv2 = tv1^2\n tv2 = Fp.add(tv2, tv1); // 4. tv2 = tv2 + tv1\n tv3 = Fp.add(tv2, Fp.ONE); // 5. tv3 = tv2 + 1\n tv3 = Fp.mul(tv3, opts.B); // 6. tv3 = B * tv3\n tv4 = Fp.cmov(opts.Z, Fp.neg(tv2), !Fp.eql(tv2, Fp.ZERO)); // 7. tv4 = CMOV(Z, -tv2, tv2 != 0)\n tv4 = Fp.mul(tv4, opts.A); // 8. tv4 = A * tv4\n tv2 = Fp.sqr(tv3); // 9. tv2 = tv3^2\n tv6 = Fp.sqr(tv4); // 10. tv6 = tv4^2\n tv5 = Fp.mul(tv6, opts.A); // 11. tv5 = A * tv6\n tv2 = Fp.add(tv2, tv5); // 12. tv2 = tv2 + tv5\n tv2 = Fp.mul(tv2, tv3); // 13. tv2 = tv2 * tv3\n tv6 = Fp.mul(tv6, tv4); // 14. tv6 = tv6 * tv4\n tv5 = Fp.mul(tv6, opts.B); // 15. tv5 = B * tv6\n tv2 = Fp.add(tv2, tv5); // 16. tv2 = tv2 + tv5\n x = Fp.mul(tv1, tv3); // 17. x = tv1 * tv3\n const {\n isValid,\n value\n } = sqrtRatio(tv2, tv6); // 18. (is_gx1_square, y1) = sqrt_ratio(tv2, tv6)\n y = Fp.mul(tv1, u); // 19. y = tv1 * u -> Z * u^3 * y1\n y = Fp.mul(y, value); // 20. y = y * y1\n x = Fp.cmov(x, tv3, isValid); // 21. x = CMOV(x, tv3, is_gx1_square)\n y = Fp.cmov(y, value, isValid); // 22. y = CMOV(y, y1, is_gx1_square)\n const e1 = Fp.isOdd(u) === Fp.isOdd(y); // 23. e1 = sgn0(u) == sgn0(y)\n y = Fp.cmov(Fp.neg(y), y, e1); // 24. y = CMOV(-y, y, e1)\n x = Fp.div(x, tv4); // 25. x = x / tv4\n return {\n x,\n y\n };\n };\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getHash = getHash;\nexports.createCurve = createCurve;\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nconst hmac_1 = require(\"@noble/hashes/hmac\");\nconst utils_1 = require(\"@noble/hashes/utils\");\nconst weierstrass_js_1 = require(\"./abstract/weierstrass.js\");\n// connects noble-curves to noble-hashes\nfunction getHash(hash) {\n return {\n hash,\n hmac: (key, ...msgs) => (0, hmac_1.hmac)(hash, key, (0, utils_1.concatBytes)(...msgs)),\n randomBytes: utils_1.randomBytes\n };\n}\nfunction createCurve(curveDef, defHash) {\n const create = hash => (0, weierstrass_js_1.weierstrass)({\n ...curveDef,\n ...getHash(hash)\n });\n return Object.freeze({\n ...create(defHash),\n create\n });\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.expand_message_xmd = expand_message_xmd;\nexports.expand_message_xof = expand_message_xof;\nexports.hash_to_field = hash_to_field;\nexports.isogenyMap = isogenyMap;\nexports.createHasher = createHasher;\nconst modular_js_1 = require(\"./modular.js\");\nconst utils_js_1 = require(\"./utils.js\");\n// Octet Stream to Integer. \"spec\" implementation of os2ip is 2.5x slower vs bytesToNumberBE.\nconst os2ip = utils_js_1.bytesToNumberBE;\n// Integer to Octet Stream (numberToBytesBE)\nfunction i2osp(value, length) {\n if (value < 0 || value >= 1 << 8 * length) {\n throw new Error(`bad I2OSP call: value=${value} length=${length}`);\n }\n const res = Array.from({\n length\n }).fill(0);\n for (let i = length - 1; i >= 0; i--) {\n res[i] = value & 0xff;\n value >>>= 8;\n }\n return new Uint8Array(res);\n}\nfunction strxor(a, b) {\n const arr = new Uint8Array(a.length);\n for (let i = 0; i < a.length; i++) {\n arr[i] = a[i] ^ b[i];\n }\n return arr;\n}\nfunction anum(item) {\n if (!Number.isSafeInteger(item)) throw new Error('number expected');\n}\n// Produces a uniformly random byte string using a cryptographic hash function H that outputs b bits\n// https://www.rfc-editor.org/rfc/rfc9380#section-5.3.1\nfunction expand_message_xmd(msg, DST, lenInBytes, H) {\n (0, utils_js_1.abytes)(msg);\n (0, utils_js_1.abytes)(DST);\n anum(lenInBytes);\n // https://www.rfc-editor.org/rfc/rfc9380#section-5.3.3\n if (DST.length > 255) DST = H((0, utils_js_1.concatBytes)((0, utils_js_1.utf8ToBytes)('H2C-OVERSIZE-DST-'), DST));\n const {\n outputLen: b_in_bytes,\n blockLen: r_in_bytes\n } = H;\n const ell = Math.ceil(lenInBytes / b_in_bytes);\n if (ell > 255) throw new Error('Invalid xmd length');\n const DST_prime = (0, utils_js_1.concatBytes)(DST, i2osp(DST.length, 1));\n const Z_pad = i2osp(0, r_in_bytes);\n const l_i_b_str = i2osp(lenInBytes, 2); // len_in_bytes_str\n const b = new Array(ell);\n const b_0 = H((0, utils_js_1.concatBytes)(Z_pad, msg, l_i_b_str, i2osp(0, 1), DST_prime));\n b[0] = H((0, utils_js_1.concatBytes)(b_0, i2osp(1, 1), DST_prime));\n for (let i = 1; i <= ell; i++) {\n const args = [strxor(b_0, b[i - 1]), i2osp(i + 1, 1), DST_prime];\n b[i] = H((0, utils_js_1.concatBytes)(...args));\n }\n const pseudo_random_bytes = (0, utils_js_1.concatBytes)(...b);\n return pseudo_random_bytes.slice(0, lenInBytes);\n}\n// Produces a uniformly random byte string using an extendable-output function (XOF) H.\n// 1. The collision resistance of H MUST be at least k bits.\n// 2. H MUST be an XOF that has been proved indifferentiable from\n// a random oracle under a reasonable cryptographic assumption.\n// https://www.rfc-editor.org/rfc/rfc9380#section-5.3.2\nfunction expand_message_xof(msg, DST, lenInBytes, k, H) {\n (0, utils_js_1.abytes)(msg);\n (0, utils_js_1.abytes)(DST);\n anum(lenInBytes);\n // https://www.rfc-editor.org/rfc/rfc9380#section-5.3.3\n // DST = H('H2C-OVERSIZE-DST-' || a_very_long_DST, Math.ceil((lenInBytes * k) / 8));\n if (DST.length > 255) {\n const dkLen = Math.ceil(2 * k / 8);\n DST = H.create({\n dkLen\n }).update((0, utils_js_1.utf8ToBytes)('H2C-OVERSIZE-DST-')).update(DST).digest();\n }\n if (lenInBytes > 65535 || DST.length > 255) throw new Error('expand_message_xof: invalid lenInBytes');\n return H.create({\n dkLen: lenInBytes\n }).update(msg).update(i2osp(lenInBytes, 2))\n // 2. DST_prime = DST || I2OSP(len(DST), 1)\n .update(DST).update(i2osp(DST.length, 1)).digest();\n}\n/**\n * Hashes arbitrary-length byte strings to a list of one or more elements of a finite field F\n * https://www.rfc-editor.org/rfc/rfc9380#section-5.2\n * @param msg a byte string containing the message to hash\n * @param count the number of elements of F to output\n * @param options `{DST: string, p: bigint, m: number, k: number, expand: 'xmd' | 'xof', hash: H}`, see above\n * @returns [u_0, ..., u_(count - 1)], a list of field elements.\n */\nfunction hash_to_field(msg, count, options) {\n (0, utils_js_1.validateObject)(options, {\n DST: 'stringOrUint8Array',\n p: 'bigint',\n m: 'isSafeInteger',\n k: 'isSafeInteger',\n hash: 'hash'\n });\n const {\n p,\n k,\n m,\n hash,\n expand,\n DST: _DST\n } = options;\n (0, utils_js_1.abytes)(msg);\n anum(count);\n const DST = typeof _DST === 'string' ? (0, utils_js_1.utf8ToBytes)(_DST) : _DST;\n const log2p = p.toString(2).length;\n const L = Math.ceil((log2p + k) / 8); // section 5.1 of ietf draft link above\n const len_in_bytes = count * m * L;\n let prb; // pseudo_random_bytes\n if (expand === 'xmd') {\n prb = expand_message_xmd(msg, DST, len_in_bytes, hash);\n } else if (expand === 'xof') {\n prb = expand_message_xof(msg, DST, len_in_bytes, k, hash);\n } else if (expand === '_internal_pass') {\n // for internal tests only\n prb = msg;\n } else {\n throw new Error('expand must be \"xmd\" or \"xof\"');\n }\n const u = new Array(count);\n for (let i = 0; i < count; i++) {\n const e = new Array(m);\n for (let j = 0; j < m; j++) {\n const elm_offset = L * (j + i * m);\n const tv = prb.subarray(elm_offset, elm_offset + L);\n e[j] = (0, modular_js_1.mod)(os2ip(tv), p);\n }\n u[i] = e;\n }\n return u;\n}\nfunction isogenyMap(field, map) {\n // Make same order as in spec\n const COEFF = map.map(i => Array.from(i).reverse());\n return (x, y) => {\n const [xNum, xDen, yNum, yDen] = COEFF.map(val => val.reduce((acc, i) => field.add(field.mul(acc, x), i)));\n x = field.div(xNum, xDen); // xNum / xDen\n y = field.mul(y, field.div(yNum, yDen)); // y * (yNum / yDev)\n return {\n x,\n y\n };\n };\n}\nfunction createHasher(Point, mapToCurve, def) {\n if (typeof mapToCurve !== 'function') throw new Error('mapToCurve() must be defined');\n return {\n // Encodes byte string to elliptic curve.\n // hash_to_curve from https://www.rfc-editor.org/rfc/rfc9380#section-3\n hashToCurve(msg, options) {\n const u = hash_to_field(msg, 2, {\n ...def,\n DST: def.DST,\n ...options\n });\n const u0 = Point.fromAffine(mapToCurve(u[0]));\n const u1 = Point.fromAffine(mapToCurve(u[1]));\n const P = u0.add(u1).clearCofactor();\n P.assertValidity();\n return P;\n },\n // Encodes byte string to elliptic curve.\n // encode_to_curve from https://www.rfc-editor.org/rfc/rfc9380#section-3\n encodeToCurve(msg, options) {\n const u = hash_to_field(msg, 1, {\n ...def,\n DST: def.encodeDST,\n ...options\n });\n const P = Point.fromAffine(mapToCurve(u[0])).clearCofactor();\n P.assertValidity();\n return P;\n },\n // Same as encodeToCurve, but without hash\n mapToCurve(scalars) {\n if (!Array.isArray(scalars)) throw new Error('mapToCurve: expected array of bigints');\n for (const i of scalars) if (typeof i !== 'bigint') throw new Error(`mapToCurve: expected array of bigints, got ${i} in array`);\n const P = Point.fromAffine(mapToCurve(scalars)).clearCofactor();\n P.assertValidity();\n return P;\n }\n };\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.encodeToCurve = exports.hashToCurve = exports.schnorr = exports.secp256k1 = void 0;\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nconst sha256_1 = require(\"@noble/hashes/sha256\");\nconst utils_1 = require(\"@noble/hashes/utils\");\nconst _shortw_utils_js_1 = require(\"./_shortw_utils.js\");\nconst hash_to_curve_js_1 = require(\"./abstract/hash-to-curve.js\");\nconst modular_js_1 = require(\"./abstract/modular.js\");\nconst utils_js_1 = require(\"./abstract/utils.js\");\nconst weierstrass_js_1 = require(\"./abstract/weierstrass.js\");\nconst secp256k1P = BigInt('0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f');\nconst secp256k1N = BigInt('0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141');\nconst _1n = BigInt(1);\nconst _2n = BigInt(2);\nconst divNearest = (a, b) => (a + b / _2n) / b;\n/**\n * √n = n^((p+1)/4) for fields p = 3 mod 4. We unwrap the loop and multiply bit-by-bit.\n * (P+1n/4n).toString(2) would produce bits [223x 1, 0, 22x 1, 4x 0, 11, 00]\n */\nfunction sqrtMod(y) {\n const P = secp256k1P;\n // prettier-ignore\n const _3n = BigInt(3),\n _6n = BigInt(6),\n _11n = BigInt(11),\n _22n = BigInt(22);\n // prettier-ignore\n const _23n = BigInt(23),\n _44n = BigInt(44),\n _88n = BigInt(88);\n const b2 = y * y * y % P; // x^3, 11\n const b3 = b2 * b2 * y % P; // x^7\n const b6 = (0, modular_js_1.pow2)(b3, _3n, P) * b3 % P;\n const b9 = (0, modular_js_1.pow2)(b6, _3n, P) * b3 % P;\n const b11 = (0, modular_js_1.pow2)(b9, _2n, P) * b2 % P;\n const b22 = (0, modular_js_1.pow2)(b11, _11n, P) * b11 % P;\n const b44 = (0, modular_js_1.pow2)(b22, _22n, P) * b22 % P;\n const b88 = (0, modular_js_1.pow2)(b44, _44n, P) * b44 % P;\n const b176 = (0, modular_js_1.pow2)(b88, _88n, P) * b88 % P;\n const b220 = (0, modular_js_1.pow2)(b176, _44n, P) * b44 % P;\n const b223 = (0, modular_js_1.pow2)(b220, _3n, P) * b3 % P;\n const t1 = (0, modular_js_1.pow2)(b223, _23n, P) * b22 % P;\n const t2 = (0, modular_js_1.pow2)(t1, _6n, P) * b2 % P;\n const root = (0, modular_js_1.pow2)(t2, _2n, P);\n if (!Fp.eql(Fp.sqr(root), y)) throw new Error('Cannot find square root');\n return root;\n}\nconst Fp = (0, modular_js_1.Field)(secp256k1P, undefined, undefined, {\n sqrt: sqrtMod\n});\nexports.secp256k1 = (0, _shortw_utils_js_1.createCurve)({\n a: BigInt(0),\n // equation params: a, b\n b: BigInt(7),\n // Seem to be rigid: bitcointalk.org/index.php?topic=289795.msg3183975#msg3183975\n Fp,\n // Field's prime: 2n**256n - 2n**32n - 2n**9n - 2n**8n - 2n**7n - 2n**6n - 2n**4n - 1n\n n: secp256k1N,\n // Curve order, total count of valid points in the field\n // Base point (x, y) aka generator point\n Gx: BigInt('55066263022277343669578718895168534326250603453777594175500187360389116729240'),\n Gy: BigInt('32670510020758816978083085130507043184471273380659243275938904335757337482424'),\n h: BigInt(1),\n // Cofactor\n lowS: true,\n // Allow only low-S signatures by default in sign() and verify()\n /**\n * secp256k1 belongs to Koblitz curves: it has efficiently computable endomorphism.\n * Endomorphism uses 2x less RAM, speeds up precomputation by 2x and ECDH / key recovery by 20%.\n * For precomputed wNAF it trades off 1/2 init time & 1/3 ram for 20% perf hit.\n * Explanation: https://gist.github.com/paulmillr/eb670806793e84df628a7c434a873066\n */\n endo: {\n beta: BigInt('0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee'),\n splitScalar: k => {\n const n = secp256k1N;\n const a1 = BigInt('0x3086d221a7d46bcde86c90e49284eb15');\n const b1 = -_1n * BigInt('0xe4437ed6010e88286f547fa90abfe4c3');\n const a2 = BigInt('0x114ca50f7a8e2f3f657c1108d9d44cfd8');\n const b2 = a1;\n const POW_2_128 = BigInt('0x100000000000000000000000000000000'); // (2n**128n).toString(16)\n const c1 = divNearest(b2 * k, n);\n const c2 = divNearest(-b1 * k, n);\n let k1 = (0, modular_js_1.mod)(k - c1 * a1 - c2 * a2, n);\n let k2 = (0, modular_js_1.mod)(-c1 * b1 - c2 * b2, n);\n const k1neg = k1 > POW_2_128;\n const k2neg = k2 > POW_2_128;\n if (k1neg) k1 = n - k1;\n if (k2neg) k2 = n - k2;\n if (k1 > POW_2_128 || k2 > POW_2_128) {\n throw new Error('splitScalar: Endomorphism failed, k=' + k);\n }\n return {\n k1neg,\n k1,\n k2neg,\n k2\n };\n }\n }\n}, sha256_1.sha256);\n// Schnorr signatures are superior to ECDSA from above. Below is Schnorr-specific BIP0340 code.\n// https://github.com/bitcoin/bips/blob/master/bip-0340.mediawiki\nconst _0n = BigInt(0);\nconst fe = x => typeof x === 'bigint' && _0n < x && x < secp256k1P;\nconst ge = x => typeof x === 'bigint' && _0n < x && x < secp256k1N;\n/** An object mapping tags to their tagged hash prefix of [SHA256(tag) | SHA256(tag)] */\nconst TAGGED_HASH_PREFIXES = {};\nfunction taggedHash(tag, ...messages) {\n let tagP = TAGGED_HASH_PREFIXES[tag];\n if (tagP === undefined) {\n const tagH = (0, sha256_1.sha256)(Uint8Array.from(tag, c => c.charCodeAt(0)));\n tagP = (0, utils_js_1.concatBytes)(tagH, tagH);\n TAGGED_HASH_PREFIXES[tag] = tagP;\n }\n return (0, sha256_1.sha256)((0, utils_js_1.concatBytes)(tagP, ...messages));\n}\n// ECDSA compact points are 33-byte. Schnorr is 32: we strip first byte 0x02 or 0x03\nconst pointToBytes = point => point.toRawBytes(true).slice(1);\nconst numTo32b = n => (0, utils_js_1.numberToBytesBE)(n, 32);\nconst modP = x => (0, modular_js_1.mod)(x, secp256k1P);\nconst modN = x => (0, modular_js_1.mod)(x, secp256k1N);\nconst Point = exports.secp256k1.ProjectivePoint;\nconst GmulAdd = (Q, a, b) => Point.BASE.multiplyAndAddUnsafe(Q, a, b);\n// Calculate point, scalar and bytes\nfunction schnorrGetExtPubKey(priv) {\n let d_ = exports.secp256k1.utils.normPrivateKeyToScalar(priv); // same method executed in fromPrivateKey\n let p = Point.fromPrivateKey(d_); // P = d'⋅G; 0 < d' < n check is done inside\n const scalar = p.hasEvenY() ? d_ : modN(-d_);\n return {\n scalar: scalar,\n bytes: pointToBytes(p)\n };\n}\n/**\n * lift_x from BIP340. Convert 32-byte x coordinate to elliptic curve point.\n * @returns valid point checked for being on-curve\n */\nfunction lift_x(x) {\n if (!fe(x)) throw new Error('bad x: need 0 < x < p'); // Fail if x ≥ p.\n const xx = modP(x * x);\n const c = modP(xx * x + BigInt(7)); // Let c = x³ + 7 mod p.\n let y = sqrtMod(c); // Let y = c^(p+1)/4 mod p.\n if (y % _2n !== _0n) y = modP(-y); // Return the unique point P such that x(P) = x and\n const p = new Point(x, y, _1n); // y(P) = y if y mod 2 = 0 or y(P) = p-y otherwise.\n p.assertValidity();\n return p;\n}\n/**\n * Create tagged hash, convert it to bigint, reduce modulo-n.\n */\nfunction challenge(...args) {\n return modN((0, utils_js_1.bytesToNumberBE)(taggedHash('BIP0340/challenge', ...args)));\n}\n/**\n * Schnorr public key is just `x` coordinate of Point as per BIP340.\n */\nfunction schnorrGetPublicKey(privateKey) {\n return schnorrGetExtPubKey(privateKey).bytes; // d'=int(sk). Fail if d'=0 or d'≥n. Ret bytes(d'⋅G)\n}\n/**\n * Creates Schnorr signature as per BIP340. Verifies itself before returning anything.\n * auxRand is optional and is not the sole source of k generation: bad CSPRNG won't be dangerous.\n */\nfunction schnorrSign(message, privateKey, auxRand = (0, utils_1.randomBytes)(32)) {\n const m = (0, utils_js_1.ensureBytes)('message', message);\n const {\n bytes: px,\n scalar: d\n } = schnorrGetExtPubKey(privateKey); // checks for isWithinCurveOrder\n const a = (0, utils_js_1.ensureBytes)('auxRand', auxRand, 32); // Auxiliary random data a: a 32-byte array\n const t = numTo32b(d ^ (0, utils_js_1.bytesToNumberBE)(taggedHash('BIP0340/aux', a))); // Let t be the byte-wise xor of bytes(d) and hash/aux(a)\n const rand = taggedHash('BIP0340/nonce', t, px, m); // Let rand = hash/nonce(t || bytes(P) || m)\n const k_ = modN((0, utils_js_1.bytesToNumberBE)(rand)); // Let k' = int(rand) mod n\n if (k_ === _0n) throw new Error('sign failed: k is zero'); // Fail if k' = 0.\n const {\n bytes: rx,\n scalar: k\n } = schnorrGetExtPubKey(k_); // Let R = k'⋅G.\n const e = challenge(rx, px, m); // Let e = int(hash/challenge(bytes(R) || bytes(P) || m)) mod n.\n const sig = new Uint8Array(64); // Let sig = bytes(R) || bytes((k + ed) mod n).\n sig.set(rx, 0);\n sig.set(numTo32b(modN(k + e * d)), 32);\n // If Verify(bytes(P), m, sig) (see below) returns failure, abort\n if (!schnorrVerify(sig, m, px)) throw new Error('sign: Invalid signature produced');\n return sig;\n}\n/**\n * Verifies Schnorr signature.\n * Will swallow errors & return false except for initial type validation of arguments.\n */\nfunction schnorrVerify(signature, message, publicKey) {\n const sig = (0, utils_js_1.ensureBytes)('signature', signature, 64);\n const m = (0, utils_js_1.ensureBytes)('message', message);\n const pub = (0, utils_js_1.ensureBytes)('publicKey', publicKey, 32);\n try {\n const P = lift_x((0, utils_js_1.bytesToNumberBE)(pub)); // P = lift_x(int(pk)); fail if that fails\n const r = (0, utils_js_1.bytesToNumberBE)(sig.subarray(0, 32)); // Let r = int(sig[0:32]); fail if r ≥ p.\n if (!fe(r)) return false;\n const s = (0, utils_js_1.bytesToNumberBE)(sig.subarray(32, 64)); // Let s = int(sig[32:64]); fail if s ≥ n.\n if (!ge(s)) return false;\n const e = challenge(numTo32b(r), pointToBytes(P), m); // int(challenge(bytes(r)||bytes(P)||m))%n\n const R = GmulAdd(P, s, modN(-e)); // R = s⋅G - e⋅P\n if (!R || !R.hasEvenY() || R.toAffine().x !== r) return false; // -eP == (n-e)P\n return true; // Fail if is_infinite(R) / not has_even_y(R) / x(R) ≠ r.\n } catch (error) {\n return false;\n }\n}\nexports.schnorr = (() => ({\n getPublicKey: schnorrGetPublicKey,\n sign: schnorrSign,\n verify: schnorrVerify,\n utils: {\n randomPrivateKey: exports.secp256k1.utils.randomPrivateKey,\n lift_x,\n pointToBytes,\n numberToBytesBE: utils_js_1.numberToBytesBE,\n bytesToNumberBE: utils_js_1.bytesToNumberBE,\n taggedHash,\n mod: modular_js_1.mod\n }\n}))();\nconst isoMap = /* @__PURE__ */(() => (0, hash_to_curve_js_1.isogenyMap)(Fp, [\n// xNum\n['0x8e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38daaaaa8c7', '0x7d3d4c80bc321d5b9f315cea7fd44c5d595d2fc0bf63b92dfff1044f17c6581', '0x534c328d23f234e6e2a413deca25caece4506144037c40314ecbd0b53d9dd262', '0x8e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38e38daaaaa88c'],\n// xDen\n['0xd35771193d94918a9ca34ccbb7b640dd86cd409542f8487d9fe6b745781eb49b', '0xedadc6f64383dc1df7c4b2d51b54225406d36b641f5e41bbc52a56612a8c6d14', '0x0000000000000000000000000000000000000000000000000000000000000001' // LAST 1\n],\n// yNum\n['0x4bda12f684bda12f684bda12f684bda12f684bda12f684bda12f684b8e38e23c', '0xc75e0c32d5cb7c0fa9d0a54b12a0a6d5647ab046d686da6fdffc90fc201d71a3', '0x29a6194691f91a73715209ef6512e576722830a201be2018a765e85a9ecee931', '0x2f684bda12f684bda12f684bda12f684bda12f684bda12f684bda12f38e38d84'],\n// yDen\n['0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffff93b', '0x7a06534bb8bdb49fd5e9e6632722c2989467c1bfc8e8d978dfb425d2685c2573', '0x6484aa716545ca2cf3a70c3fa8fe337e0a3d21162f0d6299a7bf8192bfd2a76f', '0x0000000000000000000000000000000000000000000000000000000000000001' // LAST 1\n]].map(i => i.map(j => BigInt(j)))))();\nconst mapSWU = /* @__PURE__ */(() => (0, weierstrass_js_1.mapToCurveSimpleSWU)(Fp, {\n A: BigInt('0x3f8731abdd661adca08a5558f0f5d272e953d363cb6f0e5d405447c01a444533'),\n B: BigInt('1771'),\n Z: Fp.create(BigInt('-11'))\n}))();\nconst htf = /* @__PURE__ */(() => (0, hash_to_curve_js_1.createHasher)(exports.secp256k1.ProjectivePoint, scalars => {\n const {\n x,\n y\n } = mapSWU(Fp.create(scalars[0]));\n return isoMap(x, y);\n}, {\n DST: 'secp256k1_XMD:SHA-256_SSWU_RO_',\n encodeDST: 'secp256k1_XMD:SHA-256_SSWU_NU_',\n p: Fp.ORDER,\n m: 1,\n k: 128,\n expand: 'xmd',\n hash: sha256_1.sha256\n}))();\nexports.hashToCurve = (() => htf.hashToCurve)();\nexports.encodeToCurve = (() => htf.encodeToCurve)();\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.secp256k1 = void 0;\nvar secp256k1_1 = require(\"@noble/curves/secp256k1\");\nObject.defineProperty(exports, \"secp256k1\", {\n enumerable: true,\n get: function () {\n return secp256k1_1.secp256k1;\n }\n});","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.MAX_WITHDRAWALS_PER_PAYLOAD = exports.RLP_EMPTY_STRING = exports.KECCAK256_RLP = exports.KECCAK256_RLP_S = exports.KECCAK256_RLP_ARRAY = exports.KECCAK256_RLP_ARRAY_S = exports.KECCAK256_NULL = exports.KECCAK256_NULL_S = exports.TWO_POW256 = exports.SECP256K1_ORDER_DIV_2 = exports.SECP256K1_ORDER = exports.MAX_INTEGER_BIGINT = exports.MAX_INTEGER = exports.MAX_UINT64 = void 0;\nconst buffer_1 = require(\"buffer\");\nconst secp256k1_1 = require(\"ethereum-cryptography/secp256k1\");\n/**\n * 2^64-1\n */\nexports.MAX_UINT64 = BigInt('0xffffffffffffffff');\n/**\n * The max integer that the evm can handle (2^256-1)\n */\nexports.MAX_INTEGER = BigInt('0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff');\n/**\n * The max integer that the evm can handle (2^256-1) as a bigint\n * 2^256-1 equals to 340282366920938463463374607431768211455\n * We use literal value instead of calculated value for compatibility issue.\n */\nexports.MAX_INTEGER_BIGINT = BigInt('115792089237316195423570985008687907853269984665640564039457584007913129639935');\nexports.SECP256K1_ORDER = secp256k1_1.secp256k1.CURVE.n;\nexports.SECP256K1_ORDER_DIV_2 = secp256k1_1.secp256k1.CURVE.n / BigInt(2);\n/**\n * 2^256\n */\nexports.TWO_POW256 = BigInt('0x10000000000000000000000000000000000000000000000000000000000000000');\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL_S = 'c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470';\n/**\n * Keccak-256 hash of null\n */\nexports.KECCAK256_NULL = buffer_1.Buffer.from(exports.KECCAK256_NULL_S, 'hex');\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY_S = '1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347';\n/**\n * Keccak-256 of an RLP of an empty array\n */\nexports.KECCAK256_RLP_ARRAY = buffer_1.Buffer.from(exports.KECCAK256_RLP_ARRAY_S, 'hex');\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP_S = '56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421';\n/**\n * Keccak-256 hash of the RLP of null\n */\nexports.KECCAK256_RLP = buffer_1.Buffer.from(exports.KECCAK256_RLP_S, 'hex');\n/**\n * RLP encoded empty string\n */\nexports.RLP_EMPTY_STRING = buffer_1.Buffer.from([0x80]);\nexports.MAX_WITHDRAWALS_PER_PAYLOAD = 16;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.GWEI_TO_WEI = void 0;\n/** Easy conversion from Gwei to wei */\nexports.GWEI_TO_WEI = BigInt(1000000000);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RLP = exports.utils = exports.decode = exports.encode = void 0;\n/**\n * RLP Encoding based on https://ethereum.org/en/developers/docs/data-structures-and-encoding/rlp/\n * This function takes in data, converts it to Uint8Array if not,\n * and adds a length for recursion.\n * @param input Will be converted to Uint8Array\n * @returns Uint8Array of encoded data\n **/\nfunction encode(input) {\n if (Array.isArray(input)) {\n const output = [];\n let outputLength = 0;\n for (let i = 0; i < input.length; i++) {\n const encoded = encode(input[i]);\n output.push(encoded);\n outputLength += encoded.length;\n }\n return concatBytes(encodeLength(outputLength, 192), ...output);\n }\n const inputBuf = toBytes(input);\n if (inputBuf.length === 1 && inputBuf[0] < 128) {\n return inputBuf;\n }\n return concatBytes(encodeLength(inputBuf.length, 128), inputBuf);\n}\nexports.encode = encode;\n/**\n * Slices a Uint8Array, throws if the slice goes out-of-bounds of the Uint8Array.\n * E.g. `safeSlice(hexToBytes('aa'), 1, 2)` will throw.\n * @param input\n * @param start\n * @param end\n */\nfunction safeSlice(input, start, end) {\n if (end > input.length) {\n throw new Error('invalid RLP (safeSlice): end slice of Uint8Array out-of-bounds');\n }\n return input.slice(start, end);\n}\n/**\n * Parse integers. Check if there is no leading zeros\n * @param v The value to parse\n */\nfunction decodeLength(v) {\n if (v[0] === 0) {\n throw new Error('invalid RLP: extra zeros');\n }\n return parseHexByte(bytesToHex(v));\n}\nfunction encodeLength(len, offset) {\n if (len < 56) {\n return Uint8Array.from([len + offset]);\n }\n const hexLength = numberToHex(len);\n const lLength = hexLength.length / 2;\n const firstByte = numberToHex(offset + 55 + lLength);\n return Uint8Array.from(hexToBytes(firstByte + hexLength));\n}\nfunction decode(input, stream = false) {\n if (typeof input === 'undefined' || input === null || input.length === 0) {\n return Uint8Array.from([]);\n }\n const inputBytes = toBytes(input);\n const decoded = _decode(inputBytes);\n if (stream) {\n return decoded;\n }\n if (decoded.remainder.length !== 0) {\n throw new Error('invalid RLP: remainder must be zero');\n }\n return decoded.data;\n}\nexports.decode = decode;\n/** Decode an input with RLP */\nfunction _decode(input) {\n let length, llength, data, innerRemainder, d;\n const decoded = [];\n const firstByte = input[0];\n if (firstByte <= 0x7f) {\n // a single byte whose value is in the [0x00, 0x7f] range, that byte is its own RLP encoding.\n return {\n data: input.slice(0, 1),\n remainder: input.slice(1)\n };\n } else if (firstByte <= 0xb7) {\n // string is 0-55 bytes long. A single byte with value 0x80 plus the length of the string followed by the string\n // The range of the first byte is [0x80, 0xb7]\n length = firstByte - 0x7f;\n // set 0x80 null to 0\n if (firstByte === 0x80) {\n data = Uint8Array.from([]);\n } else {\n data = safeSlice(input, 1, length);\n }\n if (length === 2 && data[0] < 0x80) {\n throw new Error('invalid RLP encoding: invalid prefix, single byte < 0x80 are not prefixed');\n }\n return {\n data,\n remainder: input.slice(length)\n };\n } else if (firstByte <= 0xbf) {\n // string is greater than 55 bytes long. A single byte with the value (0xb7 plus the length of the length),\n // followed by the length, followed by the string\n llength = firstByte - 0xb6;\n if (input.length - 1 < llength) {\n throw new Error('invalid RLP: not enough bytes for string length');\n }\n length = decodeLength(safeSlice(input, 1, llength));\n if (length <= 55) {\n throw new Error('invalid RLP: expected string length to be greater than 55');\n }\n data = safeSlice(input, llength, length + llength);\n return {\n data,\n remainder: input.slice(length + llength)\n };\n } else if (firstByte <= 0xf7) {\n // a list between 0-55 bytes long\n length = firstByte - 0xbf;\n innerRemainder = safeSlice(input, 1, length);\n while (innerRemainder.length) {\n d = _decode(innerRemainder);\n decoded.push(d.data);\n innerRemainder = d.remainder;\n }\n return {\n data: decoded,\n remainder: input.slice(length)\n };\n } else {\n // a list over 55 bytes long\n llength = firstByte - 0xf6;\n length = decodeLength(safeSlice(input, 1, llength));\n if (length < 56) {\n throw new Error('invalid RLP: encoded list too short');\n }\n const totalLength = llength + length;\n if (totalLength > input.length) {\n throw new Error('invalid RLP: total length is larger than the data');\n }\n innerRemainder = safeSlice(input, llength, totalLength);\n while (innerRemainder.length) {\n d = _decode(innerRemainder);\n decoded.push(d.data);\n innerRemainder = d.remainder;\n }\n return {\n data: decoded,\n remainder: input.slice(totalLength)\n };\n }\n}\nconst cachedHexes = Array.from({\n length: 256\n}, (_v, i) => i.toString(16).padStart(2, '0'));\nfunction bytesToHex(uint8a) {\n // Pre-caching chars with `cachedHexes` speeds this up 6x\n let hex = '';\n for (let i = 0; i < uint8a.length; i++) {\n hex += cachedHexes[uint8a[i]];\n }\n return hex;\n}\nfunction parseHexByte(hexByte) {\n const byte = Number.parseInt(hexByte, 16);\n if (Number.isNaN(byte)) throw new Error('Invalid byte sequence');\n return byte;\n}\n// Caching slows it down 2-3x\nfunction hexToBytes(hex) {\n if (typeof hex !== 'string') {\n throw new TypeError('hexToBytes: expected string, got ' + typeof hex);\n }\n if (hex.length % 2) throw new Error('hexToBytes: received invalid unpadded hex');\n const array = new Uint8Array(hex.length / 2);\n for (let i = 0; i < array.length; i++) {\n const j = i * 2;\n array[i] = parseHexByte(hex.slice(j, j + 2));\n }\n return array;\n}\n/** Concatenates two Uint8Arrays into one. */\nfunction concatBytes(...arrays) {\n if (arrays.length === 1) return arrays[0];\n const length = arrays.reduce((a, arr) => a + arr.length, 0);\n const result = new Uint8Array(length);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const arr = arrays[i];\n result.set(arr, pad);\n pad += arr.length;\n }\n return result;\n}\nfunction utf8ToBytes(utf) {\n return new TextEncoder().encode(utf);\n}\n/** Transform an integer into its hexadecimal value */\nfunction numberToHex(integer) {\n if (integer < 0) {\n throw new Error('Invalid integer as argument, must be unsigned!');\n }\n const hex = integer.toString(16);\n return hex.length % 2 ? `0${hex}` : hex;\n}\n/** Pad a string to be even */\nfunction padToEven(a) {\n return a.length % 2 ? `0${a}` : a;\n}\n/** Check if a string is prefixed by 0x */\nfunction isHexPrefixed(str) {\n return str.length >= 2 && str[0] === '0' && str[1] === 'x';\n}\n/** Removes 0x from a given String */\nfunction stripHexPrefix(str) {\n if (typeof str !== 'string') {\n return str;\n }\n return isHexPrefixed(str) ? str.slice(2) : str;\n}\n/** Transform anything into a Uint8Array */\nfunction toBytes(v) {\n if (v instanceof Uint8Array) {\n return v;\n }\n if (typeof v === 'string') {\n if (isHexPrefixed(v)) {\n return hexToBytes(padToEven(stripHexPrefix(v)));\n }\n return utf8ToBytes(v);\n }\n if (typeof v === 'number' || typeof v === 'bigint') {\n if (!v) {\n return Uint8Array.from([]);\n }\n return hexToBytes(numberToHex(v));\n }\n if (v === null || v === undefined) {\n return Uint8Array.from([]);\n }\n throw new Error('toBytes: received unsupported type ' + typeof v);\n}\nexports.utils = {\n bytesToHex,\n concatBytes,\n hexToBytes,\n utf8ToBytes\n};\nexports.RLP = {\n encode,\n decode\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.output = exports.exists = exports.hash = exports.bytes = exports.bool = exports.number = exports.isBytes = void 0;\nfunction number(n) {\n if (!Number.isSafeInteger(n) || n < 0) throw new Error(`positive integer expected, not ${n}`);\n}\nexports.number = number;\nfunction bool(b) {\n if (typeof b !== 'boolean') throw new Error(`boolean expected, not ${b}`);\n}\nexports.bool = bool;\n// copied from utils\nfunction isBytes(a) {\n return a instanceof Uint8Array || a != null && typeof a === 'object' && a.constructor.name === 'Uint8Array';\n}\nexports.isBytes = isBytes;\nfunction bytes(b, ...lengths) {\n if (!isBytes(b)) throw new Error('Uint8Array expected');\n if (lengths.length > 0 && !lengths.includes(b.length)) throw new Error(`Uint8Array expected of length ${lengths}, not of length=${b.length}`);\n}\nexports.bytes = bytes;\nfunction hash(h) {\n if (typeof h !== 'function' || typeof h.create !== 'function') throw new Error('Hash should be wrapped by utils.wrapConstructor');\n number(h.outputLen);\n number(h.blockLen);\n}\nexports.hash = hash;\nfunction exists(instance, checkFinished = true) {\n if (instance.destroyed) throw new Error('Hash instance has been destroyed');\n if (checkFinished && instance.finished) throw new Error('Hash#digest() has already been called');\n}\nexports.exists = exists;\nfunction output(out, instance) {\n bytes(out);\n const min = instance.outputLen;\n if (out.length < min) {\n throw new Error(`digestInto() expects output buffer of length at least ${min}`);\n }\n}\nexports.output = output;\nconst assert = {\n number,\n bool,\n bytes,\n hash,\n exists,\n output\n};\nexports.default = assert;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.add5L = exports.add5H = exports.add4H = exports.add4L = exports.add3H = exports.add3L = exports.add = exports.rotlBL = exports.rotlBH = exports.rotlSL = exports.rotlSH = exports.rotr32L = exports.rotr32H = exports.rotrBL = exports.rotrBH = exports.rotrSL = exports.rotrSH = exports.shrSL = exports.shrSH = exports.toBig = exports.split = exports.fromBig = void 0;\nconst U32_MASK64 = /* @__PURE__ */BigInt(2 ** 32 - 1);\nconst _32n = /* @__PURE__ */BigInt(32);\n// We are not using BigUint64Array, because they are extremely slow as per 2022\nfunction fromBig(n, le = false) {\n if (le) return {\n h: Number(n & U32_MASK64),\n l: Number(n >> _32n & U32_MASK64)\n };\n return {\n h: Number(n >> _32n & U32_MASK64) | 0,\n l: Number(n & U32_MASK64) | 0\n };\n}\nexports.fromBig = fromBig;\nfunction split(lst, le = false) {\n let Ah = new Uint32Array(lst.length);\n let Al = new Uint32Array(lst.length);\n for (let i = 0; i < lst.length; i++) {\n const {\n h,\n l\n } = fromBig(lst[i], le);\n [Ah[i], Al[i]] = [h, l];\n }\n return [Ah, Al];\n}\nexports.split = split;\nconst toBig = (h, l) => BigInt(h >>> 0) << _32n | BigInt(l >>> 0);\nexports.toBig = toBig;\n// for Shift in [0, 32)\nconst shrSH = (h, _l, s) => h >>> s;\nexports.shrSH = shrSH;\nconst shrSL = (h, l, s) => h << 32 - s | l >>> s;\nexports.shrSL = shrSL;\n// Right rotate for Shift in [1, 32)\nconst rotrSH = (h, l, s) => h >>> s | l << 32 - s;\nexports.rotrSH = rotrSH;\nconst rotrSL = (h, l, s) => h << 32 - s | l >>> s;\nexports.rotrSL = rotrSL;\n// Right rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotrBH = (h, l, s) => h << 64 - s | l >>> s - 32;\nexports.rotrBH = rotrBH;\nconst rotrBL = (h, l, s) => h >>> s - 32 | l << 64 - s;\nexports.rotrBL = rotrBL;\n// Right rotate for shift===32 (just swaps l&h)\nconst rotr32H = (_h, l) => l;\nexports.rotr32H = rotr32H;\nconst rotr32L = (h, _l) => h;\nexports.rotr32L = rotr32L;\n// Left rotate for Shift in [1, 32)\nconst rotlSH = (h, l, s) => h << s | l >>> 32 - s;\nexports.rotlSH = rotlSH;\nconst rotlSL = (h, l, s) => l << s | h >>> 32 - s;\nexports.rotlSL = rotlSL;\n// Left rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotlBH = (h, l, s) => l << s - 32 | h >>> 64 - s;\nexports.rotlBH = rotlBH;\nconst rotlBL = (h, l, s) => h << s - 32 | l >>> 64 - s;\nexports.rotlBL = rotlBL;\n// JS uses 32-bit signed integers for bitwise operations which means we cannot\n// simple take carry out of low bit sum by shift, we need to use division.\nfunction add(Ah, Al, Bh, Bl) {\n const l = (Al >>> 0) + (Bl >>> 0);\n return {\n h: Ah + Bh + (l / 2 ** 32 | 0) | 0,\n l: l | 0\n };\n}\nexports.add = add;\n// Addition with more than 2 elements\nconst add3L = (Al, Bl, Cl) => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0);\nexports.add3L = add3L;\nconst add3H = (low, Ah, Bh, Ch) => Ah + Bh + Ch + (low / 2 ** 32 | 0) | 0;\nexports.add3H = add3H;\nconst add4L = (Al, Bl, Cl, Dl) => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0);\nexports.add4L = add4L;\nconst add4H = (low, Ah, Bh, Ch, Dh) => Ah + Bh + Ch + Dh + (low / 2 ** 32 | 0) | 0;\nexports.add4H = add4H;\nconst add5L = (Al, Bl, Cl, Dl, El) => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0) + (El >>> 0);\nexports.add5L = add5L;\nconst add5H = (low, Ah, Bh, Ch, Dh, Eh) => Ah + Bh + Ch + Dh + Eh + (low / 2 ** 32 | 0) | 0;\nexports.add5H = add5H;\n// prettier-ignore\nconst u64 = {\n fromBig,\n split,\n toBig,\n shrSH,\n shrSL,\n rotrSH,\n rotrSL,\n rotrBH,\n rotrBL,\n rotr32H,\n rotr32L,\n rotlSH,\n rotlSL,\n rotlBH,\n rotlBL,\n add,\n add3L,\n add3H,\n add4L,\n add4H,\n add5H,\n add5L\n};\nexports.default = u64;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.crypto = void 0;\nexports.crypto = typeof globalThis === 'object' && 'crypto' in globalThis ? globalThis.crypto : undefined;\n","\"use strict\";\n\n/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomBytes = exports.wrapXOFConstructorWithOpts = exports.wrapConstructorWithOpts = exports.wrapConstructor = exports.checkOpts = exports.Hash = exports.concatBytes = exports.toBytes = exports.utf8ToBytes = exports.asyncLoop = exports.nextTick = exports.hexToBytes = exports.bytesToHex = exports.byteSwap32 = exports.byteSwapIfBE = exports.byteSwap = exports.isLE = exports.rotl = exports.rotr = exports.createView = exports.u32 = exports.u8 = exports.isBytes = void 0;\n// We use WebCrypto aka globalThis.crypto, which exists in browsers and node.js 16+.\n// node.js versions earlier than v19 don't declare it in global scope.\n// For node.js, package.json#exports field mapping rewrites import\n// from `crypto` to `cryptoNode`, which imports native module.\n// Makes the utils un-importable in browsers without a bundler.\n// Once node.js 18 is deprecated (2025-04-30), we can just drop the import.\nconst crypto_1 = require(\"@noble/hashes/crypto\");\nconst _assert_js_1 = require(\"./_assert.js\");\n// export { isBytes } from './_assert.js';\n// We can't reuse isBytes from _assert, because somehow this causes huge perf issues\nfunction isBytes(a) {\n return a instanceof Uint8Array || a != null && typeof a === 'object' && a.constructor.name === 'Uint8Array';\n}\nexports.isBytes = isBytes;\n// Cast array to different type\nconst u8 = arr => new Uint8Array(arr.buffer, arr.byteOffset, arr.byteLength);\nexports.u8 = u8;\nconst u32 = arr => new Uint32Array(arr.buffer, arr.byteOffset, Math.floor(arr.byteLength / 4));\nexports.u32 = u32;\n// Cast array to view\nconst createView = arr => new DataView(arr.buffer, arr.byteOffset, arr.byteLength);\nexports.createView = createView;\n// The rotate right (circular right shift) operation for uint32\nconst rotr = (word, shift) => word << 32 - shift | word >>> shift;\nexports.rotr = rotr;\n// The rotate left (circular left shift) operation for uint32\nconst rotl = (word, shift) => word << shift | word >>> 32 - shift >>> 0;\nexports.rotl = rotl;\nexports.isLE = new Uint8Array(new Uint32Array([0x11223344]).buffer)[0] === 0x44;\n// The byte swap operation for uint32\nconst byteSwap = word => word << 24 & 0xff000000 | word << 8 & 0xff0000 | word >>> 8 & 0xff00 | word >>> 24 & 0xff;\nexports.byteSwap = byteSwap;\n// Conditionally byte swap if on a big-endian platform\nexports.byteSwapIfBE = exports.isLE ? n => n : n => (0, exports.byteSwap)(n);\n// In place byte swap for Uint32Array\nfunction byteSwap32(arr) {\n for (let i = 0; i < arr.length; i++) {\n arr[i] = (0, exports.byteSwap)(arr[i]);\n }\n}\nexports.byteSwap32 = byteSwap32;\n// Array where index 0xf0 (240) is mapped to string 'f0'\nconst hexes = /* @__PURE__ */Array.from({\n length: 256\n}, (_, i) => i.toString(16).padStart(2, '0'));\n/**\n * @example bytesToHex(Uint8Array.from([0xca, 0xfe, 0x01, 0x23])) // 'cafe0123'\n */\nfunction bytesToHex(bytes) {\n (0, _assert_js_1.bytes)(bytes);\n // pre-caching improves the speed 6x\n let hex = '';\n for (let i = 0; i < bytes.length; i++) {\n hex += hexes[bytes[i]];\n }\n return hex;\n}\nexports.bytesToHex = bytesToHex;\n// We use optimized technique to convert hex string to byte array\nconst asciis = {\n _0: 48,\n _9: 57,\n _A: 65,\n _F: 70,\n _a: 97,\n _f: 102\n};\nfunction asciiToBase16(char) {\n if (char >= asciis._0 && char <= asciis._9) return char - asciis._0;\n if (char >= asciis._A && char <= asciis._F) return char - (asciis._A - 10);\n if (char >= asciis._a && char <= asciis._f) return char - (asciis._a - 10);\n return;\n}\n/**\n * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])\n */\nfunction hexToBytes(hex) {\n if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);\n const hl = hex.length;\n const al = hl / 2;\n if (hl % 2) throw new Error('padded hex string expected, got unpadded hex of length ' + hl);\n const array = new Uint8Array(al);\n for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {\n const n1 = asciiToBase16(hex.charCodeAt(hi));\n const n2 = asciiToBase16(hex.charCodeAt(hi + 1));\n if (n1 === undefined || n2 === undefined) {\n const char = hex[hi] + hex[hi + 1];\n throw new Error('hex string expected, got non-hex character \"' + char + '\" at index ' + hi);\n }\n array[ai] = n1 * 16 + n2;\n }\n return array;\n}\nexports.hexToBytes = hexToBytes;\n// There is no setImmediate in browser and setTimeout is slow.\n// call of async fn will return Promise, which will be fullfiled only on\n// next scheduler queue processing step and this is exactly what we need.\nconst nextTick = async () => {};\nexports.nextTick = nextTick;\n// Returns control to thread each 'tick' ms to avoid blocking\nasync function asyncLoop(iters, tick, cb) {\n let ts = Date.now();\n for (let i = 0; i < iters; i++) {\n cb(i);\n // Date.now() is not monotonic, so in case if clock goes backwards we return return control too\n const diff = Date.now() - ts;\n if (diff >= 0 && diff < tick) continue;\n await (0, exports.nextTick)();\n ts += diff;\n }\n}\nexports.asyncLoop = asyncLoop;\n/**\n * @example utf8ToBytes('abc') // new Uint8Array([97, 98, 99])\n */\nfunction utf8ToBytes(str) {\n if (typeof str !== 'string') throw new Error(`utf8ToBytes expected string, got ${typeof str}`);\n return new Uint8Array(new TextEncoder().encode(str)); // https://bugzil.la/1681809\n}\nexports.utf8ToBytes = utf8ToBytes;\n/**\n * Normalizes (non-hex) string or Uint8Array to Uint8Array.\n * Warning: when Uint8Array is passed, it would NOT get copied.\n * Keep in mind for future mutable operations.\n */\nfunction toBytes(data) {\n if (typeof data === 'string') data = utf8ToBytes(data);\n (0, _assert_js_1.bytes)(data);\n return data;\n}\nexports.toBytes = toBytes;\n/**\n * Copies several Uint8Arrays into one.\n */\nfunction concatBytes(...arrays) {\n let sum = 0;\n for (let i = 0; i < arrays.length; i++) {\n const a = arrays[i];\n (0, _assert_js_1.bytes)(a);\n sum += a.length;\n }\n const res = new Uint8Array(sum);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const a = arrays[i];\n res.set(a, pad);\n pad += a.length;\n }\n return res;\n}\nexports.concatBytes = concatBytes;\n// For runtime check if class implements interface\nclass Hash {\n // Safe version that clones internal state\n clone() {\n return this._cloneInto();\n }\n}\nexports.Hash = Hash;\nconst toStr = {}.toString;\nfunction checkOpts(defaults, opts) {\n if (opts !== undefined && toStr.call(opts) !== '[object Object]') throw new Error('Options should be object or undefined');\n const merged = Object.assign(defaults, opts);\n return merged;\n}\nexports.checkOpts = checkOpts;\nfunction wrapConstructor(hashCons) {\n const hashC = msg => hashCons().update(toBytes(msg)).digest();\n const tmp = hashCons();\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = () => hashCons();\n return hashC;\n}\nexports.wrapConstructor = wrapConstructor;\nfunction wrapConstructorWithOpts(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = opts => hashCons(opts);\n return hashC;\n}\nexports.wrapConstructorWithOpts = wrapConstructorWithOpts;\nfunction wrapXOFConstructorWithOpts(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = opts => hashCons(opts);\n return hashC;\n}\nexports.wrapXOFConstructorWithOpts = wrapXOFConstructorWithOpts;\n/**\n * Secure PRNG. Uses `crypto.getRandomValues`, which defers to OS.\n */\nfunction randomBytes(bytesLength = 32) {\n if (crypto_1.crypto && typeof crypto_1.crypto.getRandomValues === 'function') {\n return crypto_1.crypto.getRandomValues(new Uint8Array(bytesLength));\n }\n throw new Error('crypto.getRandomValues must be defined');\n}\nexports.randomBytes = randomBytes;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.shake256 = exports.shake128 = exports.keccak_512 = exports.keccak_384 = exports.keccak_256 = exports.keccak_224 = exports.sha3_512 = exports.sha3_384 = exports.sha3_256 = exports.sha3_224 = exports.Keccak = exports.keccakP = void 0;\nconst _assert_js_1 = require(\"./_assert.js\");\nconst _u64_js_1 = require(\"./_u64.js\");\nconst utils_js_1 = require(\"./utils.js\");\n// SHA3 (keccak) is based on a new design: basically, the internal state is bigger than output size.\n// It's called a sponge function.\n// Various per round constants calculations\nconst SHA3_PI = [];\nconst SHA3_ROTL = [];\nconst _SHA3_IOTA = [];\nconst _0n = /* @__PURE__ */BigInt(0);\nconst _1n = /* @__PURE__ */BigInt(1);\nconst _2n = /* @__PURE__ */BigInt(2);\nconst _7n = /* @__PURE__ */BigInt(7);\nconst _256n = /* @__PURE__ */BigInt(256);\nconst _0x71n = /* @__PURE__ */BigInt(0x71);\nfor (let round = 0, R = _1n, x = 1, y = 0; round < 24; round++) {\n // Pi\n [x, y] = [y, (2 * x + 3 * y) % 5];\n SHA3_PI.push(2 * (5 * y + x));\n // Rotational\n SHA3_ROTL.push((round + 1) * (round + 2) / 2 % 64);\n // Iota\n let t = _0n;\n for (let j = 0; j < 7; j++) {\n R = (R << _1n ^ (R >> _7n) * _0x71n) % _256n;\n if (R & _2n) t ^= _1n << (_1n << /* @__PURE__ */BigInt(j)) - _1n;\n }\n _SHA3_IOTA.push(t);\n}\nconst [SHA3_IOTA_H, SHA3_IOTA_L] = /* @__PURE__ */(0, _u64_js_1.split)(_SHA3_IOTA, true);\n// Left rotation (without 0, 32, 64)\nconst rotlH = (h, l, s) => s > 32 ? (0, _u64_js_1.rotlBH)(h, l, s) : (0, _u64_js_1.rotlSH)(h, l, s);\nconst rotlL = (h, l, s) => s > 32 ? (0, _u64_js_1.rotlBL)(h, l, s) : (0, _u64_js_1.rotlSL)(h, l, s);\n// Same as keccakf1600, but allows to skip some rounds\nfunction keccakP(s, rounds = 24) {\n const B = new Uint32Array(5 * 2);\n // NOTE: all indices are x2 since we store state as u32 instead of u64 (bigints to slow in js)\n for (let round = 24 - rounds; round < 24; round++) {\n // Theta θ\n for (let x = 0; x < 10; x++) B[x] = s[x] ^ s[x + 10] ^ s[x + 20] ^ s[x + 30] ^ s[x + 40];\n for (let x = 0; x < 10; x += 2) {\n const idx1 = (x + 8) % 10;\n const idx0 = (x + 2) % 10;\n const B0 = B[idx0];\n const B1 = B[idx0 + 1];\n const Th = rotlH(B0, B1, 1) ^ B[idx1];\n const Tl = rotlL(B0, B1, 1) ^ B[idx1 + 1];\n for (let y = 0; y < 50; y += 10) {\n s[x + y] ^= Th;\n s[x + y + 1] ^= Tl;\n }\n }\n // Rho (ρ) and Pi (π)\n let curH = s[2];\n let curL = s[3];\n for (let t = 0; t < 24; t++) {\n const shift = SHA3_ROTL[t];\n const Th = rotlH(curH, curL, shift);\n const Tl = rotlL(curH, curL, shift);\n const PI = SHA3_PI[t];\n curH = s[PI];\n curL = s[PI + 1];\n s[PI] = Th;\n s[PI + 1] = Tl;\n }\n // Chi (χ)\n for (let y = 0; y < 50; y += 10) {\n for (let x = 0; x < 10; x++) B[x] = s[y + x];\n for (let x = 0; x < 10; x++) s[y + x] ^= ~B[(x + 2) % 10] & B[(x + 4) % 10];\n }\n // Iota (ι)\n s[0] ^= SHA3_IOTA_H[round];\n s[1] ^= SHA3_IOTA_L[round];\n }\n B.fill(0);\n}\nexports.keccakP = keccakP;\nclass Keccak extends utils_js_1.Hash {\n // NOTE: we accept arguments in bytes instead of bits here.\n constructor(blockLen, suffix, outputLen, enableXOF = false, rounds = 24) {\n super();\n this.blockLen = blockLen;\n this.suffix = suffix;\n this.outputLen = outputLen;\n this.enableXOF = enableXOF;\n this.rounds = rounds;\n this.pos = 0;\n this.posOut = 0;\n this.finished = false;\n this.destroyed = false;\n // Can be passed from user as dkLen\n (0, _assert_js_1.number)(outputLen);\n // 1600 = 5x5 matrix of 64bit. 1600 bits === 200 bytes\n if (0 >= this.blockLen || this.blockLen >= 200) throw new Error('Sha3 supports only keccak-f1600 function');\n this.state = new Uint8Array(200);\n this.state32 = (0, utils_js_1.u32)(this.state);\n }\n keccak() {\n if (!utils_js_1.isLE) (0, utils_js_1.byteSwap32)(this.state32);\n keccakP(this.state32, this.rounds);\n if (!utils_js_1.isLE) (0, utils_js_1.byteSwap32)(this.state32);\n this.posOut = 0;\n this.pos = 0;\n }\n update(data) {\n (0, _assert_js_1.exists)(this);\n const {\n blockLen,\n state\n } = this;\n data = (0, utils_js_1.toBytes)(data);\n const len = data.length;\n for (let pos = 0; pos < len;) {\n const take = Math.min(blockLen - this.pos, len - pos);\n for (let i = 0; i < take; i++) state[this.pos++] ^= data[pos++];\n if (this.pos === blockLen) this.keccak();\n }\n return this;\n }\n finish() {\n if (this.finished) return;\n this.finished = true;\n const {\n state,\n suffix,\n pos,\n blockLen\n } = this;\n // Do the padding\n state[pos] ^= suffix;\n if ((suffix & 0x80) !== 0 && pos === blockLen - 1) this.keccak();\n state[blockLen - 1] ^= 0x80;\n this.keccak();\n }\n writeInto(out) {\n (0, _assert_js_1.exists)(this, false);\n (0, _assert_js_1.bytes)(out);\n this.finish();\n const bufferOut = this.state;\n const {\n blockLen\n } = this;\n for (let pos = 0, len = out.length; pos < len;) {\n if (this.posOut >= blockLen) this.keccak();\n const take = Math.min(blockLen - this.posOut, len - pos);\n out.set(bufferOut.subarray(this.posOut, this.posOut + take), pos);\n this.posOut += take;\n pos += take;\n }\n return out;\n }\n xofInto(out) {\n // Sha3/Keccak usage with XOF is probably mistake, only SHAKE instances can do XOF\n if (!this.enableXOF) throw new Error('XOF is not possible for this instance');\n return this.writeInto(out);\n }\n xof(bytes) {\n (0, _assert_js_1.number)(bytes);\n return this.xofInto(new Uint8Array(bytes));\n }\n digestInto(out) {\n (0, _assert_js_1.output)(out, this);\n if (this.finished) throw new Error('digest() was already called');\n this.writeInto(out);\n this.destroy();\n return out;\n }\n digest() {\n return this.digestInto(new Uint8Array(this.outputLen));\n }\n destroy() {\n this.destroyed = true;\n this.state.fill(0);\n }\n _cloneInto(to) {\n const {\n blockLen,\n suffix,\n outputLen,\n rounds,\n enableXOF\n } = this;\n to || (to = new Keccak(blockLen, suffix, outputLen, enableXOF, rounds));\n to.state32.set(this.state32);\n to.pos = this.pos;\n to.posOut = this.posOut;\n to.finished = this.finished;\n to.rounds = rounds;\n // Suffix can change in cSHAKE\n to.suffix = suffix;\n to.outputLen = outputLen;\n to.enableXOF = enableXOF;\n to.destroyed = this.destroyed;\n return to;\n }\n}\nexports.Keccak = Keccak;\nconst gen = (suffix, blockLen, outputLen) => (0, utils_js_1.wrapConstructor)(() => new Keccak(blockLen, suffix, outputLen));\nexports.sha3_224 = gen(0x06, 144, 224 / 8);\n/**\n * SHA3-256 hash function\n * @param message - that would be hashed\n */\nexports.sha3_256 = gen(0x06, 136, 256 / 8);\nexports.sha3_384 = gen(0x06, 104, 384 / 8);\nexports.sha3_512 = gen(0x06, 72, 512 / 8);\nexports.keccak_224 = gen(0x01, 144, 224 / 8);\n/**\n * keccak-256 hash function. Different from SHA3-256.\n * @param message - that would be hashed\n */\nexports.keccak_256 = gen(0x01, 136, 256 / 8);\nexports.keccak_384 = gen(0x01, 104, 384 / 8);\nexports.keccak_512 = gen(0x01, 72, 512 / 8);\nconst genShake = (suffix, blockLen, outputLen) => (0, utils_js_1.wrapXOFConstructorWithOpts)((opts = {}) => new Keccak(blockLen, suffix, opts.dkLen === undefined ? outputLen : opts.dkLen, true));\nexports.shake128 = genShake(0x1f, 168, 128 / 8);\nexports.shake256 = genShake(0x1f, 136, 256 / 8);\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.crypto = exports.utf8ToBytes = exports.createView = exports.concatBytes = exports.toHex = exports.bytesToHex = exports.assertBytes = exports.assertBool = void 0;\nexports.bytesToUtf8 = bytesToUtf8;\nexports.hexToBytes = hexToBytes;\nexports.equalsBytes = equalsBytes;\nexports.wrapHash = wrapHash;\nconst _assert_1 = __importDefault(require(\"@noble/hashes/_assert\"));\nconst utils_1 = require(\"@noble/hashes/utils\");\nconst assertBool = _assert_1.default.bool;\nexports.assertBool = assertBool;\nconst assertBytes = _assert_1.default.bytes;\nexports.assertBytes = assertBytes;\nvar utils_2 = require(\"@noble/hashes/utils\");\nObject.defineProperty(exports, \"bytesToHex\", {\n enumerable: true,\n get: function () {\n return utils_2.bytesToHex;\n }\n});\nObject.defineProperty(exports, \"toHex\", {\n enumerable: true,\n get: function () {\n return utils_2.bytesToHex;\n }\n});\nObject.defineProperty(exports, \"concatBytes\", {\n enumerable: true,\n get: function () {\n return utils_2.concatBytes;\n }\n});\nObject.defineProperty(exports, \"createView\", {\n enumerable: true,\n get: function () {\n return utils_2.createView;\n }\n});\nObject.defineProperty(exports, \"utf8ToBytes\", {\n enumerable: true,\n get: function () {\n return utils_2.utf8ToBytes;\n }\n});\n// buf.toString('utf8') -> bytesToUtf8(buf)\nfunction bytesToUtf8(data) {\n if (!(data instanceof Uint8Array)) {\n throw new TypeError(`bytesToUtf8 expected Uint8Array, got ${typeof data}`);\n }\n return new TextDecoder().decode(data);\n}\nfunction hexToBytes(data) {\n const sliced = data.startsWith(\"0x\") ? data.substring(2) : data;\n return (0, utils_1.hexToBytes)(sliced);\n}\n// buf.equals(buf2) -> equalsBytes(buf, buf2)\nfunction equalsBytes(a, b) {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n return true;\n}\n// Internal utils\nfunction wrapHash(hash) {\n return msg => {\n _assert_1.default.bytes(msg);\n return hash(msg);\n };\n}\n// TODO(v3): switch away from node crypto, remove this unnecessary variable.\nexports.crypto = (() => {\n const webCrypto = typeof globalThis === \"object\" && \"crypto\" in globalThis ? globalThis.crypto : undefined;\n const nodeRequire = typeof module !== \"undefined\" && typeof module.require === \"function\" && module.require.bind(module);\n return {\n node: nodeRequire && !webCrypto ? nodeRequire(\"crypto\") : undefined,\n web: webCrypto\n };\n})();","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.keccak512 = exports.keccak384 = exports.keccak256 = exports.keccak224 = void 0;\nconst sha3_1 = require(\"@noble/hashes/sha3\");\nconst utils_js_1 = require(\"./utils.js\");\nexports.keccak224 = (0, utils_js_1.wrapHash)(sha3_1.keccak_224);\nexports.keccak256 = (() => {\n const k = (0, utils_js_1.wrapHash)(sha3_1.keccak_256);\n k.create = sha3_1.keccak_256.create;\n return k;\n})();\nexports.keccak384 = (0, utils_js_1.wrapHash)(sha3_1.keccak_384);\nexports.keccak512 = (0, utils_js_1.wrapHash)(sha3_1.keccak_512);","\"use strict\";\n\n/*\nThe MIT License\n\nCopyright (c) 2016 Nick Dodson. nickdodson.com\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE\n */\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isHexString = exports.getKeys = exports.fromAscii = exports.fromUtf8 = exports.toAscii = exports.arrayContainsArray = exports.getBinarySize = exports.padToEven = exports.stripHexPrefix = exports.isHexPrefixed = void 0;\n/**\n * Returns a `Boolean` on whether or not the a `String` starts with '0x'\n * @param str the string input value\n * @return a boolean if it is or is not hex prefixed\n * @throws if the str input is not a string\n */\nfunction isHexPrefixed(str) {\n if (typeof str !== 'string') {\n throw new Error(`[isHexPrefixed] input must be type 'string', received type ${typeof str}`);\n }\n return str[0] === '0' && str[1] === 'x';\n}\nexports.isHexPrefixed = isHexPrefixed;\n/**\n * Removes '0x' from a given `String` if present\n * @param str the string value\n * @returns the string without 0x prefix\n */\nconst stripHexPrefix = str => {\n if (typeof str !== 'string') throw new Error(`[stripHexPrefix] input must be type 'string', received ${typeof str}`);\n return isHexPrefixed(str) ? str.slice(2) : str;\n};\nexports.stripHexPrefix = stripHexPrefix;\n/**\n * Pads a `String` to have an even length\n * @param value\n * @return output\n */\nfunction padToEven(value) {\n let a = value;\n if (typeof a !== 'string') {\n throw new Error(`[padToEven] value must be type 'string', received ${typeof a}`);\n }\n if (a.length % 2) a = `0${a}`;\n return a;\n}\nexports.padToEven = padToEven;\n/**\n * Get the binary size of a string\n * @param str\n * @returns the number of bytes contained within the string\n */\nfunction getBinarySize(str) {\n if (typeof str !== 'string') {\n throw new Error(`[getBinarySize] method requires input type 'string', received ${typeof str}`);\n }\n return Buffer.byteLength(str, 'utf8');\n}\nexports.getBinarySize = getBinarySize;\n/**\n * Returns TRUE if the first specified array contains all elements\n * from the second one. FALSE otherwise.\n *\n * @param superset\n * @param subset\n *\n */\nfunction arrayContainsArray(superset, subset, some) {\n if (Array.isArray(superset) !== true) {\n throw new Error(`[arrayContainsArray] method requires input 'superset' to be an array, got type '${typeof superset}'`);\n }\n if (Array.isArray(subset) !== true) {\n throw new Error(`[arrayContainsArray] method requires input 'subset' to be an array, got type '${typeof subset}'`);\n }\n return subset[some === true ? 'some' : 'every'](value => superset.indexOf(value) >= 0);\n}\nexports.arrayContainsArray = arrayContainsArray;\n/**\n * Should be called to get ascii from its hex representation\n *\n * @param string in hex\n * @returns ascii string representation of hex value\n */\nfunction toAscii(hex) {\n let str = '';\n let i = 0;\n const l = hex.length;\n if (hex.substring(0, 2) === '0x') i = 2;\n for (; i < l; i += 2) {\n const code = parseInt(hex.substr(i, 2), 16);\n str += String.fromCharCode(code);\n }\n return str;\n}\nexports.toAscii = toAscii;\n/**\n * Should be called to get hex representation (prefixed by 0x) of utf8 string\n *\n * @param string\n * @param optional padding\n * @returns hex representation of input string\n */\nfunction fromUtf8(stringValue) {\n const str = Buffer.from(stringValue, 'utf8');\n return `0x${padToEven(str.toString('hex')).replace(/^0+|0+$/g, '')}`;\n}\nexports.fromUtf8 = fromUtf8;\n/**\n * Should be called to get hex representation (prefixed by 0x) of ascii string\n *\n * @param string\n * @param optional padding\n * @returns hex representation of input string\n */\nfunction fromAscii(stringValue) {\n let hex = '';\n for (let i = 0; i < stringValue.length; i++) {\n const code = stringValue.charCodeAt(i);\n const n = code.toString(16);\n hex += n.length < 2 ? `0${n}` : n;\n }\n return `0x${hex}`;\n}\nexports.fromAscii = fromAscii;\n/**\n * Returns the keys from an array of objects.\n * @example\n * ```js\n * getKeys([{a: '1', b: '2'}, {a: '3', b: '4'}], 'a') => ['1', '3']\n *````\n * @param params\n * @param key\n * @param allowEmpty\n * @returns output just a simple array of output keys\n */\nfunction getKeys(params, key, allowEmpty) {\n if (!Array.isArray(params)) {\n throw new Error(`[getKeys] method expects input 'params' to be an array, got ${typeof params}`);\n }\n if (typeof key !== 'string') {\n throw new Error(`[getKeys] method expects input 'key' to be type 'string', got ${typeof params}`);\n }\n const result = [];\n for (let i = 0; i < params.length; i++) {\n let value = params[i][key];\n if (allowEmpty === true && !value) {\n value = '';\n } else if (typeof value !== 'string') {\n throw new Error(`invalid abi - expected type 'string', received ${typeof value}`);\n }\n result.push(value);\n }\n return result;\n}\nexports.getKeys = getKeys;\n/**\n * Is the string a hex string.\n *\n * @param value\n * @param length\n * @returns output the string is a hex string\n */\nfunction isHexString(value, length) {\n if (typeof value !== 'string' || !value.match(/^0x[0-9A-Fa-f]*$/)) return false;\n if (typeof length !== 'undefined' && length > 0 && value.length !== 2 + 2 * length) return false;\n return true;\n}\nexports.isHexString = isHexString;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.assertIsString = exports.assertIsArray = exports.assertIsBuffer = exports.assertIsHexString = void 0;\nconst internal_1 = require(\"./internal\");\n/**\n * Throws if a string is not hex prefixed\n * @param {string} input string to check hex prefix of\n */\nconst assertIsHexString = function (input) {\n if (!(0, internal_1.isHexString)(input)) {\n const msg = `This method only supports 0x-prefixed hex strings but input was: ${input}`;\n throw new Error(msg);\n }\n};\nexports.assertIsHexString = assertIsHexString;\n/**\n * Throws if input is not a buffer\n * @param {Buffer} input value to check\n */\nconst assertIsBuffer = function (input) {\n if (!Buffer.isBuffer(input)) {\n const msg = `This method only supports Buffer but input was: ${input}`;\n throw new Error(msg);\n }\n};\nexports.assertIsBuffer = assertIsBuffer;\n/**\n * Throws if input is not an array\n * @param {number[]} input value to check\n */\nconst assertIsArray = function (input) {\n if (!Array.isArray(input)) {\n const msg = `This method only supports number arrays but input was: ${input}`;\n throw new Error(msg);\n }\n};\nexports.assertIsArray = assertIsArray;\n/**\n * Throws if input is not a string\n * @param {string} input value to check\n */\nconst assertIsString = function (input) {\n if (typeof input !== 'string') {\n const msg = `This method only supports strings but input was: ${input}`;\n throw new Error(msg);\n }\n};\nexports.assertIsString = assertIsString;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.intToUnpaddedBuffer = exports.bigIntToUnpaddedBuffer = exports.bigIntToHex = exports.bufArrToArr = exports.arrToBufArr = exports.validateNoLeadingZeroes = exports.baToJSON = exports.toUtf8 = exports.short = exports.addHexPrefix = exports.toUnsigned = exports.fromSigned = exports.bufferToInt = exports.bigIntToBuffer = exports.bufferToBigInt = exports.bufferToHex = exports.toBuffer = exports.unpadHexString = exports.unpadArray = exports.unpadBuffer = exports.setLengthRight = exports.setLengthLeft = exports.zeros = exports.intToBuffer = exports.intToHex = void 0;\nconst helpers_1 = require(\"./helpers\");\nconst internal_1 = require(\"./internal\");\n/**\n * Converts a `Number` into a hex `String`\n * @param {Number} i\n * @return {String}\n */\nconst intToHex = function (i) {\n if (!Number.isSafeInteger(i) || i < 0) {\n throw new Error(`Received an invalid integer type: ${i}`);\n }\n return `0x${i.toString(16)}`;\n};\nexports.intToHex = intToHex;\n/**\n * Converts an `Number` to a `Buffer`\n * @param {Number} i\n * @return {Buffer}\n */\nconst intToBuffer = function (i) {\n const hex = (0, exports.intToHex)(i);\n return Buffer.from((0, internal_1.padToEven)(hex.slice(2)), 'hex');\n};\nexports.intToBuffer = intToBuffer;\n/**\n * Returns a buffer filled with 0s.\n * @param bytes the number of bytes the buffer should be\n */\nconst zeros = function (bytes) {\n return Buffer.allocUnsafe(bytes).fill(0);\n};\nexports.zeros = zeros;\n/**\n * Pads a `Buffer` with zeros till it has `length` bytes.\n * Truncates the beginning or end of input if its length exceeds `length`.\n * @param msg the value to pad (Buffer)\n * @param length the number of bytes the output should be\n * @param right whether to start padding form the left or right\n * @return (Buffer)\n */\nconst setLength = function (msg, length, right) {\n const buf = (0, exports.zeros)(length);\n if (right) {\n if (msg.length < length) {\n msg.copy(buf);\n return buf;\n }\n return msg.slice(0, length);\n } else {\n if (msg.length < length) {\n msg.copy(buf, length - msg.length);\n return buf;\n }\n return msg.slice(-length);\n }\n};\n/**\n * Left Pads a `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @param msg the value to pad (Buffer)\n * @param length the number of bytes the output should be\n * @return (Buffer)\n */\nconst setLengthLeft = function (msg, length) {\n (0, helpers_1.assertIsBuffer)(msg);\n return setLength(msg, length, false);\n};\nexports.setLengthLeft = setLengthLeft;\n/**\n * Right Pads a `Buffer` with trailing zeros till it has `length` bytes.\n * it truncates the end if it exceeds.\n * @param msg the value to pad (Buffer)\n * @param length the number of bytes the output should be\n * @return (Buffer)\n */\nconst setLengthRight = function (msg, length) {\n (0, helpers_1.assertIsBuffer)(msg);\n return setLength(msg, length, true);\n};\nexports.setLengthRight = setLengthRight;\n/**\n * Trims leading zeros from a `Buffer`, `String` or `Number[]`.\n * @param a (Buffer|Array|String)\n * @return (Buffer|Array|String)\n */\nconst stripZeros = function (a) {\n let first = a[0];\n while (a.length > 0 && first.toString() === '0') {\n a = a.slice(1);\n first = a[0];\n }\n return a;\n};\n/**\n * Trims leading zeros from a `Buffer`.\n * @param a (Buffer)\n * @return (Buffer)\n */\nconst unpadBuffer = function (a) {\n (0, helpers_1.assertIsBuffer)(a);\n return stripZeros(a);\n};\nexports.unpadBuffer = unpadBuffer;\n/**\n * Trims leading zeros from an `Array` (of numbers).\n * @param a (number[])\n * @return (number[])\n */\nconst unpadArray = function (a) {\n (0, helpers_1.assertIsArray)(a);\n return stripZeros(a);\n};\nexports.unpadArray = unpadArray;\n/**\n * Trims leading zeros from a hex-prefixed `String`.\n * @param a (String)\n * @return (String)\n */\nconst unpadHexString = function (a) {\n (0, helpers_1.assertIsHexString)(a);\n a = (0, internal_1.stripHexPrefix)(a);\n return '0x' + stripZeros(a);\n};\nexports.unpadHexString = unpadHexString;\n/**\n * Attempts to turn a value into a `Buffer`.\n * Inputs supported: `Buffer`, `String` (hex-prefixed), `Number`, null/undefined, `BigInt` and other objects\n * with a `toArray()` or `toBuffer()` method.\n * @param v the value\n */\nconst toBuffer = function (v) {\n if (v === null || v === undefined) {\n return Buffer.allocUnsafe(0);\n }\n if (Buffer.isBuffer(v)) {\n return Buffer.from(v);\n }\n if (Array.isArray(v) || v instanceof Uint8Array) {\n return Buffer.from(v);\n }\n if (typeof v === 'string') {\n if (!(0, internal_1.isHexString)(v)) {\n throw new Error(`Cannot convert string to buffer. toBuffer only supports 0x-prefixed hex strings and this string was given: ${v}`);\n }\n return Buffer.from((0, internal_1.padToEven)((0, internal_1.stripHexPrefix)(v)), 'hex');\n }\n if (typeof v === 'number') {\n return (0, exports.intToBuffer)(v);\n }\n if (typeof v === 'bigint') {\n if (v < BigInt(0)) {\n throw new Error(`Cannot convert negative bigint to buffer. Given: ${v}`);\n }\n let n = v.toString(16);\n if (n.length % 2) n = '0' + n;\n return Buffer.from(n, 'hex');\n }\n if (v.toArray) {\n // converts a BN to a Buffer\n return Buffer.from(v.toArray());\n }\n if (v.toBuffer) {\n return Buffer.from(v.toBuffer());\n }\n throw new Error('invalid type');\n};\nexports.toBuffer = toBuffer;\n/**\n * Converts a `Buffer` into a `0x`-prefixed hex `String`.\n * @param buf `Buffer` object to convert\n */\nconst bufferToHex = function (buf) {\n buf = (0, exports.toBuffer)(buf);\n return '0x' + buf.toString('hex');\n};\nexports.bufferToHex = bufferToHex;\n/**\n * Converts a {@link Buffer} to a {@link bigint}\n */\nfunction bufferToBigInt(buf) {\n const hex = (0, exports.bufferToHex)(buf);\n if (hex === '0x') {\n return BigInt(0);\n }\n return BigInt(hex);\n}\nexports.bufferToBigInt = bufferToBigInt;\n/**\n * Converts a {@link bigint} to a {@link Buffer}\n */\nfunction bigIntToBuffer(num) {\n return (0, exports.toBuffer)('0x' + num.toString(16));\n}\nexports.bigIntToBuffer = bigIntToBuffer;\n/**\n * Converts a `Buffer` to a `Number`.\n * @param buf `Buffer` object to convert\n * @throws If the input number exceeds 53 bits.\n */\nconst bufferToInt = function (buf) {\n const res = Number(bufferToBigInt(buf));\n if (!Number.isSafeInteger(res)) throw new Error('Number exceeds 53 bits');\n return res;\n};\nexports.bufferToInt = bufferToInt;\n/**\n * Interprets a `Buffer` as a signed integer and returns a `BigInt`. Assumes 256-bit numbers.\n * @param num Signed integer value\n */\nconst fromSigned = function (num) {\n return BigInt.asIntN(256, bufferToBigInt(num));\n};\nexports.fromSigned = fromSigned;\n/**\n * Converts a `BigInt` to an unsigned integer and returns it as a `Buffer`. Assumes 256-bit numbers.\n * @param num\n */\nconst toUnsigned = function (num) {\n return bigIntToBuffer(BigInt.asUintN(256, num));\n};\nexports.toUnsigned = toUnsigned;\n/**\n * Adds \"0x\" to a given `String` if it does not already start with \"0x\".\n */\nconst addHexPrefix = function (str) {\n if (typeof str !== 'string') {\n return str;\n }\n return (0, internal_1.isHexPrefixed)(str) ? str : '0x' + str;\n};\nexports.addHexPrefix = addHexPrefix;\n/**\n * Shortens a string or buffer's hex string representation to maxLength (default 50).\n *\n * Examples:\n *\n * Input: '657468657265756d000000000000000000000000000000000000000000000000'\n * Output: '657468657265756d0000000000000000000000000000000000…'\n */\nfunction short(buffer, maxLength = 50) {\n const bufferStr = Buffer.isBuffer(buffer) ? buffer.toString('hex') : buffer;\n if (bufferStr.length <= maxLength) {\n return bufferStr;\n }\n return bufferStr.slice(0, maxLength) + '…';\n}\nexports.short = short;\n/**\n * Returns the utf8 string representation from a hex string.\n *\n * Examples:\n *\n * Input 1: '657468657265756d000000000000000000000000000000000000000000000000'\n * Input 2: '657468657265756d'\n * Input 3: '000000000000000000000000000000000000000000000000657468657265756d'\n *\n * Output (all 3 input variants): 'ethereum'\n *\n * Note that this method is not intended to be used with hex strings\n * representing quantities in both big endian or little endian notation.\n *\n * @param string Hex string, should be `0x` prefixed\n * @return Utf8 string\n */\nconst toUtf8 = function (hex) {\n const zerosRegexp = /^(00)+|(00)+$/g;\n hex = (0, internal_1.stripHexPrefix)(hex);\n if (hex.length % 2 !== 0) {\n throw new Error('Invalid non-even hex string input for toUtf8() provided');\n }\n const bufferVal = Buffer.from(hex.replace(zerosRegexp, ''), 'hex');\n return bufferVal.toString('utf8');\n};\nexports.toUtf8 = toUtf8;\n/**\n * Converts a `Buffer` or `Array` to JSON.\n * @param ba (Buffer|Array)\n * @return (Array|String|null)\n */\nconst baToJSON = function (ba) {\n if (Buffer.isBuffer(ba)) {\n return `0x${ba.toString('hex')}`;\n } else if (ba instanceof Array) {\n const array = [];\n for (let i = 0; i < ba.length; i++) {\n array.push((0, exports.baToJSON)(ba[i]));\n }\n return array;\n }\n};\nexports.baToJSON = baToJSON;\n/**\n * Checks provided Buffers for leading zeroes and throws if found.\n *\n * Examples:\n *\n * Valid values: 0x1, 0x, 0x01, 0x1234\n * Invalid values: 0x0, 0x00, 0x001, 0x0001\n *\n * Note: This method is useful for validating that RLP encoded integers comply with the rule that all\n * integer values encoded to RLP must be in the most compact form and contain no leading zero bytes\n * @param values An object containing string keys and Buffer values\n * @throws if any provided value is found to have leading zero bytes\n */\nconst validateNoLeadingZeroes = function (values) {\n for (const [k, v] of Object.entries(values)) {\n if (v !== undefined && v.length > 0 && v[0] === 0) {\n throw new Error(`${k} cannot have leading zeroes, received: ${v.toString('hex')}`);\n }\n }\n};\nexports.validateNoLeadingZeroes = validateNoLeadingZeroes;\nfunction arrToBufArr(arr) {\n if (!Array.isArray(arr)) {\n return Buffer.from(arr);\n }\n return arr.map(a => arrToBufArr(a));\n}\nexports.arrToBufArr = arrToBufArr;\nfunction bufArrToArr(arr) {\n if (!Array.isArray(arr)) {\n return Uint8Array.from(arr ?? []);\n }\n return arr.map(a => bufArrToArr(a));\n}\nexports.bufArrToArr = bufArrToArr;\n/**\n * Converts a {@link bigint} to a `0x` prefixed hex string\n */\nconst bigIntToHex = num => {\n return '0x' + num.toString(16);\n};\nexports.bigIntToHex = bigIntToHex;\n/**\n * Convert value from bigint to an unpadded Buffer\n * (useful for RLP transport)\n * @param value value to convert\n */\nfunction bigIntToUnpaddedBuffer(value) {\n return (0, exports.unpadBuffer)(bigIntToBuffer(value));\n}\nexports.bigIntToUnpaddedBuffer = bigIntToUnpaddedBuffer;\nfunction intToUnpaddedBuffer(value) {\n return (0, exports.unpadBuffer)((0, exports.intToBuffer)(value));\n}\nexports.intToUnpaddedBuffer = intToUnpaddedBuffer;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.accountBodyToRLP = exports.accountBodyToSlim = exports.accountBodyFromSlim = exports.isZeroAddress = exports.zeroAddress = exports.importPublic = exports.privateToAddress = exports.privateToPublic = exports.publicToAddress = exports.pubToAddress = exports.isValidPublic = exports.isValidPrivate = exports.generateAddress2 = exports.generateAddress = exports.isValidChecksumAddress = exports.toChecksumAddress = exports.isValidAddress = exports.Account = void 0;\nconst rlp_1 = require(\"@ethereumjs/rlp\");\nconst keccak_1 = require(\"ethereum-cryptography/keccak\");\nconst secp256k1_1 = require(\"ethereum-cryptography/secp256k1\");\nconst utils_1 = require(\"ethereum-cryptography/utils\");\nconst bytes_1 = require(\"./bytes\");\nconst constants_1 = require(\"./constants\");\nconst helpers_1 = require(\"./helpers\");\nconst internal_1 = require(\"./internal\");\nconst _0n = BigInt(0);\nclass Account {\n /**\n * This constructor assigns and validates the values.\n * Use the static factory methods to assist in creating an Account from varying data types.\n */\n constructor(nonce = _0n, balance = _0n, storageRoot = constants_1.KECCAK256_RLP, codeHash = constants_1.KECCAK256_NULL) {\n this.nonce = nonce;\n this.balance = balance;\n this.storageRoot = storageRoot;\n this.codeHash = codeHash;\n this._validate();\n }\n static fromAccountData(accountData) {\n const {\n nonce,\n balance,\n storageRoot,\n codeHash\n } = accountData;\n return new Account(nonce !== undefined ? (0, bytes_1.bufferToBigInt)((0, bytes_1.toBuffer)(nonce)) : undefined, balance !== undefined ? (0, bytes_1.bufferToBigInt)((0, bytes_1.toBuffer)(balance)) : undefined, storageRoot !== undefined ? (0, bytes_1.toBuffer)(storageRoot) : undefined, codeHash !== undefined ? (0, bytes_1.toBuffer)(codeHash) : undefined);\n }\n static fromRlpSerializedAccount(serialized) {\n const values = (0, bytes_1.arrToBufArr)(rlp_1.RLP.decode(Uint8Array.from(serialized)));\n if (!Array.isArray(values)) {\n throw new Error('Invalid serialized account input. Must be array');\n }\n return this.fromValuesArray(values);\n }\n static fromValuesArray(values) {\n const [nonce, balance, storageRoot, codeHash] = values;\n return new Account((0, bytes_1.bufferToBigInt)(nonce), (0, bytes_1.bufferToBigInt)(balance), storageRoot, codeHash);\n }\n _validate() {\n if (this.nonce < _0n) {\n throw new Error('nonce must be greater than zero');\n }\n if (this.balance < _0n) {\n throw new Error('balance must be greater than zero');\n }\n if (this.storageRoot.length !== 32) {\n throw new Error('storageRoot must have a length of 32');\n }\n if (this.codeHash.length !== 32) {\n throw new Error('codeHash must have a length of 32');\n }\n }\n /**\n * Returns a Buffer Array of the raw Buffers for the account, in order.\n */\n raw() {\n return [(0, bytes_1.bigIntToUnpaddedBuffer)(this.nonce), (0, bytes_1.bigIntToUnpaddedBuffer)(this.balance), this.storageRoot, this.codeHash];\n }\n /**\n * Returns the RLP serialization of the account as a `Buffer`.\n */\n serialize() {\n return Buffer.from(rlp_1.RLP.encode((0, bytes_1.bufArrToArr)(this.raw())));\n }\n /**\n * Returns a `Boolean` determining if the account is a contract.\n */\n isContract() {\n return !this.codeHash.equals(constants_1.KECCAK256_NULL);\n }\n /**\n * Returns a `Boolean` determining if the account is empty complying to the definition of\n * account emptiness in [EIP-161](https://eips.ethereum.org/EIPS/eip-161):\n * \"An account is considered empty when it has no code and zero nonce and zero balance.\"\n */\n isEmpty() {\n return this.balance === _0n && this.nonce === _0n && this.codeHash.equals(constants_1.KECCAK256_NULL);\n }\n}\nexports.Account = Account;\n/**\n * Checks if the address is a valid. Accepts checksummed addresses too.\n */\nconst isValidAddress = function (hexAddress) {\n try {\n (0, helpers_1.assertIsString)(hexAddress);\n } catch (e) {\n return false;\n }\n return /^0x[0-9a-fA-F]{40}$/.test(hexAddress);\n};\nexports.isValidAddress = isValidAddress;\n/**\n * Returns a checksummed address.\n *\n * If an eip1191ChainId is provided, the chainId will be included in the checksum calculation. This\n * has the effect of checksummed addresses for one chain having invalid checksums for others.\n * For more details see [EIP-1191](https://eips.ethereum.org/EIPS/eip-1191).\n *\n * WARNING: Checksums with and without the chainId will differ and the EIP-1191 checksum is not\n * backwards compatible to the original widely adopted checksum format standard introduced in\n * [EIP-55](https://eips.ethereum.org/EIPS/eip-55), so this will break in existing applications.\n * Usage of this EIP is therefore discouraged unless you have a very targeted use case.\n */\nconst toChecksumAddress = function (hexAddress, eip1191ChainId) {\n (0, helpers_1.assertIsHexString)(hexAddress);\n const address = (0, internal_1.stripHexPrefix)(hexAddress).toLowerCase();\n let prefix = '';\n if (eip1191ChainId !== undefined) {\n const chainId = (0, bytes_1.bufferToBigInt)((0, bytes_1.toBuffer)(eip1191ChainId));\n prefix = chainId.toString() + '0x';\n }\n const buf = Buffer.from(prefix + address, 'utf8');\n const hash = (0, utils_1.bytesToHex)((0, keccak_1.keccak256)(buf));\n let ret = '0x';\n for (let i = 0; i < address.length; i++) {\n if (parseInt(hash[i], 16) >= 8) {\n ret += address[i].toUpperCase();\n } else {\n ret += address[i];\n }\n }\n return ret;\n};\nexports.toChecksumAddress = toChecksumAddress;\n/**\n * Checks if the address is a valid checksummed address.\n *\n * See toChecksumAddress' documentation for details about the eip1191ChainId parameter.\n */\nconst isValidChecksumAddress = function (hexAddress, eip1191ChainId) {\n return (0, exports.isValidAddress)(hexAddress) && (0, exports.toChecksumAddress)(hexAddress, eip1191ChainId) === hexAddress;\n};\nexports.isValidChecksumAddress = isValidChecksumAddress;\n/**\n * Generates an address of a newly created contract.\n * @param from The address which is creating this new address\n * @param nonce The nonce of the from account\n */\nconst generateAddress = function (from, nonce) {\n (0, helpers_1.assertIsBuffer)(from);\n (0, helpers_1.assertIsBuffer)(nonce);\n if ((0, bytes_1.bufferToBigInt)(nonce) === BigInt(0)) {\n // in RLP we want to encode null in the case of zero nonce\n // read the RLP documentation for an answer if you dare\n return Buffer.from((0, keccak_1.keccak256)(rlp_1.RLP.encode((0, bytes_1.bufArrToArr)([from, null])))).slice(-20);\n }\n // Only take the lower 160bits of the hash\n return Buffer.from((0, keccak_1.keccak256)(rlp_1.RLP.encode((0, bytes_1.bufArrToArr)([from, nonce])))).slice(-20);\n};\nexports.generateAddress = generateAddress;\n/**\n * Generates an address for a contract created using CREATE2.\n * @param from The address which is creating this new address\n * @param salt A salt\n * @param initCode The init code of the contract being created\n */\nconst generateAddress2 = function (from, salt, initCode) {\n (0, helpers_1.assertIsBuffer)(from);\n (0, helpers_1.assertIsBuffer)(salt);\n (0, helpers_1.assertIsBuffer)(initCode);\n if (from.length !== 20) {\n throw new Error('Expected from to be of length 20');\n }\n if (salt.length !== 32) {\n throw new Error('Expected salt to be of length 32');\n }\n const address = (0, keccak_1.keccak256)(Buffer.concat([Buffer.from('ff', 'hex'), from, salt, (0, keccak_1.keccak256)(initCode)]));\n return (0, bytes_1.toBuffer)(address).slice(-20);\n};\nexports.generateAddress2 = generateAddress2;\n/**\n * Checks if the private key satisfies the rules of the curve secp256k1.\n */\nconst isValidPrivate = function (privateKey) {\n return secp256k1_1.secp256k1.utils.isValidPrivateKey(privateKey);\n};\nexports.isValidPrivate = isValidPrivate;\n/**\n * Checks if the public key satisfies the rules of the curve secp256k1\n * and the requirements of Ethereum.\n * @param publicKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nconst isValidPublic = function (publicKey, sanitize = false) {\n (0, helpers_1.assertIsBuffer)(publicKey);\n if (publicKey.length === 64) {\n // Convert to SEC1 for secp256k1\n // Automatically checks whether point is on curve\n try {\n secp256k1_1.secp256k1.ProjectivePoint.fromHex(Buffer.concat([Buffer.from([4]), publicKey]));\n return true;\n } catch (e) {\n return false;\n }\n }\n if (!sanitize) {\n return false;\n }\n try {\n secp256k1_1.secp256k1.ProjectivePoint.fromHex(publicKey);\n return true;\n } catch (e) {\n return false;\n }\n};\nexports.isValidPublic = isValidPublic;\n/**\n * Returns the ethereum address of a given public key.\n * Accepts \"Ethereum public keys\" and SEC1 encoded keys.\n * @param pubKey The two points of an uncompressed key, unless sanitize is enabled\n * @param sanitize Accept public keys in other formats\n */\nconst pubToAddress = function (pubKey, sanitize = false) {\n (0, helpers_1.assertIsBuffer)(pubKey);\n if (sanitize && pubKey.length !== 64) {\n pubKey = Buffer.from(secp256k1_1.secp256k1.ProjectivePoint.fromHex(pubKey).toRawBytes(false).slice(1));\n }\n if (pubKey.length !== 64) {\n throw new Error('Expected pubKey to be of length 64');\n }\n // Only take the lower 160bits of the hash\n return Buffer.from((0, keccak_1.keccak256)(pubKey)).slice(-20);\n};\nexports.pubToAddress = pubToAddress;\nexports.publicToAddress = exports.pubToAddress;\n/**\n * Returns the ethereum public key of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nconst privateToPublic = function (privateKey) {\n (0, helpers_1.assertIsBuffer)(privateKey);\n // skip the type flag and use the X, Y points\n return Buffer.from(secp256k1_1.secp256k1.ProjectivePoint.fromPrivateKey(privateKey).toRawBytes(false).slice(1));\n};\nexports.privateToPublic = privateToPublic;\n/**\n * Returns the ethereum address of a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\nconst privateToAddress = function (privateKey) {\n return (0, exports.publicToAddress)((0, exports.privateToPublic)(privateKey));\n};\nexports.privateToAddress = privateToAddress;\n/**\n * Converts a public key to the Ethereum format.\n */\nconst importPublic = function (publicKey) {\n (0, helpers_1.assertIsBuffer)(publicKey);\n if (publicKey.length !== 64) {\n publicKey = Buffer.from(secp256k1_1.secp256k1.ProjectivePoint.fromHex(publicKey).toRawBytes(false).slice(1));\n }\n return publicKey;\n};\nexports.importPublic = importPublic;\n/**\n * Returns the zero address.\n */\nconst zeroAddress = function () {\n const addressLength = 20;\n const addr = (0, bytes_1.zeros)(addressLength);\n return (0, bytes_1.bufferToHex)(addr);\n};\nexports.zeroAddress = zeroAddress;\n/**\n * Checks if a given address is the zero address.\n */\nconst isZeroAddress = function (hexAddress) {\n try {\n (0, helpers_1.assertIsString)(hexAddress);\n } catch (e) {\n return false;\n }\n const zeroAddr = (0, exports.zeroAddress)();\n return zeroAddr === hexAddress;\n};\nexports.isZeroAddress = isZeroAddress;\nfunction accountBodyFromSlim(body) {\n const [nonce, balance, storageRoot, codeHash] = body;\n return [nonce, balance, (0, bytes_1.arrToBufArr)(storageRoot).length === 0 ? constants_1.KECCAK256_RLP : storageRoot, (0, bytes_1.arrToBufArr)(codeHash).length === 0 ? constants_1.KECCAK256_NULL : codeHash];\n}\nexports.accountBodyFromSlim = accountBodyFromSlim;\nconst emptyUint8Arr = new Uint8Array(0);\nfunction accountBodyToSlim(body) {\n const [nonce, balance, storageRoot, codeHash] = body;\n return [nonce, balance, (0, bytes_1.arrToBufArr)(storageRoot).equals(constants_1.KECCAK256_RLP) ? emptyUint8Arr : storageRoot, (0, bytes_1.arrToBufArr)(codeHash).equals(constants_1.KECCAK256_NULL) ? emptyUint8Arr : codeHash];\n}\nexports.accountBodyToSlim = accountBodyToSlim;\n/**\n * Converts a slim account (per snap protocol spec) to the RLP encoded version of the account\n * @param body Array of 4 Buffer-like items to represent the account\n * @returns RLP encoded version of the account\n */\nfunction accountBodyToRLP(body, couldBeSlim = true) {\n const accountBody = couldBeSlim ? accountBodyFromSlim(body) : body;\n return (0, bytes_1.arrToBufArr)(rlp_1.RLP.encode(accountBody));\n}\nexports.accountBodyToRLP = accountBodyToRLP;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Address = void 0;\nconst account_1 = require(\"./account\");\nconst bytes_1 = require(\"./bytes\");\n/**\n * Handling and generating Ethereum addresses\n */\nclass Address {\n constructor(buf) {\n if (buf.length !== 20) {\n throw new Error('Invalid address length');\n }\n this.buf = buf;\n }\n /**\n * Returns the zero address.\n */\n static zero() {\n return new Address((0, bytes_1.zeros)(20));\n }\n /**\n * Returns an Address object from a hex-encoded string.\n * @param str - Hex-encoded address\n */\n static fromString(str) {\n if (!(0, account_1.isValidAddress)(str)) {\n throw new Error('Invalid address');\n }\n return new Address((0, bytes_1.toBuffer)(str));\n }\n /**\n * Returns an address for a given public key.\n * @param pubKey The two points of an uncompressed key\n */\n static fromPublicKey(pubKey) {\n if (!Buffer.isBuffer(pubKey)) {\n throw new Error('Public key should be Buffer');\n }\n const buf = (0, account_1.pubToAddress)(pubKey);\n return new Address(buf);\n }\n /**\n * Returns an address for a given private key.\n * @param privateKey A private key must be 256 bits wide\n */\n static fromPrivateKey(privateKey) {\n if (!Buffer.isBuffer(privateKey)) {\n throw new Error('Private key should be Buffer');\n }\n const buf = (0, account_1.privateToAddress)(privateKey);\n return new Address(buf);\n }\n /**\n * Generates an address for a newly created contract.\n * @param from The address which is creating this new address\n * @param nonce The nonce of the from account\n */\n static generate(from, nonce) {\n if (typeof nonce !== 'bigint') {\n throw new Error('Expected nonce to be a bigint');\n }\n return new Address((0, account_1.generateAddress)(from.buf, (0, bytes_1.bigIntToBuffer)(nonce)));\n }\n /**\n * Generates an address for a contract created using CREATE2.\n * @param from The address which is creating this new address\n * @param salt A salt\n * @param initCode The init code of the contract being created\n */\n static generate2(from, salt, initCode) {\n if (!Buffer.isBuffer(salt)) {\n throw new Error('Expected salt to be a Buffer');\n }\n if (!Buffer.isBuffer(initCode)) {\n throw new Error('Expected initCode to be a Buffer');\n }\n return new Address((0, account_1.generateAddress2)(from.buf, salt, initCode));\n }\n /**\n * Is address equal to another.\n */\n equals(address) {\n return this.buf.equals(address.buf);\n }\n /**\n * Is address zero.\n */\n isZero() {\n return this.equals(Address.zero());\n }\n /**\n * True if address is in the address range defined\n * by EIP-1352\n */\n isPrecompileOrSystemAddress() {\n const address = (0, bytes_1.bufferToBigInt)(this.buf);\n const rangeMin = BigInt(0);\n const rangeMax = BigInt('0xffff');\n return address >= rangeMin && address <= rangeMax;\n }\n /**\n * Returns hex encoding of address.\n */\n toString() {\n return '0x' + this.buf.toString('hex');\n }\n /**\n * Returns Buffer representation of address.\n */\n toBuffer() {\n return Buffer.from(this.buf);\n }\n}\nexports.Address = Address;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.toType = exports.TypeOutput = void 0;\nconst bytes_1 = require(\"./bytes\");\nconst internal_1 = require(\"./internal\");\n/**\n * Type output options\n */\nvar TypeOutput;\n(function (TypeOutput) {\n TypeOutput[TypeOutput[\"Number\"] = 0] = \"Number\";\n TypeOutput[TypeOutput[\"BigInt\"] = 1] = \"BigInt\";\n TypeOutput[TypeOutput[\"Buffer\"] = 2] = \"Buffer\";\n TypeOutput[TypeOutput[\"PrefixedHexString\"] = 3] = \"PrefixedHexString\";\n})(TypeOutput = exports.TypeOutput || (exports.TypeOutput = {}));\nfunction toType(input, outputType) {\n if (input === null) {\n return null;\n }\n if (input === undefined) {\n return undefined;\n }\n if (typeof input === 'string' && !(0, internal_1.isHexString)(input)) {\n throw new Error(`A string must be provided with a 0x-prefix, given: ${input}`);\n } else if (typeof input === 'number' && !Number.isSafeInteger(input)) {\n throw new Error('The provided number is greater than MAX_SAFE_INTEGER (please use an alternative input type)');\n }\n const output = (0, bytes_1.toBuffer)(input);\n switch (outputType) {\n case TypeOutput.Buffer:\n return output;\n case TypeOutput.BigInt:\n return (0, bytes_1.bufferToBigInt)(output);\n case TypeOutput.Number:\n {\n const bigInt = (0, bytes_1.bufferToBigInt)(output);\n if (bigInt > BigInt(Number.MAX_SAFE_INTEGER)) {\n throw new Error('The provided number is greater than MAX_SAFE_INTEGER (please use an alternative output type)');\n }\n return Number(bigInt);\n }\n case TypeOutput.PrefixedHexString:\n return (0, bytes_1.bufferToHex)(output);\n default:\n throw new Error('unknown outputType');\n }\n}\nexports.toType = toType;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Withdrawal = void 0;\nconst address_1 = require(\"./address\");\nconst bytes_1 = require(\"./bytes\");\nconst types_1 = require(\"./types\");\n/**\n * Representation of EIP-4895 withdrawal data\n */\nclass Withdrawal {\n /**\n * This constructor assigns and validates the values.\n * Use the static factory methods to assist in creating a Withdrawal object from varying data types.\n * Its amount is in Gwei to match CL representation and for eventual ssz withdrawalsRoot\n */\n constructor(index, validatorIndex, address,\n /**\n * withdrawal amount in Gwei to match the CL repesentation and eventually ssz withdrawalsRoot\n */\n amount) {\n this.index = index;\n this.validatorIndex = validatorIndex;\n this.address = address;\n this.amount = amount;\n }\n static fromWithdrawalData(withdrawalData) {\n const {\n index: indexData,\n validatorIndex: validatorIndexData,\n address: addressData,\n amount: amountData\n } = withdrawalData;\n const index = (0, types_1.toType)(indexData, types_1.TypeOutput.BigInt);\n const validatorIndex = (0, types_1.toType)(validatorIndexData, types_1.TypeOutput.BigInt);\n const address = new address_1.Address((0, types_1.toType)(addressData, types_1.TypeOutput.Buffer));\n const amount = (0, types_1.toType)(amountData, types_1.TypeOutput.BigInt);\n return new Withdrawal(index, validatorIndex, address, amount);\n }\n static fromValuesArray(withdrawalArray) {\n if (withdrawalArray.length !== 4) {\n throw Error(`Invalid withdrawalArray length expected=4 actual=${withdrawalArray.length}`);\n }\n const [index, validatorIndex, address, amount] = withdrawalArray;\n return Withdrawal.fromWithdrawalData({\n index,\n validatorIndex,\n address,\n amount\n });\n }\n /**\n * Convert a withdrawal to a buffer array\n * @param withdrawal the withdrawal to convert\n * @returns buffer array of the withdrawal\n */\n static toBufferArray(withdrawal) {\n const {\n index,\n validatorIndex,\n address,\n amount\n } = withdrawal;\n const indexBuffer = (0, types_1.toType)(index, types_1.TypeOutput.BigInt) === BigInt(0) ? Buffer.alloc(0) : (0, types_1.toType)(index, types_1.TypeOutput.Buffer);\n const validatorIndexBuffer = (0, types_1.toType)(validatorIndex, types_1.TypeOutput.BigInt) === BigInt(0) ? Buffer.alloc(0) : (0, types_1.toType)(validatorIndex, types_1.TypeOutput.Buffer);\n let addressBuffer;\n if (address instanceof address_1.Address) {\n addressBuffer = address.buf;\n } else {\n addressBuffer = (0, types_1.toType)(address, types_1.TypeOutput.Buffer);\n }\n const amountBuffer = (0, types_1.toType)(amount, types_1.TypeOutput.BigInt) === BigInt(0) ? Buffer.alloc(0) : (0, types_1.toType)(amount, types_1.TypeOutput.Buffer);\n return [indexBuffer, validatorIndexBuffer, addressBuffer, amountBuffer];\n }\n raw() {\n return Withdrawal.toBufferArray(this);\n }\n toValue() {\n return {\n index: this.index,\n validatorIndex: this.validatorIndex,\n address: this.address.buf,\n amount: this.amount\n };\n }\n toJSON() {\n return {\n index: (0, bytes_1.bigIntToHex)(this.index),\n validatorIndex: (0, bytes_1.bigIntToHex)(this.validatorIndex),\n address: '0x' + this.address.buf.toString('hex'),\n amount: (0, bytes_1.bigIntToHex)(this.amount)\n };\n }\n}\nexports.Withdrawal = Withdrawal;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hashPersonalMessage = exports.isValidSignature = exports.fromRpcSig = exports.toCompactSig = exports.toRpcSig = exports.ecrecover = exports.ecsign = void 0;\nconst keccak_1 = require(\"ethereum-cryptography/keccak\");\nconst secp256k1_1 = require(\"ethereum-cryptography/secp256k1\");\nconst bytes_1 = require(\"./bytes\");\nconst constants_1 = require(\"./constants\");\nconst helpers_1 = require(\"./helpers\");\n/**\n * Returns the ECDSA signature of a message hash.\n *\n * If `chainId` is provided assume an EIP-155-style signature and calculate the `v` value\n * accordingly, otherwise return a \"static\" `v` just derived from the `recovery` bit\n */\nfunction ecsign(msgHash, privateKey, chainId) {\n const sig = secp256k1_1.secp256k1.sign(msgHash, privateKey);\n const buf = sig.toCompactRawBytes();\n const r = Buffer.from(buf.slice(0, 32));\n const s = Buffer.from(buf.slice(32, 64));\n const v = chainId === undefined ? BigInt(sig.recovery + 27) : BigInt(sig.recovery + 35) + BigInt(chainId) * BigInt(2);\n return {\n r,\n s,\n v\n };\n}\nexports.ecsign = ecsign;\nfunction calculateSigRecovery(v, chainId) {\n if (v === BigInt(0) || v === BigInt(1)) return v;\n if (chainId === undefined) {\n return v - BigInt(27);\n }\n return v - (chainId * BigInt(2) + BigInt(35));\n}\nfunction isValidSigRecovery(recovery) {\n return recovery === BigInt(0) || recovery === BigInt(1);\n}\n/**\n * ECDSA public key recovery from signature.\n * NOTE: Accepts `v === 0 | v === 1` for EIP1559 transactions\n * @returns Recovered public key\n */\nconst ecrecover = function (msgHash, v, r, s, chainId) {\n const signature = Buffer.concat([(0, bytes_1.setLengthLeft)(r, 32), (0, bytes_1.setLengthLeft)(s, 32)], 64);\n const recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n const sig = secp256k1_1.secp256k1.Signature.fromCompact(signature).addRecoveryBit(Number(recovery));\n const senderPubKey = sig.recoverPublicKey(msgHash);\n return Buffer.from(senderPubKey.toRawBytes(false).slice(1));\n};\nexports.ecrecover = ecrecover;\n/**\n * Convert signature parameters into the format of `eth_sign` RPC method.\n * NOTE: Accepts `v === 0 | v === 1` for EIP1559 transactions\n * @returns Signature\n */\nconst toRpcSig = function (v, r, s, chainId) {\n const recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n // geth (and the RPC eth_sign method) uses the 65 byte format used by Bitcoin\n return (0, bytes_1.bufferToHex)(Buffer.concat([(0, bytes_1.setLengthLeft)(r, 32), (0, bytes_1.setLengthLeft)(s, 32), (0, bytes_1.toBuffer)(v)]));\n};\nexports.toRpcSig = toRpcSig;\n/**\n * Convert signature parameters into the format of Compact Signature Representation (EIP-2098).\n * NOTE: Accepts `v === 0 | v === 1` for EIP1559 transactions\n * @returns Signature\n */\nconst toCompactSig = function (v, r, s, chainId) {\n const recovery = calculateSigRecovery(v, chainId);\n if (!isValidSigRecovery(recovery)) {\n throw new Error('Invalid signature v value');\n }\n let ss = s;\n if (v > BigInt(28) && v % BigInt(2) === BigInt(1) || v === BigInt(1) || v === BigInt(28)) {\n ss = Buffer.from(s);\n ss[0] |= 0x80;\n }\n return (0, bytes_1.bufferToHex)(Buffer.concat([(0, bytes_1.setLengthLeft)(r, 32), (0, bytes_1.setLengthLeft)(ss, 32)]));\n};\nexports.toCompactSig = toCompactSig;\n/**\n * Convert signature format of the `eth_sign` RPC method to signature parameters\n *\n * NOTE: For an extracted `v` value < 27 (see Geth bug https://github.com/ethereum/go-ethereum/issues/2053)\n * `v + 27` is returned for the `v` value\n * NOTE: After EIP1559, `v` could be `0` or `1` but this function assumes\n * it's a signed message (EIP-191 or EIP-712) adding `27` at the end. Remove if needed.\n */\nconst fromRpcSig = function (sig) {\n const buf = (0, bytes_1.toBuffer)(sig);\n let r;\n let s;\n let v;\n if (buf.length >= 65) {\n r = buf.slice(0, 32);\n s = buf.slice(32, 64);\n v = (0, bytes_1.bufferToBigInt)(buf.slice(64));\n } else if (buf.length === 64) {\n // Compact Signature Representation (https://eips.ethereum.org/EIPS/eip-2098)\n r = buf.slice(0, 32);\n s = buf.slice(32, 64);\n v = BigInt((0, bytes_1.bufferToInt)(buf.slice(32, 33)) >> 7);\n s[0] &= 0x7f;\n } else {\n throw new Error('Invalid signature length');\n }\n // support both versions of `eth_sign` responses\n if (v < 27) {\n v = v + BigInt(27);\n }\n return {\n v,\n r,\n s\n };\n};\nexports.fromRpcSig = fromRpcSig;\n/**\n * Validate a ECDSA signature.\n * NOTE: Accepts `v === 0 | v === 1` for EIP1559 transactions\n * @param homesteadOrLater Indicates whether this is being used on either the homestead hardfork or a later one\n */\nconst isValidSignature = function (v, r, s, homesteadOrLater = true, chainId) {\n if (r.length !== 32 || s.length !== 32) {\n return false;\n }\n if (!isValidSigRecovery(calculateSigRecovery(v, chainId))) {\n return false;\n }\n const rBigInt = (0, bytes_1.bufferToBigInt)(r);\n const sBigInt = (0, bytes_1.bufferToBigInt)(s);\n if (rBigInt === BigInt(0) || rBigInt >= constants_1.SECP256K1_ORDER || sBigInt === BigInt(0) || sBigInt >= constants_1.SECP256K1_ORDER) {\n return false;\n }\n if (homesteadOrLater && sBigInt >= constants_1.SECP256K1_ORDER_DIV_2) {\n return false;\n }\n return true;\n};\nexports.isValidSignature = isValidSignature;\n/**\n * Returns the keccak-256 hash of `message`, prefixed with the header used by the `eth_sign` RPC call.\n * The output of this function can be fed into `ecsign` to produce the same signature as the `eth_sign`\n * call for a given `message`, or fed to `ecrecover` along with a signature to recover the public key\n * used to produce the signature.\n */\nconst hashPersonalMessage = function (message) {\n (0, helpers_1.assertIsBuffer)(message);\n const prefix = Buffer.from(`\\u0019Ethereum Signed Message:\\n${message.length}`, 'utf-8');\n return Buffer.from((0, keccak_1.keccak256)(Buffer.concat([prefix, message])));\n};\nexports.hashPersonalMessage = hashPersonalMessage;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.compactBytesToNibbles = exports.bytesToNibbles = exports.nibblesToCompactBytes = exports.nibblesToBytes = exports.hasTerminator = void 0;\n// Reference: https://ethereum.org/en/developers/docs/data-structures-and-encoding/patricia-merkle-trie/\n/**\n *\n * @param s byte sequence\n * @returns boolean indicating if input hex nibble sequence has terminator indicating leaf-node\n * terminator is represented with 16 because a nibble ranges from 0 - 15(f)\n */\nconst hasTerminator = nibbles => {\n return nibbles.length > 0 && nibbles[nibbles.length - 1] === 16;\n};\nexports.hasTerminator = hasTerminator;\nconst nibblesToBytes = (nibbles, bytes) => {\n for (let bi = 0, ni = 0; ni < nibbles.length; bi += 1, ni += 2) {\n bytes[bi] = nibbles[ni] << 4 | nibbles[ni + 1];\n }\n};\nexports.nibblesToBytes = nibblesToBytes;\nconst nibblesToCompactBytes = nibbles => {\n let terminator = 0;\n if ((0, exports.hasTerminator)(nibbles)) {\n terminator = 1;\n // Remove the terminator from the sequence\n nibbles = nibbles.subarray(0, nibbles.length - 1);\n }\n const buf = new Uint8Array(nibbles.length / 2 + 1);\n // Shift the terminator info into the first nibble of buf[0]\n buf[0] = terminator << 5;\n // If odd length, then add that flag into the first nibble and put the odd nibble to\n // second part of buf[0] which otherwise will be left padded with a 0\n if ((nibbles.length & 1) === 1) {\n buf[0] |= 1 << 4;\n buf[0] |= nibbles[0];\n nibbles = nibbles.subarray(1);\n }\n // create bytes out of the rest even nibbles\n (0, exports.nibblesToBytes)(nibbles, buf.subarray(1));\n return buf;\n};\nexports.nibblesToCompactBytes = nibblesToCompactBytes;\nconst bytesToNibbles = str => {\n const l = str.length * 2 + 1;\n const nibbles = new Uint8Array(l);\n for (let i = 0; i < str.length; i++) {\n const b = str[i];\n nibbles[i * 2] = b / 16;\n nibbles[i * 2 + 1] = b % 16;\n }\n // This will get removed from calling function if the first nibble\n // indicates that terminator is not present\n nibbles[l - 1] = 16;\n return nibbles;\n};\nexports.bytesToNibbles = bytesToNibbles;\nconst compactBytesToNibbles = compact => {\n if (compact.length === 0) {\n return compact;\n }\n let base = (0, exports.bytesToNibbles)(compact);\n // delete terminator flag if terminator flag was not in first nibble\n if (base[0] < 2) {\n base = base.subarray(0, base.length - 1);\n }\n // chop the terminator nibble and the even padding (if there is one)\n // i.e. chop 2 left nibbles when even else 1 when odd\n const chop = 2 - (base[0] & 1);\n return base.subarray(chop);\n};\nexports.compactBytesToNibbles = compactBytesToNibbles;\n/**\n * A test helper to generates compact path for a subset of key bytes\n *\n * TODO: Commenting the code for now as this seems to be helper function\n * (from geth codebase )\n *\n */\n//\n//\n// export const getPathTo = (tillBytes: number, key: Buffer) => {\n// const hexNibbles = bytesToNibbles(key).subarray(0, tillBytes)\n// // Remove the terminator if its there, although it would be there only if tillBytes >= key.length\n// // This seems to be a test helper to generate paths so correctness of this isn't necessary\n// hexNibbles[hexNibbles.length - 1] = 0\n// const compactBytes = nibblesToCompactBytes(hexNibbles)\n// return [Buffer.from(compactBytes)]\n// }\n","\"use strict\";\n\n/**\n * Ported to Typescript from original implementation below:\n * https://github.com/ahultgren/async-eventemitter -- MIT licensed\n *\n * Type Definitions based on work by: patarapolw -- MIT licensed\n * that was contributed to Definitely Typed below:\n * https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/async-eventemitter\n */\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.AsyncEventEmitter = void 0;\nconst events_1 = require(\"events\");\nasync function runInSeries(context, tasks, data) {\n let error;\n for await (const task of tasks) {\n try {\n if (task.length < 2) {\n //sync\n task.call(context, data);\n } else {\n await new Promise((resolve, reject) => {\n task.call(context, data, error => {\n if (error) {\n reject(error);\n } else {\n resolve();\n }\n });\n });\n }\n } catch (e) {\n error = e;\n }\n }\n if (error) {\n throw error;\n }\n}\nclass AsyncEventEmitter extends events_1.EventEmitter {\n emit(event, ...args) {\n let [data, callback] = args;\n const self = this;\n let listeners = self._events[event] ?? [];\n // Optional data argument\n if (callback === undefined && typeof data === 'function') {\n callback = data;\n data = undefined;\n }\n // Special treatment of internal newListener and removeListener events\n if (event === 'newListener' || event === 'removeListener') {\n data = {\n event: data,\n fn: callback\n };\n callback = undefined;\n }\n // A single listener is just a function not an array...\n listeners = Array.isArray(listeners) ? listeners : [listeners];\n runInSeries(self, listeners.slice(), data).then(callback).catch(callback);\n return self.listenerCount(event) > 0;\n }\n once(event, listener) {\n const self = this;\n let g;\n if (typeof listener !== 'function') {\n throw new TypeError('listener must be a function');\n }\n // Hack to support set arity\n if (listener.length >= 2) {\n g = function (e, next) {\n self.removeListener(event, g);\n void listener(e, next);\n };\n } else {\n g = function (e) {\n self.removeListener(event, g);\n void listener(e, g);\n };\n }\n self.on(event, g);\n return self;\n }\n first(event, listener) {\n let listeners = this._events[event] ?? [];\n // Contract\n if (typeof listener !== 'function') {\n throw new TypeError('listener must be a function');\n }\n // Listeners are not always an array\n if (!Array.isArray(listeners)) {\n ;\n this._events[event] = listeners = [listeners];\n }\n listeners.unshift(listener);\n return this;\n }\n before(event, target, listener) {\n return this.beforeOrAfter(event, target, listener);\n }\n after(event, target, listener) {\n return this.beforeOrAfter(event, target, listener, 'after');\n }\n beforeOrAfter(event, target, listener, beforeOrAfter) {\n let listeners = this._events[event] ?? [];\n let i;\n let index;\n const add = beforeOrAfter === 'after' ? 1 : 0;\n // Contract\n if (typeof listener !== 'function') {\n throw new TypeError('listener must be a function');\n }\n if (typeof target !== 'function') {\n throw new TypeError('target must be a function');\n }\n // Listeners are not always an array\n if (!Array.isArray(listeners)) {\n ;\n this._events[event] = listeners = [listeners];\n }\n index = listeners.length;\n for (i = listeners.length; i--;) {\n if (listeners[i] === target) {\n index = i + add;\n break;\n }\n }\n listeners.splice(index, 0, listener);\n return this;\n }\n on(event, listener) {\n return super.on(event, listener);\n }\n addListener(event, listener) {\n return super.addListener(event, listener);\n }\n prependListener(event, listener) {\n return super.prependListener(event, listener);\n }\n prependOnceListener(event, listener) {\n return super.prependOnceListener(event, listener);\n }\n removeAllListeners(event) {\n return super.removeAllListeners(event);\n }\n removeListener(event, listener) {\n return super.removeListener(event, listener);\n }\n eventNames() {\n return super.eventNames();\n }\n listeners(event) {\n return super.listeners(event);\n }\n listenerCount(event) {\n return super.listenerCount(event);\n }\n getMaxListeners() {\n return super.getMaxListeners();\n }\n setMaxListeners(maxListeners) {\n return super.setMaxListeners(maxListeners);\n }\n}\nexports.AsyncEventEmitter = AsyncEventEmitter;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Lock = void 0;\n// Based on https://github.com/jsoendermann/semaphore-async-await/blob/master/src/Semaphore.ts\nclass Lock {\n constructor() {\n this.permits = 1;\n this.promiseResolverQueue = [];\n }\n /**\n * Returns a promise used to wait for a permit to become available. This method should be awaited on.\n * @returns A promise that gets resolved when execution is allowed to proceed.\n */\n async acquire() {\n if (this.permits > 0) {\n this.permits -= 1;\n return Promise.resolve(true);\n }\n // If there is no permit available, we return a promise that resolves once the semaphore gets\n // signaled enough times that permits is equal to one.\n return new Promise(resolver => this.promiseResolverQueue.push(resolver));\n }\n /**\n * Increases the number of permits by one. If there are other functions waiting, one of them will\n * continue to execute in a future iteration of the event loop.\n */\n release() {\n this.permits += 1;\n if (this.permits > 1 && this.promiseResolverQueue.length > 0) {\n // eslint-disable-next-line no-console\n console.warn('Lock.permits should never be > 0 when there is someone waiting.');\n } else if (this.permits === 1 && this.promiseResolverQueue.length > 0) {\n // If there is someone else waiting, immediately consume the permit that was released\n // at the beginning of this function and let the waiting function resume.\n this.permits -= 1;\n const nextResolver = this.promiseResolverQueue.shift();\n if (nextResolver) {\n nextResolver(true);\n }\n }\n }\n}\nexports.Lock = Lock;\n","/*! https://mths.be/punycode v1.4.1 by @mathias */\n;\n(function (root) {\n /** Detect free variables */\n var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n var freeModule = typeof module == 'object' && module && !module.nodeType && module;\n var freeGlobal = typeof global == 'object' && global;\n if (freeGlobal.global === freeGlobal || freeGlobal.window === freeGlobal || freeGlobal.self === freeGlobal) {\n root = freeGlobal;\n }\n\n /**\n * The `punycode` object.\n * @name punycode\n * @type Object\n */\n var punycode,\n /** Highest positive signed 32-bit float value */\n maxInt = 2147483647,\n // aka. 0x7FFFFFFF or 2^31-1\n\n /** Bootstring parameters */\n base = 36,\n tMin = 1,\n tMax = 26,\n skew = 38,\n damp = 700,\n initialBias = 72,\n initialN = 128,\n // 0x80\n delimiter = '-',\n // '\\x2D'\n\n /** Regular expressions */\n regexPunycode = /^xn--/,\n regexNonASCII = /[^\\x20-\\x7E]/,\n // unprintable ASCII chars + non-ASCII chars\n regexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g,\n // RFC 3490 separators\n\n /** Error messages */\n 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 /** Convenience shortcuts */\n baseMinusTMin = base - tMin,\n floor = Math.floor,\n stringFromCharCode = String.fromCharCode,\n /** Temporary variable */\n key;\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 */\n function 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 */\n function map(array, fn) {\n var length = array.length;\n var result = [];\n while (length--) {\n result[length] = fn(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 {Array} A new string of characters returned by the callback\n * function.\n */\n function mapDomain(string, fn) {\n var parts = string.split('@');\n var 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 string = parts[1];\n }\n // Avoid `split(regex)` for IE8 compatibility. See #17.\n string = string.replace(regexSeparators, '\\x2E');\n var labels = string.split('.');\n var encoded = map(labels, fn).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 \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 */\n function ucs2decode(string) {\n var output = [],\n counter = 0,\n length = string.length,\n value,\n extra;\n while (counter < length) {\n value = string.charCodeAt(counter++);\n if (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n // high surrogate, and there is a next character\n extra = string.charCodeAt(counter++);\n if ((extra & 0xFC00) == 0xDC00) {\n // low surrogate\n output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n } else {\n // unmatched surrogate; only append this code unit, in case the next\n // 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 */\n function ucs2encode(array) {\n return map(array, function (value) {\n var output = '';\n if (value > 0xFFFF) {\n value -= 0x10000;\n output += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800);\n value = 0xDC00 | value & 0x3FF;\n }\n output += stringFromCharCode(value);\n return output;\n }).join('');\n }\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 */\n function basicToDigit(codePoint) {\n if (codePoint - 48 < 10) {\n return codePoint - 22;\n }\n if (codePoint - 65 < 26) {\n return codePoint - 65;\n }\n if (codePoint - 97 < 26) {\n return codePoint - 97;\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 */\n function digitToBasic(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 */\n function adapt(delta, numPoints, firstTime) {\n var k = 0;\n delta = firstTime ? floor(delta / damp) : delta >> 1;\n delta += floor(delta / numPoints);\n for /* no initialization */\n (; 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 */\n function decode(input) {\n // Don't use UCS-2\n var output = [],\n inputLength = input.length,\n out,\n i = 0,\n n = initialN,\n bias = initialBias,\n basic,\n j,\n index,\n oldi,\n w,\n k,\n digit,\n t,\n /** Cached calculation results */\n baseMinusT;\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 basic = input.lastIndexOf(delimiter);\n if (basic < 0) {\n basic = 0;\n }\n for (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 /* no final expression */\n (index = basic > 0 ? basic + 1 : 0; index < inputLength;) {\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 for /* no condition */\n (oldi = i, w = 1, k = base;; k += base) {\n if (index >= inputLength) {\n error('invalid-input');\n }\n digit = basicToDigit(input.charCodeAt(index++));\n if (digit >= base || digit > floor((maxInt - i) / w)) {\n error('overflow');\n }\n i += digit * w;\n t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n if (digit < t) {\n break;\n }\n baseMinusT = base - t;\n if (w > floor(maxInt / baseMinusT)) {\n error('overflow');\n }\n w *= baseMinusT;\n }\n 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 += floor(i / out);\n i %= out;\n\n // Insert `n` at position `i` of the output\n output.splice(i++, 0, n);\n }\n return ucs2encode(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 */\n function encode(input) {\n var n,\n delta,\n handledCPCount,\n basicLength,\n bias,\n j,\n m,\n q,\n k,\n t,\n currentValue,\n output = [],\n /** `inputLength` will hold the number of code points in `input`. */\n inputLength,\n /** Cached calculation results */\n handledCPCountPlusOne,\n baseMinusT,\n qMinusT;\n\n // Convert the input in UCS-2 to Unicode\n input = ucs2decode(input);\n\n // Cache the length\n inputLength = input.length;\n\n // Initialize the state\n n = initialN;\n delta = 0;\n bias = initialBias;\n\n // Handle the basic code points\n for (j = 0; j < inputLength; ++j) {\n currentValue = input[j];\n if (currentValue < 0x80) {\n output.push(stringFromCharCode(currentValue));\n }\n }\n handledCPCount = basicLength = output.length;\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 - if it is not empty - with a delimiter\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 for (m = maxInt, j = 0; j < inputLength; ++j) {\n currentValue = input[j];\n if (currentValue >= n && currentValue < m) {\n m = currentValue;\n }\n }\n\n // Increase `delta` enough to advance the decoder's state to ,\n // but guard against overflow\n handledCPCountPlusOne = handledCPCount + 1;\n if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n error('overflow');\n }\n delta += (m - n) * handledCPCountPlusOne;\n n = m;\n for (j = 0; j < inputLength; ++j) {\n currentValue = input[j];\n if (currentValue < n && ++delta > maxInt) {\n error('overflow');\n }\n if (currentValue == n) {\n // Represent delta as a generalized variable-length integer\n for /* no condition */\n (q = delta, k = base;; k += base) {\n t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n if (q < t) {\n break;\n }\n qMinusT = q - t;\n baseMinusT = base - t;\n output.push(stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)));\n q = floor(qMinusT / baseMinusT);\n }\n output.push(stringFromCharCode(digitToBasic(q, 0)));\n bias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength);\n delta = 0;\n ++handledCPCount;\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 */\n function toUnicode(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 */\n function toASCII(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 */\n punycode = {\n /**\n * A string representing the current Punycode.js version number.\n * @memberOf punycode\n * @type String\n */\n 'version': '1.4.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 \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\n /** Expose `punycode` */\n // Some AMD build optimizers, like r.js, check for specific condition patterns\n // like the following:\n if (typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\n define('punycode', function () {\n return punycode;\n });\n } else if (freeExports && freeModule) {\n if (module.exports == freeExports) {\n // in Node.js, io.js, or RingoJS v0.8.0+\n freeModule.exports = punycode;\n } else {\n // in Narwhal or RingoJS v0.7.0-\n for (key in punycode) {\n punycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]);\n }\n }\n } else {\n // in Rhino or a web browser\n root.punycode = punycode;\n }\n})(this);","var hasMap = typeof Map === 'function' && Map.prototype;\nvar mapSizeDescriptor = Object.getOwnPropertyDescriptor && hasMap ? Object.getOwnPropertyDescriptor(Map.prototype, 'size') : null;\nvar mapSize = hasMap && mapSizeDescriptor && typeof mapSizeDescriptor.get === 'function' ? mapSizeDescriptor.get : null;\nvar mapForEach = hasMap && Map.prototype.forEach;\nvar hasSet = typeof Set === 'function' && Set.prototype;\nvar setSizeDescriptor = Object.getOwnPropertyDescriptor && hasSet ? Object.getOwnPropertyDescriptor(Set.prototype, 'size') : null;\nvar setSize = hasSet && setSizeDescriptor && typeof setSizeDescriptor.get === 'function' ? setSizeDescriptor.get : null;\nvar setForEach = hasSet && Set.prototype.forEach;\nvar hasWeakMap = typeof WeakMap === 'function' && WeakMap.prototype;\nvar weakMapHas = hasWeakMap ? WeakMap.prototype.has : null;\nvar hasWeakSet = typeof WeakSet === 'function' && WeakSet.prototype;\nvar weakSetHas = hasWeakSet ? WeakSet.prototype.has : null;\nvar hasWeakRef = typeof WeakRef === 'function' && WeakRef.prototype;\nvar weakRefDeref = hasWeakRef ? WeakRef.prototype.deref : null;\nvar booleanValueOf = Boolean.prototype.valueOf;\nvar objectToString = Object.prototype.toString;\nvar functionToString = Function.prototype.toString;\nvar $match = String.prototype.match;\nvar $slice = String.prototype.slice;\nvar $replace = String.prototype.replace;\nvar $toUpperCase = String.prototype.toUpperCase;\nvar $toLowerCase = String.prototype.toLowerCase;\nvar $test = RegExp.prototype.test;\nvar $concat = Array.prototype.concat;\nvar $join = Array.prototype.join;\nvar $arrSlice = Array.prototype.slice;\nvar $floor = Math.floor;\nvar bigIntValueOf = typeof BigInt === 'function' ? BigInt.prototype.valueOf : null;\nvar gOPS = Object.getOwnPropertySymbols;\nvar symToString = typeof Symbol === 'function' && typeof Symbol.iterator === 'symbol' ? Symbol.prototype.toString : null;\nvar hasShammedSymbols = typeof Symbol === 'function' && typeof Symbol.iterator === 'object';\n// ie, `has-tostringtag/shams\nvar toStringTag = typeof Symbol === 'function' && Symbol.toStringTag && (typeof Symbol.toStringTag === hasShammedSymbols ? 'object' : 'symbol') ? Symbol.toStringTag : null;\nvar isEnumerable = Object.prototype.propertyIsEnumerable;\nvar gPO = (typeof Reflect === 'function' ? Reflect.getPrototypeOf : Object.getPrototypeOf) || ([].__proto__ === Array.prototype // eslint-disable-line no-proto\n? function (O) {\n return O.__proto__; // eslint-disable-line no-proto\n} : null);\nfunction addNumericSeparator(num, str) {\n if (num === Infinity || num === -Infinity || num !== num || num && num > -1000 && num < 1000 || $test.call(/e/, str)) {\n return str;\n }\n var sepRegex = /[0-9](?=(?:[0-9]{3})+(?![0-9]))/g;\n if (typeof num === 'number') {\n var int = num < 0 ? -$floor(-num) : $floor(num); // trunc(num)\n if (int !== num) {\n var intStr = String(int);\n var dec = $slice.call(str, intStr.length + 1);\n return $replace.call(intStr, sepRegex, '$&_') + '.' + $replace.call($replace.call(dec, /([0-9]{3})/g, '$&_'), /_$/, '');\n }\n }\n return $replace.call(str, sepRegex, '$&_');\n}\nvar utilInspect = require('./util.inspect');\nvar inspectCustom = utilInspect.custom;\nvar inspectSymbol = isSymbol(inspectCustom) ? inspectCustom : null;\nvar quotes = {\n __proto__: null,\n 'double': '\"',\n single: \"'\"\n};\nvar quoteREs = {\n __proto__: null,\n 'double': /([\"\\\\])/g,\n single: /(['\\\\])/g\n};\nmodule.exports = function inspect_(obj, options, depth, seen) {\n var opts = options || {};\n if (has(opts, 'quoteStyle') && !has(quotes, opts.quoteStyle)) {\n throw new TypeError('option \"quoteStyle\" must be \"single\" or \"double\"');\n }\n if (has(opts, 'maxStringLength') && (typeof opts.maxStringLength === 'number' ? opts.maxStringLength < 0 && opts.maxStringLength !== Infinity : opts.maxStringLength !== null)) {\n throw new TypeError('option \"maxStringLength\", if provided, must be a positive integer, Infinity, or `null`');\n }\n var customInspect = has(opts, 'customInspect') ? opts.customInspect : true;\n if (typeof customInspect !== 'boolean' && customInspect !== 'symbol') {\n throw new TypeError('option \"customInspect\", if provided, must be `true`, `false`, or `\\'symbol\\'`');\n }\n if (has(opts, 'indent') && opts.indent !== null && opts.indent !== '\\t' && !(parseInt(opts.indent, 10) === opts.indent && opts.indent > 0)) {\n throw new TypeError('option \"indent\" must be \"\\\\t\", an integer > 0, or `null`');\n }\n if (has(opts, 'numericSeparator') && typeof opts.numericSeparator !== 'boolean') {\n throw new TypeError('option \"numericSeparator\", if provided, must be `true` or `false`');\n }\n var numericSeparator = opts.numericSeparator;\n if (typeof obj === 'undefined') {\n return 'undefined';\n }\n if (obj === null) {\n return 'null';\n }\n if (typeof obj === 'boolean') {\n return obj ? 'true' : 'false';\n }\n if (typeof obj === 'string') {\n return inspectString(obj, opts);\n }\n if (typeof obj === 'number') {\n if (obj === 0) {\n return Infinity / obj > 0 ? '0' : '-0';\n }\n var str = String(obj);\n return numericSeparator ? addNumericSeparator(obj, str) : str;\n }\n if (typeof obj === 'bigint') {\n var bigIntStr = String(obj) + 'n';\n return numericSeparator ? addNumericSeparator(obj, bigIntStr) : bigIntStr;\n }\n var maxDepth = typeof opts.depth === 'undefined' ? 5 : opts.depth;\n if (typeof depth === 'undefined') {\n depth = 0;\n }\n if (depth >= maxDepth && maxDepth > 0 && typeof obj === 'object') {\n return isArray(obj) ? '[Array]' : '[Object]';\n }\n var indent = getIndent(opts, depth);\n if (typeof seen === 'undefined') {\n seen = [];\n } else if (indexOf(seen, obj) >= 0) {\n return '[Circular]';\n }\n function inspect(value, from, noIndent) {\n if (from) {\n seen = $arrSlice.call(seen);\n seen.push(from);\n }\n if (noIndent) {\n var newOpts = {\n depth: opts.depth\n };\n if (has(opts, 'quoteStyle')) {\n newOpts.quoteStyle = opts.quoteStyle;\n }\n return inspect_(value, newOpts, depth + 1, seen);\n }\n return inspect_(value, opts, depth + 1, seen);\n }\n if (typeof obj === 'function' && !isRegExp(obj)) {\n // in older engines, regexes are callable\n var name = nameOf(obj);\n var keys = arrObjKeys(obj, inspect);\n return '[Function' + (name ? ': ' + name : ' (anonymous)') + ']' + (keys.length > 0 ? ' { ' + $join.call(keys, ', ') + ' }' : '');\n }\n if (isSymbol(obj)) {\n var symString = hasShammedSymbols ? $replace.call(String(obj), /^(Symbol\\(.*\\))_[^)]*$/, '$1') : symToString.call(obj);\n return typeof obj === 'object' && !hasShammedSymbols ? markBoxed(symString) : symString;\n }\n if (isElement(obj)) {\n var s = '<' + $toLowerCase.call(String(obj.nodeName));\n var attrs = obj.attributes || [];\n for (var i = 0; i < attrs.length; i++) {\n s += ' ' + attrs[i].name + '=' + wrapQuotes(quote(attrs[i].value), 'double', opts);\n }\n s += '>';\n if (obj.childNodes && obj.childNodes.length) {\n s += '...';\n }\n s += '';\n return s;\n }\n if (isArray(obj)) {\n if (obj.length === 0) {\n return '[]';\n }\n var xs = arrObjKeys(obj, inspect);\n if (indent && !singleLineValues(xs)) {\n return '[' + indentedJoin(xs, indent) + ']';\n }\n return '[ ' + $join.call(xs, ', ') + ' ]';\n }\n if (isError(obj)) {\n var parts = arrObjKeys(obj, inspect);\n if (!('cause' in Error.prototype) && 'cause' in obj && !isEnumerable.call(obj, 'cause')) {\n return '{ [' + String(obj) + '] ' + $join.call($concat.call('[cause]: ' + inspect(obj.cause), parts), ', ') + ' }';\n }\n if (parts.length === 0) {\n return '[' + String(obj) + ']';\n }\n return '{ [' + String(obj) + '] ' + $join.call(parts, ', ') + ' }';\n }\n if (typeof obj === 'object' && customInspect) {\n if (inspectSymbol && typeof obj[inspectSymbol] === 'function' && utilInspect) {\n return utilInspect(obj, {\n depth: maxDepth - depth\n });\n } else if (customInspect !== 'symbol' && typeof obj.inspect === 'function') {\n return obj.inspect();\n }\n }\n if (isMap(obj)) {\n var mapParts = [];\n if (mapForEach) {\n mapForEach.call(obj, function (value, key) {\n mapParts.push(inspect(key, obj, true) + ' => ' + inspect(value, obj));\n });\n }\n return collectionOf('Map', mapSize.call(obj), mapParts, indent);\n }\n if (isSet(obj)) {\n var setParts = [];\n if (setForEach) {\n setForEach.call(obj, function (value) {\n setParts.push(inspect(value, obj));\n });\n }\n return collectionOf('Set', setSize.call(obj), setParts, indent);\n }\n if (isWeakMap(obj)) {\n return weakCollectionOf('WeakMap');\n }\n if (isWeakSet(obj)) {\n return weakCollectionOf('WeakSet');\n }\n if (isWeakRef(obj)) {\n return weakCollectionOf('WeakRef');\n }\n if (isNumber(obj)) {\n return markBoxed(inspect(Number(obj)));\n }\n if (isBigInt(obj)) {\n return markBoxed(inspect(bigIntValueOf.call(obj)));\n }\n if (isBoolean(obj)) {\n return markBoxed(booleanValueOf.call(obj));\n }\n if (isString(obj)) {\n return markBoxed(inspect(String(obj)));\n }\n // note: in IE 8, sometimes `global !== window` but both are the prototypes of each other\n /* eslint-env browser */\n if (typeof window !== 'undefined' && obj === window) {\n return '{ [object Window] }';\n }\n if (typeof globalThis !== 'undefined' && obj === globalThis || typeof global !== 'undefined' && obj === global) {\n return '{ [object globalThis] }';\n }\n if (!isDate(obj) && !isRegExp(obj)) {\n var ys = arrObjKeys(obj, inspect);\n var isPlainObject = gPO ? gPO(obj) === Object.prototype : obj instanceof Object || obj.constructor === Object;\n var protoTag = obj instanceof Object ? '' : 'null prototype';\n var stringTag = !isPlainObject && toStringTag && Object(obj) === obj && toStringTag in obj ? $slice.call(toStr(obj), 8, -1) : protoTag ? 'Object' : '';\n var constructorTag = isPlainObject || typeof obj.constructor !== 'function' ? '' : obj.constructor.name ? obj.constructor.name + ' ' : '';\n var tag = constructorTag + (stringTag || protoTag ? '[' + $join.call($concat.call([], stringTag || [], protoTag || []), ': ') + '] ' : '');\n if (ys.length === 0) {\n return tag + '{}';\n }\n if (indent) {\n return tag + '{' + indentedJoin(ys, indent) + '}';\n }\n return tag + '{ ' + $join.call(ys, ', ') + ' }';\n }\n return String(obj);\n};\nfunction wrapQuotes(s, defaultStyle, opts) {\n var style = opts.quoteStyle || defaultStyle;\n var quoteChar = quotes[style];\n return quoteChar + s + quoteChar;\n}\nfunction quote(s) {\n return $replace.call(String(s), /\"/g, '"');\n}\nfunction isArray(obj) {\n return toStr(obj) === '[object Array]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj));\n}\nfunction isDate(obj) {\n return toStr(obj) === '[object Date]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj));\n}\nfunction isRegExp(obj) {\n return toStr(obj) === '[object RegExp]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj));\n}\nfunction isError(obj) {\n return toStr(obj) === '[object Error]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj));\n}\nfunction isString(obj) {\n return toStr(obj) === '[object String]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj));\n}\nfunction isNumber(obj) {\n return toStr(obj) === '[object Number]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj));\n}\nfunction isBoolean(obj) {\n return toStr(obj) === '[object Boolean]' && (!toStringTag || !(typeof obj === 'object' && toStringTag in obj));\n}\n\n// Symbol and BigInt do have Symbol.toStringTag by spec, so that can't be used to eliminate false positives\nfunction isSymbol(obj) {\n if (hasShammedSymbols) {\n return obj && typeof obj === 'object' && obj instanceof Symbol;\n }\n if (typeof obj === 'symbol') {\n return true;\n }\n if (!obj || typeof obj !== 'object' || !symToString) {\n return false;\n }\n try {\n symToString.call(obj);\n return true;\n } catch (e) {}\n return false;\n}\nfunction isBigInt(obj) {\n if (!obj || typeof obj !== 'object' || !bigIntValueOf) {\n return false;\n }\n try {\n bigIntValueOf.call(obj);\n return true;\n } catch (e) {}\n return false;\n}\nvar hasOwn = Object.prototype.hasOwnProperty || function (key) {\n return key in this;\n};\nfunction has(obj, key) {\n return hasOwn.call(obj, key);\n}\nfunction toStr(obj) {\n return objectToString.call(obj);\n}\nfunction nameOf(f) {\n if (f.name) {\n return f.name;\n }\n var m = $match.call(functionToString.call(f), /^function\\s*([\\w$]+)/);\n if (m) {\n return m[1];\n }\n return null;\n}\nfunction indexOf(xs, x) {\n if (xs.indexOf) {\n return xs.indexOf(x);\n }\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) {\n return i;\n }\n }\n return -1;\n}\nfunction isMap(x) {\n if (!mapSize || !x || typeof x !== 'object') {\n return false;\n }\n try {\n mapSize.call(x);\n try {\n setSize.call(x);\n } catch (s) {\n return true;\n }\n return x instanceof Map; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\nfunction isWeakMap(x) {\n if (!weakMapHas || !x || typeof x !== 'object') {\n return false;\n }\n try {\n weakMapHas.call(x, weakMapHas);\n try {\n weakSetHas.call(x, weakSetHas);\n } catch (s) {\n return true;\n }\n return x instanceof WeakMap; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\nfunction isWeakRef(x) {\n if (!weakRefDeref || !x || typeof x !== 'object') {\n return false;\n }\n try {\n weakRefDeref.call(x);\n return true;\n } catch (e) {}\n return false;\n}\nfunction isSet(x) {\n if (!setSize || !x || typeof x !== 'object') {\n return false;\n }\n try {\n setSize.call(x);\n try {\n mapSize.call(x);\n } catch (m) {\n return true;\n }\n return x instanceof Set; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\nfunction isWeakSet(x) {\n if (!weakSetHas || !x || typeof x !== 'object') {\n return false;\n }\n try {\n weakSetHas.call(x, weakSetHas);\n try {\n weakMapHas.call(x, weakMapHas);\n } catch (s) {\n return true;\n }\n return x instanceof WeakSet; // core-js workaround, pre-v2.5.0\n } catch (e) {}\n return false;\n}\nfunction isElement(x) {\n if (!x || typeof x !== 'object') {\n return false;\n }\n if (typeof HTMLElement !== 'undefined' && x instanceof HTMLElement) {\n return true;\n }\n return typeof x.nodeName === 'string' && typeof x.getAttribute === 'function';\n}\nfunction inspectString(str, opts) {\n if (str.length > opts.maxStringLength) {\n var remaining = str.length - opts.maxStringLength;\n var trailer = '... ' + remaining + ' more character' + (remaining > 1 ? 's' : '');\n return inspectString($slice.call(str, 0, opts.maxStringLength), opts) + trailer;\n }\n var quoteRE = quoteREs[opts.quoteStyle || 'single'];\n quoteRE.lastIndex = 0;\n // eslint-disable-next-line no-control-regex\n var s = $replace.call($replace.call(str, quoteRE, '\\\\$1'), /[\\x00-\\x1f]/g, lowbyte);\n return wrapQuotes(s, 'single', opts);\n}\nfunction lowbyte(c) {\n var n = c.charCodeAt(0);\n var x = {\n 8: 'b',\n 9: 't',\n 10: 'n',\n 12: 'f',\n 13: 'r'\n }[n];\n if (x) {\n return '\\\\' + x;\n }\n return '\\\\x' + (n < 0x10 ? '0' : '') + $toUpperCase.call(n.toString(16));\n}\nfunction markBoxed(str) {\n return 'Object(' + str + ')';\n}\nfunction weakCollectionOf(type) {\n return type + ' { ? }';\n}\nfunction collectionOf(type, size, entries, indent) {\n var joinedEntries = indent ? indentedJoin(entries, indent) : $join.call(entries, ', ');\n return type + ' (' + size + ') {' + joinedEntries + '}';\n}\nfunction singleLineValues(xs) {\n for (var i = 0; i < xs.length; i++) {\n if (indexOf(xs[i], '\\n') >= 0) {\n return false;\n }\n }\n return true;\n}\nfunction getIndent(opts, depth) {\n var baseIndent;\n if (opts.indent === '\\t') {\n baseIndent = '\\t';\n } else if (typeof opts.indent === 'number' && opts.indent > 0) {\n baseIndent = $join.call(Array(opts.indent + 1), ' ');\n } else {\n return null;\n }\n return {\n base: baseIndent,\n prev: $join.call(Array(depth + 1), baseIndent)\n };\n}\nfunction indentedJoin(xs, indent) {\n if (xs.length === 0) {\n return '';\n }\n var lineJoiner = '\\n' + indent.prev + indent.base;\n return lineJoiner + $join.call(xs, ',' + lineJoiner) + '\\n' + indent.prev;\n}\nfunction arrObjKeys(obj, inspect) {\n var isArr = isArray(obj);\n var xs = [];\n if (isArr) {\n xs.length = obj.length;\n for (var i = 0; i < obj.length; i++) {\n xs[i] = has(obj, i) ? inspect(obj[i], obj) : '';\n }\n }\n var syms = typeof gOPS === 'function' ? gOPS(obj) : [];\n var symMap;\n if (hasShammedSymbols) {\n symMap = {};\n for (var k = 0; k < syms.length; k++) {\n symMap['$' + syms[k]] = syms[k];\n }\n }\n for (var key in obj) {\n // eslint-disable-line no-restricted-syntax\n if (!has(obj, key)) {\n continue;\n } // eslint-disable-line no-restricted-syntax, no-continue\n if (isArr && String(Number(key)) === key && key < obj.length) {\n continue;\n } // eslint-disable-line no-restricted-syntax, no-continue\n if (hasShammedSymbols && symMap['$' + key] instanceof Symbol) {\n // this is to prevent shammed Symbols, which are stored as strings, from being included in the string key section\n continue; // eslint-disable-line no-restricted-syntax, no-continue\n } else if ($test.call(/[^\\w$]/, key)) {\n xs.push(inspect(key, obj) + ': ' + inspect(obj[key], obj));\n } else {\n xs.push(key + ': ' + inspect(obj[key], obj));\n }\n }\n if (typeof gOPS === 'function') {\n for (var j = 0; j < syms.length; j++) {\n if (isEnumerable.call(obj, syms[j])) {\n xs.push('[' + inspect(syms[j]) + ']: ' + inspect(obj[syms[j]], obj));\n }\n }\n }\n return xs;\n}","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar callBound = require('call-bind/callBound');\nvar inspect = require('object-inspect');\nvar $TypeError = require('es-errors/type');\nvar $WeakMap = GetIntrinsic('%WeakMap%', true);\nvar $Map = GetIntrinsic('%Map%', true);\nvar $weakMapGet = callBound('WeakMap.prototype.get', true);\nvar $weakMapSet = callBound('WeakMap.prototype.set', true);\nvar $weakMapHas = callBound('WeakMap.prototype.has', true);\nvar $mapGet = callBound('Map.prototype.get', true);\nvar $mapSet = callBound('Map.prototype.set', true);\nvar $mapHas = callBound('Map.prototype.has', true);\n\n/*\n* This function traverses the list returning the node corresponding to the given key.\n*\n* That node is also moved to the head of the list, so that if it's accessed again we don't need to traverse the whole list. By doing so, all the recently used nodes can be accessed relatively quickly.\n*/\n/** @type {import('.').listGetNode} */\nvar listGetNode = function (list, key) {\n // eslint-disable-line consistent-return\n /** @type {typeof list | NonNullable<(typeof list)['next']>} */\n var prev = list;\n /** @type {(typeof list)['next']} */\n var curr;\n for (; (curr = prev.next) !== null; prev = curr) {\n if (curr.key === key) {\n prev.next = curr.next;\n // eslint-disable-next-line no-extra-parens\n curr.next = /** @type {NonNullable} */list.next;\n list.next = curr; // eslint-disable-line no-param-reassign\n return curr;\n }\n }\n};\n\n/** @type {import('.').listGet} */\nvar listGet = function (objects, key) {\n var node = listGetNode(objects, key);\n return node && node.value;\n};\n/** @type {import('.').listSet} */\nvar listSet = function (objects, key, value) {\n var node = listGetNode(objects, key);\n if (node) {\n node.value = value;\n } else {\n // Prepend the new node to the beginning of the list\n objects.next = /** @type {import('.').ListNode} */{\n // eslint-disable-line no-param-reassign, no-extra-parens\n key: key,\n next: objects.next,\n value: value\n };\n }\n};\n/** @type {import('.').listHas} */\nvar listHas = function (objects, key) {\n return !!listGetNode(objects, key);\n};\n\n/** @type {import('.')} */\nmodule.exports = function getSideChannel() {\n /** @type {WeakMap} */var $wm;\n /** @type {Map} */\n var $m;\n /** @type {import('.').RootNode} */\n var $o;\n\n /** @type {import('.').Channel} */\n var channel = {\n assert: function (key) {\n if (!channel.has(key)) {\n throw new $TypeError('Side channel does not contain ' + inspect(key));\n }\n },\n get: function (key) {\n // eslint-disable-line consistent-return\n if ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {\n if ($wm) {\n return $weakMapGet($wm, key);\n }\n } else if ($Map) {\n if ($m) {\n return $mapGet($m, key);\n }\n } else {\n if ($o) {\n // eslint-disable-line no-lonely-if\n return listGet($o, key);\n }\n }\n },\n has: function (key) {\n if ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {\n if ($wm) {\n return $weakMapHas($wm, key);\n }\n } else if ($Map) {\n if ($m) {\n return $mapHas($m, key);\n }\n } else {\n if ($o) {\n // eslint-disable-line no-lonely-if\n return listHas($o, key);\n }\n }\n return false;\n },\n set: function (key, value) {\n if ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {\n if (!$wm) {\n $wm = new $WeakMap();\n }\n $weakMapSet($wm, key, value);\n } else if ($Map) {\n if (!$m) {\n $m = new $Map();\n }\n $mapSet($m, key, value);\n } else {\n if (!$o) {\n // Initialize the linked list as an empty node, so that we don't have to special-case handling of the first node: we can always refer to it as (previous node).next, instead of something like (list).head\n $o = {\n key: {},\n next: null\n };\n }\n listSet($o, key, value);\n }\n }\n };\n return channel;\n};","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\nmodule.exports = {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n },\n RFC1738: Format.RFC1738,\n RFC3986: Format.RFC3986\n};","'use strict';\n\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\nvar hexTable = function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n return array;\n}();\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n if (isArray(obj)) {\n var compacted = [];\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n item.obj[item.prop] = compacted;\n }\n }\n};\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n return obj;\n};\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if (options && (options.plainObjects || options.allowPrototypes) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n return target;\n }\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\nvar limit = 1024;\n\n/* eslint operator-linebreak: [2, \"before\"] */\n\nvar encode = function encode(str, defaultEncoder, charset, kind, format) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n var out = '';\n for (var j = 0; j < string.length; j += limit) {\n var segment = string.length >= limit ? string.slice(j, j + limit) : string;\n var arr = [];\n for (var i = 0; i < segment.length; ++i) {\n var c = segment.charCodeAt(i);\n if (c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || c >= 0x30 && c <= 0x39 // 0-9\n || c >= 0x41 && c <= 0x5A // a-z\n || c >= 0x61 && c <= 0x7A // A-Z\n || format === formats.RFC1738 && (c === 0x28 || c === 0x29) // ( )\n ) {\n arr[arr.length] = segment.charAt(i);\n continue;\n }\n if (c < 0x80) {\n arr[arr.length] = hexTable[c];\n continue;\n }\n if (c < 0x800) {\n arr[arr.length] = hexTable[0xC0 | c >> 6] + hexTable[0x80 | c & 0x3F];\n continue;\n }\n if (c < 0xD800 || c >= 0xE000) {\n arr[arr.length] = hexTable[0xE0 | c >> 12] + hexTable[0x80 | c >> 6 & 0x3F] + hexTable[0x80 | c & 0x3F];\n continue;\n }\n i += 1;\n c = 0x10000 + ((c & 0x3FF) << 10 | segment.charCodeAt(i) & 0x3FF);\n arr[arr.length] = hexTable[0xF0 | c >> 18] + hexTable[0x80 | c >> 12 & 0x3F] + hexTable[0x80 | c >> 6 & 0x3F] + hexTable[0x80 | c & 0x3F];\n }\n out += arr.join('');\n }\n return out;\n};\nvar compact = function compact(value) {\n var queue = [{\n obj: {\n o: value\n },\n prop: 'o'\n }];\n var refs = [];\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({\n obj: obj,\n prop: key\n });\n refs.push(val);\n }\n }\n }\n compactQueue(queue);\n return value;\n};\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};","'use strict';\n\nvar getSideChannel = require('side-channel');\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\nvar isArray = Array.isArray;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\nvar toISO = Date.prototype.toISOString;\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n allowEmptyArrays: false,\n arrayFormat: 'indices',\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encodeDotInKeys: false,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string' || typeof v === 'number' || typeof v === 'boolean' || typeof v === 'symbol' || typeof v === 'bigint';\n};\nvar sentinel = {};\nvar stringify = function stringify(object, prefix, generateArrayPrefix, commaRoundTrip, allowEmptyArrays, strictNullHandling, skipNulls, encodeDotInKeys, encoder, filter, sort, allowDots, serializeDate, format, formatter, encodeValuesOnly, charset, sideChannel) {\n var obj = object;\n var tmpSc = sideChannel;\n var step = 0;\n var findFlag = false;\n while ((tmpSc = tmpSc.get(sentinel)) !== void undefined && !findFlag) {\n // Where object last appeared in the ref tree\n var pos = tmpSc.get(object);\n step += 1;\n if (typeof pos !== 'undefined') {\n if (pos === step) {\n throw new RangeError('Cyclic object value');\n } else {\n findFlag = true; // Break while\n }\n }\n if (typeof tmpSc.get(sentinel) === 'undefined') {\n step = 0;\n }\n }\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n });\n }\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key', format) : prefix;\n }\n obj = '';\n }\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key', format);\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value', format))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n var values = [];\n if (typeof obj === 'undefined') {\n return values;\n }\n var objKeys;\n if (generateArrayPrefix === 'comma' && isArray(obj)) {\n // we need to join elements in\n if (encodeValuesOnly && encoder) {\n obj = utils.maybeMap(obj, encoder);\n }\n objKeys = [{\n value: obj.length > 0 ? obj.join(',') || null : void undefined\n }];\n } else if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n var encodedPrefix = encodeDotInKeys ? prefix.replace(/\\./g, '%2E') : prefix;\n var adjustedPrefix = commaRoundTrip && isArray(obj) && obj.length === 1 ? encodedPrefix + '[]' : encodedPrefix;\n if (allowEmptyArrays && isArray(obj) && obj.length === 0) {\n return adjustedPrefix + '[]';\n }\n for (var j = 0; j < objKeys.length; ++j) {\n var key = objKeys[j];\n var value = typeof key === 'object' && typeof key.value !== 'undefined' ? key.value : obj[key];\n if (skipNulls && value === null) {\n continue;\n }\n var encodedKey = allowDots && encodeDotInKeys ? key.replace(/\\./g, '%2E') : key;\n var keyPrefix = isArray(obj) ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(adjustedPrefix, encodedKey) : adjustedPrefix : adjustedPrefix + (allowDots ? '.' + encodedKey : '[' + encodedKey + ']');\n sideChannel.set(object, step);\n var valueSideChannel = getSideChannel();\n valueSideChannel.set(sentinel, sideChannel);\n pushToArray(values, stringify(value, keyPrefix, generateArrayPrefix, commaRoundTrip, allowEmptyArrays, strictNullHandling, skipNulls, encodeDotInKeys, generateArrayPrefix === 'comma' && encodeValuesOnly && isArray(obj) ? null : encoder, filter, sort, allowDots, serializeDate, format, formatter, encodeValuesOnly, charset, valueSideChannel));\n }\n return values;\n};\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n if (typeof opts.allowEmptyArrays !== 'undefined' && typeof opts.allowEmptyArrays !== 'boolean') {\n throw new TypeError('`allowEmptyArrays` option can only be `true` or `false`, when provided');\n }\n if (typeof opts.encodeDotInKeys !== 'undefined' && typeof opts.encodeDotInKeys !== 'boolean') {\n throw new TypeError('`encodeDotInKeys` option can only be `true` or `false`, when provided');\n }\n if (opts.encoder !== null && typeof opts.encoder !== 'undefined' && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n var arrayFormat;\n if (opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if ('indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = defaults.arrayFormat;\n }\n if ('commaRoundTrip' in opts && typeof opts.commaRoundTrip !== 'boolean') {\n throw new TypeError('`commaRoundTrip` must be a boolean, or absent');\n }\n var allowDots = typeof opts.allowDots === 'undefined' ? opts.encodeDotInKeys === true ? true : defaults.allowDots : !!opts.allowDots;\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: allowDots,\n allowEmptyArrays: typeof opts.allowEmptyArrays === 'boolean' ? !!opts.allowEmptyArrays : defaults.allowEmptyArrays,\n arrayFormat: arrayFormat,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n commaRoundTrip: opts.commaRoundTrip,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encodeDotInKeys: typeof opts.encodeDotInKeys === 'boolean' ? opts.encodeDotInKeys : defaults.encodeDotInKeys,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n format: format,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n var objKeys;\n var filter;\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n var keys = [];\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n var generateArrayPrefix = arrayPrefixGenerators[options.arrayFormat];\n var commaRoundTrip = generateArrayPrefix === 'comma' && options.commaRoundTrip;\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n var sideChannel = getSideChannel();\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(obj[key], key, generateArrayPrefix, commaRoundTrip, options.allowEmptyArrays, options.strictNullHandling, options.skipNulls, options.encodeDotInKeys, options.encode ? options.encoder : null, options.filter, options.sort, options.allowDots, options.serializeDate, options.format, options.formatter, options.encodeValuesOnly, options.charset, sideChannel));\n }\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n return joined.length > 0 ? prefix + joined : '';\n};","'use strict';\n\nvar utils = require('./utils');\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\nvar defaults = {\n allowDots: false,\n allowEmptyArrays: false,\n allowPrototypes: false,\n allowSparse: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decodeDotInKeys: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n duplicates: 'combine',\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictDepth: false,\n strictNullHandling: false\n};\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {\n __proto__: null\n };\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n cleanStr = cleanStr.replace(/%5B/gi, '[').replace(/%5D/gi, ']');\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(parseArrayValue(part.slice(pos + 1), options), function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n });\n }\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n var existing = has.call(obj, key);\n if (existing && options.duplicates === 'combine') {\n obj[key] = utils.combine(obj[key], val);\n } else if (!existing || options.duplicates === 'last') {\n obj[key] = val;\n }\n }\n return obj;\n};\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n if (root === '[]' && options.parseArrays) {\n obj = options.allowEmptyArrays && (leaf === '' || options.strictNullHandling && leaf === null) ? [] : [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var decodedRoot = options.decodeDotInKeys ? cleanRoot.replace(/%2E/g, '.') : cleanRoot;\n var index = parseInt(decodedRoot, 10);\n if (!options.parseArrays && decodedRoot === '') {\n obj = {\n 0: leaf\n };\n } else if (!isNaN(index) && root !== decodedRoot && String(index) === decodedRoot && index >= 0 && options.parseArrays && index <= options.arrayLimit) {\n obj = [];\n obj[index] = leaf;\n } else if (decodedRoot !== '__proto__') {\n obj[decodedRoot] = leaf;\n }\n }\n leaf = obj;\n }\n return leaf;\n};\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, check strictDepth option for throw, else just add whatever is left\n\n if (segment) {\n if (options.strictDepth === true) {\n throw new RangeError('Input depth exceeded depth option of ' + options.depth + ' and strictDepth is true');\n }\n keys.push('[' + key.slice(segment.index) + ']');\n }\n return parseObject(keys, val, options, valuesParsed);\n};\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n if (typeof opts.allowEmptyArrays !== 'undefined' && typeof opts.allowEmptyArrays !== 'boolean') {\n throw new TypeError('`allowEmptyArrays` option can only be `true` or `false`, when provided');\n }\n if (typeof opts.decodeDotInKeys !== 'undefined' && typeof opts.decodeDotInKeys !== 'boolean') {\n throw new TypeError('`decodeDotInKeys` option can only be `true` or `false`, when provided');\n }\n if (opts.decoder !== null && typeof opts.decoder !== 'undefined' && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n var duplicates = typeof opts.duplicates === 'undefined' ? defaults.duplicates : opts.duplicates;\n if (duplicates !== 'combine' && duplicates !== 'first' && duplicates !== 'last') {\n throw new TypeError('The duplicates option must be either combine, first, or last');\n }\n var allowDots = typeof opts.allowDots === 'undefined' ? opts.decodeDotInKeys === true ? true : defaults.allowDots : !!opts.allowDots;\n return {\n allowDots: allowDots,\n allowEmptyArrays: typeof opts.allowEmptyArrays === 'boolean' ? !!opts.allowEmptyArrays : defaults.allowEmptyArrays,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n allowSparse: typeof opts.allowSparse === 'boolean' ? opts.allowSparse : defaults.allowSparse,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decodeDotInKeys: typeof opts.decodeDotInKeys === 'boolean' ? opts.decodeDotInKeys : defaults.decodeDotInKeys,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: typeof opts.depth === 'number' || opts.depth === false ? +opts.depth : defaults.depth,\n duplicates: duplicates,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictDepth: typeof opts.strictDepth === 'boolean' ? !!opts.strictDepth : defaults.strictDepth,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n if (options.allowSparse === true) {\n return obj;\n }\n return utils.compact(obj);\n};","'use strict';\n\nvar stringify = require('./stringify');\nvar parse = require('./parse');\nvar formats = require('./formats');\nmodule.exports = {\n formats: formats,\n parse: parse,\n stringify: stringify\n};","/*\n * Copyright Joyent, Inc. and other Node contributors.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a\n * 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 permit\n * persons to whom the Software is furnished to do so, subject to the\n * following conditions:\n *\n * The above copyright notice and this permission notice shall be included\n * in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n * NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n * USE OR OTHER DEALINGS IN THE SOFTWARE.\n */\n\n'use strict';\n\nvar punycode = require('punycode/');\nfunction Url() {\n this.protocol = null;\n this.slashes = null;\n this.auth = null;\n this.host = null;\n this.port = null;\n this.hostname = null;\n this.hash = null;\n this.search = null;\n this.query = null;\n this.pathname = null;\n this.path = null;\n this.href = null;\n}\n\n// Reference: RFC 3986, RFC 1808, RFC 2396\n\n/*\n * define these here so at least they only have to be\n * compiled once on the first module load.\n */\nvar protocolPattern = /^([a-z0-9.+-]+:)/i,\n portPattern = /:[0-9]*$/,\n // Special case for a simple path URL\n simplePathPattern = /^(\\/\\/?(?!\\/)[^?\\s]*)(\\?[^\\s]*)?$/,\n /*\n * RFC 2396: characters reserved for delimiting URLs.\n * We actually just auto-escape these.\n */\n delims = ['<', '>', '\"', '`', ' ', '\\r', '\\n', '\\t'],\n // RFC 2396: characters not allowed for various reasons.\n unwise = ['{', '}', '|', '\\\\', '^', '`'].concat(delims),\n // Allowed by RFCs, but cause of XSS attacks. Always escape these.\n autoEscape = ['\\''].concat(unwise),\n /*\n * Characters that are never ever allowed in a hostname.\n * Note that any invalid chars are also handled, but these\n * are the ones that are *expected* to be seen, so we fast-path\n * them.\n */\n nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape),\n hostEndingChars = ['/', '?', '#'],\n hostnameMaxLen = 255,\n hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/,\n hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/,\n // protocols that can allow \"unsafe\" and \"unwise\" chars.\n unsafeProtocol = {\n javascript: true,\n 'javascript:': true\n },\n // protocols that never have a hostname.\n hostlessProtocol = {\n javascript: true,\n 'javascript:': true\n },\n // protocols that always contain a // bit.\n slashedProtocol = {\n http: true,\n https: true,\n ftp: true,\n gopher: true,\n file: true,\n 'http:': true,\n 'https:': true,\n 'ftp:': true,\n 'gopher:': true,\n 'file:': true\n },\n querystring = require('qs');\nfunction urlParse(url, parseQueryString, slashesDenoteHost) {\n if (url && typeof url === 'object' && url instanceof Url) {\n return url;\n }\n var u = new Url();\n u.parse(url, parseQueryString, slashesDenoteHost);\n return u;\n}\nUrl.prototype.parse = function (url, parseQueryString, slashesDenoteHost) {\n if (typeof url !== 'string') {\n throw new TypeError(\"Parameter 'url' must be a string, not \" + typeof url);\n }\n\n /*\n * Copy chrome, IE, opera backslash-handling behavior.\n * Back slashes before the query string get converted to forward slashes\n * See: https://code.google.com/p/chromium/issues/detail?id=25916\n */\n var queryIndex = url.indexOf('?'),\n splitter = queryIndex !== -1 && queryIndex < url.indexOf('#') ? '?' : '#',\n uSplit = url.split(splitter),\n slashRegex = /\\\\/g;\n uSplit[0] = uSplit[0].replace(slashRegex, '/');\n url = uSplit.join(splitter);\n var rest = url;\n\n /*\n * trim before proceeding.\n * This is to support parse stuff like \" http://foo.com \\n\"\n */\n rest = rest.trim();\n if (!slashesDenoteHost && url.split('#').length === 1) {\n // Try fast path regexp\n var simplePath = simplePathPattern.exec(rest);\n if (simplePath) {\n this.path = rest;\n this.href = rest;\n this.pathname = simplePath[1];\n if (simplePath[2]) {\n this.search = simplePath[2];\n if (parseQueryString) {\n this.query = querystring.parse(this.search.substr(1));\n } else {\n this.query = this.search.substr(1);\n }\n } else if (parseQueryString) {\n this.search = '';\n this.query = {};\n }\n return this;\n }\n }\n var proto = protocolPattern.exec(rest);\n if (proto) {\n proto = proto[0];\n var lowerProto = proto.toLowerCase();\n this.protocol = lowerProto;\n rest = rest.substr(proto.length);\n }\n\n /*\n * figure out if it's got a host\n * user@server is *always* interpreted as a hostname, and url\n * resolution will treat //foo/bar as host=foo,path=bar because that's\n * how the browser resolves relative URLs.\n */\n if (slashesDenoteHost || proto || rest.match(/^\\/\\/[^@/]+@[^@/]+/)) {\n var slashes = rest.substr(0, 2) === '//';\n if (slashes && !(proto && hostlessProtocol[proto])) {\n rest = rest.substr(2);\n this.slashes = true;\n }\n }\n if (!hostlessProtocol[proto] && (slashes || proto && !slashedProtocol[proto])) {\n /*\n * there's a hostname.\n * the first instance of /, ?, ;, or # ends the host.\n *\n * If there is an @ in the hostname, then non-host chars *are* allowed\n * to the left of the last @ sign, unless some host-ending character\n * comes *before* the @-sign.\n * URLs are obnoxious.\n *\n * ex:\n * http://a@b@c/ => user:a@b host:c\n * http://a@b?@c => user:a host:c path:/?@c\n */\n\n /*\n * v0.12 TODO(isaacs): This is not quite how Chrome does things.\n * Review our test case against browsers more comprehensively.\n */\n\n // find the first instance of any hostEndingChars\n var hostEnd = -1;\n for (var i = 0; i < hostEndingChars.length; i++) {\n var hec = rest.indexOf(hostEndingChars[i]);\n if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) {\n hostEnd = hec;\n }\n }\n\n /*\n * at this point, either we have an explicit point where the\n * auth portion cannot go past, or the last @ char is the decider.\n */\n var auth, atSign;\n if (hostEnd === -1) {\n // atSign can be anywhere.\n atSign = rest.lastIndexOf('@');\n } else {\n /*\n * atSign must be in auth portion.\n * http://a@b/c@d => host:b auth:a path:/c@d\n */\n atSign = rest.lastIndexOf('@', hostEnd);\n }\n\n /*\n * Now we have a portion which is definitely the auth.\n * Pull that off.\n */\n if (atSign !== -1) {\n auth = rest.slice(0, atSign);\n rest = rest.slice(atSign + 1);\n this.auth = decodeURIComponent(auth);\n }\n\n // the host is the remaining to the left of the first non-host char\n hostEnd = -1;\n for (var i = 0; i < nonHostChars.length; i++) {\n var hec = rest.indexOf(nonHostChars[i]);\n if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) {\n hostEnd = hec;\n }\n }\n // if we still have not hit it, then the entire thing is a host.\n if (hostEnd === -1) {\n hostEnd = rest.length;\n }\n this.host = rest.slice(0, hostEnd);\n rest = rest.slice(hostEnd);\n\n // pull out port.\n this.parseHost();\n\n /*\n * we've indicated that there is a hostname,\n * so even if it's empty, it has to be present.\n */\n this.hostname = this.hostname || '';\n\n /*\n * if hostname begins with [ and ends with ]\n * assume that it's an IPv6 address.\n */\n var ipv6Hostname = this.hostname[0] === '[' && this.hostname[this.hostname.length - 1] === ']';\n\n // validate a little.\n if (!ipv6Hostname) {\n var hostparts = this.hostname.split(/\\./);\n for (var i = 0, l = hostparts.length; i < l; i++) {\n var part = hostparts[i];\n if (!part) {\n continue;\n }\n if (!part.match(hostnamePartPattern)) {\n var newpart = '';\n for (var j = 0, k = part.length; j < k; j++) {\n if (part.charCodeAt(j) > 127) {\n /*\n * we replace non-ASCII char with a temporary placeholder\n * we need this to make sure size of hostname is not\n * broken by replacing non-ASCII by nothing\n */\n newpart += 'x';\n } else {\n newpart += part[j];\n }\n }\n // we test again with ASCII char only\n if (!newpart.match(hostnamePartPattern)) {\n var validParts = hostparts.slice(0, i);\n var notHost = hostparts.slice(i + 1);\n var bit = part.match(hostnamePartStart);\n if (bit) {\n validParts.push(bit[1]);\n notHost.unshift(bit[2]);\n }\n if (notHost.length) {\n rest = '/' + notHost.join('.') + rest;\n }\n this.hostname = validParts.join('.');\n break;\n }\n }\n }\n }\n if (this.hostname.length > hostnameMaxLen) {\n this.hostname = '';\n } else {\n // hostnames are always lower case.\n this.hostname = this.hostname.toLowerCase();\n }\n if (!ipv6Hostname) {\n /*\n * IDNA Support: Returns a punycoded representation of \"domain\".\n * It only converts parts of the domain name that\n * have non-ASCII characters, i.e. it doesn't matter if\n * you call it with a domain that already is ASCII-only.\n */\n this.hostname = punycode.toASCII(this.hostname);\n }\n var p = this.port ? ':' + this.port : '';\n var h = this.hostname || '';\n this.host = h + p;\n this.href += this.host;\n\n /*\n * strip [ and ] from the hostname\n * the host field still retains them, though\n */\n if (ipv6Hostname) {\n this.hostname = this.hostname.substr(1, this.hostname.length - 2);\n if (rest[0] !== '/') {\n rest = '/' + rest;\n }\n }\n }\n\n /*\n * now rest is set to the post-host stuff.\n * chop off any delim chars.\n */\n if (!unsafeProtocol[lowerProto]) {\n /*\n * First, make 100% sure that any \"autoEscape\" chars get\n * escaped, even if encodeURIComponent doesn't think they\n * need to be.\n */\n for (var i = 0, l = autoEscape.length; i < l; i++) {\n var ae = autoEscape[i];\n if (rest.indexOf(ae) === -1) {\n continue;\n }\n var esc = encodeURIComponent(ae);\n if (esc === ae) {\n esc = escape(ae);\n }\n rest = rest.split(ae).join(esc);\n }\n }\n\n // chop off from the tail first.\n var hash = rest.indexOf('#');\n if (hash !== -1) {\n // got a fragment string.\n this.hash = rest.substr(hash);\n rest = rest.slice(0, hash);\n }\n var qm = rest.indexOf('?');\n if (qm !== -1) {\n this.search = rest.substr(qm);\n this.query = rest.substr(qm + 1);\n if (parseQueryString) {\n this.query = querystring.parse(this.query);\n }\n rest = rest.slice(0, qm);\n } else if (parseQueryString) {\n // no query string, but parseQueryString still requested\n this.search = '';\n this.query = {};\n }\n if (rest) {\n this.pathname = rest;\n }\n if (slashedProtocol[lowerProto] && this.hostname && !this.pathname) {\n this.pathname = '/';\n }\n\n // to support http.request\n if (this.pathname || this.search) {\n var p = this.pathname || '';\n var s = this.search || '';\n this.path = p + s;\n }\n\n // finally, reconstruct the href based on what has been validated.\n this.href = this.format();\n return this;\n};\n\n// format a parsed object into a url string\nfunction urlFormat(obj) {\n /*\n * ensure it's an object, and not a string url.\n * If it's an obj, this is a no-op.\n * this way, you can call url_format() on strings\n * to clean up potentially wonky urls.\n */\n if (typeof obj === 'string') {\n obj = urlParse(obj);\n }\n if (!(obj instanceof Url)) {\n return Url.prototype.format.call(obj);\n }\n return obj.format();\n}\nUrl.prototype.format = function () {\n var auth = this.auth || '';\n if (auth) {\n auth = encodeURIComponent(auth);\n auth = auth.replace(/%3A/i, ':');\n auth += '@';\n }\n var protocol = this.protocol || '',\n pathname = this.pathname || '',\n hash = this.hash || '',\n host = false,\n query = '';\n if (this.host) {\n host = auth + this.host;\n } else if (this.hostname) {\n host = auth + (this.hostname.indexOf(':') === -1 ? this.hostname : '[' + this.hostname + ']');\n if (this.port) {\n host += ':' + this.port;\n }\n }\n if (this.query && typeof this.query === 'object' && Object.keys(this.query).length) {\n query = querystring.stringify(this.query, {\n arrayFormat: 'repeat',\n addQueryPrefix: false\n });\n }\n var search = this.search || query && '?' + query || '';\n if (protocol && protocol.substr(-1) !== ':') {\n protocol += ':';\n }\n\n /*\n * only the slashedProtocols get the //. Not mailto:, xmpp:, etc.\n * unless they had them to begin with.\n */\n if (this.slashes || (!protocol || slashedProtocol[protocol]) && host !== false) {\n host = '//' + (host || '');\n if (pathname && pathname.charAt(0) !== '/') {\n pathname = '/' + pathname;\n }\n } else if (!host) {\n host = '';\n }\n if (hash && hash.charAt(0) !== '#') {\n hash = '#' + hash;\n }\n if (search && search.charAt(0) !== '?') {\n search = '?' + search;\n }\n pathname = pathname.replace(/[?#]/g, function (match) {\n return encodeURIComponent(match);\n });\n search = search.replace('#', '%23');\n return protocol + host + pathname + search + hash;\n};\nfunction urlResolve(source, relative) {\n return urlParse(source, false, true).resolve(relative);\n}\nUrl.prototype.resolve = function (relative) {\n return this.resolveObject(urlParse(relative, false, true)).format();\n};\nfunction urlResolveObject(source, relative) {\n if (!source) {\n return relative;\n }\n return urlParse(source, false, true).resolveObject(relative);\n}\nUrl.prototype.resolveObject = function (relative) {\n if (typeof relative === 'string') {\n var rel = new Url();\n rel.parse(relative, false, true);\n relative = rel;\n }\n var result = new Url();\n var tkeys = Object.keys(this);\n for (var tk = 0; tk < tkeys.length; tk++) {\n var tkey = tkeys[tk];\n result[tkey] = this[tkey];\n }\n\n /*\n * hash is always overridden, no matter what.\n * even href=\"\" will remove it.\n */\n result.hash = relative.hash;\n\n // if the relative url is empty, then there's nothing left to do here.\n if (relative.href === '') {\n result.href = result.format();\n return result;\n }\n\n // hrefs like //foo/bar always cut to the protocol.\n if (relative.slashes && !relative.protocol) {\n // take everything except the protocol from relative\n var rkeys = Object.keys(relative);\n for (var rk = 0; rk < rkeys.length; rk++) {\n var rkey = rkeys[rk];\n if (rkey !== 'protocol') {\n result[rkey] = relative[rkey];\n }\n }\n\n // urlParse appends trailing / to urls like http://www.example.com\n if (slashedProtocol[result.protocol] && result.hostname && !result.pathname) {\n result.pathname = '/';\n result.path = result.pathname;\n }\n result.href = result.format();\n return result;\n }\n if (relative.protocol && relative.protocol !== result.protocol) {\n /*\n * if it's a known url protocol, then changing\n * the protocol does weird things\n * first, if it's not file:, then we MUST have a host,\n * and if there was a path\n * to begin with, then we MUST have a path.\n * if it is file:, then the host is dropped,\n * because that's known to be hostless.\n * anything else is assumed to be absolute.\n */\n if (!slashedProtocol[relative.protocol]) {\n var keys = Object.keys(relative);\n for (var v = 0; v < keys.length; v++) {\n var k = keys[v];\n result[k] = relative[k];\n }\n result.href = result.format();\n return result;\n }\n result.protocol = relative.protocol;\n if (!relative.host && !hostlessProtocol[relative.protocol]) {\n var relPath = (relative.pathname || '').split('/');\n while (relPath.length && !(relative.host = relPath.shift())) {}\n if (!relative.host) {\n relative.host = '';\n }\n if (!relative.hostname) {\n relative.hostname = '';\n }\n if (relPath[0] !== '') {\n relPath.unshift('');\n }\n if (relPath.length < 2) {\n relPath.unshift('');\n }\n result.pathname = relPath.join('/');\n } else {\n result.pathname = relative.pathname;\n }\n result.search = relative.search;\n result.query = relative.query;\n result.host = relative.host || '';\n result.auth = relative.auth;\n result.hostname = relative.hostname || relative.host;\n result.port = relative.port;\n // to support http.request\n if (result.pathname || result.search) {\n var p = result.pathname || '';\n var s = result.search || '';\n result.path = p + s;\n }\n result.slashes = result.slashes || relative.slashes;\n result.href = result.format();\n return result;\n }\n var isSourceAbs = result.pathname && result.pathname.charAt(0) === '/',\n isRelAbs = relative.host || relative.pathname && relative.pathname.charAt(0) === '/',\n mustEndAbs = isRelAbs || isSourceAbs || result.host && relative.pathname,\n removeAllDots = mustEndAbs,\n srcPath = result.pathname && result.pathname.split('/') || [],\n relPath = relative.pathname && relative.pathname.split('/') || [],\n psychotic = result.protocol && !slashedProtocol[result.protocol];\n\n /*\n * if the url is a non-slashed url, then relative\n * links like ../.. should be able\n * to crawl up to the hostname, as well. This is strange.\n * result.protocol has already been set by now.\n * Later on, put the first path part into the host field.\n */\n if (psychotic) {\n result.hostname = '';\n result.port = null;\n if (result.host) {\n if (srcPath[0] === '') {\n srcPath[0] = result.host;\n } else {\n srcPath.unshift(result.host);\n }\n }\n result.host = '';\n if (relative.protocol) {\n relative.hostname = null;\n relative.port = null;\n if (relative.host) {\n if (relPath[0] === '') {\n relPath[0] = relative.host;\n } else {\n relPath.unshift(relative.host);\n }\n }\n relative.host = null;\n }\n mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === '');\n }\n if (isRelAbs) {\n // it's absolute.\n result.host = relative.host || relative.host === '' ? relative.host : result.host;\n result.hostname = relative.hostname || relative.hostname === '' ? relative.hostname : result.hostname;\n result.search = relative.search;\n result.query = relative.query;\n srcPath = relPath;\n // fall through to the dot-handling below.\n } else if (relPath.length) {\n /*\n * it's relative\n * throw away the existing file, and take the new path instead.\n */\n if (!srcPath) {\n srcPath = [];\n }\n srcPath.pop();\n srcPath = srcPath.concat(relPath);\n result.search = relative.search;\n result.query = relative.query;\n } else if (relative.search != null) {\n /*\n * just pull out the search.\n * like href='?foo'.\n * Put this after the other two cases because it simplifies the booleans\n */\n if (psychotic) {\n result.host = srcPath.shift();\n result.hostname = result.host;\n /*\n * occationaly the auth can get stuck only in host\n * this especially happens in cases like\n * url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n */\n var authInHost = result.host && result.host.indexOf('@') > 0 ? result.host.split('@') : false;\n if (authInHost) {\n result.auth = authInHost.shift();\n result.hostname = authInHost.shift();\n result.host = result.hostname;\n }\n }\n result.search = relative.search;\n result.query = relative.query;\n // to support http.request\n if (result.pathname !== null || result.search !== null) {\n result.path = (result.pathname ? result.pathname : '') + (result.search ? result.search : '');\n }\n result.href = result.format();\n return result;\n }\n if (!srcPath.length) {\n /*\n * no path at all. easy.\n * we've already handled the other stuff above.\n */\n result.pathname = null;\n // to support http.request\n if (result.search) {\n result.path = '/' + result.search;\n } else {\n result.path = null;\n }\n result.href = result.format();\n return result;\n }\n\n /*\n * if a url ENDs in . or .., then it must get a trailing slash.\n * however, if it ends in anything else non-slashy,\n * then it must NOT get a trailing slash.\n */\n var last = srcPath.slice(-1)[0];\n var hasTrailingSlash = (result.host || relative.host || srcPath.length > 1) && (last === '.' || last === '..') || last === '';\n\n /*\n * strip single dots, resolve double dots to parent dir\n * if the path tries to go above the root, `up` ends up > 0\n */\n var up = 0;\n for (var i = srcPath.length; i >= 0; i--) {\n last = srcPath[i];\n if (last === '.') {\n srcPath.splice(i, 1);\n } else if (last === '..') {\n srcPath.splice(i, 1);\n up++;\n } else if (up) {\n srcPath.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (!mustEndAbs && !removeAllDots) {\n for (; up--; up) {\n srcPath.unshift('..');\n }\n }\n if (mustEndAbs && srcPath[0] !== '' && (!srcPath[0] || srcPath[0].charAt(0) !== '/')) {\n srcPath.unshift('');\n }\n if (hasTrailingSlash && srcPath.join('/').substr(-1) !== '/') {\n srcPath.push('');\n }\n var isAbsolute = srcPath[0] === '' || srcPath[0] && srcPath[0].charAt(0) === '/';\n\n // put the host back\n if (psychotic) {\n result.hostname = isAbsolute ? '' : srcPath.length ? srcPath.shift() : '';\n result.host = result.hostname;\n /*\n * occationaly the auth can get stuck only in host\n * this especially happens in cases like\n * url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n */\n var authInHost = result.host && result.host.indexOf('@') > 0 ? result.host.split('@') : false;\n if (authInHost) {\n result.auth = authInHost.shift();\n result.hostname = authInHost.shift();\n result.host = result.hostname;\n }\n }\n mustEndAbs = mustEndAbs || result.host && srcPath.length;\n if (mustEndAbs && !isAbsolute) {\n srcPath.unshift('');\n }\n if (srcPath.length > 0) {\n result.pathname = srcPath.join('/');\n } else {\n result.pathname = null;\n result.path = null;\n }\n\n // to support request.http\n if (result.pathname !== null || result.search !== null) {\n result.path = (result.pathname ? result.pathname : '') + (result.search ? result.search : '');\n }\n result.auth = relative.auth || result.auth;\n result.slashes = result.slashes || relative.slashes;\n result.href = result.format();\n return result;\n};\nUrl.prototype.parseHost = function () {\n var host = this.host;\n var port = portPattern.exec(host);\n if (port) {\n port = port[0];\n if (port !== ':') {\n this.port = port.substr(1);\n }\n host = host.substr(0, host.length - port.length);\n }\n if (host) {\n this.hostname = host;\n }\n};\nexports.parse = urlParse;\nexports.resolve = urlResolve;\nexports.resolveObject = urlResolveObject;\nexports.format = urlFormat;\nexports.Url = Url;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.InvalidStatusCodeError = exports.InvalidCertError = void 0;\nconst DEFAULT_OPT = Object.freeze({\n redirect: true,\n expectStatusCode: 200,\n headers: {},\n full: false,\n keepAlive: true,\n cors: false,\n referrer: false,\n sslAllowSelfSigned: false,\n _redirectCount: 0\n});\nclass InvalidCertError extends Error {\n constructor(msg, fingerprint256) {\n super(msg);\n this.fingerprint256 = fingerprint256;\n }\n}\nexports.InvalidCertError = InvalidCertError;\nclass InvalidStatusCodeError extends Error {\n constructor(statusCode) {\n super(`Request Failed. Status Code: ${statusCode}`);\n this.statusCode = statusCode;\n }\n}\nexports.InvalidStatusCodeError = InvalidStatusCodeError;\nfunction detectType(b, type) {\n if (!type || type === 'text' || type === 'json') {\n try {\n let text = new TextDecoder('utf8', {\n fatal: true\n }).decode(b);\n if (type === 'text') return text;\n try {\n return JSON.parse(text);\n } catch (err) {\n if (type === 'json') throw err;\n return text;\n }\n } catch (err) {\n if (type === 'text' || type === 'json') throw err;\n }\n }\n return b;\n}\nlet agents = {};\nfunction fetchNode(url, _options) {\n let options = {\n ...DEFAULT_OPT,\n ..._options\n };\n const http = require('http');\n const https = require('https');\n const zlib = require('zlib');\n const {\n promisify\n } = require('util');\n const {\n resolve: urlResolve\n } = require('url');\n const isSecure = !!/^https/.test(url);\n let opts = {\n method: options.method || 'GET',\n headers: {\n 'Accept-Encoding': 'gzip, deflate, br'\n }\n };\n const compactFP = s => s.replace(/:| /g, '').toLowerCase();\n if (options.keepAlive) {\n const agentOpt = {\n keepAlive: true,\n keepAliveMsecs: 30 * 1000,\n maxFreeSockets: 1024,\n maxCachedSessions: 1024\n };\n const agentKey = [isSecure, isSecure && options.sslPinnedCertificates?.map(i => compactFP(i)).sort()].join();\n opts.agent = agents[agentKey] || (agents[agentKey] = new (isSecure ? https : http).Agent(agentOpt));\n }\n if (options.type === 'json') opts.headers['Content-Type'] = 'application/json';\n if (options.data) {\n if (!options.method) opts.method = 'POST';\n opts.body = options.type === 'json' ? JSON.stringify(options.data) : options.data;\n }\n opts.headers = {\n ...opts.headers,\n ...options.headers\n };\n if (options.sslAllowSelfSigned) opts.rejectUnauthorized = false;\n const handleRes = async res => {\n const status = res.statusCode;\n if (options.redirect && 300 <= status && status < 400 && res.headers['location']) {\n if (options._redirectCount == 10) throw new Error('Request failed. Too much redirects.');\n options._redirectCount += 1;\n return await fetchNode(urlResolve(url, res.headers['location']), options);\n }\n if (options.expectStatusCode && status !== options.expectStatusCode) {\n res.resume();\n throw new InvalidStatusCodeError(status);\n }\n let buf = [];\n for await (const chunk of res) buf.push(chunk);\n let bytes = Buffer.concat(buf);\n const encoding = res.headers['content-encoding'];\n if (encoding === 'br') bytes = await promisify(zlib.brotliDecompress)(bytes);\n if (encoding === 'gzip' || encoding === 'deflate') bytes = await promisify(zlib.unzip)(bytes);\n const body = detectType(bytes, options.type);\n if (options.full) return {\n headers: res.headers,\n status,\n body\n };\n return body;\n };\n return new Promise((resolve, reject) => {\n const handleError = async err => {\n if (err && err.code === 'DEPTH_ZERO_SELF_SIGNED_CERT') {\n try {\n await fetchNode(url, {\n ...options,\n sslAllowSelfSigned: true,\n sslPinnedCertificates: []\n });\n } catch (e) {\n if (e && e.fingerprint256) {\n err = new InvalidCertError(`Self-signed SSL certificate: ${e.fingerprint256}`, e.fingerprint256);\n }\n }\n }\n reject(err);\n };\n const req = (isSecure ? https : http).request(url, opts, res => {\n res.on('error', handleError);\n (async () => {\n try {\n resolve(await handleRes(res));\n } catch (error) {\n reject(error);\n }\n })();\n });\n req.on('error', handleError);\n const pinned = options.sslPinnedCertificates?.map(i => compactFP(i));\n const mfetchSecureConnect = socket => {\n const fp256 = compactFP(socket.getPeerCertificate()?.fingerprint256 || '');\n if (!fp256 && socket.isSessionReused()) return;\n if (pinned.includes(fp256)) return;\n req.emit('error', new InvalidCertError(`Invalid SSL certificate: ${fp256} Expected: ${pinned}`, fp256));\n return req.abort();\n };\n if (options.sslPinnedCertificates) {\n req.on('socket', socket => {\n const hasListeners = socket.listeners('secureConnect').map(i => (i.name || '').replace('bound ', '')).includes('mfetchSecureConnect');\n if (hasListeners) return;\n socket.on('secureConnect', mfetchSecureConnect.bind(null, socket));\n });\n }\n if (options.keepAlive) req.setNoDelay(true);\n if (opts.body) req.write(opts.body);\n req.end();\n });\n}\nconst SAFE_HEADERS = new Set(['Accept', 'Accept-Language', 'Content-Language', 'Content-Type'].map(i => i.toLowerCase()));\nconst FORBIDDEN_HEADERS = new Set(['Accept-Charset', 'Accept-Encoding', 'Access-Control-Request-Headers', 'Access-Control-Request-Method', 'Connection', 'Content-Length', 'Cookie', 'Cookie2', 'Date', 'DNT', 'Expect', 'Host', 'Keep-Alive', 'Origin', 'Referer', 'TE', 'Trailer', 'Transfer-Encoding', 'Upgrade', 'Via'].map(i => i.toLowerCase()));\nasync function fetchBrowser(url, _options) {\n let options = {\n ...DEFAULT_OPT,\n ..._options\n };\n const headers = new Headers();\n if (options.type === 'json') headers.set('Content-Type', 'application/json');\n let parsed = new URL(url);\n if (parsed.username) {\n const auth = btoa(`${parsed.username}:${parsed.password}`);\n headers.set('Authorization', `Basic ${auth}`);\n parsed.username = '';\n parsed.password = '';\n }\n url = '' + parsed;\n for (let k in options.headers) {\n const name = k.toLowerCase();\n if (SAFE_HEADERS.has(name) || options.cors && !FORBIDDEN_HEADERS.has(name)) headers.set(k, options.headers[k]);\n }\n let opts = {\n headers,\n redirect: options.redirect ? 'follow' : 'manual'\n };\n if (!options.referrer) opts.referrerPolicy = 'no-referrer';\n if (options.cors) opts.mode = 'cors';\n if (options.data) {\n if (!options.method) opts.method = 'POST';\n opts.body = options.type === 'json' ? JSON.stringify(options.data) : options.data;\n }\n const res = await fetch(url, opts);\n if (options.expectStatusCode && res.status !== options.expectStatusCode) throw new InvalidStatusCodeError(res.status);\n const body = detectType(new Uint8Array(await res.arrayBuffer()), options.type);\n if (options.full) return {\n headers: Object.fromEntries(res.headers.entries()),\n status: res.status,\n body\n };\n return body;\n}\nconst IS_NODE = !!(typeof process == 'object' && process.versions && process.versions.node && process.versions.v8);\nfunction fetchUrl(url, options) {\n const fn = IS_NODE ? fetchNode : fetchBrowser;\n return fn(url, options);\n}\nexports.default = fetchUrl;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getProvider = exports.fetchFromProvider = void 0;\nconst micro_ftch_1 = require(\"micro-ftch\");\nconst fetchFromProvider = async (url, params) => {\n const res = await (0, micro_ftch_1.default)(url, {\n headers: {\n 'content-type': 'application/json'\n },\n type: 'json',\n data: {\n method: params.method,\n params: params.params,\n jsonrpc: '2.0',\n id: 1\n }\n });\n return res.result;\n};\nexports.fetchFromProvider = fetchFromProvider;\nconst getProvider = provider => {\n if (typeof provider === 'string') {\n return provider;\n } else if (provider?.connection?.url !== undefined) {\n return provider.connection.url;\n } else {\n throw new Error('Must provide valid provider URL or Web3Provider');\n }\n};\nexports.getProvider = getProvider;\n","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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\", {\n value: true\n});\nexports.toAscii = exports.stripHexPrefix = exports.padToEven = exports.isHexString = exports.isHexPrefixed = exports.getKeys = exports.getBinarySize = exports.fromUtf8 = exports.fromAscii = exports.arrayContainsArray = void 0;\n/**\n * Constants\n */\n__exportStar(require(\"./constants\"), exports);\n/**\n * Units helpers\n */\n__exportStar(require(\"./units\"), exports);\n/**\n * Account class and helper functions\n */\n__exportStar(require(\"./account\"), exports);\n/**\n * Address type\n */\n__exportStar(require(\"./address\"), exports);\n/**\n * Withdrawal type\n */\n__exportStar(require(\"./withdrawal\"), exports);\n/**\n * ECDSA signature\n */\n__exportStar(require(\"./signature\"), exports);\n/**\n * Utilities for manipulating Buffers, byte arrays, etc.\n */\n__exportStar(require(\"./bytes\"), exports);\n/**\n * Helpful TypeScript types\n */\n__exportStar(require(\"./types\"), exports);\n/**\n * Helper function for working with compact encoding\n */\n__exportStar(require(\"./encoding\"), exports);\n/**\n * Export ethjs-util methods\n */\n__exportStar(require(\"./asyncEventEmitter\"), exports);\nvar internal_1 = require(\"./internal\");\nObject.defineProperty(exports, \"arrayContainsArray\", {\n enumerable: true,\n get: function () {\n return internal_1.arrayContainsArray;\n }\n});\nObject.defineProperty(exports, \"fromAscii\", {\n enumerable: true,\n get: function () {\n return internal_1.fromAscii;\n }\n});\nObject.defineProperty(exports, \"fromUtf8\", {\n enumerable: true,\n get: function () {\n return internal_1.fromUtf8;\n }\n});\nObject.defineProperty(exports, \"getBinarySize\", {\n enumerable: true,\n get: function () {\n return internal_1.getBinarySize;\n }\n});\nObject.defineProperty(exports, \"getKeys\", {\n enumerable: true,\n get: function () {\n return internal_1.getKeys;\n }\n});\nObject.defineProperty(exports, \"isHexPrefixed\", {\n enumerable: true,\n get: function () {\n return internal_1.isHexPrefixed;\n }\n});\nObject.defineProperty(exports, \"isHexString\", {\n enumerable: true,\n get: function () {\n return internal_1.isHexString;\n }\n});\nObject.defineProperty(exports, \"padToEven\", {\n enumerable: true,\n get: function () {\n return internal_1.padToEven;\n }\n});\nObject.defineProperty(exports, \"stripHexPrefix\", {\n enumerable: true,\n get: function () {\n return internal_1.stripHexPrefix;\n }\n});\nObject.defineProperty(exports, \"toAscii\", {\n enumerable: true,\n get: function () {\n return internal_1.toAscii;\n }\n});\n__exportStar(require(\"./lock\"), exports);\n__exportStar(require(\"./provider\"), exports);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst sha3_1 = require(\"@noble/hashes/sha3\");\nconst utils_1 = require(\"@noble/hashes/utils\");\n/**\n * Keccak256 hash\n * @param data The data\n */\nfunction keccak256(data) {\n return bytesToHex(sha3_1.keccak_256(toByteArray(data)));\n}\nexports.keccak256 = keccak256;\n/**\n * Adding padding to string on the left\n * @param value The value\n * @param chars The chars\n */\nexports.padLeft = (value, chars) => {\n const hasPrefix = /^0x/i.test(value) || typeof value === 'number';\n value = value.toString().replace(/^0x/i, '');\n const padding = chars - value.length + 1 >= 0 ? chars - value.length + 1 : 0;\n return (hasPrefix ? '0x' : '') + new Array(padding).join('0') + value;\n};\n/**\n * Convert bytes to hex\n * @param bytes The bytes\n */\nfunction bytesToHex(bytes) {\n return \"0x\" + utils_1.bytesToHex(bytes);\n}\nexports.bytesToHex = bytesToHex;\n/**\n * To byte array\n * @param value The value\n */\nfunction toByteArray(value) {\n if (value == null) {\n throw new Error('cannot convert null value to array');\n }\n if (typeof value === 'string') {\n const match = value.match(/^(0x)?[0-9a-fA-F]*$/);\n if (!match) {\n throw new Error('invalid hexidecimal string');\n }\n if (match[1] !== '0x') {\n throw new Error('hex string must have 0x prefix');\n }\n value = value.substring(2);\n if (value.length % 2) {\n value = '0' + value;\n }\n const result = [];\n for (let i = 0; i < value.length; i += 2) {\n result.push(parseInt(value.substr(i, 2), 16));\n }\n return addSlice(new Uint8Array(result));\n }\n if (isByteArray(value)) {\n return addSlice(new Uint8Array(value));\n }\n throw new Error('invalid arrayify value');\n}\nexports.toByteArray = toByteArray;\n/**\n * Is byte array\n * @param value The value\n */\nfunction isByteArray(value) {\n if (!value ||\n // tslint:disable-next-line: radix\n parseInt(String(value.length)) != value.length || typeof value === 'string') {\n return false;\n }\n for (let i = 0; i < value.length; i++) {\n const v = value[i];\n // tslint:disable-next-line: radix\n if (v < 0 || v >= 256 || parseInt(String(v)) != v) {\n return false;\n }\n }\n return true;\n}\n/**\n * Add slice to array\n * @param array The array\n */\nfunction addSlice(array) {\n if (array.slice !== undefined) {\n return array;\n }\n array.slice = () => {\n const args = Array.prototype.slice.call(arguments);\n return addSlice(new Uint8Array(Array.prototype.slice.apply(array, args)));\n };\n return array;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst utils_1 = require(\"./utils\");\n/**\n * Returns true if the bloom is a valid bloom\n * @param bloom The bloom\n */\nfunction isBloom(bloom) {\n if (typeof bloom !== 'string') {\n return false;\n }\n if (!/^(0x)?[0-9a-f]{512}$/i.test(bloom)) {\n return false;\n }\n if (/^(0x)?[0-9a-f]{512}$/.test(bloom) || /^(0x)?[0-9A-F]{512}$/.test(bloom)) {\n return true;\n }\n return false;\n}\nexports.isBloom = isBloom;\n/**\n * Returns true if the value is part of the given bloom\n * note: false positives are possible.\n * @param bloom encoded bloom\n * @param value The value\n */\nfunction isInBloom(bloom, value) {\n if (typeof value === 'object' && value.constructor === Uint8Array) {\n value = utils_1.bytesToHex(value);\n }\n const hash = utils_1.keccak256(value).replace('0x', '');\n for (let i = 0; i < 12; i += 4) {\n // calculate bit position in bloom filter that must be active\n const bitpos = (parseInt(hash.substr(i, 2), 16) << 8) + parseInt(hash.substr(i + 2, 2), 16) & 2047;\n // test if bitpos in bloom is active\n const code = codePointToInt(bloom.charCodeAt(bloom.length - 1 - Math.floor(bitpos / 4)));\n const offset = 1 << bitpos % 4;\n if ((code & offset) !== offset) {\n return false;\n }\n }\n return true;\n}\nexports.isInBloom = isInBloom;\n/**\n * Code points to int\n * @param codePoint The code point\n */\nfunction codePointToInt(codePoint) {\n if (codePoint >= 48 && codePoint <= 57) {\n /* ['0'..'9'] -> [0..9] */\n return codePoint - 48;\n }\n if (codePoint >= 65 && codePoint <= 70) {\n /* ['A'..'F'] -> [10..15] */\n return codePoint - 55;\n }\n if (codePoint >= 97 && codePoint <= 102) {\n /* ['a'..'f'] -> [10..15] */\n return codePoint - 87;\n }\n throw new Error('invalid bloom');\n}\n/**\n * Returns true if the ethereum users address is part of the given bloom.\n * note: false positives are possible.\n * @param bloom encoded bloom\n * @param address the address to test\n */\nfunction isUserEthereumAddressInBloom(bloom, ethereumAddress) {\n if (!isBloom(bloom)) {\n throw new Error('Invalid bloom given');\n }\n if (!isAddress(ethereumAddress)) {\n throw new Error(`Invalid ethereum address given: \"${ethereumAddress}\"`);\n }\n // you have to pad the ethereum address to 32 bytes\n // else the bloom filter does not work\n // this is only if your matching the USERS\n // ethereum address. Contract address do not need this\n // hence why we have 2 methods\n // (0x is not in the 2nd parameter of padleft so 64 chars is fine)\n const address = utils_1.padLeft(ethereumAddress, 64);\n return isInBloom(bloom, address);\n}\nexports.isUserEthereumAddressInBloom = isUserEthereumAddressInBloom;\n/**\n * Returns true if the contract address is part of the given bloom.\n * note: false positives are possible.\n * @param bloom encoded bloom\n * @param contractAddress the contract address to test\n */\nfunction isContractAddressInBloom(bloom, contractAddress) {\n if (!isBloom(bloom)) {\n throw new Error('Invalid bloom given');\n }\n if (!isAddress(contractAddress)) {\n throw new Error(`Invalid contract address given: \"${contractAddress}\"`);\n }\n return isInBloom(bloom, contractAddress);\n}\nexports.isContractAddressInBloom = isContractAddressInBloom;\n/**\n * Returns true if the topic is part of the given bloom.\n * note: false positives are possible.\n * @param bloom encoded bloom\n * @param topic the topic encoded hex\n */\nfunction isTopicInBloom(bloom, topic) {\n if (!isBloom(bloom)) {\n throw new Error('Invalid bloom given');\n }\n if (!isTopic(topic)) {\n throw new Error('Invalid topic');\n }\n return isInBloom(bloom, topic);\n}\nexports.isTopicInBloom = isTopicInBloom;\n/**\n * Checks if its a valid topic\n * @param topic encoded hex topic\n */\nfunction isTopic(topic) {\n if (typeof topic !== 'string') {\n return false;\n }\n if (!/^(0x)?[0-9a-f]{64}$/i.test(topic)) {\n return false;\n } else if (/^(0x)?[0-9a-f]{64}$/.test(topic) || /^(0x)?[0-9A-F]{64}$/.test(topic)) {\n return true;\n }\n return false;\n}\nexports.isTopic = isTopic;\n/**\n * Is valid address\n * @param address The address\n */\nfunction isAddress(address) {\n if (typeof address !== 'string') {\n return false;\n }\n if (address.match(/^(0x)?[0-9a-fA-F]{40}$/)) {\n return true;\n }\n if (address.match(/^XE[0-9]{2}[0-9A-Za-z]{30,31}$/)) {\n return true;\n }\n return false;\n}\nexports.isAddress = isAddress;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.output = exports.exists = exports.hash = exports.bytes = exports.bool = exports.number = exports.isBytes = void 0;\nfunction number(n) {\n if (!Number.isSafeInteger(n) || n < 0) throw new Error(`positive integer expected, not ${n}`);\n}\nexports.number = number;\nfunction bool(b) {\n if (typeof b !== 'boolean') throw new Error(`boolean expected, not ${b}`);\n}\nexports.bool = bool;\n// copied from utils\nfunction isBytes(a) {\n return a instanceof Uint8Array || a != null && typeof a === 'object' && a.constructor.name === 'Uint8Array';\n}\nexports.isBytes = isBytes;\nfunction bytes(b, ...lengths) {\n if (!isBytes(b)) throw new Error('Uint8Array expected');\n if (lengths.length > 0 && !lengths.includes(b.length)) throw new Error(`Uint8Array expected of length ${lengths}, not of length=${b.length}`);\n}\nexports.bytes = bytes;\nfunction hash(h) {\n if (typeof h !== 'function' || typeof h.create !== 'function') throw new Error('Hash should be wrapped by utils.wrapConstructor');\n number(h.outputLen);\n number(h.blockLen);\n}\nexports.hash = hash;\nfunction exists(instance, checkFinished = true) {\n if (instance.destroyed) throw new Error('Hash instance has been destroyed');\n if (checkFinished && instance.finished) throw new Error('Hash#digest() has already been called');\n}\nexports.exists = exists;\nfunction output(out, instance) {\n bytes(out);\n const min = instance.outputLen;\n if (out.length < min) {\n throw new Error(`digestInto() expects output buffer of length at least ${min}`);\n }\n}\nexports.output = output;\nconst assert = {\n number,\n bool,\n bytes,\n hash,\n exists,\n output\n};\nexports.default = assert;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.add5L = exports.add5H = exports.add4H = exports.add4L = exports.add3H = exports.add3L = exports.add = exports.rotlBL = exports.rotlBH = exports.rotlSL = exports.rotlSH = exports.rotr32L = exports.rotr32H = exports.rotrBL = exports.rotrBH = exports.rotrSL = exports.rotrSH = exports.shrSL = exports.shrSH = exports.toBig = exports.split = exports.fromBig = void 0;\nconst U32_MASK64 = /* @__PURE__ */BigInt(2 ** 32 - 1);\nconst _32n = /* @__PURE__ */BigInt(32);\n// We are not using BigUint64Array, because they are extremely slow as per 2022\nfunction fromBig(n, le = false) {\n if (le) return {\n h: Number(n & U32_MASK64),\n l: Number(n >> _32n & U32_MASK64)\n };\n return {\n h: Number(n >> _32n & U32_MASK64) | 0,\n l: Number(n & U32_MASK64) | 0\n };\n}\nexports.fromBig = fromBig;\nfunction split(lst, le = false) {\n let Ah = new Uint32Array(lst.length);\n let Al = new Uint32Array(lst.length);\n for (let i = 0; i < lst.length; i++) {\n const {\n h,\n l\n } = fromBig(lst[i], le);\n [Ah[i], Al[i]] = [h, l];\n }\n return [Ah, Al];\n}\nexports.split = split;\nconst toBig = (h, l) => BigInt(h >>> 0) << _32n | BigInt(l >>> 0);\nexports.toBig = toBig;\n// for Shift in [0, 32)\nconst shrSH = (h, _l, s) => h >>> s;\nexports.shrSH = shrSH;\nconst shrSL = (h, l, s) => h << 32 - s | l >>> s;\nexports.shrSL = shrSL;\n// Right rotate for Shift in [1, 32)\nconst rotrSH = (h, l, s) => h >>> s | l << 32 - s;\nexports.rotrSH = rotrSH;\nconst rotrSL = (h, l, s) => h << 32 - s | l >>> s;\nexports.rotrSL = rotrSL;\n// Right rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotrBH = (h, l, s) => h << 64 - s | l >>> s - 32;\nexports.rotrBH = rotrBH;\nconst rotrBL = (h, l, s) => h >>> s - 32 | l << 64 - s;\nexports.rotrBL = rotrBL;\n// Right rotate for shift===32 (just swaps l&h)\nconst rotr32H = (_h, l) => l;\nexports.rotr32H = rotr32H;\nconst rotr32L = (h, _l) => h;\nexports.rotr32L = rotr32L;\n// Left rotate for Shift in [1, 32)\nconst rotlSH = (h, l, s) => h << s | l >>> 32 - s;\nexports.rotlSH = rotlSH;\nconst rotlSL = (h, l, s) => l << s | h >>> 32 - s;\nexports.rotlSL = rotlSL;\n// Left rotate for Shift in (32, 64), NOTE: 32 is special case.\nconst rotlBH = (h, l, s) => l << s - 32 | h >>> 64 - s;\nexports.rotlBH = rotlBH;\nconst rotlBL = (h, l, s) => h << s - 32 | l >>> 64 - s;\nexports.rotlBL = rotlBL;\n// JS uses 32-bit signed integers for bitwise operations which means we cannot\n// simple take carry out of low bit sum by shift, we need to use division.\nfunction add(Ah, Al, Bh, Bl) {\n const l = (Al >>> 0) + (Bl >>> 0);\n return {\n h: Ah + Bh + (l / 2 ** 32 | 0) | 0,\n l: l | 0\n };\n}\nexports.add = add;\n// Addition with more than 2 elements\nconst add3L = (Al, Bl, Cl) => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0);\nexports.add3L = add3L;\nconst add3H = (low, Ah, Bh, Ch) => Ah + Bh + Ch + (low / 2 ** 32 | 0) | 0;\nexports.add3H = add3H;\nconst add4L = (Al, Bl, Cl, Dl) => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0);\nexports.add4L = add4L;\nconst add4H = (low, Ah, Bh, Ch, Dh) => Ah + Bh + Ch + Dh + (low / 2 ** 32 | 0) | 0;\nexports.add4H = add4H;\nconst add5L = (Al, Bl, Cl, Dl, El) => (Al >>> 0) + (Bl >>> 0) + (Cl >>> 0) + (Dl >>> 0) + (El >>> 0);\nexports.add5L = add5L;\nconst add5H = (low, Ah, Bh, Ch, Dh, Eh) => Ah + Bh + Ch + Dh + Eh + (low / 2 ** 32 | 0) | 0;\nexports.add5H = add5H;\n// prettier-ignore\nconst u64 = {\n fromBig,\n split,\n toBig,\n shrSH,\n shrSL,\n rotrSH,\n rotrSL,\n rotrBH,\n rotrBL,\n rotr32H,\n rotr32L,\n rotlSH,\n rotlSL,\n rotlBH,\n rotlBL,\n add,\n add3L,\n add3H,\n add4L,\n add4H,\n add5H,\n add5L\n};\nexports.default = u64;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.crypto = void 0;\nexports.crypto = typeof globalThis === 'object' && 'crypto' in globalThis ? globalThis.crypto : undefined;\n","\"use strict\";\n\n/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.randomBytes = exports.wrapXOFConstructorWithOpts = exports.wrapConstructorWithOpts = exports.wrapConstructor = exports.checkOpts = exports.Hash = exports.concatBytes = exports.toBytes = exports.utf8ToBytes = exports.asyncLoop = exports.nextTick = exports.hexToBytes = exports.bytesToHex = exports.byteSwap32 = exports.byteSwapIfBE = exports.byteSwap = exports.isLE = exports.rotl = exports.rotr = exports.createView = exports.u32 = exports.u8 = exports.isBytes = void 0;\n// We use WebCrypto aka globalThis.crypto, which exists in browsers and node.js 16+.\n// node.js versions earlier than v19 don't declare it in global scope.\n// For node.js, package.json#exports field mapping rewrites import\n// from `crypto` to `cryptoNode`, which imports native module.\n// Makes the utils un-importable in browsers without a bundler.\n// Once node.js 18 is deprecated (2025-04-30), we can just drop the import.\nconst crypto_1 = require(\"@noble/hashes/crypto\");\nconst _assert_js_1 = require(\"./_assert.js\");\n// export { isBytes } from './_assert.js';\n// We can't reuse isBytes from _assert, because somehow this causes huge perf issues\nfunction isBytes(a) {\n return a instanceof Uint8Array || a != null && typeof a === 'object' && a.constructor.name === 'Uint8Array';\n}\nexports.isBytes = isBytes;\n// Cast array to different type\nconst u8 = arr => new Uint8Array(arr.buffer, arr.byteOffset, arr.byteLength);\nexports.u8 = u8;\nconst u32 = arr => new Uint32Array(arr.buffer, arr.byteOffset, Math.floor(arr.byteLength / 4));\nexports.u32 = u32;\n// Cast array to view\nconst createView = arr => new DataView(arr.buffer, arr.byteOffset, arr.byteLength);\nexports.createView = createView;\n// The rotate right (circular right shift) operation for uint32\nconst rotr = (word, shift) => word << 32 - shift | word >>> shift;\nexports.rotr = rotr;\n// The rotate left (circular left shift) operation for uint32\nconst rotl = (word, shift) => word << shift | word >>> 32 - shift >>> 0;\nexports.rotl = rotl;\nexports.isLE = new Uint8Array(new Uint32Array([0x11223344]).buffer)[0] === 0x44;\n// The byte swap operation for uint32\nconst byteSwap = word => word << 24 & 0xff000000 | word << 8 & 0xff0000 | word >>> 8 & 0xff00 | word >>> 24 & 0xff;\nexports.byteSwap = byteSwap;\n// Conditionally byte swap if on a big-endian platform\nexports.byteSwapIfBE = exports.isLE ? n => n : n => (0, exports.byteSwap)(n);\n// In place byte swap for Uint32Array\nfunction byteSwap32(arr) {\n for (let i = 0; i < arr.length; i++) {\n arr[i] = (0, exports.byteSwap)(arr[i]);\n }\n}\nexports.byteSwap32 = byteSwap32;\n// Array where index 0xf0 (240) is mapped to string 'f0'\nconst hexes = /* @__PURE__ */Array.from({\n length: 256\n}, (_, i) => i.toString(16).padStart(2, '0'));\n/**\n * @example bytesToHex(Uint8Array.from([0xca, 0xfe, 0x01, 0x23])) // 'cafe0123'\n */\nfunction bytesToHex(bytes) {\n (0, _assert_js_1.bytes)(bytes);\n // pre-caching improves the speed 6x\n let hex = '';\n for (let i = 0; i < bytes.length; i++) {\n hex += hexes[bytes[i]];\n }\n return hex;\n}\nexports.bytesToHex = bytesToHex;\n// We use optimized technique to convert hex string to byte array\nconst asciis = {\n _0: 48,\n _9: 57,\n _A: 65,\n _F: 70,\n _a: 97,\n _f: 102\n};\nfunction asciiToBase16(char) {\n if (char >= asciis._0 && char <= asciis._9) return char - asciis._0;\n if (char >= asciis._A && char <= asciis._F) return char - (asciis._A - 10);\n if (char >= asciis._a && char <= asciis._f) return char - (asciis._a - 10);\n return;\n}\n/**\n * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])\n */\nfunction hexToBytes(hex) {\n if (typeof hex !== 'string') throw new Error('hex string expected, got ' + typeof hex);\n const hl = hex.length;\n const al = hl / 2;\n if (hl % 2) throw new Error('padded hex string expected, got unpadded hex of length ' + hl);\n const array = new Uint8Array(al);\n for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {\n const n1 = asciiToBase16(hex.charCodeAt(hi));\n const n2 = asciiToBase16(hex.charCodeAt(hi + 1));\n if (n1 === undefined || n2 === undefined) {\n const char = hex[hi] + hex[hi + 1];\n throw new Error('hex string expected, got non-hex character \"' + char + '\" at index ' + hi);\n }\n array[ai] = n1 * 16 + n2;\n }\n return array;\n}\nexports.hexToBytes = hexToBytes;\n// There is no setImmediate in browser and setTimeout is slow.\n// call of async fn will return Promise, which will be fullfiled only on\n// next scheduler queue processing step and this is exactly what we need.\nconst nextTick = async () => {};\nexports.nextTick = nextTick;\n// Returns control to thread each 'tick' ms to avoid blocking\nasync function asyncLoop(iters, tick, cb) {\n let ts = Date.now();\n for (let i = 0; i < iters; i++) {\n cb(i);\n // Date.now() is not monotonic, so in case if clock goes backwards we return return control too\n const diff = Date.now() - ts;\n if (diff >= 0 && diff < tick) continue;\n await (0, exports.nextTick)();\n ts += diff;\n }\n}\nexports.asyncLoop = asyncLoop;\n/**\n * @example utf8ToBytes('abc') // new Uint8Array([97, 98, 99])\n */\nfunction utf8ToBytes(str) {\n if (typeof str !== 'string') throw new Error(`utf8ToBytes expected string, got ${typeof str}`);\n return new Uint8Array(new TextEncoder().encode(str)); // https://bugzil.la/1681809\n}\nexports.utf8ToBytes = utf8ToBytes;\n/**\n * Normalizes (non-hex) string or Uint8Array to Uint8Array.\n * Warning: when Uint8Array is passed, it would NOT get copied.\n * Keep in mind for future mutable operations.\n */\nfunction toBytes(data) {\n if (typeof data === 'string') data = utf8ToBytes(data);\n (0, _assert_js_1.bytes)(data);\n return data;\n}\nexports.toBytes = toBytes;\n/**\n * Copies several Uint8Arrays into one.\n */\nfunction concatBytes(...arrays) {\n let sum = 0;\n for (let i = 0; i < arrays.length; i++) {\n const a = arrays[i];\n (0, _assert_js_1.bytes)(a);\n sum += a.length;\n }\n const res = new Uint8Array(sum);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const a = arrays[i];\n res.set(a, pad);\n pad += a.length;\n }\n return res;\n}\nexports.concatBytes = concatBytes;\n// For runtime check if class implements interface\nclass Hash {\n // Safe version that clones internal state\n clone() {\n return this._cloneInto();\n }\n}\nexports.Hash = Hash;\nconst toStr = {}.toString;\nfunction checkOpts(defaults, opts) {\n if (opts !== undefined && toStr.call(opts) !== '[object Object]') throw new Error('Options should be object or undefined');\n const merged = Object.assign(defaults, opts);\n return merged;\n}\nexports.checkOpts = checkOpts;\nfunction wrapConstructor(hashCons) {\n const hashC = msg => hashCons().update(toBytes(msg)).digest();\n const tmp = hashCons();\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = () => hashCons();\n return hashC;\n}\nexports.wrapConstructor = wrapConstructor;\nfunction wrapConstructorWithOpts(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = opts => hashCons(opts);\n return hashC;\n}\nexports.wrapConstructorWithOpts = wrapConstructorWithOpts;\nfunction wrapXOFConstructorWithOpts(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = opts => hashCons(opts);\n return hashC;\n}\nexports.wrapXOFConstructorWithOpts = wrapXOFConstructorWithOpts;\n/**\n * Secure PRNG. Uses `crypto.getRandomValues`, which defers to OS.\n */\nfunction randomBytes(bytesLength = 32) {\n if (crypto_1.crypto && typeof crypto_1.crypto.getRandomValues === 'function') {\n return crypto_1.crypto.getRandomValues(new Uint8Array(bytesLength));\n }\n throw new Error('crypto.getRandomValues must be defined');\n}\nexports.randomBytes = randomBytes;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.shake256 = exports.shake128 = exports.keccak_512 = exports.keccak_384 = exports.keccak_256 = exports.keccak_224 = exports.sha3_512 = exports.sha3_384 = exports.sha3_256 = exports.sha3_224 = exports.Keccak = exports.keccakP = void 0;\nconst _assert_js_1 = require(\"./_assert.js\");\nconst _u64_js_1 = require(\"./_u64.js\");\nconst utils_js_1 = require(\"./utils.js\");\n// SHA3 (keccak) is based on a new design: basically, the internal state is bigger than output size.\n// It's called a sponge function.\n// Various per round constants calculations\nconst SHA3_PI = [];\nconst SHA3_ROTL = [];\nconst _SHA3_IOTA = [];\nconst _0n = /* @__PURE__ */BigInt(0);\nconst _1n = /* @__PURE__ */BigInt(1);\nconst _2n = /* @__PURE__ */BigInt(2);\nconst _7n = /* @__PURE__ */BigInt(7);\nconst _256n = /* @__PURE__ */BigInt(256);\nconst _0x71n = /* @__PURE__ */BigInt(0x71);\nfor (let round = 0, R = _1n, x = 1, y = 0; round < 24; round++) {\n // Pi\n [x, y] = [y, (2 * x + 3 * y) % 5];\n SHA3_PI.push(2 * (5 * y + x));\n // Rotational\n SHA3_ROTL.push((round + 1) * (round + 2) / 2 % 64);\n // Iota\n let t = _0n;\n for (let j = 0; j < 7; j++) {\n R = (R << _1n ^ (R >> _7n) * _0x71n) % _256n;\n if (R & _2n) t ^= _1n << (_1n << /* @__PURE__ */BigInt(j)) - _1n;\n }\n _SHA3_IOTA.push(t);\n}\nconst [SHA3_IOTA_H, SHA3_IOTA_L] = /* @__PURE__ */(0, _u64_js_1.split)(_SHA3_IOTA, true);\n// Left rotation (without 0, 32, 64)\nconst rotlH = (h, l, s) => s > 32 ? (0, _u64_js_1.rotlBH)(h, l, s) : (0, _u64_js_1.rotlSH)(h, l, s);\nconst rotlL = (h, l, s) => s > 32 ? (0, _u64_js_1.rotlBL)(h, l, s) : (0, _u64_js_1.rotlSL)(h, l, s);\n// Same as keccakf1600, but allows to skip some rounds\nfunction keccakP(s, rounds = 24) {\n const B = new Uint32Array(5 * 2);\n // NOTE: all indices are x2 since we store state as u32 instead of u64 (bigints to slow in js)\n for (let round = 24 - rounds; round < 24; round++) {\n // Theta θ\n for (let x = 0; x < 10; x++) B[x] = s[x] ^ s[x + 10] ^ s[x + 20] ^ s[x + 30] ^ s[x + 40];\n for (let x = 0; x < 10; x += 2) {\n const idx1 = (x + 8) % 10;\n const idx0 = (x + 2) % 10;\n const B0 = B[idx0];\n const B1 = B[idx0 + 1];\n const Th = rotlH(B0, B1, 1) ^ B[idx1];\n const Tl = rotlL(B0, B1, 1) ^ B[idx1 + 1];\n for (let y = 0; y < 50; y += 10) {\n s[x + y] ^= Th;\n s[x + y + 1] ^= Tl;\n }\n }\n // Rho (ρ) and Pi (π)\n let curH = s[2];\n let curL = s[3];\n for (let t = 0; t < 24; t++) {\n const shift = SHA3_ROTL[t];\n const Th = rotlH(curH, curL, shift);\n const Tl = rotlL(curH, curL, shift);\n const PI = SHA3_PI[t];\n curH = s[PI];\n curL = s[PI + 1];\n s[PI] = Th;\n s[PI + 1] = Tl;\n }\n // Chi (χ)\n for (let y = 0; y < 50; y += 10) {\n for (let x = 0; x < 10; x++) B[x] = s[y + x];\n for (let x = 0; x < 10; x++) s[y + x] ^= ~B[(x + 2) % 10] & B[(x + 4) % 10];\n }\n // Iota (ι)\n s[0] ^= SHA3_IOTA_H[round];\n s[1] ^= SHA3_IOTA_L[round];\n }\n B.fill(0);\n}\nexports.keccakP = keccakP;\nclass Keccak extends utils_js_1.Hash {\n // NOTE: we accept arguments in bytes instead of bits here.\n constructor(blockLen, suffix, outputLen, enableXOF = false, rounds = 24) {\n super();\n this.blockLen = blockLen;\n this.suffix = suffix;\n this.outputLen = outputLen;\n this.enableXOF = enableXOF;\n this.rounds = rounds;\n this.pos = 0;\n this.posOut = 0;\n this.finished = false;\n this.destroyed = false;\n // Can be passed from user as dkLen\n (0, _assert_js_1.number)(outputLen);\n // 1600 = 5x5 matrix of 64bit. 1600 bits === 200 bytes\n if (0 >= this.blockLen || this.blockLen >= 200) throw new Error('Sha3 supports only keccak-f1600 function');\n this.state = new Uint8Array(200);\n this.state32 = (0, utils_js_1.u32)(this.state);\n }\n keccak() {\n if (!utils_js_1.isLE) (0, utils_js_1.byteSwap32)(this.state32);\n keccakP(this.state32, this.rounds);\n if (!utils_js_1.isLE) (0, utils_js_1.byteSwap32)(this.state32);\n this.posOut = 0;\n this.pos = 0;\n }\n update(data) {\n (0, _assert_js_1.exists)(this);\n const {\n blockLen,\n state\n } = this;\n data = (0, utils_js_1.toBytes)(data);\n const len = data.length;\n for (let pos = 0; pos < len;) {\n const take = Math.min(blockLen - this.pos, len - pos);\n for (let i = 0; i < take; i++) state[this.pos++] ^= data[pos++];\n if (this.pos === blockLen) this.keccak();\n }\n return this;\n }\n finish() {\n if (this.finished) return;\n this.finished = true;\n const {\n state,\n suffix,\n pos,\n blockLen\n } = this;\n // Do the padding\n state[pos] ^= suffix;\n if ((suffix & 0x80) !== 0 && pos === blockLen - 1) this.keccak();\n state[blockLen - 1] ^= 0x80;\n this.keccak();\n }\n writeInto(out) {\n (0, _assert_js_1.exists)(this, false);\n (0, _assert_js_1.bytes)(out);\n this.finish();\n const bufferOut = this.state;\n const {\n blockLen\n } = this;\n for (let pos = 0, len = out.length; pos < len;) {\n if (this.posOut >= blockLen) this.keccak();\n const take = Math.min(blockLen - this.posOut, len - pos);\n out.set(bufferOut.subarray(this.posOut, this.posOut + take), pos);\n this.posOut += take;\n pos += take;\n }\n return out;\n }\n xofInto(out) {\n // Sha3/Keccak usage with XOF is probably mistake, only SHAKE instances can do XOF\n if (!this.enableXOF) throw new Error('XOF is not possible for this instance');\n return this.writeInto(out);\n }\n xof(bytes) {\n (0, _assert_js_1.number)(bytes);\n return this.xofInto(new Uint8Array(bytes));\n }\n digestInto(out) {\n (0, _assert_js_1.output)(out, this);\n if (this.finished) throw new Error('digest() was already called');\n this.writeInto(out);\n this.destroy();\n return out;\n }\n digest() {\n return this.digestInto(new Uint8Array(this.outputLen));\n }\n destroy() {\n this.destroyed = true;\n this.state.fill(0);\n }\n _cloneInto(to) {\n const {\n blockLen,\n suffix,\n outputLen,\n rounds,\n enableXOF\n } = this;\n to || (to = new Keccak(blockLen, suffix, outputLen, enableXOF, rounds));\n to.state32.set(this.state32);\n to.pos = this.pos;\n to.posOut = this.posOut;\n to.finished = this.finished;\n to.rounds = rounds;\n // Suffix can change in cSHAKE\n to.suffix = suffix;\n to.outputLen = outputLen;\n to.enableXOF = enableXOF;\n to.destroyed = this.destroyed;\n return to;\n }\n}\nexports.Keccak = Keccak;\nconst gen = (suffix, blockLen, outputLen) => (0, utils_js_1.wrapConstructor)(() => new Keccak(blockLen, suffix, outputLen));\nexports.sha3_224 = gen(0x06, 144, 224 / 8);\n/**\n * SHA3-256 hash function\n * @param message - that would be hashed\n */\nexports.sha3_256 = gen(0x06, 136, 256 / 8);\nexports.sha3_384 = gen(0x06, 104, 384 / 8);\nexports.sha3_512 = gen(0x06, 72, 512 / 8);\nexports.keccak_224 = gen(0x01, 144, 224 / 8);\n/**\n * keccak-256 hash function. Different from SHA3-256.\n * @param message - that would be hashed\n */\nexports.keccak_256 = gen(0x01, 136, 256 / 8);\nexports.keccak_384 = gen(0x01, 104, 384 / 8);\nexports.keccak_512 = gen(0x01, 72, 512 / 8);\nconst genShake = (suffix, blockLen, outputLen) => (0, utils_js_1.wrapXOFConstructorWithOpts)((opts = {}) => new Keccak(blockLen, suffix, opts.dkLen === undefined ? outputLen : opts.dkLen, true));\nexports.shake128 = genShake(0x1f, 168, 128 / 8);\nexports.shake256 = genShake(0x1f, 136, 256 / 8);\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.crypto = exports.utf8ToBytes = exports.createView = exports.concatBytes = exports.toHex = exports.bytesToHex = exports.assertBytes = exports.assertBool = void 0;\nexports.bytesToUtf8 = bytesToUtf8;\nexports.hexToBytes = hexToBytes;\nexports.equalsBytes = equalsBytes;\nexports.wrapHash = wrapHash;\nconst _assert_1 = __importDefault(require(\"@noble/hashes/_assert\"));\nconst utils_1 = require(\"@noble/hashes/utils\");\nconst assertBool = _assert_1.default.bool;\nexports.assertBool = assertBool;\nconst assertBytes = _assert_1.default.bytes;\nexports.assertBytes = assertBytes;\nvar utils_2 = require(\"@noble/hashes/utils\");\nObject.defineProperty(exports, \"bytesToHex\", {\n enumerable: true,\n get: function () {\n return utils_2.bytesToHex;\n }\n});\nObject.defineProperty(exports, \"toHex\", {\n enumerable: true,\n get: function () {\n return utils_2.bytesToHex;\n }\n});\nObject.defineProperty(exports, \"concatBytes\", {\n enumerable: true,\n get: function () {\n return utils_2.concatBytes;\n }\n});\nObject.defineProperty(exports, \"createView\", {\n enumerable: true,\n get: function () {\n return utils_2.createView;\n }\n});\nObject.defineProperty(exports, \"utf8ToBytes\", {\n enumerable: true,\n get: function () {\n return utils_2.utf8ToBytes;\n }\n});\n// buf.toString('utf8') -> bytesToUtf8(buf)\nfunction bytesToUtf8(data) {\n if (!(data instanceof Uint8Array)) {\n throw new TypeError(`bytesToUtf8 expected Uint8Array, got ${typeof data}`);\n }\n return new TextDecoder().decode(data);\n}\nfunction hexToBytes(data) {\n const sliced = data.startsWith(\"0x\") ? data.substring(2) : data;\n return (0, utils_1.hexToBytes)(sliced);\n}\n// buf.equals(buf2) -> equalsBytes(buf, buf2)\nfunction equalsBytes(a, b) {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n return true;\n}\n// Internal utils\nfunction wrapHash(hash) {\n return msg => {\n _assert_1.default.bytes(msg);\n return hash(msg);\n };\n}\n// TODO(v3): switch away from node crypto, remove this unnecessary variable.\nexports.crypto = (() => {\n const webCrypto = typeof globalThis === \"object\" && \"crypto\" in globalThis ? globalThis.crypto : undefined;\n const nodeRequire = typeof module !== \"undefined\" && typeof module.require === \"function\" && module.require.bind(module);\n return {\n node: nodeRequire && !webCrypto ? nodeRequire(\"crypto\") : undefined,\n web: webCrypto\n };\n})();","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.keccak512 = exports.keccak384 = exports.keccak256 = exports.keccak224 = void 0;\nconst sha3_1 = require(\"@noble/hashes/sha3\");\nconst utils_js_1 = require(\"./utils.js\");\nexports.keccak224 = (0, utils_js_1.wrapHash)(sha3_1.keccak_224);\nexports.keccak256 = (() => {\n const k = (0, utils_js_1.wrapHash)(sha3_1.keccak_256);\n k.create = sha3_1.keccak_256.create;\n return k;\n})();\nexports.keccak384 = (0, utils_js_1.wrapHash)(sha3_1.keccak_384);\nexports.keccak512 = (0, utils_js_1.wrapHash)(sha3_1.keccak_512);","/*\n This file is part of web3.js.\n\n web3.js is free software: you can redistribute it and/or modify\n it under the terms of the GNU Lesser 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 web3.js 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 Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public License\n along with web3.js. If not, see .\n */\n/**\n * @file utils.js\n * @author Fabian Vogelsteller \n * @date 2017\n */\nvar BN = require('bn.js');\nvar numberToBN = require('number-to-bn');\nvar utf8 = require('utf8');\nvar ethereumjsUtil = require('@ethereumjs/util');\nvar ethereumBloomFilters = require('ethereum-bloom-filters');\nvar {\n keccak256\n} = require('ethereum-cryptography/keccak.js');\n/**\n * Returns true if object is BN, otherwise false\n *\n * @method isBN\n * @param {Object} object\n * @return {Boolean}\n */\nvar isBN = function (object) {\n return BN.isBN(object);\n};\n/**\n * Returns true if object is BigNumber, otherwise false\n *\n * @method isBigNumber\n * @param {Object} object\n * @return {Boolean}\n */\nvar isBigNumber = function (object) {\n return object && object.constructor && object.constructor.name === 'BigNumber';\n};\n/**\n * Takes an input and transforms it into an BN\n *\n * @method toBN\n * @param {Number|String|BN} number, string, HEX string or BN\n * @return {BN} BN\n */\nvar toBN = function (number) {\n try {\n return numberToBN.apply(null, arguments);\n } catch (e) {\n throw new Error(e + ' Given value: \"' + number + '\"');\n }\n};\n/**\n * Takes and input transforms it into BN and if it is negative value, into two's complement\n *\n * @method toTwosComplement\n * @param {Number|String|BN} number\n * @return {String}\n */\nvar toTwosComplement = function (number) {\n return '0x' + toBN(number).toTwos(256).toString(16, 64);\n};\n/**\n * Checks if the given string is an address\n *\n * @method isAddress\n * @param {String} address the given HEX address\n * @return {Boolean}\n */\nvar isAddress = function (address) {\n // check if it has the basic requirements of an address\n if (!/^(0x)?[0-9a-f]{40}$/i.test(address)) {\n return false;\n // If it's ALL lowercase or ALL upppercase\n } else if (/^(0x|0X)?[0-9a-f]{40}$/.test(address) || /^(0x|0X)?[0-9A-F]{40}$/.test(address)) {\n return true;\n // Otherwise check each case\n } else {\n return checkAddressChecksum(address);\n }\n};\n/**\n * Checks if the given string is a checksummed address\n *\n * @method checkAddressChecksum\n * @param {String} address the given HEX address\n * @return {Boolean}\n */\nvar checkAddressChecksum = function (address) {\n // Check each case\n address = address.replace(/^0x/i, '');\n var addressHash = sha3(address.toLowerCase()).replace(/^0x/i, '');\n for (var i = 0; i < 40; i++) {\n // the nth letter should be uppercase if the nth digit of casemap is 1\n if (parseInt(addressHash[i], 16) > 7 && address[i].toUpperCase() !== address[i] || parseInt(addressHash[i], 16) <= 7 && address[i].toLowerCase() !== address[i]) {\n return false;\n }\n }\n return true;\n};\n/**\n * Should be called to pad string to expected length\n *\n * @method leftPad\n * @param {String} string to be padded\n * @param {Number} chars that result string should have\n * @param {String} sign, by default 0\n * @returns {String} right aligned string\n */\nvar leftPad = function (string, chars, sign) {\n var hasPrefix = /^0x/i.test(string) || typeof string === 'number';\n string = string.toString(16).replace(/^0x/i, '');\n var padding = chars - string.length + 1 >= 0 ? chars - string.length + 1 : 0;\n return (hasPrefix ? '0x' : '') + new Array(padding).join(sign ? sign : \"0\") + string;\n};\n/**\n * Should be called to pad string to expected length\n *\n * @method rightPad\n * @param {String} string to be padded\n * @param {Number} chars that result string should have\n * @param {String} sign, by default 0\n * @returns {String} right aligned string\n */\nvar rightPad = function (string, chars, sign) {\n var hasPrefix = /^0x/i.test(string) || typeof string === 'number';\n string = string.toString(16).replace(/^0x/i, '');\n var padding = chars - string.length + 1 >= 0 ? chars - string.length + 1 : 0;\n return (hasPrefix ? '0x' : '') + string + new Array(padding).join(sign ? sign : \"0\");\n};\n/**\n * Should be called to get hex representation (prefixed by 0x) of utf8 string\n *\n * @method utf8ToHex\n * @param {String} str\n * @returns {String} hex representation of input string\n */\nvar utf8ToHex = function (str) {\n str = utf8.encode(str);\n var hex = \"\";\n // remove \\u0000 padding from either side\n str = str.replace(/^(?:\\u0000)*/, '');\n str = str.split(\"\").reverse().join(\"\");\n str = str.replace(/^(?:\\u0000)*/, '');\n str = str.split(\"\").reverse().join(\"\");\n for (var i = 0; i < str.length; i++) {\n var code = str.charCodeAt(i);\n // if (code !== 0) {\n var n = code.toString(16);\n hex += n.length < 2 ? '0' + n : n;\n // }\n }\n return \"0x\" + hex;\n};\n/**\n * Should be called to get utf8 from it's hex representation\n *\n * @method hexToUtf8\n * @param {String} hex\n * @returns {String} ascii string representation of hex value\n */\nvar hexToUtf8 = function (hex) {\n if (!isHexStrict(hex)) throw new Error('The parameter \"' + hex + '\" must be a valid HEX string.');\n var str = \"\";\n var code = 0;\n hex = hex.replace(/^0x/i, '');\n // remove 00 padding from either side\n hex = hex.replace(/^(?:00)*/, '');\n hex = hex.split(\"\").reverse().join(\"\");\n hex = hex.replace(/^(?:00)*/, '');\n hex = hex.split(\"\").reverse().join(\"\");\n var l = hex.length;\n for (var i = 0; i < l; i += 2) {\n code = parseInt(hex.slice(i, i + 2), 16);\n // if (code !== 0) {\n str += String.fromCharCode(code);\n // }\n }\n return utf8.decode(str);\n};\n/**\n * Converts value to it's number representation.\n * However, if the value is larger than the maximum safe integer, returns the value as a string.\n *\n * @method hexToNumber\n * @param {String|Number|BN} value\n * @param {Boolean} bigIntOnOverflow - if true, return the hex value in case of overflow\n * @return {Number|String}\n */\nvar hexToNumber = function (value, bigIntOnOverflow = false) {\n if (!value) {\n return value;\n }\n if (typeof value === 'string' && !isHexStrict(value)) {\n throw new Error('Given value \"' + value + '\" is not a valid hex string.');\n }\n const n = toBN(value);\n if (bigIntOnOverflow && (n > Number.MAX_SAFE_INTEGER || n < Number.MIN_SAFE_INTEGER)) {\n return BigInt(n);\n }\n return n.toNumber();\n};\n/**\n * Converts value to it's decimal representation in string\n *\n * @method hexToNumberString\n * @param {String|Number|BN} value\n * @return {String}\n */\nvar hexToNumberString = function (value) {\n if (!value) return value;\n if (typeof value === 'string' && !isHexStrict(value)) {\n throw new Error('Given value \"' + value + '\" is not a valid hex string.');\n }\n return toBN(value).toString(10);\n};\n/**\n * Converts value to it's hex representation\n *\n * @method numberToHex\n * @param {String|Number|BN} value\n * @return {String}\n */\nvar numberToHex = function (value) {\n if (value === null || value === undefined) {\n return value;\n }\n if (!isFinite(value) && !isHexStrict(value)) {\n throw new Error('Given input \"' + value + '\" is not a number.');\n }\n var number = toBN(value);\n var result = number.toString(16);\n return number.lt(new BN(0)) ? '-0x' + result.slice(1) : '0x' + result;\n};\n/**\n * Convert a byte array to a hex string\n *\n * Note: Implementation from crypto-js\n *\n * @method bytesToHex\n * @param {Array} bytes\n * @return {String} the hex string\n */\nvar bytesToHex = function (bytes) {\n for (var hex = [], i = 0; i < bytes.length; i++) {\n /* jshint ignore:start */\n hex.push((bytes[i] >>> 4).toString(16));\n hex.push((bytes[i] & 0xF).toString(16));\n /* jshint ignore:end */\n }\n return '0x' + hex.join(\"\");\n};\n/**\n * Convert a hex string to a byte array\n *\n * Note: Implementation from crypto-js\n *\n * @method hexToBytes\n * @param {string} hex\n * @return {Array} the byte array\n */\nvar hexToBytes = function (hex) {\n hex = hex.toString(16);\n if (!isHexStrict(hex)) {\n throw new Error('Given value \"' + hex + '\" is not a valid hex string.');\n }\n hex = hex.replace(/^0x/i, '');\n for (var bytes = [], c = 0; c < hex.length; c += 2) bytes.push(parseInt(hex.slice(c, c + 2), 16));\n return bytes;\n};\n/**\n * Auto converts any given value into it's hex representation.\n *\n * And even stringifys objects before.\n *\n * @method toHex\n * @param {String|Number|BN|Object|Buffer} value\n * @param {Boolean} returnType\n * @return {String}\n */\nvar toHex = function (value, returnType) {\n /*jshint maxcomplexity: false */\n if (isAddress(value)) {\n return returnType ? 'address' : '0x' + value.toLowerCase().replace(/^0x/i, '');\n }\n if (typeof value === 'boolean') {\n return returnType ? 'bool' : value ? '0x01' : '0x00';\n }\n if (Buffer.isBuffer(value)) {\n return '0x' + value.toString('hex');\n }\n if (typeof value === 'object' && !!value && !isBigNumber(value) && !isBN(value)) {\n return returnType ? 'string' : utf8ToHex(JSON.stringify(value));\n }\n // if its a negative number, pass it through numberToHex\n if (typeof value === 'string') {\n if (value.indexOf('-0x') === 0 || value.indexOf('-0X') === 0) {\n return returnType ? 'int256' : numberToHex(value);\n } else if (value.indexOf('0x') === 0 || value.indexOf('0X') === 0) {\n return returnType ? 'bytes' : value;\n } else if (!isFinite(value)) {\n return returnType ? 'string' : utf8ToHex(value);\n }\n }\n return returnType ? value < 0 ? 'int256' : 'uint256' : numberToHex(value);\n};\n/**\n * Check if string is HEX, requires a 0x in front\n *\n * @method isHexStrict\n * @param {String} hex to be checked\n * @returns {Boolean}\n */\nvar isHexStrict = function (hex) {\n return (typeof hex === 'string' || typeof hex === 'number') && /^(-)?0x[0-9a-f]*$/i.test(hex);\n};\n/**\n * Check if string is HEX\n *\n * @method isHex\n * @param {String} hex to be checked\n * @returns {Boolean}\n */\nvar isHex = function (hex) {\n return (typeof hex === 'string' || typeof hex === 'number') && /^(-0x|0x)?[0-9a-f]*$/i.test(hex);\n};\n/**\n * Remove 0x prefix from string\n *\n * @method stripHexPrefix\n * @param {String} str to be checked\n * @returns {String}\n */\nvar stripHexPrefix = function (str) {\n if (str !== 0 && isHex(str)) return str.replace(/^(-)?0x/i, '$1');\n return str;\n};\n/**\n * Returns true if given string is a valid Ethereum block header bloom.\n *\n * @method isBloom\n * @param {String} bloom encoded bloom filter\n * @return {Boolean}\n */\nvar isBloom = function (bloom) {\n return ethereumBloomFilters.isBloom(bloom);\n};\n/**\n * Returns true if the ethereum users address is part of the given bloom\n * note: false positives are possible.\n *\n * @method isUserEthereumAddressInBloom\n * @param {String} ethereumAddress encoded bloom filter\n * @param {String} bloom ethereum addresss\n * @return {Boolean}\n */\nvar isUserEthereumAddressInBloom = function (bloom, ethereumAddress) {\n return ethereumBloomFilters.isUserEthereumAddressInBloom(bloom, ethereumAddress);\n};\n/**\n * Returns true if the contract address is part of the given bloom\n * note: false positives are possible.\n *\n * @method isUserEthereumAddressInBloom\n * @param {String} bloom encoded bloom filter\n * @param {String} contractAddress contract addresss\n * @return {Boolean}\n */\nvar isContractAddressInBloom = function (bloom, contractAddress) {\n return ethereumBloomFilters.isContractAddressInBloom(bloom, contractAddress);\n};\n/**\n * Returns true if given string is a valid log topic.\n *\n * @method isTopic\n * @param {String} topic encoded topic\n * @return {Boolean}\n */\nvar isTopic = function (topic) {\n return ethereumBloomFilters.isTopic(topic);\n};\n/**\n * Returns true if the topic is part of the given bloom\n * note: false positives are possible.\n *\n * @method isTopicInBloom\n * @param {String} bloom encoded bloom filter\n * @param {String} topic encoded topic\n * @return {Boolean}\n */\nvar isTopicInBloom = function (bloom, topic) {\n return ethereumBloomFilters.isTopicInBloom(bloom, topic);\n};\n/**\n * Returns true if the value is part of the given bloom\n * note: false positives are possible.\n *\n * @method isInBloom\n * @param {String} bloom encoded bloom filter\n * @param {String | Uint8Array} topic encoded value\n * @return {Boolean}\n */\nvar isInBloom = function (bloom, topic) {\n return ethereumBloomFilters.isInBloom(bloom, topic);\n};\n/**\n * Hashes values to a sha3 hash using keccak 256\n *\n * To hash a HEX string the hex must have 0x in front.\n *\n * @method sha3\n * @return {String} the sha3 string\n */\nvar SHA3_NULL_S = '0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470';\nvar sha3 = function (value) {\n if (isBN(value)) {\n value = value.toString();\n }\n if (isHexStrict(value) && /^0x/i.test(value.toString())) {\n value = ethereumjsUtil.toBuffer(value);\n } else if (typeof value === 'string') {\n // Assume value is an arbitrary string\n value = Buffer.from(value, 'utf-8');\n }\n var returnValue = ethereumjsUtil.bufferToHex(keccak256(value));\n if (returnValue === SHA3_NULL_S) {\n return null;\n } else {\n return returnValue;\n }\n};\n// expose the under the hood keccak256\nsha3._Hash = keccak256;\n/**\n * @method sha3Raw\n *\n * @param value\n *\n * @returns {string}\n */\nvar sha3Raw = function (value) {\n value = sha3(value);\n if (value === null) {\n return SHA3_NULL_S;\n }\n return value;\n};\n/**\n * Auto converts any given value into it's hex representation,\n * then converts hex to number.\n *\n * @method toNumber\n * @param {String|Number|BN} value\n * @param {Boolean} bigIntOnOverflow - if true, return the hex value in case of overflow\n * @return {Number|String}\n */\nvar toNumber = function (value, bigIntOnOverflow = false) {\n return typeof value === 'number' ? value : hexToNumber(toHex(value), bigIntOnOverflow);\n};\n// 1.x currently accepts 0x... strings, bn.js after update doesn't. it would be a breaking change\nvar BNwrapped = function (value) {\n // check negative\n if (typeof value == \"string\" && value.includes(\"0x\")) {\n const [negative, hexValue] = value.toLocaleLowerCase().startsWith('-') ? [\"-\", value.slice(3)] : [\"\", value.slice(2)];\n return new BN(negative + hexValue, 16);\n } else {\n return new BN(value);\n }\n};\nObject.setPrototypeOf(BNwrapped, BN);\nObject.setPrototypeOf(BNwrapped.prototype, BN.prototype);\nmodule.exports = {\n BN: BNwrapped,\n isBN: isBN,\n isBigNumber: isBigNumber,\n toBN: toBN,\n isAddress: isAddress,\n isBloom: isBloom,\n isUserEthereumAddressInBloom: isUserEthereumAddressInBloom,\n isContractAddressInBloom: isContractAddressInBloom,\n isTopic: isTopic,\n isTopicInBloom: isTopicInBloom,\n isInBloom: isInBloom,\n checkAddressChecksum: checkAddressChecksum,\n utf8ToHex: utf8ToHex,\n hexToUtf8: hexToUtf8,\n hexToNumber: hexToNumber,\n hexToNumberString: hexToNumberString,\n numberToHex: numberToHex,\n toHex: toHex,\n hexToBytes: hexToBytes,\n bytesToHex: bytesToHex,\n isHex: isHex,\n isHexStrict: isHexStrict,\n stripHexPrefix: stripHexPrefix,\n leftPad: leftPad,\n rightPad: rightPad,\n toTwosComplement: toTwosComplement,\n sha3: sha3,\n sha3Raw: sha3Raw,\n toNumber: toNumber\n};","/*\n This file is part of web3.js.\n\n web3.js is free software: you can redistribute it and/or modify\n it under the terms of the GNU Lesser 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 web3.js 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 Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public License\n along with web3.js. If not, see .\n */\n/**\n * @file soliditySha3.js\n * @author Fabian Vogelsteller \n * @date 2017\n */\nvar BN = require('bn.js');\nvar utils = require('./utils.js');\nvar _elementaryName = function (name) {\n /*jshint maxcomplexity:false */\n if (name.startsWith('int[')) {\n return 'int256' + name.slice(3);\n } else if (name === 'int') {\n return 'int256';\n } else if (name.startsWith('uint[')) {\n return 'uint256' + name.slice(4);\n } else if (name === 'uint') {\n return 'uint256';\n } else if (name.startsWith('fixed[')) {\n return 'fixed128x128' + name.slice(5);\n } else if (name === 'fixed') {\n return 'fixed128x128';\n } else if (name.startsWith('ufixed[')) {\n return 'ufixed128x128' + name.slice(6);\n } else if (name === 'ufixed') {\n return 'ufixed128x128';\n }\n return name;\n};\n// Parse N from type\nvar _parseTypeN = function (type) {\n var typesize = /^\\D+(\\d+).*$/.exec(type);\n return typesize ? parseInt(typesize[1], 10) : null;\n};\n// Parse N from type[]\nvar _parseTypeNArray = function (type) {\n var arraySize = /^\\D+\\d*\\[(\\d+)\\]$/.exec(type);\n return arraySize ? parseInt(arraySize[1], 10) : null;\n};\nvar _parseNumber = function (arg) {\n var type = typeof arg;\n if (type === 'string') {\n if (utils.isHexStrict(arg)) {\n return new BN(arg.replace(/0x/i, ''), 16);\n } else {\n return new BN(arg, 10);\n }\n } else if (type === 'number') {\n return new BN(arg);\n } else if (utils.isBigNumber(arg)) {\n return new BN(arg.toString(10));\n } else if (utils.isBN(arg)) {\n return arg;\n } else {\n throw new Error(arg + ' is not a number');\n }\n};\nvar _solidityPack = function (type, value, arraySize) {\n /*jshint maxcomplexity:false */\n var size, num;\n type = _elementaryName(type);\n if (type === 'bytes') {\n if (value.replace(/^0x/i, '').length % 2 !== 0) {\n throw new Error('Invalid bytes characters ' + value.length);\n }\n return value;\n } else if (type === 'string') {\n return utils.utf8ToHex(value);\n } else if (type === 'bool') {\n return value ? '01' : '00';\n } else if (type.startsWith('address')) {\n if (arraySize) {\n size = 64;\n } else {\n size = 40;\n }\n if (!utils.isAddress(value)) {\n throw new Error(value + ' is not a valid address, or the checksum is invalid.');\n }\n return utils.leftPad(value.toLowerCase(), size);\n }\n size = _parseTypeN(type);\n if (type.startsWith('bytes')) {\n if (!size) {\n throw new Error('bytes[] not yet supported in solidity');\n }\n // must be 32 byte slices when in an array\n if (arraySize) {\n size = 32;\n }\n if (size < 1 || size > 32 || size < value.replace(/^0x/i, '').length / 2) {\n throw new Error('Invalid bytes' + size + ' for ' + value);\n }\n return utils.rightPad(value, size * 2);\n } else if (type.startsWith('uint')) {\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid uint' + size + ' size');\n }\n num = _parseNumber(value);\n if (num.bitLength() > size) {\n throw new Error('Supplied uint exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n if (num.lt(new BN(0))) {\n throw new Error('Supplied uint ' + num.toString() + ' is negative');\n }\n return size ? utils.leftPad(num.toString('hex'), size / 8 * 2) : num;\n } else if (type.startsWith('int')) {\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid int' + size + ' size');\n }\n num = _parseNumber(value);\n if (num.bitLength() > size) {\n throw new Error('Supplied int exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n if (num.lt(new BN(0))) {\n return num.toTwos(size).toString('hex');\n } else {\n return size ? utils.leftPad(num.toString('hex'), size / 8 * 2) : num;\n }\n } else {\n // FIXME: support all other types\n throw new Error('Unsupported or invalid type: ' + type);\n }\n};\nvar _processSolidityEncodePackedArgs = function (arg) {\n /*jshint maxcomplexity:false */\n if (Array.isArray(arg)) {\n throw new Error('Autodetection of array types is not supported.');\n }\n var type,\n value = '';\n var hexArg, arraySize;\n // if type is given\n if (!!arg && typeof arg === 'object' && (arg.hasOwnProperty('v') || arg.hasOwnProperty('t') || arg.hasOwnProperty('value') || arg.hasOwnProperty('type'))) {\n type = arg.hasOwnProperty('t') ? arg.t : arg.type;\n value = arg.hasOwnProperty('v') ? arg.v : arg.value;\n // otherwise try to guess the type\n } else {\n type = utils.toHex(arg, true);\n value = utils.toHex(arg);\n if (!type.startsWith('int') && !type.startsWith('uint')) {\n type = 'bytes';\n }\n }\n if ((type.startsWith('int') || type.startsWith('uint')) && typeof value === 'string' && !/^(-)?0x/i.test(value)) {\n value = new BN(value);\n }\n // get the array size\n if (Array.isArray(value)) {\n arraySize = _parseTypeNArray(type);\n if (arraySize && value.length !== arraySize) {\n throw new Error(type + ' is not matching the given array ' + JSON.stringify(value));\n } else {\n arraySize = value.length;\n }\n }\n if (Array.isArray(value)) {\n hexArg = value.map(function (val) {\n return _solidityPack(type, val, arraySize).toString('hex').replace('0x', '');\n });\n return hexArg.join('');\n } else {\n hexArg = _solidityPack(type, value, arraySize);\n return hexArg.toString('hex').replace('0x', '');\n }\n};\n/**\n * Hashes solidity values to a sha3 hash using keccak 256\n *\n * @method soliditySha3\n * @return {Object} the sha3\n */\nvar soliditySha3 = function () {\n /*jshint maxcomplexity:false */\n var args = Array.prototype.slice.call(arguments);\n var hexArgs = args.map(_processSolidityEncodePackedArgs);\n // console.log(args, hexArgs);\n // console.log('0x'+ hexArgs.join(''));\n return utils.sha3('0x' + hexArgs.join(''));\n};\n/**\n * Hashes solidity values to a sha3 hash using keccak 256 but does return the hash of value `null` instead of `null`\n *\n * @method soliditySha3Raw\n * @return {Object} the sha3\n */\nvar soliditySha3Raw = function () {\n return utils.sha3Raw('0x' + Array.prototype.slice.call(arguments).map(_processSolidityEncodePackedArgs).join(''));\n};\n/**\n * Encode packed args to hex\n *\n * @method encodePacked\n * @return {String} the hex encoded arguments\n */\nvar encodePacked = function () {\n /*jshint maxcomplexity:false */\n var args = Array.prototype.slice.call(arguments);\n var hexArgs = args.map(_processSolidityEncodePackedArgs);\n return '0x' + hexArgs.join('').toLowerCase();\n};\nmodule.exports = {\n soliditySha3: soliditySha3,\n soliditySha3Raw: soliditySha3Raw,\n encodePacked: encodePacked\n};","/*\n This file is part of web3.js.\n\n web3.js is free software: you can redistribute it and/or modify\n it under the terms of the GNU Lesser 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 web3.js 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 Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public License\n along with web3.js. If not, see .\n */\n/**\n * @file utils.js\n * @author Marek Kotewicz \n * @author Fabian Vogelsteller \n * @date 2017\n */\nvar ethjsUnit = require('ethjs-unit');\nvar utils = require('./utils.js');\nvar soliditySha3 = require('./soliditySha3.js');\nvar randombytes = require('randombytes');\nvar BN = require('bn.js');\n/**\n * Fires an error in an event emitter and callback and returns the eventemitter\n *\n * @method _fireError\n * @param {Object} error a string, a error, or an object with {message, data}\n * @param {Object} emitter\n * @param {Function} reject\n * @param {Function} callback\n * @param {any} optionalData\n * @return {Object} the emitter\n */\nvar _fireError = function (error, emitter, reject, callback, optionalData) {\n /*jshint maxcomplexity: 10 */\n // add data if given\n if (!!error && typeof error === 'object' && !(error instanceof Error) && error.data) {\n if (!!error.data && typeof error.data === 'object' || Array.isArray(error.data)) {\n error.data = JSON.stringify(error.data, null, 2);\n }\n error = error.message + \"\\n\" + error.data;\n }\n if (typeof error === 'string') {\n error = new Error(error);\n }\n if (typeof callback === 'function') {\n callback(error, optionalData);\n }\n if (typeof reject === 'function') {\n // suppress uncatched error if an error listener is present\n // OR suppress uncatched error if an callback listener is present\n if (emitter && typeof emitter.listeners === 'function' && emitter.listeners('error').length || typeof callback === 'function') {\n emitter.catch(function () {});\n }\n // reject later, to be able to return emitter\n setTimeout(function () {\n reject(error);\n }, 1);\n }\n if (emitter && typeof emitter.emit === 'function') {\n // emit later, to be able to return emitter\n setTimeout(function () {\n emitter.emit('error', error, optionalData);\n emitter.removeAllListeners();\n }, 1);\n }\n return emitter;\n};\n/**\n * Should be used to create full function/event name from json abi\n *\n * @method _jsonInterfaceMethodToString\n * @param {Object} json\n * @return {String} full function/event name\n */\nvar _jsonInterfaceMethodToString = function (json) {\n if (!!json && typeof json === 'object' && json.name && json.name.indexOf('(') !== -1) {\n return json.name;\n }\n return json.name + '(' + _flattenTypes(false, json.inputs).join(',') + ')';\n};\n/**\n * Should be used to flatten json abi inputs/outputs into an array of type-representing-strings\n *\n * @method _flattenTypes\n * @param {bool} includeTuple\n * @param {Object} puts\n * @return {Array} parameters as strings\n */\nvar _flattenTypes = function (includeTuple, puts) {\n // console.log(\"entered _flattenTypes. inputs/outputs: \" + puts)\n var types = [];\n puts.forEach(function (param) {\n if (typeof param.components === 'object') {\n if (param.type.substring(0, 5) !== 'tuple') {\n throw new Error('components found but type is not tuple; report on GitHub');\n }\n var suffix = '';\n var arrayBracket = param.type.indexOf('[');\n if (arrayBracket >= 0) {\n suffix = param.type.substring(arrayBracket);\n }\n var result = _flattenTypes(includeTuple, param.components);\n // console.log(\"result should have things: \" + result)\n if (Array.isArray(result) && includeTuple) {\n // console.log(\"include tuple word, and its an array. joining...: \" + result.types)\n types.push('tuple(' + result.join(',') + ')' + suffix);\n } else if (!includeTuple) {\n // console.log(\"don't include tuple, but its an array. joining...: \" + result)\n types.push('(' + result.join(',') + ')' + suffix);\n } else {\n // console.log(\"its a single type within a tuple: \" + result.types)\n types.push('(' + result + ')');\n }\n } else {\n // console.log(\"its a type and not directly in a tuple: \" + param.type)\n types.push(param.type);\n }\n });\n return types;\n};\n/**\n * Returns a random hex string by the given bytes size\n *\n * @param {Number} size\n * @returns {string}\n */\nvar randomHex = function (size) {\n return '0x' + randombytes(size).toString('hex');\n};\n/**\n * Should be called to get ascii from it's hex representation\n *\n * @method hexToAscii\n * @param {String} hex\n * @returns {String} ascii string representation of hex value\n */\nvar hexToAscii = function (hex) {\n if (!utils.isHexStrict(hex)) throw new Error('The parameter must be a valid HEX string.');\n var str = \"\";\n var i = 0,\n l = hex.length;\n if (hex.substring(0, 2) === '0x') {\n i = 2;\n }\n for (; i < l; i += 2) {\n var code = parseInt(hex.slice(i, i + 2), 16);\n str += String.fromCharCode(code);\n }\n return str;\n};\n/**\n * Should be called to get hex representation (prefixed by 0x) of ascii string\n *\n * @method asciiToHex\n * @param {String} str\n * @returns {String} hex representation of input string\n */\nvar asciiToHex = function (str) {\n if (!str) return \"0x00\";\n var hex = \"\";\n for (var i = 0; i < str.length; i++) {\n var code = str.charCodeAt(i);\n var n = code.toString(16);\n hex += n.length < 2 ? '0' + n : n;\n }\n return \"0x\" + hex;\n};\n/**\n * Returns value of unit in Wei\n *\n * @method getUnitValue\n * @param {String} unit the unit to convert to, default ether\n * @returns {BN} value of the unit (in Wei)\n * @throws error if the unit is not correct:w\n */\nvar getUnitValue = function (unit) {\n unit = unit ? unit.toLowerCase() : 'ether';\n if (!ethjsUnit.unitMap[unit]) {\n throw new Error('This unit \"' + unit + '\" doesn\\'t exist, please use the one of the following units' + JSON.stringify(ethjsUnit.unitMap, null, 2));\n }\n return unit;\n};\n/**\n * Takes a number of wei and converts it to any other ether unit.\n *\n * Possible units are:\n * SI Short SI Full Effigy Other\n * - kwei femtoether babbage\n * - mwei picoether lovelace\n * - gwei nanoether shannon nano\n * - -- microether szabo micro\n * - -- milliether finney milli\n * - ether -- --\n * - kether -- grand\n * - mether\n * - gether\n * - tether\n *\n * @method fromWei\n * @param {Number|String} number can be a number, number string or a HEX of a decimal\n * @param {String} unit the unit to convert to, default ether\n * @return {String|Object} When given a BN object it returns one as well, otherwise a number\n */\nvar fromWei = function (number, unit) {\n unit = getUnitValue(unit);\n if (!utils.isBN(number) && !(typeof number === 'string')) {\n throw new Error('Please pass numbers as strings or BN objects to avoid precision errors.');\n }\n return utils.isBN(number) ? ethjsUnit.fromWei(number, unit) : ethjsUnit.fromWei(number, unit).toString(10);\n};\n/**\n * Takes a number of a unit and converts it to wei.\n *\n * Possible units are:\n * SI Short SI Full Effigy Other\n * - kwei femtoether babbage\n * - mwei picoether lovelace\n * - gwei nanoether shannon nano\n * - -- microether szabo micro\n * - -- microether szabo micro\n * - -- milliether finney milli\n * - ether -- --\n * - kether -- grand\n * - mether\n * - gether\n * - tether\n *\n * @method toWei\n * @param {Number|String|BN} number can be a number, number string or a HEX of a decimal\n * @param {String} unit the unit to convert from, default ether\n * @return {String|Object} When given a BN object it returns one as well, otherwise a number\n */\nvar toWei = function (number, unit) {\n unit = getUnitValue(unit);\n if (!utils.isBN(number) && !(typeof number === 'string')) {\n throw new Error('Please pass numbers as strings or BN objects to avoid precision errors.');\n }\n return utils.isBN(number) ? ethjsUnit.toWei(number, unit) : ethjsUnit.toWei(number, unit).toString(10);\n};\n/**\n * Converts to a checksum address\n *\n * @method toChecksumAddress\n * @param {String} address the given HEX address\n * @return {String}\n */\nvar toChecksumAddress = function (address) {\n if (typeof address === 'undefined') return '';\n if (!/^(0x)?[0-9a-f]{40}$/i.test(address)) throw new Error('Given address \"' + address + '\" is not a valid Ethereum address.');\n address = address.toLowerCase().replace(/^0x/i, '');\n var addressHash = utils.sha3(address).replace(/^0x/i, '');\n var checksumAddress = '0x';\n for (var i = 0; i < address.length; i++) {\n // If ith character is 8 to f then make it uppercase\n if (parseInt(addressHash[i], 16) > 7) {\n checksumAddress += address[i].toUpperCase();\n } else {\n checksumAddress += address[i];\n }\n }\n return checksumAddress;\n};\n/**\n * Returns -1 if ab; 0 if a == b.\n * For more details on this type of function, see\n * developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort\n * Block tag `safe` and `block number` combination param is not supported\n * @method compareBlockNumbers\n *\n * @param {String|Number|BN} a\n *\n * @param {String|Number|BN} b\n *\n * @returns {Number} -1, 0, or 1\n */\nvar compareBlockNumbers = function (a, b) {\n // Increasing order: (genesis = earliest), safe, (finalized ~ latest), pending\n // safe vs block-num cant be compared as block number provided can be on left or right side of safe tag, until safe tag block number is extracted and compared\n if (a === b) {\n return 0;\n } else if ((\"genesis\" === a || \"earliest\" === a || 0 === a) && (\"genesis\" === b || \"earliest\" === b || 0 === b)) {\n return 0;\n } else if (\"genesis\" === a || \"earliest\" === a || a === 0) {\n // b !== a, thus a < b\n return -1;\n } else if (\"genesis\" === b || \"earliest\" === b || b === 0) {\n // b !== a, thus a > b\n return 1;\n } else if (a === \"latest\" || a === \"finalized\") {\n if (b === \"pending\") {\n return -1;\n } else {\n // b !== (\"pending\" OR \"latest\"), thus a > b\n return 1;\n }\n } else if (b === \"latest\" || b === \"finalized\") {\n if (a === \"pending\") {\n return 1;\n } else {\n // b !== (\"pending\" OR \"latest\"), thus a > b\n return -1;\n }\n } else if (a === \"pending\") {\n // b (== OR <) \"latest\", thus a > b\n return 1;\n } else if (b === \"pending\") {\n return -1;\n } else if (a === \"safe\" || b === \"safe\") {\n // either a or b is \"safe\" and the other one did not fall into any of the conditions above, so the other one is a number\n return undefined;\n } else {\n let bnA = new BN(a);\n let bnB = new BN(b);\n if (bnA.lt(bnB)) {\n return -1;\n } else if (bnA.eq(bnB)) {\n return 0;\n } else {\n return 1;\n }\n }\n};\nmodule.exports = {\n _fireError: _fireError,\n _jsonInterfaceMethodToString: _jsonInterfaceMethodToString,\n _flattenTypes: _flattenTypes,\n // extractDisplayName: extractDisplayName,\n // extractTypeName: extractTypeName,\n randomHex: randomHex,\n BN: utils.BN,\n isBN: utils.isBN,\n isBigNumber: utils.isBigNumber,\n isHex: utils.isHex,\n isHexStrict: utils.isHexStrict,\n sha3: utils.sha3,\n sha3Raw: utils.sha3Raw,\n keccak256: utils.sha3,\n soliditySha3: soliditySha3.soliditySha3,\n soliditySha3Raw: soliditySha3.soliditySha3Raw,\n encodePacked: soliditySha3.encodePacked,\n isAddress: utils.isAddress,\n checkAddressChecksum: utils.checkAddressChecksum,\n toChecksumAddress: toChecksumAddress,\n toHex: utils.toHex,\n toBN: utils.toBN,\n bytesToHex: utils.bytesToHex,\n hexToBytes: utils.hexToBytes,\n hexToNumberString: utils.hexToNumberString,\n hexToNumber: utils.hexToNumber,\n toDecimal: utils.hexToNumber,\n numberToHex: utils.numberToHex,\n fromDecimal: utils.numberToHex,\n hexToUtf8: utils.hexToUtf8,\n hexToString: utils.hexToUtf8,\n toUtf8: utils.hexToUtf8,\n stripHexPrefix: utils.stripHexPrefix,\n utf8ToHex: utils.utf8ToHex,\n stringToHex: utils.utf8ToHex,\n fromUtf8: utils.utf8ToHex,\n hexToAscii: hexToAscii,\n toAscii: hexToAscii,\n asciiToHex: asciiToHex,\n fromAscii: asciiToHex,\n unitMap: ethjsUnit.unitMap,\n toWei: toWei,\n fromWei: fromWei,\n padLeft: utils.leftPad,\n leftPad: utils.leftPad,\n padRight: utils.rightPad,\n rightPad: utils.rightPad,\n toTwosComplement: utils.toTwosComplement,\n isBloom: utils.isBloom,\n isUserEthereumAddressInBloom: utils.isUserEthereumAddressInBloom,\n isContractAddressInBloom: utils.isContractAddressInBloom,\n isTopic: utils.isTopic,\n isTopicInBloom: utils.isTopicInBloom,\n isInBloom: utils.isInBloom,\n compareBlockNumbers: compareBlockNumbers,\n toNumber: utils.toNumber\n};","/*\n This file is part of web3.js.\n\n web3.js is free software: you can redistribute it and/or modify\n it under the terms of the GNU Lesser 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 web3.js 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 Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public License\n along with web3.js. If not, see .\n */\n/**\n * @file index.js\n * @author Marek Kotewicz \n * @author Fabian Vogelsteller \n * @date 2018\n */\nvar Buffer = require('buffer').Buffer;\nvar utils = require('web3-utils');\nvar EthersAbiCoder = require('@ethersproject/abi').AbiCoder;\nvar ParamType = require('@ethersproject/abi').ParamType;\nvar ethersAbiCoder = new EthersAbiCoder(function (type, value) {\n if (type.match(/^u?int/) && !Array.isArray(value) && (!(!!value && typeof value === 'object') || value.constructor.name !== 'BN')) {\n return value.toString();\n }\n return value;\n});\n// result method\nfunction Result() {}\n/**\n * ABICoder prototype should be used to encode/decode solidity params of any type\n */\nvar ABICoder = function () {};\n/**\n * Encodes the function name to its ABI representation, which are the first 4 bytes of the sha3 of the function name including types.\n *\n * @method encodeFunctionSignature\n * @param {String|Object} functionName\n * @return {String} encoded function name\n */\nABICoder.prototype.encodeFunctionSignature = function (functionName) {\n if (typeof functionName === 'function' || typeof functionName === 'object' && functionName) {\n functionName = utils._jsonInterfaceMethodToString(functionName);\n }\n return utils.sha3(functionName).slice(0, 10);\n};\n/**\n * Encodes the function name to its ABI representation, which are the first 4 bytes of the sha3 of the function name including types.\n *\n * @method encodeEventSignature\n * @param {String|Object} functionName\n * @return {String} encoded function name\n */\nABICoder.prototype.encodeEventSignature = function (functionName) {\n if (typeof functionName === 'function' || typeof functionName === 'object' && functionName) {\n functionName = utils._jsonInterfaceMethodToString(functionName);\n }\n return utils.sha3(functionName);\n};\n/**\n * Should be used to encode plain param\n *\n * @method encodeParameter\n *\n * @param {String|Object} type\n * @param {any} param\n *\n * @return {String} encoded plain param\n */\nABICoder.prototype.encodeParameter = function (type, param) {\n return this.encodeParameters([type], [param]);\n};\n/**\n * Should be used to encode list of params\n *\n * @method encodeParameters\n *\n * @param {Array} types\n * @param {Array} params\n *\n * @return {String} encoded list of params\n */\nABICoder.prototype.encodeParameters = function (types, params) {\n var self = this;\n types = self.mapTypes(types);\n params = params.map(function (param, index) {\n let type = types[index];\n if (typeof type === 'object' && type.type) {\n // We may get a named type of shape {name, type}\n type = type.type;\n }\n param = self.formatParam(type, param);\n // Format params for tuples\n if (typeof type === 'string' && type.includes('tuple')) {\n const coder = ethersAbiCoder._getCoder(ParamType.from(type));\n const modifyParams = (coder, param) => {\n if (coder.name === 'array') {\n if (!coder.type.match(/\\[(\\d+)\\]/)) {\n return param.map(p => modifyParams(ethersAbiCoder._getCoder(ParamType.from(coder.type.replace('[]', ''))), p));\n }\n const arrayLength = parseInt(coder.type.match(/\\[(\\d+)\\]/)[1]);\n if (param.length !== arrayLength) {\n throw new Error('Array length does not matches with the given input');\n }\n return param.map(p => modifyParams(ethersAbiCoder._getCoder(ParamType.from(coder.type.replace(/\\[\\d+\\]/, ''))), p));\n }\n coder.coders.forEach((c, i) => {\n if (c.name === 'tuple') {\n modifyParams(c, param[i]);\n } else {\n param[i] = self.formatParam(c.name, param[i]);\n }\n });\n };\n modifyParams(coder, param);\n }\n return param;\n });\n return ethersAbiCoder.encode(types, params);\n};\n/**\n * Map types if simplified format is used\n *\n * @method mapTypes\n * @param {Array} types\n * @return {Array}\n */\nABICoder.prototype.mapTypes = function (types) {\n var self = this;\n var mappedTypes = [];\n types.forEach(function (type) {\n // Remap `function` type params to bytes24 since Ethers does not\n // recognize former type. Solidity docs say `Function` is a bytes24\n // encoding the contract address followed by the function selector hash.\n if (typeof type === 'object' && type.type === 'function') {\n type = Object.assign({}, type, {\n type: \"bytes24\"\n });\n }\n if (self.isSimplifiedStructFormat(type)) {\n var structName = Object.keys(type)[0];\n mappedTypes.push(Object.assign(self.mapStructNameAndType(structName), {\n components: self.mapStructToCoderFormat(type[structName])\n }));\n return;\n }\n mappedTypes.push(type);\n });\n return mappedTypes;\n};\n/**\n * Check if type is simplified struct format\n *\n * @method isSimplifiedStructFormat\n * @param {string | Object} type\n * @returns {boolean}\n */\nABICoder.prototype.isSimplifiedStructFormat = function (type) {\n return typeof type === 'object' && typeof type.components === 'undefined' && typeof type.name === 'undefined';\n};\n/**\n * Maps the correct tuple type and name when the simplified format in encode/decodeParameter is used\n *\n * @method mapStructNameAndType\n * @param {string} structName\n * @return {{type: string, name: *}}\n */\nABICoder.prototype.mapStructNameAndType = function (structName) {\n var type = 'tuple';\n if (structName.indexOf('[]') > -1) {\n type = 'tuple[]';\n structName = structName.slice(0, -2);\n }\n return {\n type: type,\n name: structName\n };\n};\n/**\n * Maps the simplified format in to the expected format of the ABICoder\n *\n * @method mapStructToCoderFormat\n * @param {Object} struct\n * @return {Array}\n */\nABICoder.prototype.mapStructToCoderFormat = function (struct) {\n var self = this;\n var components = [];\n Object.keys(struct).forEach(function (key) {\n if (typeof struct[key] === 'object') {\n components.push(Object.assign(self.mapStructNameAndType(key), {\n components: self.mapStructToCoderFormat(struct[key])\n }));\n return;\n }\n components.push({\n name: key,\n type: struct[key]\n });\n });\n return components;\n};\n/**\n * Handle some formatting of params for backwards compatability with Ethers V4\n *\n * @method formatParam\n * @param {String} - type\n * @param {any} - param\n * @return {any} - The formatted param\n */\nABICoder.prototype.formatParam = function (type, param) {\n const paramTypeBytes = new RegExp(/^bytes([0-9]*)$/);\n const paramTypeBytesArray = new RegExp(/^bytes([0-9]*)\\[\\]$/);\n const paramTypeNumber = new RegExp(/^(u?int)([0-9]*)$/);\n const paramTypeNumberArray = new RegExp(/^(u?int)([0-9]*)\\[\\]$/);\n // Format BN to string\n if (utils.isBN(param) || utils.isBigNumber(param)) {\n return param.toString(10);\n }\n if (type.match(paramTypeBytesArray) || type.match(paramTypeNumberArray)) {\n return param.map(p => this.formatParam(type.replace('[]', ''), p));\n }\n // Format correct width for u?int[0-9]*\n let match = type.match(paramTypeNumber);\n if (match) {\n let size = parseInt(match[2] || \"256\");\n if (size / 8 < param.length) {\n param = param.startsWith(\"-\")\n // pad to correct bit width, with - at the beginning\n ? `-${utils.leftPad(param.substring(1), size)}`\n // pad to correct bit width\n : utils.leftPad(param, size);\n }\n }\n // Format correct length for bytes[0-9]+\n match = type.match(paramTypeBytes);\n if (match) {\n if (Buffer.isBuffer(param)) {\n param = utils.toHex(param);\n }\n // format to correct length\n let size = parseInt(match[1]);\n if (size) {\n let maxSize = size * 2;\n if (param.substring(0, 2) === '0x') {\n maxSize += 2;\n }\n if (param.length < maxSize) {\n // pad to correct length\n param = utils.rightPad(param, size * 2);\n }\n }\n // format odd-length bytes to even-length\n if (param.length % 2 === 1) {\n param = '0x0' + param.substring(2);\n }\n }\n return param;\n};\n/**\n * Encodes a function call from its json interface and parameters.\n *\n * @method encodeFunctionCall\n * @param {Array} jsonInterface\n * @param {Array} params\n * @return {String} The encoded ABI for this function call\n */\nABICoder.prototype.encodeFunctionCall = function (jsonInterface, params) {\n return this.encodeFunctionSignature(jsonInterface) + this.encodeParameters(jsonInterface.inputs, params).replace('0x', '');\n};\n/**\n * Should be used to decode bytes to plain param\n *\n * @method decodeParameter\n * @param {String} type\n * @param {String} bytes\n * @return {Object} plain param\n */\nABICoder.prototype.decodeParameter = function (type, bytes) {\n return this.decodeParameters([type], bytes)[0];\n};\n/**\n * Should be used to decode list of params\n *\n * @method decodeParameter\n * @param {Array} outputs\n * @param {String} bytes\n * @return {Array} array of plain params\n */\nABICoder.prototype.decodeParameters = function (outputs, bytes) {\n return this.decodeParametersWith(outputs, bytes, false);\n};\n/**\n * Should be used to decode list of params\n *\n * @method decodeParameter\n * @param {Array} outputs\n * @param {String} bytes\n * @param {Boolean} loose\n * @return {Array} array of plain params\n */\nABICoder.prototype.decodeParametersWith = function (outputs, bytes, loose) {\n if (outputs.length > 0 && (!bytes || bytes === '0x' || bytes === '0X')) {\n throw new Error('Returned values aren\\'t valid, did it run Out of Gas? ' + 'You might also see this error if you are not using the ' + 'correct ABI for the contract you are retrieving data from, ' + 'requesting data from a block number that does not exist, ' + 'or querying a node which is not fully synced.');\n }\n var res = ethersAbiCoder.decode(this.mapTypes(outputs), '0x' + bytes.replace(/0x/i, ''), loose);\n var returnValue = new Result();\n returnValue.__length__ = 0;\n outputs.forEach(function (output, i) {\n var decodedValue = res[returnValue.__length__];\n const isStringObject = typeof output === 'object' && output.type && output.type === 'string';\n const isStringType = typeof output === 'string' && output === 'string';\n // only convert `0x` to null if it's not string value\n decodedValue = decodedValue === '0x' && !isStringObject && !isStringType ? null : decodedValue;\n returnValue[i] = decodedValue;\n if ((typeof output === 'function' || !!output && typeof output === 'object') && output.name) {\n returnValue[output.name] = decodedValue;\n }\n returnValue.__length__++;\n });\n return returnValue;\n};\n/**\n * Decodes events non- and indexed parameters.\n *\n * @method decodeLog\n * @param {Object} inputs\n * @param {String} data\n * @param {Array} topics\n * @return {Array} array of plain params\n */\nABICoder.prototype.decodeLog = function (inputs, data, topics) {\n var _this = this;\n topics = Array.isArray(topics) ? topics : [topics];\n data = data || '';\n var notIndexedInputs = [];\n var indexedParams = [];\n var topicCount = 0;\n // TODO check for anonymous logs?\n inputs.forEach(function (input, i) {\n if (input.indexed) {\n indexedParams[i] = ['bool', 'int', 'uint', 'address', 'fixed', 'ufixed'].find(function (staticType) {\n return input.type.indexOf(staticType) !== -1;\n }) ? _this.decodeParameter(input.type, topics[topicCount]) : topics[topicCount];\n topicCount++;\n } else {\n notIndexedInputs[i] = input;\n }\n });\n var nonIndexedData = data;\n var notIndexedParams = nonIndexedData ? this.decodeParametersWith(notIndexedInputs, nonIndexedData, true) : [];\n var returnValue = new Result();\n returnValue.__length__ = 0;\n inputs.forEach(function (res, i) {\n returnValue[i] = res.type === 'string' ? '' : null;\n if (typeof notIndexedParams[i] !== 'undefined') {\n returnValue[i] = notIndexedParams[i];\n }\n if (typeof indexedParams[i] !== 'undefined') {\n returnValue[i] = indexedParams[i];\n }\n if (res.name) {\n returnValue[res.name] = returnValue[i];\n }\n returnValue.__length__++;\n });\n return returnValue;\n};\nvar coder = new ABICoder();\nmodule.exports = coder;","const {\n sha3,\n BN\n} = require(\"web3-utils\");\nconst abiCoder = require(\"web3-eth-abi\");\nconst state = {\n savedABIs: [],\n methodIDs: {},\n keepNonDecodedLogs: false\n};\nfunction _getABIs() {\n return state.savedABIs;\n}\nfunction _typeToString(input) {\n if (input.type === \"tuple\") {\n return \"(\" + input.components.map(_typeToString).join(\",\") + \")\";\n }\n return input.type;\n}\nfunction _addABI(abiArray) {\n if (Array.isArray(abiArray)) {\n // Iterate new abi to generate method id\"s\n abiArray.map(function (abi) {\n if (abi.name) {\n const signature = sha3(abi.name + \"(\" + abi.inputs.map(_typeToString).join(\",\") + \")\");\n if (abi.type === \"event\") {\n state.methodIDs[signature.slice(2)] = abi;\n } else {\n state.methodIDs[signature.slice(2, 10)] = abi;\n }\n }\n });\n state.savedABIs = state.savedABIs.concat(abiArray);\n } else {\n throw new Error(\"Expected ABI array, got \" + typeof abiArray);\n }\n}\nfunction _removeABI(abiArray) {\n if (Array.isArray(abiArray)) {\n // Iterate new abi to generate method id\"s\n abiArray.map(function (abi) {\n if (abi.name) {\n const signature = sha3(abi.name + \"(\" + abi.inputs.map(function (input) {\n return input.type;\n }).join(\",\") + \")\");\n if (abi.type === \"event\") {\n if (state.methodIDs[signature.slice(2)]) {\n delete state.methodIDs[signature.slice(2)];\n }\n } else {\n if (state.methodIDs[signature.slice(2, 10)]) {\n delete state.methodIDs[signature.slice(2, 10)];\n }\n }\n }\n });\n } else {\n throw new Error(\"Expected ABI array, got \" + typeof abiArray);\n }\n}\nfunction _getMethodIDs() {\n return state.methodIDs;\n}\nfunction _decodeMethod(data) {\n const methodID = data.slice(2, 10);\n const abiItem = state.methodIDs[methodID];\n if (abiItem) {\n let decoded = abiCoder.decodeParameters(abiItem.inputs, data.slice(10));\n let retData = {\n name: abiItem.name,\n params: []\n };\n for (let i = 0; i < decoded.__length__; i++) {\n let param = decoded[i];\n let parsedParam = param;\n const isUint = abiItem.inputs[i].type.indexOf(\"uint\") === 0;\n const isInt = abiItem.inputs[i].type.indexOf(\"int\") === 0;\n const isAddress = abiItem.inputs[i].type.indexOf(\"address\") === 0;\n if (isUint || isInt) {\n const isArray = Array.isArray(param);\n if (isArray) {\n parsedParam = param.map(val => new BN(val).toString());\n } else {\n parsedParam = new BN(param).toString();\n }\n }\n\n // Addresses returned by web3 are randomly cased so we need to standardize and lowercase all\n if (isAddress) {\n const isArray = Array.isArray(param);\n if (isArray) {\n parsedParam = param.map(_ => _.toLowerCase());\n } else {\n parsedParam = param.toLowerCase();\n }\n }\n retData.params.push({\n name: abiItem.inputs[i].name,\n value: parsedParam,\n type: abiItem.inputs[i].type\n });\n }\n return retData;\n }\n}\nfunction _decodeLogs(logs) {\n return logs.filter(log => log.topics.length > 0).map(logItem => {\n const methodID = logItem.topics[0].slice(2);\n const method = state.methodIDs[methodID];\n if (method) {\n const logData = logItem.data;\n let decodedParams = [];\n let dataIndex = 0;\n let topicsIndex = 1;\n let dataTypes = [];\n method.inputs.map(function (input) {\n if (!input.indexed) {\n dataTypes.push(input.type);\n }\n });\n const decodedData = abiCoder.decodeParameters(dataTypes, logData.slice(2));\n\n // Loop topic and data to get the params\n method.inputs.map(function (param) {\n let decodedP = {\n name: param.name,\n type: param.type\n };\n if (param.indexed) {\n decodedP.value = logItem.topics[topicsIndex];\n topicsIndex++;\n } else {\n decodedP.value = decodedData[dataIndex];\n dataIndex++;\n }\n if (param.type === \"address\") {\n decodedP.value = decodedP.value.toLowerCase();\n // 42 because len(0x) + 40\n if (decodedP.value.length > 42) {\n let toRemove = decodedP.value.length - 42;\n let temp = decodedP.value.split(\"\");\n temp.splice(2, toRemove);\n decodedP.value = temp.join(\"\");\n }\n }\n if (param.type === \"uint256\" || param.type === \"uint8\" || param.type === \"int\") {\n // ensure to remove leading 0x for hex numbers\n if (typeof decodedP.value === \"string\" && decodedP.value.startsWith(\"0x\")) {\n decodedP.value = new BN(decodedP.value.slice(2), 16).toString(10);\n } else {\n decodedP.value = new BN(decodedP.value).toString(10);\n }\n }\n decodedParams.push(decodedP);\n });\n return {\n name: method.name,\n events: decodedParams,\n address: logItem.address\n };\n }\n }).filter(decoded => state.keepNonDecodedLogs || decoded);\n}\nfunction _keepNonDecodedLogs() {\n state.keepNonDecodedLogs = true;\n}\nfunction _discardNonDecodedLogs() {\n state.keepNonDecodedLogs = false;\n}\nmodule.exports = {\n getABIs: _getABIs,\n addABI: _addABI,\n getMethodIDs: _getMethodIDs,\n decodeMethod: _decodeMethod,\n decodeLogs: _decodeLogs,\n removeABI: _removeABI,\n keepNonDecodedLogs: _keepNonDecodedLogs,\n discardNonDecodedLogs: _discardNonDecodedLogs\n};","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RelayProvider = void 0;\n/* eslint-disable no-void */\n// @ts-ignore\nconst abi_decoder_1 = __importDefault(require(\"abi-decoder\"));\nconst bignumber_1 = require(\"@ethersproject/bignumber\");\nconst common_1 = require(\"@opengsn/common\");\nconst IRelayHub_json_1 = __importDefault(require(\"@opengsn/common/dist/interfaces/IRelayHub.json\"));\nconst RelayClient_1 = require(\"./RelayClient\");\nabi_decoder_1.default.addABI(IRelayHub_json_1.default);\nconst TX_FUTURE = 'tx-future';\nconst TX_NOTFOUND = 'tx-notfound';\nconst BLOCKS_FOR_LOOKUP = 5000;\nclass RelayProvider {\n constructor(relayClient) {\n this.submittedRelayRequests = new Map();\n if (relayClient.send != null) {\n throw new Error('Using new RelayProvider() constructor directly is deprecated.\\nPlease create provider using RelayProvider.newProvider({})');\n }\n this.relayClient = relayClient;\n this.origProvider = this.relayClient.getUnderlyingProvider();\n this.logger = this.relayClient.logger;\n this._origProviderSend = this.origProvider.send.bind(this.origProvider);\n this._delegateEventsApi();\n }\n static newProvider(input) {\n return new RelayProvider(new RelayClient_1.RelayClient(input));\n }\n origProviderSend(payload, callback) {\n var _a;\n this._origProviderSend(payload.method, (_a = payload.params) !== null && _a !== void 0 ? _a : []).then(it => {\n var _a;\n const response = {\n jsonrpc: '2.0',\n id: (_a = payload.id) !== null && _a !== void 0 ? _a : 0,\n result: it\n };\n callback(null, response);\n }).catch(err => {\n callback(err);\n });\n }\n async init(useTokenPaymaster = false) {\n await this.relayClient.init(useTokenPaymaster);\n this.config = this.relayClient.config;\n this.asyncSignTypedData = this.relayClient.dependencies.asyncSignTypedData;\n this.logger.info(`Created new RelayProvider ver.${common_1.gsnRuntimeVersion}`);\n return this;\n }\n registerEventListener(handler) {\n this.relayClient.registerEventListener(handler);\n }\n unregisterEventListener(handler) {\n this.relayClient.unregisterEventListener(handler);\n }\n _delegateEventsApi() {\n // If the subprovider is a ws or ipc provider, then register all its methods on this provider\n // and delegate calls to the subprovider. This allows subscriptions to work.\n ['on', 'removeListener', 'removeAllListeners', 'reset', 'disconnect', 'addDefaultEvents', 'once', 'reconnect'].forEach(func => {\n // @ts-ignore\n if (this.origProvider[func] !== undefined) {\n // @ts-ignore\n this[func] = this.origProvider[func].bind(this.origProvider);\n }\n });\n }\n send(payload, callback) {\n if (this._useGSN(payload)) {\n if (payload.method === 'eth_sendTransaction') {\n // @ts-ignore\n if (payload.params[0].to === undefined) {\n callback(new Error('GSN cannot relay contract deployment transactions. Add {from: accountWithEther, useGSN: false}.'));\n return;\n }\n void this._ethSendTransaction(payload, callback);\n return;\n }\n if (payload.method === 'eth_getTransactionReceipt') {\n void this._ethGetTransactionReceipt(payload, callback);\n return;\n }\n if (payload.method === 'eth_getTransactionByHash') {\n void this._ethGetTransactionByHash(payload, callback);\n return;\n }\n if (payload.method === 'eth_accounts') {\n this._getAccounts(payload, callback);\n return;\n }\n if (payload.method === 'eth_sign') {\n this._sign(payload, callback);\n return;\n }\n if (payload.method === 'eth_signTransaction') {\n this._signTransaction(payload, callback);\n return;\n }\n if (payload.method === 'eth_signTypedData') {\n this._signTypedData(payload, callback);\n return;\n }\n }\n this.origProviderSend(payload, callback);\n }\n _ethGetTransactionReceiptWithTransactionHash(payload, callback) {\n this.logger.info('calling sendAsync' + JSON.stringify(payload));\n this.origProviderSend(payload, (error, rpcResponse) => {\n // Sometimes, ganache seems to return 'false' for 'no error' (breaking TypeScript declarations)\n // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions\n if (error) {\n callback(error, rpcResponse);\n return;\n }\n if (rpcResponse == null || rpcResponse.result == null) {\n callback(error, rpcResponse);\n return;\n }\n rpcResponse.result = this._getTranslatedGsnResponseResult(rpcResponse.result);\n callback(error, rpcResponse);\n });\n }\n /**\n * pack promise call as a jsonrpc callback\n * @param promise the promise request. return value is \"result\" for the callback\n * @param payload original payload. used to copy rpc param (jsonrpc, id)\n * @param callback callback to call result or error (for exception)\n */\n asCallback(promise, payload, callback) {\n promise.then(result => {\n callback(null, {\n result,\n // @ts-ignore\n id: payload.id,\n jsonrpc: payload.jsonrpc\n });\n }).catch(error => {\n const err = {\n error,\n // @ts-ignore\n id: payload.id,\n jsonrpc: payload.jsonrpc\n };\n callback(err);\n });\n }\n async _getSubmissionDetailsForRelayRequestId(relayRequestID) {\n const submissionDetails = this.submittedRelayRequests.get(relayRequestID);\n if (submissionDetails != null) {\n return submissionDetails;\n }\n const blockNumber = await this.origProvider.getBlockNumber();\n const manyBlocksAgo = Math.max(1, blockNumber - BLOCKS_FOR_LOOKUP);\n this.logger.warn(`Looking up relayed transaction by its RelayRequestID(${relayRequestID}) from block ${manyBlocksAgo}`);\n return {\n submissionBlock: manyBlocksAgo,\n validUntilTime: Number.MAX_SAFE_INTEGER.toString()\n };\n }\n async _ethGetTransactionByHash(payload, callback) {\n // @ts-ignore\n const relayRequestID = payload.params[0];\n const submissionDetails = await this._getSubmissionDetailsForRelayRequestId(relayRequestID);\n let txHash = await this._getTransactionIdFromRequestId(relayRequestID, submissionDetails);\n if (!txHash.startsWith('0x')) {\n txHash = relayRequestID;\n }\n const tx = await this._origProviderSend('eth_getTransactionByHash', [txHash]);\n if (tx != null) {\n // must return exactly what was requested...\n tx.hash = relayRequestID;\n tx.actualTransactionHash = txHash;\n }\n this.asCallback(Promise.resolve(tx), payload, callback);\n }\n /**\n * The ID can be either a RelayRequestID which requires event-based lookup or Transaction Hash that goes through\n * @param payload\n * @param callback\n */\n async _ethGetTransactionReceipt(payload, callback) {\n var _a, _b;\n const id = (_a = typeof payload.id === 'string' ? parseInt(payload.id) : payload.id) !== null && _a !== void 0 ? _a : -1;\n const relayRequestID = (_b = payload.params) === null || _b === void 0 ? void 0 : _b[0];\n const hasPrefix = relayRequestID.includes('0x00000000');\n if (!hasPrefix) {\n this._ethGetTransactionReceiptWithTransactionHash(payload, callback);\n return;\n }\n try {\n const result = await this._createTransactionReceiptForRelayRequestID(relayRequestID);\n const rpcResponse = {\n id,\n result,\n jsonrpc: '2.0'\n };\n callback(null, rpcResponse);\n } catch (error) {\n callback(error, undefined);\n }\n }\n async _ethSendTransaction(payload, callback) {\n var _a;\n this.logger.info('calling sendAsync' + JSON.stringify(payload));\n let gsnTransactionDetails;\n try {\n gsnTransactionDetails = await this._fixGasFees((_a = payload.params) === null || _a === void 0 ? void 0 : _a[0]);\n } catch (e) {\n this.logger.error(e);\n callback(e);\n return;\n }\n try {\n const r = await this.relayClient.relayTransaction(gsnTransactionDetails);\n void this._onRelayTransactionFulfilled(r, payload, callback);\n } catch (reason) {\n void this._onRelayTransactionRejected(reason, callback);\n }\n }\n _onRelayTransactionFulfilled(relayingResult, payload, callback) {\n if (relayingResult.relayRequestID != null) {\n const jsonRpcSendResult = this._convertRelayRequestIdToRpcSendResponse(relayingResult.relayRequestID, payload);\n this.cacheSubmittedTransactionDetails(relayingResult);\n callback(null, jsonRpcSendResult);\n } else {\n const message = `Failed to relay call. Results:\\n${(0, RelayClient_1._dumpRelayingResult)(relayingResult)}`;\n this.logger.error(message);\n callback(new Error(message));\n }\n }\n _onRelayTransactionRejected(reason, callback) {\n const reasonStr = reason instanceof Error ? reason.message : JSON.stringify(reason);\n const msg = `Rejected relayTransaction call with reason: ${reasonStr}`;\n this.logger.info(msg);\n callback(new Error(msg));\n }\n _convertRelayRequestIdToRpcSendResponse(relayRequestID, request) {\n var _a;\n const id = (_a = typeof request.id === 'string' ? parseInt(request.id) : request.id) !== null && _a !== void 0 ? _a : -1;\n return {\n jsonrpc: '2.0',\n id,\n result: relayRequestID\n };\n }\n /**\n * convert relayRequestId (which is a \"synthethic\" transaction ID) into the actual transaction Id.\n * This is done by parsing RelayHub event, and can only be done after mining.\n * @param relayRequestID\n * @param submissionDetails\n * @return transactionId or marker:\n * If the transaction is already mined, return a real transactionId\n * If the transaction is no longer valid, return TX_NOTFOUND\n * If the transaction can still be mined, returns TX_FUTURE\n */\n async _getTransactionIdFromRequestId(relayRequestID, submissionDetails) {\n const extraTopics = [null, null, [relayRequestID]];\n const events = await this.relayClient.dependencies.contractInteractor.getPastEventsForHub(extraTopics, {\n fromBlock: submissionDetails.submissionBlock\n }, [common_1.TransactionRelayed, common_1.TransactionRejectedByPaymaster]);\n if (events.length === 0) {\n if (parseInt(submissionDetails.validUntilTime) > Date.now()) {\n return TX_FUTURE;\n }\n return TX_NOTFOUND;\n }\n return this._pickSingleEvent(events, relayRequestID).transactionHash;\n }\n /**\n * If the transaction is already mined, return a simulated successful transaction receipt\n * If the transaction is no longer valid, return a simulated reverted transaction receipt\n * If the transaction can still be mined, returns \"null\" like a regular RPC call would do\n */\n async _createTransactionReceiptForRelayRequestID(relayRequestID) {\n const submissionDetails = await this._getSubmissionDetailsForRelayRequestId(relayRequestID);\n const transactionHash = await this._getTransactionIdFromRequestId(relayRequestID, submissionDetails);\n if (transactionHash === TX_FUTURE) {\n return null;\n }\n if (transactionHash === TX_NOTFOUND) {\n return this._createTransactionRevertedReceipt();\n }\n const originalTransactionReceipt = await this.origProvider.getTransactionReceipt(transactionHash);\n if (originalTransactionReceipt == null) {\n return null;\n }\n return this._getTranslatedGsnResponseResult(originalTransactionReceipt, relayRequestID);\n }\n _getTranslatedGsnResponseResult(respResult, relayRequestID) {\n const fixedTransactionReceipt = Object.assign({}, respResult);\n // adding non declared field to receipt object - can be used in tests\n // @ts-ignore\n fixedTransactionReceipt.actualTransactionHash = fixedTransactionReceipt.transactionHash;\n fixedTransactionReceipt.transactionHash = relayRequestID !== null && relayRequestID !== void 0 ? relayRequestID : fixedTransactionReceipt.transactionHash;\n // older Web3.js versions require 'status' to be an integer. Will be set to '0' if needed later in this method.\n // @ts-ignore\n fixedTransactionReceipt.status = '1';\n if (respResult.logs.length === 0) {\n return fixedTransactionReceipt;\n }\n const logs = abi_decoder_1.default.decodeLogs(respResult.logs);\n const paymasterRejectedEvents = logs.find(e => e != null && e.name === 'TransactionRejectedByPaymaster');\n if (paymasterRejectedEvents !== null && paymasterRejectedEvents !== undefined) {\n const paymasterRejectionReason = paymasterRejectedEvents.events.find(e => e.name === 'reason');\n if (paymasterRejectionReason !== undefined) {\n this.logger.info(`Paymaster rejected on-chain: ${paymasterRejectionReason.value}. changing status to zero`);\n // @ts-ignore\n fixedTransactionReceipt.status = '0';\n }\n return fixedTransactionReceipt;\n }\n const transactionRelayed = logs.find(e => e != null && e.name === 'TransactionRelayed');\n if (transactionRelayed != null) {\n const transactionRelayedStatus = transactionRelayed.events.find(e => e.name === 'status');\n if (transactionRelayedStatus !== undefined) {\n const status = transactionRelayedStatus.value.toString();\n // 0 signifies success\n if (status !== '0') {\n this.logger.info(`reverted relayed transaction, status code ${status}. changing status to zero`);\n // @ts-ignore\n fixedTransactionReceipt.status = '0';\n }\n }\n }\n return fixedTransactionReceipt;\n }\n _useGSN(payload) {\n var _a, _b;\n if (payload.method === 'eth_accounts') {\n return true;\n }\n if (((_a = payload.params) === null || _a === void 0 ? void 0 : _a[0]) === undefined) {\n return false;\n }\n const gsnTransactionDetails = payload.params[0];\n return (_b = gsnTransactionDetails === null || gsnTransactionDetails === void 0 ? void 0 : gsnTransactionDetails.useGSN) !== null && _b !== void 0 ? _b : true;\n }\n async _fixGasFees(_txDetails) {\n const txDetails = Object.assign({}, _txDetails);\n if (txDetails.maxFeePerGas != null && txDetails.maxPriorityFeePerGas != null) {\n delete txDetails.gasPrice;\n return txDetails;\n }\n if (txDetails.gasPrice != null && txDetails.maxFeePerGas == null && txDetails.maxPriorityFeePerGas == null) {\n txDetails.maxFeePerGas = txDetails.gasPrice;\n txDetails.maxPriorityFeePerGas = txDetails.gasPrice;\n delete txDetails.gasPrice;\n return txDetails;\n }\n if (txDetails.gasPrice == null && txDetails.maxFeePerGas == null && txDetails.maxPriorityFeePerGas == null) {\n const gasFees = await this.calculateGasFees();\n txDetails.maxPriorityFeePerGas = gasFees.maxPriorityFeePerGas;\n txDetails.maxFeePerGas = gasFees.maxFeePerGas;\n return txDetails;\n }\n throw new Error('Relay Provider: cannot provide only one of maxFeePerGas and maxPriorityFeePerGas');\n }\n /* wrapping HttpProvider interface */\n // host: string\n // connected: boolean\n supportsSubscriptions() {\n return false;\n }\n disconnect() {\n return false;\n }\n newAccount() {\n return this.relayClient.newAccount();\n }\n async calculateGasFees() {\n return await this.relayClient.calculateGasFees();\n }\n addAccount(privateKey) {\n return this.relayClient.addAccount(privateKey);\n }\n isEphemeralAccount(account) {\n const ephemeralAccounts = this.relayClient.dependencies.accountManager.getAccounts();\n return ephemeralAccounts.find(it => (0, common_1.isSameAddress)(account, it)) != null;\n }\n _sign(payload, callback) {\n var _a, _b, _c;\n const id = (_a = typeof payload.id === 'string' ? parseInt(payload.id) : payload.id) !== null && _a !== void 0 ? _a : -1;\n const from = (_b = payload.params) === null || _b === void 0 ? void 0 : _b[0];\n if (from != null && this.isEphemeralAccount(from)) {\n const result = this.relayClient.dependencies.accountManager.signMessage((_c = payload.params) === null || _c === void 0 ? void 0 : _c[1], from);\n const rpcResponse = {\n id,\n result,\n jsonrpc: '2.0'\n };\n callback(null, rpcResponse);\n return;\n }\n this.origProviderSend(payload, callback);\n }\n _signTransaction(payload, callback) {\n var _a, _b;\n const id = (_a = typeof payload.id === 'string' ? parseInt(payload.id) : payload.id) !== null && _a !== void 0 ? _a : -1;\n const transactionConfig = (_b = payload.params) === null || _b === void 0 ? void 0 : _b[0];\n const from = transactionConfig === null || transactionConfig === void 0 ? void 0 : transactionConfig.from;\n if (from != null && this.isEphemeralAccount(from)) {\n const result = this.relayClient.dependencies.accountManager.signTransaction(transactionConfig, from);\n const rpcResponse = {\n id,\n result,\n jsonrpc: '2.0'\n };\n callback(null, rpcResponse);\n return;\n }\n this.origProviderSend(payload, callback);\n }\n _signTypedData(payload, callback) {\n var _a, _b, _c;\n const id = (_a = typeof payload.id === 'string' ? parseInt(payload.id) : payload.id) !== null && _a !== void 0 ? _a : -1;\n const from = (_b = payload.params) === null || _b === void 0 ? void 0 : _b[0];\n const typedData = (_c = payload.params) === null || _c === void 0 ? void 0 : _c[1];\n if (from != null && this.isEphemeralAccount(from)) {\n this.logger.debug(`Using ephemeral key for address ${from} to sign a Relay Request or a Typed Message`);\n const result = this.relayClient.dependencies.accountManager.signTypedData(typedData, from);\n const rpcResponse = {\n id,\n result,\n jsonrpc: '2.0'\n };\n callback(null, rpcResponse);\n return;\n }\n if (this.asyncSignTypedData != null) {\n this.logger.debug('Using override for asyncSignTypedData to sign a Relay Request or a Typed Message');\n this.asyncSignTypedData(typedData, from).then(function (result) {\n const rpcResponse = {\n id,\n result,\n jsonrpc: '2.0'\n };\n callback(null, rpcResponse);\n }).catch(function (error) {\n callback(error);\n });\n return;\n }\n this.logger.debug('Using an RPC call to sign a Relay Request or a Typed Message');\n this.origProviderSend(payload, callback);\n }\n _getAccounts(payload, callback) {\n this.origProviderSend(payload, (error, rpcResponse) => {\n if (rpcResponse != null && Array.isArray(rpcResponse.result)) {\n const ephemeralAccounts = this.relayClient.dependencies.accountManager.getAccounts();\n rpcResponse.result = rpcResponse.result.concat(ephemeralAccounts);\n }\n callback(error, rpcResponse);\n });\n }\n /**\n * In an edge case many events with the same ID may be mined.\n * If there is a successful {@link TransactionRelayed} event, it will be returned.\n * If all events are {@link TransactionRejectedByPaymaster}, return the last one.\n * If there is more than one successful {@link TransactionRelayed} throws as this is impossible for current Forwarder\n */\n _pickSingleEvent(events, relayRequestID) {\n const successes = events.filter(it => it.name === common_1.TransactionRelayed);\n if (successes.length === 0) {\n const sorted = events.sort((a, b) => b.blockNumber - a.blockNumber);\n return sorted[0];\n } else if (successes.length === 1) {\n return successes[0];\n } else {\n throw new Error(`Multiple TransactionRelayed events with the same ${relayRequestID} found!`);\n }\n }\n cacheSubmittedTransactionDetails(relayingResult\n // relayRequestID: string,\n // submissionBlock: number,\n // validUntil: string\n ) {\n if (relayingResult.relayRequestID == null || relayingResult.submissionBlock == null || relayingResult.validUntilTime == null) {\n throw new Error('Missing info in RelayingResult - internal GSN error, should not happen');\n }\n this.submittedRelayRequests.set(relayingResult.relayRequestID, {\n validUntilTime: relayingResult.validUntilTime,\n submissionBlock: relayingResult.submissionBlock\n });\n }\n _createTransactionRevertedReceipt() {\n return {\n // TODO: I am not sure about these two, these were not required in Web3.js\n confirmations: 0,\n byzantium: false,\n type: 0,\n to: '',\n from: '',\n contractAddress: '',\n logsBloom: '',\n blockHash: '',\n transactionHash: '',\n transactionIndex: 0,\n gasUsed: bignumber_1.BigNumber.from(0),\n logs: [],\n blockNumber: 0,\n cumulativeGasUsed: bignumber_1.BigNumber.from(0),\n effectiveGasPrice: bignumber_1.BigNumber.from(0),\n status: 0 // failure\n };\n }\n}\nexports.RelayProvider = RelayProvider;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.wrapSigner = exports.wrapContract = void 0;\nconst ethers_1 = require(\"ethers\");\nconst RelayProvider_1 = require(\"./RelayProvider\");\nasync function wrapContract(contract, config, overrideDependencies) {\n const signer = await wrapSigner(contract.signer, config, overrideDependencies);\n return contract.connect(signer);\n}\nexports.wrapContract = wrapContract;\nasync function wrapSigner(signer, config, overrideDependencies) {\n const provider = signer.provider;\n if (provider == null) {\n throw new Error('GSN requires a Signer instance with a provider to wrap it');\n }\n const input = {\n // TODO: we don't use anything JsonRpcProvider - specific, but 'getSigner' is not defined on base provider\n provider: provider,\n config,\n overrideDependencies\n };\n // types have a very small conflict about whether \"jsonrpc\" field is actually required so not worth wrapping again\n // @ts-ignore\n const gsnProvider = await RelayProvider_1.RelayProvider.newProvider(input).init();\n const ethersProvider = new ethers_1.providers.Web3Provider(gsnProvider);\n const address = await signer.getAddress();\n return ethersProvider.getSigner(address);\n}\nexports.wrapSigner = wrapSigner;\n","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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\", {\n value: true\n});\n__exportStar(require(\"@opengsn/common\"), exports);\n__exportStar(require(\"./AccountManager\"), exports);\n__exportStar(require(\"./GSNConfigurator\"), exports);\n__exportStar(require(\"./GsnEvents\"), exports);\n__exportStar(require(\"./KnownRelaysManager\"), exports);\n__exportStar(require(\"./RelayClient\"), exports);\n__exportStar(require(\"./RelayedTransactionValidator\"), exports);\n__exportStar(require(\"./RelayProvider\"), exports);\n__exportStar(require(\"./RelaySelectionManager\"), exports);\n__exportStar(require(\"./WrapContract\"), exports);\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\n/* global Reflect, Promise */\n\nvar extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n};\nexport function __extends(d, b) {\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\nexport var __assign = function () {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n}\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length,\n r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc,\n d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\nexport function __param(paramIndex, decorator) {\n return function (target, key) {\n decorator(target, key, paramIndex);\n };\n}\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\nexport function __generator(thisArg, body) {\n var _ = {\n label: 0,\n sent: function () {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n },\n f,\n y,\n t,\n g;\n return g = {\n next: verb(0),\n \"throw\": verb(1),\n \"return\": verb(2)\n }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function () {\n return this;\n }), g;\n function verb(n) {\n return function (v) {\n return step([n, v]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [0];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [6, e];\n y = 0;\n } finally {\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n}\nexport function __createBinding(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}\nexport function __exportStar(m, exports) {\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\n}\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n}\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n}\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j];\n return r;\n}\n;\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []),\n i,\n q = [];\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () {\n return this;\n }, i;\n function verb(n) {\n if (g[n]) i[n] = function (v) {\n return new Promise(function (a, b) {\n q.push([n, v, a, b]) > 1 || resume(n, v);\n });\n };\n }\n function resume(n, v) {\n try {\n step(g[n](v));\n } catch (e) {\n settle(q[0][3], e);\n }\n }\n function step(r) {\n r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n }\n function fulfill(value) {\n resume(\"next\", value);\n }\n function reject(value) {\n resume(\"throw\", value);\n }\n function settle(f, v) {\n if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n }\n}\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) {\n throw e;\n }), verb(\"return\"), i[Symbol.iterator] = function () {\n return this;\n }, i;\n function verb(n, f) {\n i[n] = o[n] ? function (v) {\n return (p = !p) ? {\n value: __await(o[n](v)),\n done: n === \"return\"\n } : f ? f(v) : v;\n } : f;\n }\n}\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator],\n i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () {\n return this;\n }, i);\n function verb(n) {\n i[n] = o[n] && function (v) {\n return new Promise(function (resolve, reject) {\n v = o[n](v), settle(resolve, reject, v.done, v.value);\n });\n };\n }\n function settle(resolve, reject, d, v) {\n Promise.resolve(v).then(function (v) {\n resolve({\n value: v,\n done: d\n });\n }, reject);\n }\n}\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) {\n Object.defineProperty(cooked, \"raw\", {\n value: raw\n });\n } else {\n cooked.raw = raw;\n }\n return cooked;\n}\n;\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n result.default = mod;\n return result;\n}\nexport function __importDefault(mod) {\n return mod && mod.__esModule ? mod : {\n default: mod\n };\n}\nexport function __classPrivateFieldGet(receiver, privateMap) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to get private field on non-instance\");\n }\n return privateMap.get(receiver);\n}\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to set private field on non-instance\");\n }\n privateMap.set(receiver, value);\n return value;\n}","export class IEvents {}\n","export * from \"./events\";\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.IHeartBeat = void 0;\nconst events_1 = require(\"@walletconnect/events\");\nclass IHeartBeat extends events_1.IEvents {\n constructor(opts) {\n super();\n }\n}\nexports.IHeartBeat = IHeartBeat;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst tslib_1 = require(\"tslib\");\ntslib_1.__exportStar(require(\"./heartbeat\"), exports);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HEARTBEAT_EVENTS = exports.HEARTBEAT_INTERVAL = void 0;\nconst time_1 = require(\"@walletconnect/time\");\nexports.HEARTBEAT_INTERVAL = time_1.FIVE_SECONDS;\nexports.HEARTBEAT_EVENTS = {\n pulse: \"heartbeat_pulse\"\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst tslib_1 = require(\"tslib\");\ntslib_1.__exportStar(require(\"./heartbeat\"), exports);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HeartBeat = void 0;\nconst tslib_1 = require(\"tslib\");\nconst events_1 = require(\"events\");\nconst time_1 = require(\"@walletconnect/time\");\nconst types_1 = require(\"./types\");\nconst constants_1 = require(\"./constants\");\nclass HeartBeat extends types_1.IHeartBeat {\n constructor(opts) {\n super(opts);\n this.events = new events_1.EventEmitter();\n this.interval = constants_1.HEARTBEAT_INTERVAL;\n this.interval = (opts === null || opts === void 0 ? void 0 : opts.interval) || constants_1.HEARTBEAT_INTERVAL;\n }\n static init(opts) {\n return tslib_1.__awaiter(this, void 0, void 0, function* () {\n const heartbeat = new HeartBeat(opts);\n yield heartbeat.init();\n return heartbeat;\n });\n }\n init() {\n return tslib_1.__awaiter(this, void 0, void 0, function* () {\n yield this.initialize();\n });\n }\n stop() {\n clearInterval(this.intervalRef);\n }\n on(event, listener) {\n this.events.on(event, listener);\n }\n once(event, listener) {\n this.events.once(event, listener);\n }\n off(event, listener) {\n this.events.off(event, listener);\n }\n removeListener(event, listener) {\n this.events.removeListener(event, listener);\n }\n initialize() {\n return tslib_1.__awaiter(this, void 0, void 0, function* () {\n this.intervalRef = setInterval(() => this.pulse(), time_1.toMiliseconds(this.interval));\n });\n }\n pulse() {\n this.events.emit(constants_1.HEARTBEAT_EVENTS.pulse);\n }\n}\nexports.HeartBeat = HeartBeat;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst tslib_1 = require(\"tslib\");\ntslib_1.__exportStar(require(\"./heartbeat\"), exports);\ntslib_1.__exportStar(require(\"./types\"), exports);\ntslib_1.__exportStar(require(\"./constants\"), exports);\n","'use strict';\n\nfunction tryStringify(o) {\n try {\n return JSON.stringify(o);\n } catch (e) {\n return '\"[Circular]\"';\n }\n}\nmodule.exports = format;\nfunction format(f, args, opts) {\n var ss = opts && opts.stringify || tryStringify;\n var offset = 1;\n if (typeof f === 'object' && f !== null) {\n var len = args.length + offset;\n if (len === 1) return f;\n var objects = new Array(len);\n objects[0] = ss(f);\n for (var index = 1; index < len; index++) {\n objects[index] = ss(args[index]);\n }\n return objects.join(' ');\n }\n if (typeof f !== 'string') {\n return f;\n }\n var argLen = args.length;\n if (argLen === 0) return f;\n var str = '';\n var a = 1 - offset;\n var lastPos = -1;\n var flen = f && f.length || 0;\n for (var i = 0; i < flen;) {\n if (f.charCodeAt(i) === 37 && i + 1 < flen) {\n lastPos = lastPos > -1 ? lastPos : 0;\n switch (f.charCodeAt(i + 1)) {\n case 100: // 'd'\n case 102:\n // 'f'\n if (a >= argLen) break;\n if (args[a] == null) break;\n if (lastPos < i) str += f.slice(lastPos, i);\n str += Number(args[a]);\n lastPos = i + 2;\n i++;\n break;\n case 105:\n // 'i'\n if (a >= argLen) break;\n if (args[a] == null) break;\n if (lastPos < i) str += f.slice(lastPos, i);\n str += Math.floor(Number(args[a]));\n lastPos = i + 2;\n i++;\n break;\n case 79: // 'O'\n case 111: // 'o'\n case 106:\n // 'j'\n if (a >= argLen) break;\n if (args[a] === undefined) break;\n if (lastPos < i) str += f.slice(lastPos, i);\n var type = typeof args[a];\n if (type === 'string') {\n str += '\\'' + args[a] + '\\'';\n lastPos = i + 2;\n i++;\n break;\n }\n if (type === 'function') {\n str += args[a].name || '';\n lastPos = i + 2;\n i++;\n break;\n }\n str += ss(args[a]);\n lastPos = i + 2;\n i++;\n break;\n case 115:\n // 's'\n if (a >= argLen) break;\n if (lastPos < i) str += f.slice(lastPos, i);\n str += String(args[a]);\n lastPos = i + 2;\n i++;\n break;\n case 37:\n // '%'\n if (lastPos < i) str += f.slice(lastPos, i);\n str += '%';\n lastPos = i + 2;\n i++;\n a--;\n break;\n }\n ++a;\n }\n ++i;\n }\n if (lastPos === -1) return f;else if (lastPos < flen) {\n str += f.slice(lastPos);\n }\n return str;\n}","'use strict';\n\nconst format = require('quick-format-unescaped');\nmodule.exports = pino;\nconst _console = pfGlobalThisOrFallback().console || {};\nconst stdSerializers = {\n mapHttpRequest: mock,\n mapHttpResponse: mock,\n wrapRequestSerializer: passthrough,\n wrapResponseSerializer: passthrough,\n wrapErrorSerializer: passthrough,\n req: mock,\n res: mock,\n err: asErrValue\n};\nfunction shouldSerialize(serialize, serializers) {\n if (Array.isArray(serialize)) {\n const hasToFilter = serialize.filter(function (k) {\n return k !== '!stdSerializers.err';\n });\n return hasToFilter;\n } else if (serialize === true) {\n return Object.keys(serializers);\n }\n return false;\n}\nfunction pino(opts) {\n opts = opts || {};\n opts.browser = opts.browser || {};\n const transmit = opts.browser.transmit;\n if (transmit && typeof transmit.send !== 'function') {\n throw Error('pino: transmit option must have a send function');\n }\n const proto = opts.browser.write || _console;\n if (opts.browser.write) opts.browser.asObject = true;\n const serializers = opts.serializers || {};\n const serialize = shouldSerialize(opts.browser.serialize, serializers);\n let stdErrSerialize = opts.browser.serialize;\n if (Array.isArray(opts.browser.serialize) && opts.browser.serialize.indexOf('!stdSerializers.err') > -1) stdErrSerialize = false;\n const levels = ['error', 'fatal', 'warn', 'info', 'debug', 'trace'];\n if (typeof proto === 'function') {\n proto.error = proto.fatal = proto.warn = proto.info = proto.debug = proto.trace = proto;\n }\n if (opts.enabled === false) opts.level = 'silent';\n const level = opts.level || 'info';\n const logger = Object.create(proto);\n if (!logger.log) logger.log = noop;\n Object.defineProperty(logger, 'levelVal', {\n get: getLevelVal\n });\n Object.defineProperty(logger, 'level', {\n get: getLevel,\n set: setLevel\n });\n const setOpts = {\n transmit,\n serialize,\n asObject: opts.browser.asObject,\n levels,\n timestamp: getTimeFunction(opts)\n };\n logger.levels = pino.levels;\n logger.level = level;\n logger.setMaxListeners = logger.getMaxListeners = logger.emit = logger.addListener = logger.on = logger.prependListener = logger.once = logger.prependOnceListener = logger.removeListener = logger.removeAllListeners = logger.listeners = logger.listenerCount = logger.eventNames = logger.write = logger.flush = noop;\n logger.serializers = serializers;\n logger._serialize = serialize;\n logger._stdErrSerialize = stdErrSerialize;\n logger.child = child;\n if (transmit) logger._logEvent = createLogEventShape();\n function getLevelVal() {\n return this.level === 'silent' ? Infinity : this.levels.values[this.level];\n }\n function getLevel() {\n return this._level;\n }\n function setLevel(level) {\n if (level !== 'silent' && !this.levels.values[level]) {\n throw Error('unknown level ' + level);\n }\n this._level = level;\n set(setOpts, logger, 'error', 'log'); // <-- must stay first\n set(setOpts, logger, 'fatal', 'error');\n set(setOpts, logger, 'warn', 'error');\n set(setOpts, logger, 'info', 'log');\n set(setOpts, logger, 'debug', 'log');\n set(setOpts, logger, 'trace', 'log');\n }\n function child(bindings, childOptions) {\n if (!bindings) {\n throw new Error('missing bindings for child Pino');\n }\n childOptions = childOptions || {};\n if (serialize && bindings.serializers) {\n childOptions.serializers = bindings.serializers;\n }\n const childOptionsSerializers = childOptions.serializers;\n if (serialize && childOptionsSerializers) {\n var childSerializers = Object.assign({}, serializers, childOptionsSerializers);\n var childSerialize = opts.browser.serialize === true ? Object.keys(childSerializers) : serialize;\n delete bindings.serializers;\n applySerializers([bindings], childSerialize, childSerializers, this._stdErrSerialize);\n }\n function Child(parent) {\n this._childLevel = (parent._childLevel | 0) + 1;\n this.error = bind(parent, bindings, 'error');\n this.fatal = bind(parent, bindings, 'fatal');\n this.warn = bind(parent, bindings, 'warn');\n this.info = bind(parent, bindings, 'info');\n this.debug = bind(parent, bindings, 'debug');\n this.trace = bind(parent, bindings, 'trace');\n if (childSerializers) {\n this.serializers = childSerializers;\n this._serialize = childSerialize;\n }\n if (transmit) {\n this._logEvent = createLogEventShape([].concat(parent._logEvent.bindings, bindings));\n }\n }\n Child.prototype = this;\n return new Child(this);\n }\n return logger;\n}\npino.levels = {\n values: {\n fatal: 60,\n error: 50,\n warn: 40,\n info: 30,\n debug: 20,\n trace: 10\n },\n labels: {\n 10: 'trace',\n 20: 'debug',\n 30: 'info',\n 40: 'warn',\n 50: 'error',\n 60: 'fatal'\n }\n};\npino.stdSerializers = stdSerializers;\npino.stdTimeFunctions = Object.assign({}, {\n nullTime,\n epochTime,\n unixTime,\n isoTime\n});\nfunction set(opts, logger, level, fallback) {\n const proto = Object.getPrototypeOf(logger);\n logger[level] = logger.levelVal > logger.levels.values[level] ? noop : proto[level] ? proto[level] : _console[level] || _console[fallback] || noop;\n wrap(opts, logger, level);\n}\nfunction wrap(opts, logger, level) {\n if (!opts.transmit && logger[level] === noop) return;\n logger[level] = function (write) {\n return function LOG() {\n const ts = opts.timestamp();\n const args = new Array(arguments.length);\n const proto = Object.getPrototypeOf && Object.getPrototypeOf(this) === _console ? _console : this;\n for (var i = 0; i < args.length; i++) args[i] = arguments[i];\n if (opts.serialize && !opts.asObject) {\n applySerializers(args, this._serialize, this.serializers, this._stdErrSerialize);\n }\n if (opts.asObject) write.call(proto, asObject(this, level, args, ts));else write.apply(proto, args);\n if (opts.transmit) {\n const transmitLevel = opts.transmit.level || logger.level;\n const transmitValue = pino.levels.values[transmitLevel];\n const methodValue = pino.levels.values[level];\n if (methodValue < transmitValue) return;\n transmit(this, {\n ts,\n methodLevel: level,\n methodValue,\n transmitLevel,\n transmitValue: pino.levels.values[opts.transmit.level || logger.level],\n send: opts.transmit.send,\n val: logger.levelVal\n }, args);\n }\n };\n }(logger[level]);\n}\nfunction asObject(logger, level, args, ts) {\n if (logger._serialize) applySerializers(args, logger._serialize, logger.serializers, logger._stdErrSerialize);\n const argsCloned = args.slice();\n let msg = argsCloned[0];\n const o = {};\n if (ts) {\n o.time = ts;\n }\n o.level = pino.levels.values[level];\n let lvl = (logger._childLevel | 0) + 1;\n if (lvl < 1) lvl = 1;\n // deliberate, catching objects, arrays\n if (msg !== null && typeof msg === 'object') {\n while (lvl-- && typeof argsCloned[0] === 'object') {\n Object.assign(o, argsCloned.shift());\n }\n msg = argsCloned.length ? format(argsCloned.shift(), argsCloned) : undefined;\n } else if (typeof msg === 'string') msg = format(argsCloned.shift(), argsCloned);\n if (msg !== undefined) o.msg = msg;\n return o;\n}\nfunction applySerializers(args, serialize, serializers, stdErrSerialize) {\n for (const i in args) {\n if (stdErrSerialize && args[i] instanceof Error) {\n args[i] = pino.stdSerializers.err(args[i]);\n } else if (typeof args[i] === 'object' && !Array.isArray(args[i])) {\n for (const k in args[i]) {\n if (serialize && serialize.indexOf(k) > -1 && k in serializers) {\n args[i][k] = serializers[k](args[i][k]);\n }\n }\n }\n }\n}\nfunction bind(parent, bindings, level) {\n return function () {\n const args = new Array(1 + arguments.length);\n args[0] = bindings;\n for (var i = 1; i < args.length; i++) {\n args[i] = arguments[i - 1];\n }\n return parent[level].apply(this, args);\n };\n}\nfunction transmit(logger, opts, args) {\n const send = opts.send;\n const ts = opts.ts;\n const methodLevel = opts.methodLevel;\n const methodValue = opts.methodValue;\n const val = opts.val;\n const bindings = logger._logEvent.bindings;\n applySerializers(args, logger._serialize || Object.keys(logger.serializers), logger.serializers, logger._stdErrSerialize === undefined ? true : logger._stdErrSerialize);\n logger._logEvent.ts = ts;\n logger._logEvent.messages = args.filter(function (arg) {\n // bindings can only be objects, so reference equality check via indexOf is fine\n return bindings.indexOf(arg) === -1;\n });\n logger._logEvent.level.label = methodLevel;\n logger._logEvent.level.value = methodValue;\n send(methodLevel, logger._logEvent, val);\n logger._logEvent = createLogEventShape(bindings);\n}\nfunction createLogEventShape(bindings) {\n return {\n ts: 0,\n messages: [],\n bindings: bindings || [],\n level: {\n label: '',\n value: 0\n }\n };\n}\nfunction asErrValue(err) {\n const obj = {\n type: err.constructor.name,\n msg: err.message,\n stack: err.stack\n };\n for (const key in err) {\n if (obj[key] === undefined) {\n obj[key] = err[key];\n }\n }\n return obj;\n}\nfunction getTimeFunction(opts) {\n if (typeof opts.timestamp === 'function') {\n return opts.timestamp;\n }\n if (opts.timestamp === false) {\n return nullTime;\n }\n return epochTime;\n}\nfunction mock() {\n return {};\n}\nfunction passthrough(a) {\n return a;\n}\nfunction noop() {}\nfunction nullTime() {\n return false;\n}\nfunction epochTime() {\n return Date.now();\n}\nfunction unixTime() {\n return Math.round(Date.now() / 1000.0);\n}\nfunction isoTime() {\n return new Date(Date.now()).toISOString();\n} // using Date.now() for testability\n\n/* eslint-disable */\n/* istanbul ignore next */\nfunction pfGlobalThisOrFallback() {\n function defd(o) {\n return typeof o !== 'undefined' && o;\n }\n try {\n if (typeof globalThis !== 'undefined') return globalThis;\n Object.defineProperty(Object.prototype, 'globalThis', {\n get: function () {\n delete Object.prototype.globalThis;\n return this.globalThis = this;\n },\n configurable: true\n });\n return globalThis;\n } catch (e) {\n return defd(self) || defd(window) || defd(this) || {};\n }\n}\n/* eslint-enable */","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\n/* global Reflect, Promise */\n\nvar extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n};\nexport function __extends(d, b) {\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\nexport var __assign = function () {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n}\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length,\n r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc,\n d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\nexport function __param(paramIndex, decorator) {\n return function (target, key) {\n decorator(target, key, paramIndex);\n };\n}\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\nexport function __generator(thisArg, body) {\n var _ = {\n label: 0,\n sent: function () {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n },\n f,\n y,\n t,\n g;\n return g = {\n next: verb(0),\n \"throw\": verb(1),\n \"return\": verb(2)\n }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function () {\n return this;\n }), g;\n function verb(n) {\n return function (v) {\n return step([n, v]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [0];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [6, e];\n y = 0;\n } finally {\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n}\nexport function __createBinding(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}\nexport function __exportStar(m, exports) {\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) exports[p] = m[p];\n}\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n}\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n}\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j];\n return r;\n}\n;\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []),\n i,\n q = [];\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () {\n return this;\n }, i;\n function verb(n) {\n if (g[n]) i[n] = function (v) {\n return new Promise(function (a, b) {\n q.push([n, v, a, b]) > 1 || resume(n, v);\n });\n };\n }\n function resume(n, v) {\n try {\n step(g[n](v));\n } catch (e) {\n settle(q[0][3], e);\n }\n }\n function step(r) {\n r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n }\n function fulfill(value) {\n resume(\"next\", value);\n }\n function reject(value) {\n resume(\"throw\", value);\n }\n function settle(f, v) {\n if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n }\n}\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) {\n throw e;\n }), verb(\"return\"), i[Symbol.iterator] = function () {\n return this;\n }, i;\n function verb(n, f) {\n i[n] = o[n] ? function (v) {\n return (p = !p) ? {\n value: __await(o[n](v)),\n done: n === \"return\"\n } : f ? f(v) : v;\n } : f;\n }\n}\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator],\n i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () {\n return this;\n }, i);\n function verb(n) {\n i[n] = o[n] && function (v) {\n return new Promise(function (resolve, reject) {\n v = o[n](v), settle(resolve, reject, v.done, v.value);\n });\n };\n }\n function settle(resolve, reject, d, v) {\n Promise.resolve(v).then(function (v) {\n resolve({\n value: v,\n done: d\n });\n }, reject);\n }\n}\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) {\n Object.defineProperty(cooked, \"raw\", {\n value: raw\n });\n } else {\n cooked.raw = raw;\n }\n return cooked;\n}\n;\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\n result.default = mod;\n return result;\n}\nexport function __importDefault(mod) {\n return mod && mod.__esModule ? mod : {\n default: mod\n };\n}\nexport function __classPrivateFieldGet(receiver, privateMap) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to get private field on non-instance\");\n }\n return privateMap.get(receiver);\n}\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to set private field on non-instance\");\n }\n privateMap.set(receiver, value);\n return value;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isBrowserCryptoAvailable = exports.getSubtleCrypto = exports.getBrowerCrypto = void 0;\nfunction getBrowerCrypto() {\n return (global === null || global === void 0 ? void 0 : global.crypto) || (global === null || global === void 0 ? void 0 : global.msCrypto) || {};\n}\nexports.getBrowerCrypto = getBrowerCrypto;\nfunction getSubtleCrypto() {\n const browserCrypto = getBrowerCrypto();\n return browserCrypto.subtle || browserCrypto.webkitSubtle;\n}\nexports.getSubtleCrypto = getSubtleCrypto;\nfunction isBrowserCryptoAvailable() {\n return !!getBrowerCrypto() && !!getSubtleCrypto();\n}\nexports.isBrowserCryptoAvailable = isBrowserCryptoAvailable;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isBrowser = exports.isNode = exports.isReactNative = void 0;\nfunction isReactNative() {\n return typeof document === \"undefined\" && typeof navigator !== \"undefined\" && navigator.product === \"ReactNative\";\n}\nexports.isReactNative = isReactNative;\nfunction isNode() {\n return typeof process !== \"undefined\" && typeof process.versions !== \"undefined\" && typeof process.versions.node !== \"undefined\";\n}\nexports.isNode = isNode;\nfunction isBrowser() {\n return !isReactNative() && !isNode();\n}\nexports.isBrowser = isBrowser;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst tslib_1 = require(\"tslib\");\ntslib_1.__exportStar(require(\"./crypto\"), exports);\ntslib_1.__exportStar(require(\"./env\"), exports);\n","'use strict';\n\nmodule.exports = function () {\n throw new Error('ws does not work in the browser. Browser clients must use the native ' + 'WebSocket object');\n};","export default function (e, n) {\n return n = n || {}, new Promise(function (t, r) {\n var s = new XMLHttpRequest(),\n o = [],\n u = [],\n i = {},\n a = function () {\n return {\n ok: 2 == (s.status / 100 | 0),\n statusText: s.statusText,\n status: s.status,\n url: s.responseURL,\n text: function () {\n return Promise.resolve(s.responseText);\n },\n json: function () {\n return Promise.resolve(s.responseText).then(JSON.parse);\n },\n blob: function () {\n return Promise.resolve(new Blob([s.response]));\n },\n clone: a,\n headers: {\n keys: function () {\n return o;\n },\n entries: function () {\n return u;\n },\n get: function (e) {\n return i[e.toLowerCase()];\n },\n has: function (e) {\n return e.toLowerCase() in i;\n }\n }\n };\n };\n for (var l in s.open(n.method || \"get\", e, !0), s.onload = function () {\n s.getAllResponseHeaders().replace(/^(.*?):[^\\S\\n]*([\\s\\S]*?)$/gm, function (e, n, t) {\n o.push(n = n.toLowerCase()), u.push([n, t]), i[n] = i[n] ? i[n] + \",\" + t : t;\n }), t(a());\n }, s.onerror = r, s.withCredentials = \"include\" == n.credentials, n.headers) s.setRequestHeader(l, n.headers[l]);\n s.send(n.body || null);\n });\n}\n","module.exports = self.fetch || (self.fetch = require('unfetch').default || require('unfetch'));","var global = typeof self !== 'undefined' ? self : this;\nvar __self__ = function () {\n function F() {\n this.fetch = false;\n this.DOMException = global.DOMException;\n }\n F.prototype = global;\n return new F();\n}();\n(function (self) {\n var irrelevant = function (exports) {\n var support = {\n searchParams: 'URLSearchParams' in self,\n iterable: 'Symbol' in self && 'iterator' in Symbol,\n blob: 'FileReader' in self && 'Blob' in self && function () {\n try {\n new Blob();\n return true;\n } catch (e) {\n return false;\n }\n }(),\n formData: 'FormData' in self,\n arrayBuffer: 'ArrayBuffer' in self\n };\n function isDataView(obj) {\n return obj && DataView.prototype.isPrototypeOf(obj);\n }\n if (support.arrayBuffer) {\n var viewClasses = ['[object Int8Array]', '[object Uint8Array]', '[object Uint8ClampedArray]', '[object Int16Array]', '[object Uint16Array]', '[object Int32Array]', '[object Uint32Array]', '[object Float32Array]', '[object Float64Array]'];\n var isArrayBufferView = ArrayBuffer.isView || function (obj) {\n return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1;\n };\n }\n function normalizeName(name) {\n if (typeof name !== 'string') {\n name = String(name);\n }\n if (/[^a-z0-9\\-#$%&'*+.^_`|~]/i.test(name)) {\n throw new TypeError('Invalid character in header field name');\n }\n return name.toLowerCase();\n }\n function normalizeValue(value) {\n if (typeof value !== 'string') {\n value = String(value);\n }\n return value;\n }\n\n // Build a destructive iterator for the value list\n function iteratorFor(items) {\n var iterator = {\n next: function () {\n var value = items.shift();\n return {\n done: value === undefined,\n value: value\n };\n }\n };\n if (support.iterable) {\n iterator[Symbol.iterator] = function () {\n return iterator;\n };\n }\n return iterator;\n }\n function Headers(headers) {\n this.map = {};\n if (headers instanceof Headers) {\n headers.forEach(function (value, name) {\n this.append(name, value);\n }, this);\n } else if (Array.isArray(headers)) {\n headers.forEach(function (header) {\n this.append(header[0], header[1]);\n }, this);\n } else if (headers) {\n Object.getOwnPropertyNames(headers).forEach(function (name) {\n this.append(name, headers[name]);\n }, this);\n }\n }\n Headers.prototype.append = function (name, value) {\n name = normalizeName(name);\n value = normalizeValue(value);\n var oldValue = this.map[name];\n this.map[name] = oldValue ? oldValue + ', ' + value : value;\n };\n Headers.prototype['delete'] = function (name) {\n delete this.map[normalizeName(name)];\n };\n Headers.prototype.get = function (name) {\n name = normalizeName(name);\n return this.has(name) ? this.map[name] : null;\n };\n Headers.prototype.has = function (name) {\n return this.map.hasOwnProperty(normalizeName(name));\n };\n Headers.prototype.set = function (name, value) {\n this.map[normalizeName(name)] = normalizeValue(value);\n };\n Headers.prototype.forEach = function (callback, thisArg) {\n for (var name in this.map) {\n if (this.map.hasOwnProperty(name)) {\n callback.call(thisArg, this.map[name], name, this);\n }\n }\n };\n Headers.prototype.keys = function () {\n var items = [];\n this.forEach(function (value, name) {\n items.push(name);\n });\n return iteratorFor(items);\n };\n Headers.prototype.values = function () {\n var items = [];\n this.forEach(function (value) {\n items.push(value);\n });\n return iteratorFor(items);\n };\n Headers.prototype.entries = function () {\n var items = [];\n this.forEach(function (value, name) {\n items.push([name, value]);\n });\n return iteratorFor(items);\n };\n if (support.iterable) {\n Headers.prototype[Symbol.iterator] = Headers.prototype.entries;\n }\n function consumed(body) {\n if (body.bodyUsed) {\n return Promise.reject(new TypeError('Already read'));\n }\n body.bodyUsed = true;\n }\n function fileReaderReady(reader) {\n return new Promise(function (resolve, reject) {\n reader.onload = function () {\n resolve(reader.result);\n };\n reader.onerror = function () {\n reject(reader.error);\n };\n });\n }\n function readBlobAsArrayBuffer(blob) {\n var reader = new FileReader();\n var promise = fileReaderReady(reader);\n reader.readAsArrayBuffer(blob);\n return promise;\n }\n function readBlobAsText(blob) {\n var reader = new FileReader();\n var promise = fileReaderReady(reader);\n reader.readAsText(blob);\n return promise;\n }\n function readArrayBufferAsText(buf) {\n var view = new Uint8Array(buf);\n var chars = new Array(view.length);\n for (var i = 0; i < view.length; i++) {\n chars[i] = String.fromCharCode(view[i]);\n }\n return chars.join('');\n }\n function bufferClone(buf) {\n if (buf.slice) {\n return buf.slice(0);\n } else {\n var view = new Uint8Array(buf.byteLength);\n view.set(new Uint8Array(buf));\n return view.buffer;\n }\n }\n function Body() {\n this.bodyUsed = false;\n this._initBody = function (body) {\n this._bodyInit = body;\n if (!body) {\n this._bodyText = '';\n } else if (typeof body === 'string') {\n this._bodyText = body;\n } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n this._bodyBlob = body;\n } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n this._bodyFormData = body;\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this._bodyText = body.toString();\n } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n this._bodyArrayBuffer = bufferClone(body.buffer);\n // IE 10-11 can't handle a DataView body.\n this._bodyInit = new Blob([this._bodyArrayBuffer]);\n } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n this._bodyArrayBuffer = bufferClone(body);\n } else {\n this._bodyText = body = Object.prototype.toString.call(body);\n }\n if (!this.headers.get('content-type')) {\n if (typeof body === 'string') {\n this.headers.set('content-type', 'text/plain;charset=UTF-8');\n } else if (this._bodyBlob && this._bodyBlob.type) {\n this.headers.set('content-type', this._bodyBlob.type);\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8');\n }\n }\n };\n if (support.blob) {\n this.blob = function () {\n var rejected = consumed(this);\n if (rejected) {\n return rejected;\n }\n if (this._bodyBlob) {\n return Promise.resolve(this._bodyBlob);\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(new Blob([this._bodyArrayBuffer]));\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as blob');\n } else {\n return Promise.resolve(new Blob([this._bodyText]));\n }\n };\n this.arrayBuffer = function () {\n if (this._bodyArrayBuffer) {\n return consumed(this) || Promise.resolve(this._bodyArrayBuffer);\n } else {\n return this.blob().then(readBlobAsArrayBuffer);\n }\n };\n }\n this.text = function () {\n var rejected = consumed(this);\n if (rejected) {\n return rejected;\n }\n if (this._bodyBlob) {\n return readBlobAsText(this._bodyBlob);\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer));\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as text');\n } else {\n return Promise.resolve(this._bodyText);\n }\n };\n if (support.formData) {\n this.formData = function () {\n return this.text().then(decode);\n };\n }\n this.json = function () {\n return this.text().then(JSON.parse);\n };\n return this;\n }\n\n // HTTP methods whose capitalization should be normalized\n var methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT'];\n function normalizeMethod(method) {\n var upcased = method.toUpperCase();\n return methods.indexOf(upcased) > -1 ? upcased : method;\n }\n function Request(input, options) {\n options = options || {};\n var body = options.body;\n if (input instanceof Request) {\n if (input.bodyUsed) {\n throw new TypeError('Already read');\n }\n this.url = input.url;\n this.credentials = input.credentials;\n if (!options.headers) {\n this.headers = new Headers(input.headers);\n }\n this.method = input.method;\n this.mode = input.mode;\n this.signal = input.signal;\n if (!body && input._bodyInit != null) {\n body = input._bodyInit;\n input.bodyUsed = true;\n }\n } else {\n this.url = String(input);\n }\n this.credentials = options.credentials || this.credentials || 'same-origin';\n if (options.headers || !this.headers) {\n this.headers = new Headers(options.headers);\n }\n this.method = normalizeMethod(options.method || this.method || 'GET');\n this.mode = options.mode || this.mode || null;\n this.signal = options.signal || this.signal;\n this.referrer = null;\n if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n throw new TypeError('Body not allowed for GET or HEAD requests');\n }\n this._initBody(body);\n }\n Request.prototype.clone = function () {\n return new Request(this, {\n body: this._bodyInit\n });\n };\n function decode(body) {\n var form = new FormData();\n body.trim().split('&').forEach(function (bytes) {\n if (bytes) {\n var split = bytes.split('=');\n var name = split.shift().replace(/\\+/g, ' ');\n var value = split.join('=').replace(/\\+/g, ' ');\n form.append(decodeURIComponent(name), decodeURIComponent(value));\n }\n });\n return form;\n }\n function parseHeaders(rawHeaders) {\n var headers = new Headers();\n // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n // https://tools.ietf.org/html/rfc7230#section-3.2\n var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ');\n preProcessedHeaders.split(/\\r?\\n/).forEach(function (line) {\n var parts = line.split(':');\n var key = parts.shift().trim();\n if (key) {\n var value = parts.join(':').trim();\n headers.append(key, value);\n }\n });\n return headers;\n }\n Body.call(Request.prototype);\n function Response(bodyInit, options) {\n if (!options) {\n options = {};\n }\n this.type = 'default';\n this.status = options.status === undefined ? 200 : options.status;\n this.ok = this.status >= 200 && this.status < 300;\n this.statusText = 'statusText' in options ? options.statusText : 'OK';\n this.headers = new Headers(options.headers);\n this.url = options.url || '';\n this._initBody(bodyInit);\n }\n Body.call(Response.prototype);\n Response.prototype.clone = function () {\n return new Response(this._bodyInit, {\n status: this.status,\n statusText: this.statusText,\n headers: new Headers(this.headers),\n url: this.url\n });\n };\n Response.error = function () {\n var response = new Response(null, {\n status: 0,\n statusText: ''\n });\n response.type = 'error';\n return response;\n };\n var redirectStatuses = [301, 302, 303, 307, 308];\n Response.redirect = function (url, status) {\n if (redirectStatuses.indexOf(status) === -1) {\n throw new RangeError('Invalid status code');\n }\n return new Response(null, {\n status: status,\n headers: {\n location: url\n }\n });\n };\n exports.DOMException = self.DOMException;\n try {\n new exports.DOMException();\n } catch (err) {\n exports.DOMException = function (message, name) {\n this.message = message;\n this.name = name;\n var error = Error(message);\n this.stack = error.stack;\n };\n exports.DOMException.prototype = Object.create(Error.prototype);\n exports.DOMException.prototype.constructor = exports.DOMException;\n }\n function fetch(input, init) {\n return new Promise(function (resolve, reject) {\n var request = new Request(input, init);\n if (request.signal && request.signal.aborted) {\n return reject(new exports.DOMException('Aborted', 'AbortError'));\n }\n var xhr = new XMLHttpRequest();\n function abortXhr() {\n xhr.abort();\n }\n xhr.onload = function () {\n var options = {\n status: xhr.status,\n statusText: xhr.statusText,\n headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n };\n options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL');\n var body = 'response' in xhr ? xhr.response : xhr.responseText;\n resolve(new Response(body, options));\n };\n xhr.onerror = function () {\n reject(new TypeError('Network request failed'));\n };\n xhr.ontimeout = function () {\n reject(new TypeError('Network request failed'));\n };\n xhr.onabort = function () {\n reject(new exports.DOMException('Aborted', 'AbortError'));\n };\n xhr.open(request.method, request.url, true);\n if (request.credentials === 'include') {\n xhr.withCredentials = true;\n } else if (request.credentials === 'omit') {\n xhr.withCredentials = false;\n }\n if ('responseType' in xhr && support.blob) {\n xhr.responseType = 'blob';\n }\n request.headers.forEach(function (value, name) {\n xhr.setRequestHeader(name, value);\n });\n if (request.signal) {\n request.signal.addEventListener('abort', abortXhr);\n xhr.onreadystatechange = function () {\n // DONE (success or failure)\n if (xhr.readyState === 4) {\n request.signal.removeEventListener('abort', abortXhr);\n }\n };\n }\n xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit);\n });\n }\n fetch.polyfill = true;\n if (!self.fetch) {\n self.fetch = fetch;\n self.Headers = Headers;\n self.Request = Request;\n self.Response = Response;\n }\n exports.Headers = Headers;\n exports.Request = Request;\n exports.Response = Response;\n exports.fetch = fetch;\n Object.defineProperty(exports, '__esModule', {\n value: true\n });\n return exports;\n }({});\n})(__self__);\n__self__.fetch.ponyfill = true;\n// Remove \"polyfill\" property added by whatwg-fetch\ndelete __self__.fetch.polyfill;\n// Choose between native implementation (global) or custom implementation (__self__)\n// var ctx = global.fetch ? global : __self__;\nvar ctx = __self__; // this line disable service worker support temporarily\nexports = ctx.fetch; // To enable: import fetch from 'cross-fetch'\nexports.default = ctx.fetch; // For TypeScript consumers without esModuleInterop.\nexports.fetch = ctx.fetch; // To enable: import {fetch} from 'cross-fetch'\nexports.Headers = ctx.Headers;\nexports.Request = ctx.Request;\nexports.Response = ctx.Response;\nmodule.exports = exports;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.walletLogo = void 0;\nconst walletLogo = (type, width) => {\n let height;\n switch (type) {\n case \"standard\":\n height = width;\n return `data:image/svg+xml,%3Csvg width='${width}' height='${height}' viewBox='0 0 1024 1024' fill='none' xmlns='http://www.w3.org/2000/svg'%3E %3Crect width='1024' height='1024' fill='%230052FF'/%3E %3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M152 512C152 710.823 313.177 872 512 872C710.823 872 872 710.823 872 512C872 313.177 710.823 152 512 152C313.177 152 152 313.177 152 512ZM420 396C406.745 396 396 406.745 396 420V604C396 617.255 406.745 628 420 628H604C617.255 628 628 617.255 628 604V420C628 406.745 617.255 396 604 396H420Z' fill='white'/%3E %3C/svg%3E `;\n case \"circle\":\n height = width;\n return `data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='${width}' height='${height}' viewBox='0 0 999.81 999.81'%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill:%230052fe;%7D.cls-2%7Bfill:%23fefefe;%7D.cls-3%7Bfill:%230152fe;%7D%3C/style%3E%3C/defs%3E%3Cpath class='cls-1' d='M655-115.9h56c.83,1.59,2.36.88,3.56,1a478,478,0,0,1,75.06,10.42C891.4-81.76,978.33-32.58,1049.19,44q116.7,126,131.94,297.61c.38,4.14-.34,8.53,1.78,12.45v59c-1.58.84-.91,2.35-1,3.56a482.05,482.05,0,0,1-10.38,74.05c-24,106.72-76.64,196.76-158.83,268.93s-178.18,112.82-287.2,122.6c-4.83.43-9.86-.25-14.51,1.77H654c-1-1.68-2.69-.91-4.06-1a496.89,496.89,0,0,1-105.9-18.59c-93.54-27.42-172.78-77.59-236.91-150.94Q199.34,590.1,184.87,426.58c-.47-5.19.25-10.56-1.77-15.59V355c1.68-1,.91-2.7,1-4.06a498.12,498.12,0,0,1,18.58-105.9c26-88.75,72.64-164.9,140.6-227.57q126-116.27,297.21-131.61C645.32-114.57,650.35-113.88,655-115.9Zm377.92,500c0-192.44-156.31-349.49-347.56-350.15-194.13-.68-350.94,155.13-352.29,347.42-1.37,194.55,155.51,352.1,348.56,352.47C876.15,734.23,1032.93,577.84,1032.93,384.11Z' transform='translate(-183.1 115.9)'/%3E%3Cpath class='cls-2' d='M1032.93,384.11c0,193.73-156.78,350.12-351.29,349.74-193-.37-349.93-157.92-348.56-352.47C334.43,189.09,491.24,33.28,685.37,34,876.62,34.62,1032.94,191.67,1032.93,384.11ZM683,496.81q43.74,0,87.48,0c15.55,0,25.32-9.72,25.33-25.21q0-87.48,0-175c0-15.83-9.68-25.46-25.59-25.46H595.77c-15.88,0-25.57,9.64-25.58,25.46q0,87.23,0,174.45c0,16.18,9.59,25.7,25.84,25.71Z' transform='translate(-183.1 115.9)'/%3E%3Cpath class='cls-3' d='M683,496.81H596c-16.25,0-25.84-9.53-25.84-25.71q0-87.23,0-174.45c0-15.82,9.7-25.46,25.58-25.46H770.22c15.91,0,25.59,9.63,25.59,25.46q0,87.47,0,175c0,15.49-9.78,25.2-25.33,25.21Q726.74,496.84,683,496.81Z' transform='translate(-183.1 115.9)'/%3E%3C/svg%3E`;\n case \"text\":\n height = (0.1 * width).toFixed(2);\n return `data:image/svg+xml,%3Csvg width='${width}' height='${height}' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 528.15 53.64'%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill:%230052ff;%7D%3C/style%3E%3C/defs%3E%3Ctitle%3ECoinbase_Wordmark_SubBrands_ALL%3C/title%3E%3Cpath class='cls-1' d='M164.45,15a15,15,0,0,0-11.74,5.4V0h-8.64V52.92h8.5V48a15,15,0,0,0,11.88,5.62c10.37,0,18.21-8.21,18.21-19.3S174.67,15,164.45,15Zm-1.3,30.67c-6.19,0-10.73-4.83-10.73-11.31S157,23,163.22,23s10.66,4.82,10.66,11.37S169.34,45.65,163.15,45.65Zm83.31-14.91-6.34-.93c-3-.43-5.18-1.44-5.18-3.82,0-2.59,2.8-3.89,6.62-3.89,4.18,0,6.84,1.8,7.42,4.76h8.35c-.94-7.49-6.7-11.88-15.55-11.88-9.15,0-15.2,4.68-15.2,11.3,0,6.34,4,10,12,11.16l6.33.94c3.1.43,4.83,1.65,4.83,4,0,2.95-3,4.17-7.2,4.17-5.12,0-8-2.09-8.43-5.25h-8.49c.79,7.27,6.48,12.38,16.84,12.38,9.44,0,15.7-4.32,15.7-11.74C258.12,35.28,253.58,31.82,246.46,30.74Zm-27.65-2.3c0-8.06-4.9-13.46-15.27-13.46-9.79,0-15.26,5-16.34,12.6h8.57c.43-3,2.73-5.4,7.63-5.4,4.39,0,6.55,1.94,6.55,4.32,0,3.09-4,3.88-8.85,4.39-6.63.72-14.84,3-14.84,11.66,0,6.7,5,11,12.89,11,6.19,0,10.08-2.59,12-6.7.28,3.67,3,6.05,6.84,6.05h5v-7.7h-4.25Zm-8.5,9.36c0,5-4.32,8.64-9.57,8.64-3.24,0-6-1.37-6-4.25,0-3.67,4.39-4.68,8.42-5.11s6-1.22,7.13-2.88ZM281.09,15c-11.09,0-19.23,8.35-19.23,19.36,0,11.6,8.72,19.3,19.37,19.3,9,0,16.06-5.33,17.86-12.89h-9c-1.3,3.31-4.47,5.19-8.71,5.19-5.55,0-9.72-3.46-10.66-9.51H299.3V33.12C299.3,22.46,291.53,15,281.09,15Zm-9.87,15.26c1.37-5.18,5.26-7.7,9.72-7.7,4.9,0,8.64,2.8,9.51,7.7ZM19.3,23a9.84,9.84,0,0,1,9.5,7h9.14c-1.65-8.93-9-15-18.57-15A19,19,0,0,0,0,34.34c0,11.09,8.28,19.3,19.37,19.3,9.36,0,16.85-6,18.5-15H28.8a9.75,9.75,0,0,1-9.43,7.06c-6.27,0-10.66-4.83-10.66-11.31S13,23,19.3,23Zm41.11-8A19,19,0,0,0,41,34.34c0,11.09,8.28,19.3,19.37,19.3A19,19,0,0,0,79.92,34.27C79.92,23.33,71.64,15,60.41,15Zm.07,30.67c-6.19,0-10.73-4.83-10.73-11.31S54.22,23,60.41,23s10.8,4.89,10.8,11.37S66.67,45.65,60.48,45.65ZM123.41,15c-5.62,0-9.29,2.3-11.45,5.54V15.7h-8.57V52.92H112V32.69C112,27,115.63,23,121,23c5,0,8.06,3.53,8.06,8.64V52.92h8.64V31C137.66,21.6,132.84,15,123.41,15ZM92,.36a5.36,5.36,0,0,0-5.55,5.47,5.55,5.55,0,0,0,11.09,0A5.35,5.35,0,0,0,92,.36Zm-9.72,23h5.4V52.92h8.64V15.7h-14Zm298.17-7.7L366.2,52.92H372L375.29,44H392l3.33,8.88h6L386.87,15.7ZM377,39.23l6.45-17.56h.1l6.56,17.56ZM362.66,15.7l-7.88,29h-.11l-8.14-29H341l-8,28.93h-.1l-8-28.87H319L329.82,53h5.45l8.19-29.24h.11L352,53h5.66L368.1,15.7Zm135.25,0v4.86h12.32V52.92h5.6V20.56h12.32V15.7ZM467.82,52.92h25.54V48.06H473.43v-12h18.35V31.35H473.43V20.56h19.93V15.7H467.82ZM443,15.7h-5.6V52.92h24.32V48.06H443Zm-30.45,0h-5.61V52.92h24.32V48.06H412.52Z'/%3E%3C/svg%3E`;\n case \"textWithLogo\":\n height = (0.25 * width).toFixed(2);\n return `data:image/svg+xml,%3Csvg width='${width}' height='${height}' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 308.44 77.61'%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill:%230052ff;%7D%3C/style%3E%3C/defs%3E%3Cpath class='cls-1' d='M142.94,20.2l-7.88,29H135l-8.15-29h-5.55l-8,28.93h-.11l-8-28.87H99.27l10.84,37.27h5.44l8.2-29.24h.1l8.41,29.24h5.66L148.39,20.2Zm17.82,0L146.48,57.42h5.82l3.28-8.88h16.65l3.34,8.88h6L167.16,20.2Zm-3.44,23.52,6.45-17.55h.11l6.56,17.55ZM278.2,20.2v4.86h12.32V57.42h5.6V25.06h12.32V20.2ZM248.11,57.42h25.54V52.55H253.71V40.61h18.35V35.85H253.71V25.06h19.94V20.2H248.11ZM223.26,20.2h-5.61V57.42H242V52.55H223.26Zm-30.46,0h-5.6V57.42h24.32V52.55H192.8Zm-154,38A19.41,19.41,0,1,1,57.92,35.57H77.47a38.81,38.81,0,1,0,0,6.47H57.92A19.39,19.39,0,0,1,38.81,58.21Z'/%3E%3C/svg%3E`;\n case \"textLight\":\n height = (0.1 * width).toFixed(2);\n return `data:image/svg+xml,%3Csvg width='${width}' height='${height}' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 528.15 53.64'%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill:%23fefefe;%7D%3C/style%3E%3C/defs%3E%3Ctitle%3ECoinbase_Wordmark_SubBrands_ALL%3C/title%3E%3Cpath class='cls-1' d='M164.45,15a15,15,0,0,0-11.74,5.4V0h-8.64V52.92h8.5V48a15,15,0,0,0,11.88,5.62c10.37,0,18.21-8.21,18.21-19.3S174.67,15,164.45,15Zm-1.3,30.67c-6.19,0-10.73-4.83-10.73-11.31S157,23,163.22,23s10.66,4.82,10.66,11.37S169.34,45.65,163.15,45.65Zm83.31-14.91-6.34-.93c-3-.43-5.18-1.44-5.18-3.82,0-2.59,2.8-3.89,6.62-3.89,4.18,0,6.84,1.8,7.42,4.76h8.35c-.94-7.49-6.7-11.88-15.55-11.88-9.15,0-15.2,4.68-15.2,11.3,0,6.34,4,10,12,11.16l6.33.94c3.1.43,4.83,1.65,4.83,4,0,2.95-3,4.17-7.2,4.17-5.12,0-8-2.09-8.43-5.25h-8.49c.79,7.27,6.48,12.38,16.84,12.38,9.44,0,15.7-4.32,15.7-11.74C258.12,35.28,253.58,31.82,246.46,30.74Zm-27.65-2.3c0-8.06-4.9-13.46-15.27-13.46-9.79,0-15.26,5-16.34,12.6h8.57c.43-3,2.73-5.4,7.63-5.4,4.39,0,6.55,1.94,6.55,4.32,0,3.09-4,3.88-8.85,4.39-6.63.72-14.84,3-14.84,11.66,0,6.7,5,11,12.89,11,6.19,0,10.08-2.59,12-6.7.28,3.67,3,6.05,6.84,6.05h5v-7.7h-4.25Zm-8.5,9.36c0,5-4.32,8.64-9.57,8.64-3.24,0-6-1.37-6-4.25,0-3.67,4.39-4.68,8.42-5.11s6-1.22,7.13-2.88ZM281.09,15c-11.09,0-19.23,8.35-19.23,19.36,0,11.6,8.72,19.3,19.37,19.3,9,0,16.06-5.33,17.86-12.89h-9c-1.3,3.31-4.47,5.19-8.71,5.19-5.55,0-9.72-3.46-10.66-9.51H299.3V33.12C299.3,22.46,291.53,15,281.09,15Zm-9.87,15.26c1.37-5.18,5.26-7.7,9.72-7.7,4.9,0,8.64,2.8,9.51,7.7ZM19.3,23a9.84,9.84,0,0,1,9.5,7h9.14c-1.65-8.93-9-15-18.57-15A19,19,0,0,0,0,34.34c0,11.09,8.28,19.3,19.37,19.3,9.36,0,16.85-6,18.5-15H28.8a9.75,9.75,0,0,1-9.43,7.06c-6.27,0-10.66-4.83-10.66-11.31S13,23,19.3,23Zm41.11-8A19,19,0,0,0,41,34.34c0,11.09,8.28,19.3,19.37,19.3A19,19,0,0,0,79.92,34.27C79.92,23.33,71.64,15,60.41,15Zm.07,30.67c-6.19,0-10.73-4.83-10.73-11.31S54.22,23,60.41,23s10.8,4.89,10.8,11.37S66.67,45.65,60.48,45.65ZM123.41,15c-5.62,0-9.29,2.3-11.45,5.54V15.7h-8.57V52.92H112V32.69C112,27,115.63,23,121,23c5,0,8.06,3.53,8.06,8.64V52.92h8.64V31C137.66,21.6,132.84,15,123.41,15ZM92,.36a5.36,5.36,0,0,0-5.55,5.47,5.55,5.55,0,0,0,11.09,0A5.35,5.35,0,0,0,92,.36Zm-9.72,23h5.4V52.92h8.64V15.7h-14Zm298.17-7.7L366.2,52.92H372L375.29,44H392l3.33,8.88h6L386.87,15.7ZM377,39.23l6.45-17.56h.1l6.56,17.56ZM362.66,15.7l-7.88,29h-.11l-8.14-29H341l-8,28.93h-.1l-8-28.87H319L329.82,53h5.45l8.19-29.24h.11L352,53h5.66L368.1,15.7Zm135.25,0v4.86h12.32V52.92h5.6V20.56h12.32V15.7ZM467.82,52.92h25.54V48.06H473.43v-12h18.35V31.35H473.43V20.56h19.93V15.7H467.82ZM443,15.7h-5.6V52.92h24.32V48.06H443Zm-30.45,0h-5.61V52.92h24.32V48.06H412.52Z'/%3E%3C/svg%3E`;\n case \"textWithLogoLight\":\n height = (0.25 * width).toFixed(2);\n return `data:image/svg+xml,%3Csvg width='${width}' height='${height}' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 308.44 77.61'%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill:%23fefefe;%7D%3C/style%3E%3C/defs%3E%3Cpath class='cls-1' d='M142.94,20.2l-7.88,29H135l-8.15-29h-5.55l-8,28.93h-.11l-8-28.87H99.27l10.84,37.27h5.44l8.2-29.24h.1l8.41,29.24h5.66L148.39,20.2Zm17.82,0L146.48,57.42h5.82l3.28-8.88h16.65l3.34,8.88h6L167.16,20.2Zm-3.44,23.52,6.45-17.55h.11l6.56,17.55ZM278.2,20.2v4.86h12.32V57.42h5.6V25.06h12.32V20.2ZM248.11,57.42h25.54V52.55H253.71V40.61h18.35V35.85H253.71V25.06h19.94V20.2H248.11ZM223.26,20.2h-5.61V57.42H242V52.55H223.26Zm-30.46,0h-5.6V57.42h24.32V52.55H192.8Zm-154,38A19.41,19.41,0,1,1,57.92,35.57H77.47a38.81,38.81,0,1,0,0,6.47H57.92A19.39,19.39,0,0,1,38.81,58.21Z'/%3E%3C/svg%3E`;\n default:\n height = width;\n return `data:image/svg+xml,%3Csvg width='${width}' height='${height}' viewBox='0 0 1024 1024' fill='none' xmlns='http://www.w3.org/2000/svg'%3E %3Crect width='1024' height='1024' fill='%230052FF'/%3E %3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M152 512C152 710.823 313.177 872 512 872C710.823 872 872 710.823 872 512C872 313.177 710.823 152 512 152C313.177 152 152 313.177 152 512ZM420 396C406.745 396 396 406.745 396 420V604C396 617.255 406.745 628 420 628H604C617.255 628 628 617.255 628 604V420C628 406.745 617.255 396 604 396H420Z' fill='white'/%3E %3C/svg%3E `;\n }\n};\nexports.walletLogo = walletLogo;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LINK_API_URL = void 0;\nexports.LINK_API_URL = \"https://www.walletlink.org\";","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ScopedLocalStorage = void 0;\nclass ScopedLocalStorage {\n constructor(scope) {\n this.scope = scope;\n }\n setItem(key, value) {\n localStorage.setItem(this.scopedKey(key), value);\n }\n getItem(key) {\n return localStorage.getItem(this.scopedKey(key));\n }\n removeItem(key) {\n localStorage.removeItem(this.scopedKey(key));\n }\n clear() {\n const prefix = this.scopedKey(\"\");\n const keysToRemove = [];\n for (let i = 0; i < localStorage.length; i++) {\n const key = localStorage.key(i);\n if (typeof key === \"string\" && key.startsWith(prefix)) {\n keysToRemove.push(key);\n }\n }\n keysToRemove.forEach(key => localStorage.removeItem(key));\n }\n scopedKey(key) {\n return `${this.scope}:${key}`;\n }\n}\nexports.ScopedLocalStorage = ScopedLocalStorage;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst events_1 = require(\"events\");\nfunction safeApply(handler, context, args) {\n try {\n Reflect.apply(handler, context, args);\n } catch (err) {\n // Throw error after timeout so as not to interrupt the stack\n setTimeout(() => {\n throw err;\n });\n }\n}\nfunction arrayClone(arr) {\n const n = arr.length;\n const copy = new Array(n);\n for (let i = 0; i < n; i += 1) {\n copy[i] = arr[i];\n }\n return copy;\n}\nclass SafeEventEmitter extends events_1.EventEmitter {\n emit(type, ...args) {\n let doError = type === 'error';\n const events = this._events;\n if (events !== undefined) {\n doError = doError && events.error === undefined;\n } else if (!doError) {\n return false;\n }\n // If there is no 'error' event listener then throw.\n if (doError) {\n let er;\n if (args.length > 0) {\n [er] = args;\n }\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n const err = new Error(`Unhandled error.${er ? ` (${er.message})` : ''}`);\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n const handler = events[type];\n if (handler === undefined) {\n return false;\n }\n if (typeof handler === 'function') {\n safeApply(handler, this, args);\n } else {\n const len = handler.length;\n const listeners = arrayClone(handler);\n for (let i = 0; i < len; i += 1) {\n safeApply(listeners[i], this, args);\n }\n }\n return true;\n }\n}\nexports.default = SafeEventEmitter;\n","\"use strict\";\n\n// DiagnosticLogger for debugging purposes only\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.EVENTS = void 0;\nexports.EVENTS = {\n STARTED_CONNECTING: \"walletlink_sdk.started.connecting\",\n CONNECTED_STATE_CHANGE: \"walletlink_sdk.connected\",\n DISCONNECTED: \"walletlink_sdk.disconnected\",\n METADATA_DESTROYED: \"walletlink_sdk_metadata_destroyed\",\n LINKED: \"walletlink_sdk.linked\",\n FAILURE: \"walletlink_sdk.generic_failure\",\n SESSION_CONFIG_RECEIVED: \"walletlink_sdk.session_config_event_received\",\n ETH_ACCOUNTS_STATE: \"walletlink_sdk.eth_accounts_state\",\n SESSION_STATE_CHANGE: \"walletlink_sdk.session_state_change\",\n UNLINKED_ERROR_STATE: \"walletlink_sdk.unlinked_error_state\",\n SKIPPED_CLEARING_SESSION: \"walletlink_sdk.skipped_clearing_session\",\n GENERAL_ERROR: \"walletlink_sdk.general_error\",\n WEB3_REQUEST: \"walletlink_sdk.web3.request\",\n WEB3_REQUEST_PUBLISHED: \"walletlink_sdk.web3.request_published\",\n WEB3_RESPONSE: \"walletlink_sdk.web3.response\",\n UNKNOWN_ADDRESS_ENCOUNTERED: \"walletlink_sdk.unknown_address_encountered\"\n};","module.exports = stringify;\nstringify.default = stringify;\nstringify.stable = deterministicStringify;\nstringify.stableStringify = deterministicStringify;\nvar LIMIT_REPLACE_NODE = '[...]';\nvar CIRCULAR_REPLACE_NODE = '[Circular]';\nvar arr = [];\nvar replacerStack = [];\nfunction defaultOptions() {\n return {\n depthLimit: Number.MAX_SAFE_INTEGER,\n edgesLimit: Number.MAX_SAFE_INTEGER\n };\n}\n\n// Regular stringify\nfunction stringify(obj, replacer, spacer, options) {\n if (typeof options === 'undefined') {\n options = defaultOptions();\n }\n decirc(obj, '', 0, [], undefined, 0, options);\n var res;\n try {\n if (replacerStack.length === 0) {\n res = JSON.stringify(obj, replacer, spacer);\n } else {\n res = JSON.stringify(obj, replaceGetterValues(replacer), spacer);\n }\n } catch (_) {\n return JSON.stringify('[unable to serialize, circular reference is too complex to analyze]');\n } finally {\n while (arr.length !== 0) {\n var part = arr.pop();\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3]);\n } else {\n part[0][part[1]] = part[2];\n }\n }\n }\n return res;\n}\nfunction setReplace(replace, val, k, parent) {\n var propertyDescriptor = Object.getOwnPropertyDescriptor(parent, k);\n if (propertyDescriptor.get !== undefined) {\n if (propertyDescriptor.configurable) {\n Object.defineProperty(parent, k, {\n value: replace\n });\n arr.push([parent, k, val, propertyDescriptor]);\n } else {\n replacerStack.push([val, k, replace]);\n }\n } else {\n parent[k] = replace;\n arr.push([parent, k, val]);\n }\n}\nfunction decirc(val, k, edgeIndex, stack, parent, depth, options) {\n depth += 1;\n var i;\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n setReplace(CIRCULAR_REPLACE_NODE, val, k, parent);\n return;\n }\n }\n if (typeof options.depthLimit !== 'undefined' && depth > options.depthLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n if (typeof options.edgesLimit !== 'undefined' && edgeIndex + 1 > options.edgesLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n stack.push(val);\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n decirc(val[i], i, i, stack, val, depth, options);\n }\n } else {\n var keys = Object.keys(val);\n for (i = 0; i < keys.length; i++) {\n var key = keys[i];\n decirc(val[key], key, i, stack, val, depth, options);\n }\n }\n stack.pop();\n }\n}\n\n// Stable-stringify\nfunction compareFunction(a, b) {\n if (a < b) {\n return -1;\n }\n if (a > b) {\n return 1;\n }\n return 0;\n}\nfunction deterministicStringify(obj, replacer, spacer, options) {\n if (typeof options === 'undefined') {\n options = defaultOptions();\n }\n var tmp = deterministicDecirc(obj, '', 0, [], undefined, 0, options) || obj;\n var res;\n try {\n if (replacerStack.length === 0) {\n res = JSON.stringify(tmp, replacer, spacer);\n } else {\n res = JSON.stringify(tmp, replaceGetterValues(replacer), spacer);\n }\n } catch (_) {\n return JSON.stringify('[unable to serialize, circular reference is too complex to analyze]');\n } finally {\n // Ensure that we restore the object as it was.\n while (arr.length !== 0) {\n var part = arr.pop();\n if (part.length === 4) {\n Object.defineProperty(part[0], part[1], part[3]);\n } else {\n part[0][part[1]] = part[2];\n }\n }\n }\n return res;\n}\nfunction deterministicDecirc(val, k, edgeIndex, stack, parent, depth, options) {\n depth += 1;\n var i;\n if (typeof val === 'object' && val !== null) {\n for (i = 0; i < stack.length; i++) {\n if (stack[i] === val) {\n setReplace(CIRCULAR_REPLACE_NODE, val, k, parent);\n return;\n }\n }\n try {\n if (typeof val.toJSON === 'function') {\n return;\n }\n } catch (_) {\n return;\n }\n if (typeof options.depthLimit !== 'undefined' && depth > options.depthLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n if (typeof options.edgesLimit !== 'undefined' && edgeIndex + 1 > options.edgesLimit) {\n setReplace(LIMIT_REPLACE_NODE, val, k, parent);\n return;\n }\n stack.push(val);\n // Optimize for Arrays. Big arrays could kill the performance otherwise!\n if (Array.isArray(val)) {\n for (i = 0; i < val.length; i++) {\n deterministicDecirc(val[i], i, i, stack, val, depth, options);\n }\n } else {\n // Create a temporary object in the required way\n var tmp = {};\n var keys = Object.keys(val).sort(compareFunction);\n for (i = 0; i < keys.length; i++) {\n var key = keys[i];\n deterministicDecirc(val[key], key, i, stack, val, depth, options);\n tmp[key] = val[key];\n }\n if (typeof parent !== 'undefined') {\n arr.push([parent, k, val]);\n parent[k] = tmp;\n } else {\n return tmp;\n }\n }\n stack.pop();\n }\n}\n\n// wraps replacer function to handle values we couldn't replace\n// and mark them as replaced value\nfunction replaceGetterValues(replacer) {\n replacer = typeof replacer !== 'undefined' ? replacer : function (k, v) {\n return v;\n };\n return function (key, val) {\n if (replacerStack.length > 0) {\n for (var i = 0; i < replacerStack.length; i++) {\n var part = replacerStack[i];\n if (part[1] === key && part[0] === val) {\n val = part[2];\n replacerStack.splice(i, 1);\n break;\n }\n }\n }\n return replacer.call(this, key, val);\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.EthereumProviderError = exports.EthereumRpcError = void 0;\nconst fast_safe_stringify_1 = require(\"fast-safe-stringify\");\n/**\n * Error subclass implementing JSON RPC 2.0 errors and Ethereum RPC errors\n * per EIP-1474.\n * Permits any integer error code.\n */\nclass EthereumRpcError extends Error {\n constructor(code, message, data) {\n if (!Number.isInteger(code)) {\n throw new Error('\"code\" must be an integer.');\n }\n if (!message || typeof message !== 'string') {\n throw new Error('\"message\" must be a nonempty string.');\n }\n super(message);\n this.code = code;\n if (data !== undefined) {\n this.data = data;\n }\n }\n /**\n * Returns a plain object with all public class properties.\n */\n serialize() {\n const serialized = {\n code: this.code,\n message: this.message\n };\n if (this.data !== undefined) {\n serialized.data = this.data;\n }\n if (this.stack) {\n serialized.stack = this.stack;\n }\n return serialized;\n }\n /**\n * Return a string representation of the serialized error, omitting\n * any circular references.\n */\n toString() {\n return fast_safe_stringify_1.default(this.serialize(), stringifyReplacer, 2);\n }\n}\nexports.EthereumRpcError = EthereumRpcError;\n/**\n * Error subclass implementing Ethereum Provider errors per EIP-1193.\n * Permits integer error codes in the [ 1000 <= 4999 ] range.\n */\nclass EthereumProviderError extends EthereumRpcError {\n /**\n * Create an Ethereum Provider JSON-RPC error.\n * `code` must be an integer in the 1000 <= 4999 range.\n */\n constructor(code, message, data) {\n if (!isValidEthProviderCode(code)) {\n throw new Error('\"code\" must be an integer such that: 1000 <= code <= 4999');\n }\n super(code, message, data);\n }\n}\nexports.EthereumProviderError = EthereumProviderError;\n// Internal\nfunction isValidEthProviderCode(code) {\n return Number.isInteger(code) && code >= 1000 && code <= 4999;\n}\nfunction stringifyReplacer(_, value) {\n if (value === '[Circular]') {\n return undefined;\n }\n return value;\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.errorValues = exports.errorCodes = void 0;\nexports.errorCodes = {\n rpc: {\n invalidInput: -32000,\n resourceNotFound: -32001,\n resourceUnavailable: -32002,\n transactionRejected: -32003,\n methodNotSupported: -32004,\n limitExceeded: -32005,\n parse: -32700,\n invalidRequest: -32600,\n methodNotFound: -32601,\n invalidParams: -32602,\n internal: -32603\n },\n provider: {\n userRejectedRequest: 4001,\n unauthorized: 4100,\n unsupportedMethod: 4200,\n disconnected: 4900,\n chainDisconnected: 4901\n }\n};\nexports.errorValues = {\n '-32700': {\n standard: 'JSON RPC 2.0',\n message: 'Invalid JSON was received by the server. An error occurred on the server while parsing the JSON text.'\n },\n '-32600': {\n standard: 'JSON RPC 2.0',\n message: 'The JSON sent is not a valid Request object.'\n },\n '-32601': {\n standard: 'JSON RPC 2.0',\n message: 'The method does not exist / is not available.'\n },\n '-32602': {\n standard: 'JSON RPC 2.0',\n message: 'Invalid method parameter(s).'\n },\n '-32603': {\n standard: 'JSON RPC 2.0',\n message: 'Internal JSON-RPC error.'\n },\n '-32000': {\n standard: 'EIP-1474',\n message: 'Invalid input.'\n },\n '-32001': {\n standard: 'EIP-1474',\n message: 'Resource not found.'\n },\n '-32002': {\n standard: 'EIP-1474',\n message: 'Resource unavailable.'\n },\n '-32003': {\n standard: 'EIP-1474',\n message: 'Transaction rejected.'\n },\n '-32004': {\n standard: 'EIP-1474',\n message: 'Method not supported.'\n },\n '-32005': {\n standard: 'EIP-1474',\n message: 'Request limit exceeded.'\n },\n '4001': {\n standard: 'EIP-1193',\n message: 'User rejected the request.'\n },\n '4100': {\n standard: 'EIP-1193',\n message: 'The requested account and/or method has not been authorized by the user.'\n },\n '4200': {\n standard: 'EIP-1193',\n message: 'The requested method is not supported by this Ethereum provider.'\n },\n '4900': {\n standard: 'EIP-1193',\n message: 'The provider is disconnected from all chains.'\n },\n '4901': {\n standard: 'EIP-1193',\n message: 'The provider is disconnected from the specified chain.'\n }\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.serializeError = exports.isValidCode = exports.getMessageFromCode = exports.JSON_RPC_SERVER_ERROR_MESSAGE = void 0;\nconst error_constants_1 = require(\"./error-constants\");\nconst classes_1 = require(\"./classes\");\nconst FALLBACK_ERROR_CODE = error_constants_1.errorCodes.rpc.internal;\nconst FALLBACK_MESSAGE = 'Unspecified error message. This is a bug, please report it.';\nconst FALLBACK_ERROR = {\n code: FALLBACK_ERROR_CODE,\n message: getMessageFromCode(FALLBACK_ERROR_CODE)\n};\nexports.JSON_RPC_SERVER_ERROR_MESSAGE = 'Unspecified server error.';\n/**\n * Gets the message for a given code, or a fallback message if the code has\n * no corresponding message.\n */\nfunction getMessageFromCode(code, fallbackMessage = FALLBACK_MESSAGE) {\n if (Number.isInteger(code)) {\n const codeString = code.toString();\n if (hasKey(error_constants_1.errorValues, codeString)) {\n return error_constants_1.errorValues[codeString].message;\n }\n if (isJsonRpcServerError(code)) {\n return exports.JSON_RPC_SERVER_ERROR_MESSAGE;\n }\n }\n return fallbackMessage;\n}\nexports.getMessageFromCode = getMessageFromCode;\n/**\n * Returns whether the given code is valid.\n * A code is only valid if it has a message.\n */\nfunction isValidCode(code) {\n if (!Number.isInteger(code)) {\n return false;\n }\n const codeString = code.toString();\n if (error_constants_1.errorValues[codeString]) {\n return true;\n }\n if (isJsonRpcServerError(code)) {\n return true;\n }\n return false;\n}\nexports.isValidCode = isValidCode;\n/**\n * Serializes the given error to an Ethereum JSON RPC-compatible error object.\n * Merely copies the given error's values if it is already compatible.\n * If the given error is not fully compatible, it will be preserved on the\n * returned object's data.originalError property.\n */\nfunction serializeError(error, {\n fallbackError = FALLBACK_ERROR,\n shouldIncludeStack = false\n} = {}) {\n var _a, _b;\n if (!fallbackError || !Number.isInteger(fallbackError.code) || typeof fallbackError.message !== 'string') {\n throw new Error('Must provide fallback error with integer number code and string message.');\n }\n if (error instanceof classes_1.EthereumRpcError) {\n return error.serialize();\n }\n const serialized = {};\n if (error && typeof error === 'object' && !Array.isArray(error) && hasKey(error, 'code') && isValidCode(error.code)) {\n const _error = error;\n serialized.code = _error.code;\n if (_error.message && typeof _error.message === 'string') {\n serialized.message = _error.message;\n if (hasKey(_error, 'data')) {\n serialized.data = _error.data;\n }\n } else {\n serialized.message = getMessageFromCode(serialized.code);\n serialized.data = {\n originalError: assignOriginalError(error)\n };\n }\n } else {\n serialized.code = fallbackError.code;\n const message = (_a = error) === null || _a === void 0 ? void 0 : _a.message;\n serialized.message = message && typeof message === 'string' ? message : fallbackError.message;\n serialized.data = {\n originalError: assignOriginalError(error)\n };\n }\n const stack = (_b = error) === null || _b === void 0 ? void 0 : _b.stack;\n if (shouldIncludeStack && error && stack && typeof stack === 'string') {\n serialized.stack = stack;\n }\n return serialized;\n}\nexports.serializeError = serializeError;\n// Internal\nfunction isJsonRpcServerError(code) {\n return code >= -32099 && code <= -32000;\n}\nfunction assignOriginalError(error) {\n if (error && typeof error === 'object' && !Array.isArray(error)) {\n return Object.assign({}, error);\n }\n return error;\n}\nfunction hasKey(obj, key) {\n return Object.prototype.hasOwnProperty.call(obj, key);\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ethErrors = void 0;\nconst classes_1 = require(\"./classes\");\nconst utils_1 = require(\"./utils\");\nconst error_constants_1 = require(\"./error-constants\");\nexports.ethErrors = {\n rpc: {\n /**\n * Get a JSON RPC 2.0 Parse (-32700) error.\n */\n parse: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.parse, arg),\n /**\n * Get a JSON RPC 2.0 Invalid Request (-32600) error.\n */\n invalidRequest: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.invalidRequest, arg),\n /**\n * Get a JSON RPC 2.0 Invalid Params (-32602) error.\n */\n invalidParams: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.invalidParams, arg),\n /**\n * Get a JSON RPC 2.0 Method Not Found (-32601) error.\n */\n methodNotFound: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.methodNotFound, arg),\n /**\n * Get a JSON RPC 2.0 Internal (-32603) error.\n */\n internal: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.internal, arg),\n /**\n * Get a JSON RPC 2.0 Server error.\n * Permits integer error codes in the [ -32099 <= -32005 ] range.\n * Codes -32000 through -32004 are reserved by EIP-1474.\n */\n server: opts => {\n if (!opts || typeof opts !== 'object' || Array.isArray(opts)) {\n throw new Error('Ethereum RPC Server errors must provide single object argument.');\n }\n const {\n code\n } = opts;\n if (!Number.isInteger(code) || code > -32005 || code < -32099) {\n throw new Error('\"code\" must be an integer such that: -32099 <= code <= -32005');\n }\n return getEthJsonRpcError(code, opts);\n },\n /**\n * Get an Ethereum JSON RPC Invalid Input (-32000) error.\n */\n invalidInput: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.invalidInput, arg),\n /**\n * Get an Ethereum JSON RPC Resource Not Found (-32001) error.\n */\n resourceNotFound: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.resourceNotFound, arg),\n /**\n * Get an Ethereum JSON RPC Resource Unavailable (-32002) error.\n */\n resourceUnavailable: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.resourceUnavailable, arg),\n /**\n * Get an Ethereum JSON RPC Transaction Rejected (-32003) error.\n */\n transactionRejected: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.transactionRejected, arg),\n /**\n * Get an Ethereum JSON RPC Method Not Supported (-32004) error.\n */\n methodNotSupported: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.methodNotSupported, arg),\n /**\n * Get an Ethereum JSON RPC Limit Exceeded (-32005) error.\n */\n limitExceeded: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.limitExceeded, arg)\n },\n provider: {\n /**\n * Get an Ethereum Provider User Rejected Request (4001) error.\n */\n userRejectedRequest: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.userRejectedRequest, arg);\n },\n /**\n * Get an Ethereum Provider Unauthorized (4100) error.\n */\n unauthorized: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.unauthorized, arg);\n },\n /**\n * Get an Ethereum Provider Unsupported Method (4200) error.\n */\n unsupportedMethod: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.unsupportedMethod, arg);\n },\n /**\n * Get an Ethereum Provider Not Connected (4900) error.\n */\n disconnected: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.disconnected, arg);\n },\n /**\n * Get an Ethereum Provider Chain Not Connected (4901) error.\n */\n chainDisconnected: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.chainDisconnected, arg);\n },\n /**\n * Get a custom Ethereum Provider error.\n */\n custom: opts => {\n if (!opts || typeof opts !== 'object' || Array.isArray(opts)) {\n throw new Error('Ethereum Provider custom errors must provide single object argument.');\n }\n const {\n code,\n message,\n data\n } = opts;\n if (!message || typeof message !== 'string') {\n throw new Error('\"message\" must be a nonempty string');\n }\n return new classes_1.EthereumProviderError(code, message, data);\n }\n }\n};\n// Internal\nfunction getEthJsonRpcError(code, arg) {\n const [message, data] = parseOpts(arg);\n return new classes_1.EthereumRpcError(code, message || utils_1.getMessageFromCode(code), data);\n}\nfunction getEthProviderError(code, arg) {\n const [message, data] = parseOpts(arg);\n return new classes_1.EthereumProviderError(code, message || utils_1.getMessageFromCode(code), data);\n}\nfunction parseOpts(arg) {\n if (arg) {\n if (typeof arg === 'string') {\n return [arg];\n } else if (typeof arg === 'object' && !Array.isArray(arg)) {\n const {\n message,\n data\n } = arg;\n if (message && typeof message !== 'string') {\n throw new Error('Must specify string message.');\n }\n return [message || undefined, data];\n }\n }\n return [];\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getMessageFromCode = exports.serializeError = exports.EthereumProviderError = exports.EthereumRpcError = exports.ethErrors = exports.errorCodes = void 0;\nconst classes_1 = require(\"./classes\");\nObject.defineProperty(exports, \"EthereumRpcError\", {\n enumerable: true,\n get: function () {\n return classes_1.EthereumRpcError;\n }\n});\nObject.defineProperty(exports, \"EthereumProviderError\", {\n enumerable: true,\n get: function () {\n return classes_1.EthereumProviderError;\n }\n});\nconst utils_1 = require(\"./utils\");\nObject.defineProperty(exports, \"serializeError\", {\n enumerable: true,\n get: function () {\n return utils_1.serializeError;\n }\n});\nObject.defineProperty(exports, \"getMessageFromCode\", {\n enumerable: true,\n get: function () {\n return utils_1.getMessageFromCode;\n }\n});\nconst errors_1 = require(\"./errors\");\nObject.defineProperty(exports, \"ethErrors\", {\n enumerable: true,\n get: function () {\n return errors_1.ethErrors;\n }\n});\nconst error_constants_1 = require(\"./error-constants\");\nObject.defineProperty(exports, \"errorCodes\", {\n enumerable: true,\n get: function () {\n return error_constants_1.errorCodes;\n }\n});\n","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Web3Method = void 0;\nvar Web3Method;\n(function (Web3Method) {\n Web3Method[\"requestEthereumAccounts\"] = \"requestEthereumAccounts\";\n Web3Method[\"signEthereumMessage\"] = \"signEthereumMessage\";\n Web3Method[\"signEthereumTransaction\"] = \"signEthereumTransaction\";\n Web3Method[\"submitEthereumTransaction\"] = \"submitEthereumTransaction\";\n Web3Method[\"ethereumAddressFromSignedMessage\"] = \"ethereumAddressFromSignedMessage\";\n Web3Method[\"scanQRCode\"] = \"scanQRCode\";\n Web3Method[\"generic\"] = \"generic\";\n Web3Method[\"childRequestEthereumAccounts\"] = \"childRequestEthereumAccounts\";\n Web3Method[\"addEthereumChain\"] = \"addEthereumChain\";\n Web3Method[\"switchEthereumChain\"] = \"switchEthereumChain\";\n Web3Method[\"makeEthereumJSONRPCRequest\"] = \"makeEthereumJSONRPCRequest\";\n Web3Method[\"watchAsset\"] = \"watchAsset\";\n Web3Method[\"selectProvider\"] = \"selectProvider\";\n})(Web3Method = exports.Web3Method || (exports.Web3Method = {}));","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.EthereumAddressFromSignedMessageResponse = exports.SubmitEthereumTransactionResponse = exports.SignEthereumTransactionResponse = exports.SignEthereumMessageResponse = exports.isRequestEthereumAccountsResponse = exports.SelectProviderResponse = exports.WatchAssetReponse = exports.RequestEthereumAccountsResponse = exports.SwitchEthereumChainResponse = exports.AddEthereumChainResponse = exports.isErrorResponse = void 0;\nconst Web3Method_1 = require(\"./Web3Method\");\nfunction isErrorResponse(response) {\n var _a, _b;\n return ((_a = response) === null || _a === void 0 ? void 0 : _a.method) !== undefined && ((_b = response) === null || _b === void 0 ? void 0 : _b.errorMessage) !== undefined;\n}\nexports.isErrorResponse = isErrorResponse;\nfunction AddEthereumChainResponse(addResponse) {\n return {\n method: Web3Method_1.Web3Method.addEthereumChain,\n result: addResponse\n };\n}\nexports.AddEthereumChainResponse = AddEthereumChainResponse;\nfunction SwitchEthereumChainResponse(switchResponse) {\n return {\n method: Web3Method_1.Web3Method.switchEthereumChain,\n result: switchResponse\n };\n}\nexports.SwitchEthereumChainResponse = SwitchEthereumChainResponse;\nfunction RequestEthereumAccountsResponse(addresses) {\n return {\n method: Web3Method_1.Web3Method.requestEthereumAccounts,\n result: addresses\n };\n}\nexports.RequestEthereumAccountsResponse = RequestEthereumAccountsResponse;\nfunction WatchAssetReponse(success) {\n return {\n method: Web3Method_1.Web3Method.watchAsset,\n result: success\n };\n}\nexports.WatchAssetReponse = WatchAssetReponse;\nfunction SelectProviderResponse(selectedProviderKey) {\n return {\n method: Web3Method_1.Web3Method.selectProvider,\n result: selectedProviderKey\n };\n}\nexports.SelectProviderResponse = SelectProviderResponse;\nfunction isRequestEthereumAccountsResponse(res) {\n return res && res.method === Web3Method_1.Web3Method.requestEthereumAccounts;\n}\nexports.isRequestEthereumAccountsResponse = isRequestEthereumAccountsResponse;\nfunction SignEthereumMessageResponse(signature) {\n return {\n method: Web3Method_1.Web3Method.signEthereumMessage,\n result: signature\n };\n}\nexports.SignEthereumMessageResponse = SignEthereumMessageResponse;\nfunction SignEthereumTransactionResponse(signedData) {\n return {\n method: Web3Method_1.Web3Method.signEthereumTransaction,\n result: signedData\n };\n}\nexports.SignEthereumTransactionResponse = SignEthereumTransactionResponse;\nfunction SubmitEthereumTransactionResponse(txHash) {\n return {\n method: Web3Method_1.Web3Method.submitEthereumTransaction,\n result: txHash\n };\n}\nexports.SubmitEthereumTransactionResponse = SubmitEthereumTransactionResponse;\nfunction EthereumAddressFromSignedMessageResponse(address) {\n return {\n method: Web3Method_1.Web3Method.ethereumAddressFromSignedMessage,\n result: address\n };\n}\nexports.EthereumAddressFromSignedMessageResponse = EthereumAddressFromSignedMessageResponse;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LIB_VERSION = void 0;\nexports.LIB_VERSION = \"3.7.2\";","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getErrorCode = exports.serializeError = exports.standardErrors = exports.standardErrorMessage = exports.standardErrorCodes = void 0;\n// eslint-disable-next-line no-restricted-imports\nconst eth_rpc_errors_1 = require(\"eth-rpc-errors\");\nconst Web3Response_1 = require(\"./relay/Web3Response\");\nconst version_1 = require(\"./version\");\nexports.standardErrorCodes = Object.freeze(Object.assign(Object.assign({}, eth_rpc_errors_1.errorCodes), {\n provider: Object.freeze(Object.assign(Object.assign({}, eth_rpc_errors_1.errorCodes.provider), {\n unsupportedChain: 4902\n }))\n}));\nfunction standardErrorMessage(code) {\n return code !== undefined ? (0, eth_rpc_errors_1.getMessageFromCode)(code) : \"Unknown error\";\n}\nexports.standardErrorMessage = standardErrorMessage;\nexports.standardErrors = Object.freeze(Object.assign(Object.assign({}, eth_rpc_errors_1.ethErrors), {\n provider: Object.freeze(Object.assign(Object.assign({}, eth_rpc_errors_1.ethErrors.provider), {\n unsupportedChain: (chainId = \"\") => eth_rpc_errors_1.ethErrors.provider.custom({\n code: exports.standardErrorCodes.provider.unsupportedChain,\n message: `Unrecognized chain ID ${chainId}. Try adding the chain using wallet_addEthereumChain first.`\n })\n }))\n}));\n/**\n * Serializes an error to a format that is compatible with the Ethereum JSON RPC error format.\n * See https://docs.cloud.coinbase.com/wallet-sdk/docs/errors\n * for more information.\n */\nfunction serializeError(error, requestOrMethod) {\n const serialized = (0, eth_rpc_errors_1.serializeError)(getErrorObject(error), {\n shouldIncludeStack: true\n });\n const docUrl = new URL(\"https://docs.cloud.coinbase.com/wallet-sdk/docs/errors\");\n docUrl.searchParams.set(\"version\", version_1.LIB_VERSION);\n docUrl.searchParams.set(\"code\", serialized.code.toString());\n const method = getMethod(serialized.data, requestOrMethod);\n if (method) {\n docUrl.searchParams.set(\"method\", method);\n }\n docUrl.searchParams.set(\"message\", serialized.message);\n return Object.assign(Object.assign({}, serialized), {\n docUrl: docUrl.href\n });\n}\nexports.serializeError = serializeError;\n/**\n * Converts an error to a serializable object.\n */\nfunction getErrorObject(error) {\n if (typeof error === \"string\") {\n return {\n message: error,\n code: exports.standardErrorCodes.rpc.internal\n };\n } else if ((0, Web3Response_1.isErrorResponse)(error)) {\n return Object.assign(Object.assign({}, error), {\n message: error.errorMessage,\n code: error.errorCode,\n data: {\n method: error.method,\n result: error.result\n }\n });\n } else {\n return error;\n }\n}\n/**\n * Gets the method name from the serialized data or the request.\n */\nfunction getMethod(serializedData, request) {\n var _a;\n const methodInData = (_a = serializedData) === null || _a === void 0 ? void 0 : _a.method;\n if (methodInData) {\n return methodInData;\n }\n if (request === undefined) {\n return undefined;\n } else if (typeof request === \"string\") {\n return request;\n } else if (!Array.isArray(request)) {\n return request.method;\n } else if (request.length > 0) {\n return request[0].method;\n } else {\n return undefined;\n }\n}\n// ----------------- getErrorCode -----------------\n/**\n * Returns the error code from an error object.\n */\nfunction getErrorCode(error) {\n var _a;\n if (typeof error === \"number\") {\n return error;\n } else if (isErrorWithCode(error)) {\n return (_a = error.code) !== null && _a !== void 0 ? _a : error.errorCode;\n }\n return undefined;\n}\nexports.getErrorCode = getErrorCode;\nfunction isErrorWithCode(error) {\n return typeof error === \"object\" && error !== null && (typeof error.code === \"number\" || typeof error.errorCode === \"number\");\n}","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ProviderType = exports.RegExpString = exports.IntNumber = exports.BigIntString = exports.AddressString = exports.HexString = exports.OpaqueType = void 0;\nfunction OpaqueType() {\n return value => value;\n}\nexports.OpaqueType = OpaqueType;\nexports.HexString = OpaqueType();\nexports.AddressString = OpaqueType();\nexports.BigIntString = OpaqueType();\nfunction IntNumber(num) {\n return Math.floor(num);\n}\nexports.IntNumber = IntNumber;\nexports.RegExpString = OpaqueType();\nvar ProviderType;\n(function (ProviderType) {\n ProviderType[\"CoinbaseWallet\"] = \"CoinbaseWallet\";\n ProviderType[\"MetaMask\"] = \"MetaMask\";\n ProviderType[\"Unselected\"] = \"\";\n})(ProviderType = exports.ProviderType || (exports.ProviderType = {}));","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isInIFrame = exports.createQrUrl = exports.getFavicon = exports.range = exports.isBigNumber = exports.ensureParsedJSONObject = exports.ensureBN = exports.ensureRegExpString = exports.ensureIntNumber = exports.ensureBuffer = exports.ensureAddressString = exports.ensureEvenLengthHexString = exports.ensureHexString = exports.isHexString = exports.prepend0x = exports.strip0x = exports.has0xPrefix = exports.hexStringFromIntNumber = exports.intNumberFromHexString = exports.bigIntStringFromBN = exports.hexStringFromBuffer = exports.hexStringToUint8Array = exports.uint8ArrayToHex = exports.randomBytesHex = void 0;\nconst bn_js_1 = __importDefault(require(\"bn.js\"));\nconst qs_1 = require(\"qs\");\nconst errors_1 = require(\"./errors\");\nconst types_1 = require(\"./types\");\nconst INT_STRING_REGEX = /^[0-9]*$/;\nconst HEXADECIMAL_STRING_REGEX = /^[a-f0-9]*$/;\n/**\n * @param length number of bytes\n */\nfunction randomBytesHex(length) {\n return uint8ArrayToHex(crypto.getRandomValues(new Uint8Array(length)));\n}\nexports.randomBytesHex = randomBytesHex;\nfunction uint8ArrayToHex(value) {\n return [...value].map(b => b.toString(16).padStart(2, \"0\")).join(\"\");\n}\nexports.uint8ArrayToHex = uint8ArrayToHex;\nfunction hexStringToUint8Array(hexString) {\n return new Uint8Array(hexString.match(/.{1,2}/g).map(byte => parseInt(byte, 16)));\n}\nexports.hexStringToUint8Array = hexStringToUint8Array;\nfunction hexStringFromBuffer(buf, includePrefix = false) {\n const hex = buf.toString(\"hex\");\n return (0, types_1.HexString)(includePrefix ? \"0x\" + hex : hex);\n}\nexports.hexStringFromBuffer = hexStringFromBuffer;\nfunction bigIntStringFromBN(bn) {\n return (0, types_1.BigIntString)(bn.toString(10));\n}\nexports.bigIntStringFromBN = bigIntStringFromBN;\nfunction intNumberFromHexString(hex) {\n return (0, types_1.IntNumber)(new bn_js_1.default(ensureEvenLengthHexString(hex, false), 16).toNumber());\n}\nexports.intNumberFromHexString = intNumberFromHexString;\nfunction hexStringFromIntNumber(num) {\n return (0, types_1.HexString)(\"0x\" + new bn_js_1.default(num).toString(16));\n}\nexports.hexStringFromIntNumber = hexStringFromIntNumber;\nfunction has0xPrefix(str) {\n return str.startsWith(\"0x\") || str.startsWith(\"0X\");\n}\nexports.has0xPrefix = has0xPrefix;\nfunction strip0x(hex) {\n if (has0xPrefix(hex)) {\n return hex.slice(2);\n }\n return hex;\n}\nexports.strip0x = strip0x;\nfunction prepend0x(hex) {\n if (has0xPrefix(hex)) {\n return \"0x\" + hex.slice(2);\n }\n return \"0x\" + hex;\n}\nexports.prepend0x = prepend0x;\nfunction isHexString(hex) {\n if (typeof hex !== \"string\") {\n return false;\n }\n const s = strip0x(hex).toLowerCase();\n return HEXADECIMAL_STRING_REGEX.test(s);\n}\nexports.isHexString = isHexString;\nfunction ensureHexString(hex, includePrefix = false) {\n if (typeof hex === \"string\") {\n const s = strip0x(hex).toLowerCase();\n if (HEXADECIMAL_STRING_REGEX.test(s)) {\n return (0, types_1.HexString)(includePrefix ? \"0x\" + s : s);\n }\n }\n throw errors_1.standardErrors.rpc.invalidParams(`\"${String(hex)}\" is not a hexadecimal string`);\n}\nexports.ensureHexString = ensureHexString;\nfunction ensureEvenLengthHexString(hex, includePrefix = false) {\n let h = ensureHexString(hex, false);\n if (h.length % 2 === 1) {\n h = (0, types_1.HexString)(\"0\" + h);\n }\n return includePrefix ? (0, types_1.HexString)(\"0x\" + h) : h;\n}\nexports.ensureEvenLengthHexString = ensureEvenLengthHexString;\nfunction ensureAddressString(str) {\n if (typeof str === \"string\") {\n const s = strip0x(str).toLowerCase();\n if (isHexString(s) && s.length === 40) {\n return (0, types_1.AddressString)(prepend0x(s));\n }\n }\n throw errors_1.standardErrors.rpc.invalidParams(`Invalid Ethereum address: ${String(str)}`);\n}\nexports.ensureAddressString = ensureAddressString;\nfunction ensureBuffer(str) {\n if (Buffer.isBuffer(str)) {\n return str;\n }\n if (typeof str === \"string\") {\n if (isHexString(str)) {\n const s = ensureEvenLengthHexString(str, false);\n return Buffer.from(s, \"hex\");\n } else {\n return Buffer.from(str, \"utf8\");\n }\n }\n throw errors_1.standardErrors.rpc.invalidParams(`Not binary data: ${String(str)}`);\n}\nexports.ensureBuffer = ensureBuffer;\nfunction ensureIntNumber(num) {\n if (typeof num === \"number\" && Number.isInteger(num)) {\n return (0, types_1.IntNumber)(num);\n }\n if (typeof num === \"string\") {\n if (INT_STRING_REGEX.test(num)) {\n return (0, types_1.IntNumber)(Number(num));\n }\n if (isHexString(num)) {\n return (0, types_1.IntNumber)(new bn_js_1.default(ensureEvenLengthHexString(num, false), 16).toNumber());\n }\n }\n throw errors_1.standardErrors.rpc.invalidParams(`Not an integer: ${String(num)}`);\n}\nexports.ensureIntNumber = ensureIntNumber;\nfunction ensureRegExpString(regExp) {\n if (regExp instanceof RegExp) {\n return (0, types_1.RegExpString)(regExp.toString());\n }\n throw errors_1.standardErrors.rpc.invalidParams(`Not a RegExp: ${String(regExp)}`);\n}\nexports.ensureRegExpString = ensureRegExpString;\nfunction ensureBN(val) {\n if (val !== null && (bn_js_1.default.isBN(val) || isBigNumber(val))) {\n return new bn_js_1.default(val.toString(10), 10);\n }\n if (typeof val === \"number\") {\n return new bn_js_1.default(ensureIntNumber(val));\n }\n if (typeof val === \"string\") {\n if (INT_STRING_REGEX.test(val)) {\n return new bn_js_1.default(val, 10);\n }\n if (isHexString(val)) {\n return new bn_js_1.default(ensureEvenLengthHexString(val, false), 16);\n }\n }\n throw errors_1.standardErrors.rpc.invalidParams(`Not an integer: ${String(val)}`);\n}\nexports.ensureBN = ensureBN;\nfunction ensureParsedJSONObject(val) {\n if (typeof val === \"string\") {\n return JSON.parse(val);\n }\n if (typeof val === \"object\") {\n return val;\n }\n throw errors_1.standardErrors.rpc.invalidParams(`Not a JSON string or an object: ${String(val)}`);\n}\nexports.ensureParsedJSONObject = ensureParsedJSONObject;\nfunction isBigNumber(val) {\n if (val == null || typeof val.constructor !== \"function\") {\n return false;\n }\n const {\n constructor\n } = val;\n return typeof constructor.config === \"function\" && typeof constructor.EUCLID === \"number\";\n}\nexports.isBigNumber = isBigNumber;\nfunction range(start, stop) {\n return Array.from({\n length: stop - start\n }, (_, i) => start + i);\n}\nexports.range = range;\nfunction getFavicon() {\n const el = document.querySelector('link[sizes=\"192x192\"]') || document.querySelector('link[sizes=\"180x180\"]') || document.querySelector('link[rel=\"icon\"]') || document.querySelector('link[rel=\"shortcut icon\"]');\n const {\n protocol,\n host\n } = document.location;\n const href = el ? el.getAttribute(\"href\") : null;\n if (!href || href.startsWith(\"javascript:\")) {\n return null;\n }\n if (href.startsWith(\"http://\") || href.startsWith(\"https://\") || href.startsWith(\"data:\")) {\n return href;\n }\n if (href.startsWith(\"//\")) {\n return protocol + href;\n }\n return `${protocol}//${host}${href}`;\n}\nexports.getFavicon = getFavicon;\nfunction createQrUrl(sessionId, sessionSecret, serverUrl, isParentConnection, version, chainId) {\n const sessionIdKey = isParentConnection ? \"parent-id\" : \"id\";\n const query = (0, qs_1.stringify)({\n [sessionIdKey]: sessionId,\n secret: sessionSecret,\n server: serverUrl,\n v: version,\n chainId\n });\n const qrUrl = `${serverUrl}/#/link?${query}`;\n return qrUrl;\n}\nexports.createQrUrl = createQrUrl;\nfunction isInIFrame() {\n try {\n return window.frameElement !== null;\n } catch (e) {\n return false;\n }\n}\nexports.isInIFrame = isInIFrame;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Session = void 0;\nconst sha_js_1 = require(\"sha.js\");\nconst util_1 = require(\"../util\");\nconst STORAGE_KEY_SESSION_ID = \"session:id\";\nconst STORAGE_KEY_SESSION_SECRET = \"session:secret\";\nconst STORAGE_KEY_SESSION_LINKED = \"session:linked\";\nclass Session {\n constructor(storage, id, secret, linked) {\n this._storage = storage;\n this._id = id || (0, util_1.randomBytesHex)(16);\n this._secret = secret || (0, util_1.randomBytesHex)(32);\n this._key = new sha_js_1.sha256().update(`${this._id}, ${this._secret} WalletLink`) // ensure old sessions stay connected\n .digest(\"hex\");\n this._linked = !!linked;\n }\n static load(storage) {\n const id = storage.getItem(STORAGE_KEY_SESSION_ID);\n const linked = storage.getItem(STORAGE_KEY_SESSION_LINKED);\n const secret = storage.getItem(STORAGE_KEY_SESSION_SECRET);\n if (id && secret) {\n return new Session(storage, id, secret, linked === \"1\");\n }\n return null;\n }\n /**\n * Takes in a session ID and returns the sha256 hash of it.\n * @param sessionId session ID\n */\n static hash(sessionId) {\n return new sha_js_1.sha256().update(sessionId).digest(\"hex\");\n }\n get id() {\n return this._id;\n }\n get secret() {\n return this._secret;\n }\n get key() {\n return this._key;\n }\n get linked() {\n return this._linked;\n }\n set linked(val) {\n this._linked = val;\n this.persistLinked();\n }\n save() {\n this._storage.setItem(STORAGE_KEY_SESSION_ID, this._id);\n this._storage.setItem(STORAGE_KEY_SESSION_SECRET, this._secret);\n this.persistLinked();\n return this;\n }\n persistLinked() {\n this._storage.setItem(STORAGE_KEY_SESSION_LINKED, this._linked ? \"1\" : \"0\");\n }\n}\nexports.Session = Session;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.WalletSDKRelayAbstract = exports.APP_VERSION_KEY = exports.LOCAL_STORAGE_ADDRESSES_KEY = exports.WALLET_USER_NAME_KEY = void 0;\nconst errors_1 = require(\"../errors\");\nexports.WALLET_USER_NAME_KEY = \"walletUsername\";\nexports.LOCAL_STORAGE_ADDRESSES_KEY = \"Addresses\";\nexports.APP_VERSION_KEY = \"AppVersion\";\nclass WalletSDKRelayAbstract {\n async makeEthereumJSONRPCRequest(request, jsonRpcUrl) {\n if (!jsonRpcUrl) throw new Error(\"Error: No jsonRpcUrl provided\");\n return window.fetch(jsonRpcUrl, {\n method: \"POST\",\n body: JSON.stringify(request),\n mode: \"cors\",\n headers: {\n \"Content-Type\": \"application/json\"\n }\n }).then(res => res.json()).then(json => {\n if (!json) {\n throw errors_1.standardErrors.rpc.parse({});\n }\n const response = json;\n const {\n error\n } = response;\n if (error) {\n throw (0, errors_1.serializeError)(error, request.method);\n }\n return response;\n });\n }\n}\nexports.WalletSDKRelayAbstract = WalletSDKRelayAbstract;","// Extracted from https://github.com/ethereumjs/ethereumjs-util and stripped out irrelevant code\n// Original code licensed under the Mozilla Public License Version 2.0\n\nconst createKeccakHash = require('keccak/js');\nconst BN = require('bn.js');\n\n/**\n * Returns a buffer filled with 0s\n * @method zeros\n * @param {Number} bytes the number of bytes the buffer should be\n * @return {Buffer}\n */\nfunction zeros(bytes) {\n return Buffer.allocUnsafe(bytes).fill(0);\n}\n\n/**\n * Left Pads an `Array` or `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @method setLength\n * @param {Buffer|Array} msg the value to pad\n * @param {Number} length the number of bytes the output should be\n * @param {Boolean} [right=false] whether to start padding form the left or right\n * @return {Buffer|Array}\n */\nfunction setLength(msg, length, right) {\n const buf = zeros(length);\n msg = toBuffer(msg);\n if (right) {\n if (msg.length < length) {\n msg.copy(buf);\n return buf;\n }\n return msg.slice(0, length);\n } else {\n if (msg.length < length) {\n msg.copy(buf, length - msg.length);\n return buf;\n }\n return msg.slice(-length);\n }\n}\n\n/**\n * Right Pads an `Array` or `Buffer` with leading zeros till it has `length` bytes.\n * Or it truncates the beginning if it exceeds.\n * @param {Buffer|Array} msg the value to pad\n * @param {Number} length the number of bytes the output should be\n * @return {Buffer|Array}\n */\nfunction setLengthRight(msg, length) {\n return setLength(msg, length, true);\n}\n\n/**\n * Attempts to turn a value into a `Buffer`. As input it supports `Buffer`, `String`, `Number`, null/undefined, `BN` and other objects with a `toArray()` method.\n * @param {*} v the value\n */\nfunction toBuffer(v) {\n if (!Buffer.isBuffer(v)) {\n if (Array.isArray(v)) {\n v = Buffer.from(v);\n } else if (typeof v === 'string') {\n if (isHexString(v)) {\n v = Buffer.from(padToEven(stripHexPrefix(v)), 'hex');\n } else {\n v = Buffer.from(v);\n }\n } else if (typeof v === 'number') {\n v = intToBuffer(v);\n } else if (v === null || v === undefined) {\n v = Buffer.allocUnsafe(0);\n } else if (BN.isBN(v)) {\n v = v.toArrayLike(Buffer);\n } else if (v.toArray) {\n // converts a BN to a Buffer\n v = Buffer.from(v.toArray());\n } else {\n throw new Error('invalid type');\n }\n }\n return v;\n}\n\n/**\n * Converts a `Buffer` into a hex `String`\n * @param {Buffer} buf\n * @return {String}\n */\nfunction bufferToHex(buf) {\n buf = toBuffer(buf);\n return '0x' + buf.toString('hex');\n}\n\n/**\n * Creates Keccak hash of the input\n * @param {Buffer|Array|String|Number} a the input data\n * @param {Number} [bits=256] the Keccak width\n * @return {Buffer}\n */\nfunction keccak(a, bits) {\n a = toBuffer(a);\n if (!bits) bits = 256;\n return createKeccakHash('keccak' + bits).update(a).digest();\n}\nfunction padToEven(str) {\n return str.length % 2 ? '0' + str : str;\n}\nfunction isHexString(str) {\n return typeof str === 'string' && str.match(/^0x[0-9A-Fa-f]*$/);\n}\nfunction stripHexPrefix(str) {\n if (typeof str === 'string' && str.startsWith('0x')) {\n return str.slice(2);\n }\n return str;\n}\nmodule.exports = {\n zeros,\n setLength,\n setLengthRight,\n isHexString,\n stripHexPrefix,\n toBuffer,\n bufferToHex,\n keccak\n};","// Extracted from https://github.com/ethereumjs/ethereumjs-abi and stripped out irrelevant code\n// Original code licensed under the MIT License - Copyright (c) 2015 Alex Beregszaszi\n\nconst util = require('./util');\nconst BN = require('bn.js');\n\n// Convert from short to canonical names\n// FIXME: optimise or make this nicer?\nfunction elementaryName(name) {\n if (name.startsWith('int[')) {\n return 'int256' + name.slice(3);\n } else if (name === 'int') {\n return 'int256';\n } else if (name.startsWith('uint[')) {\n return 'uint256' + name.slice(4);\n } else if (name === 'uint') {\n return 'uint256';\n } else if (name.startsWith('fixed[')) {\n return 'fixed128x128' + name.slice(5);\n } else if (name === 'fixed') {\n return 'fixed128x128';\n } else if (name.startsWith('ufixed[')) {\n return 'ufixed128x128' + name.slice(6);\n } else if (name === 'ufixed') {\n return 'ufixed128x128';\n }\n return name;\n}\n\n// Parse N from type\nfunction parseTypeN(type) {\n return parseInt(/^\\D+(\\d+)$/.exec(type)[1], 10);\n}\n\n// Parse N,M from typex\nfunction parseTypeNxM(type) {\n var tmp = /^\\D+(\\d+)x(\\d+)$/.exec(type);\n return [parseInt(tmp[1], 10), parseInt(tmp[2], 10)];\n}\n\n// Parse N in type[] where \"type\" can itself be an array type.\nfunction parseTypeArray(type) {\n var tmp = type.match(/(.*)\\[(.*?)\\]$/);\n if (tmp) {\n return tmp[2] === '' ? 'dynamic' : parseInt(tmp[2], 10);\n }\n return null;\n}\nfunction parseNumber(arg) {\n var type = typeof arg;\n if (type === 'string') {\n if (util.isHexString(arg)) {\n return new BN(util.stripHexPrefix(arg), 16);\n } else {\n return new BN(arg, 10);\n }\n } else if (type === 'number') {\n return new BN(arg);\n } else if (arg.toArray) {\n // assume this is a BN for the moment, replace with BN.isBN soon\n return arg;\n } else {\n throw new Error('Argument is not a number');\n }\n}\n\n// Encodes a single item (can be dynamic array)\n// @returns: Buffer\nfunction encodeSingle(type, arg) {\n var size, num, ret, i;\n if (type === 'address') {\n return encodeSingle('uint160', parseNumber(arg));\n } else if (type === 'bool') {\n return encodeSingle('uint8', arg ? 1 : 0);\n } else if (type === 'string') {\n return encodeSingle('bytes', new Buffer(arg, 'utf8'));\n } else if (isArray(type)) {\n // this part handles fixed-length ([2]) and variable length ([]) arrays\n // NOTE: we catch here all calls to arrays, that simplifies the rest\n if (typeof arg.length === 'undefined') {\n throw new Error('Not an array?');\n }\n size = parseTypeArray(type);\n if (size !== 'dynamic' && size !== 0 && arg.length > size) {\n throw new Error('Elements exceed array size: ' + size);\n }\n ret = [];\n type = type.slice(0, type.lastIndexOf('['));\n if (typeof arg === 'string') {\n arg = JSON.parse(arg);\n }\n for (i in arg) {\n ret.push(encodeSingle(type, arg[i]));\n }\n if (size === 'dynamic') {\n var length = encodeSingle('uint256', arg.length);\n ret.unshift(length);\n }\n return Buffer.concat(ret);\n } else if (type === 'bytes') {\n arg = new Buffer(arg);\n ret = Buffer.concat([encodeSingle('uint256', arg.length), arg]);\n if (arg.length % 32 !== 0) {\n ret = Buffer.concat([ret, util.zeros(32 - arg.length % 32)]);\n }\n return ret;\n } else if (type.startsWith('bytes')) {\n size = parseTypeN(type);\n if (size < 1 || size > 32) {\n throw new Error('Invalid bytes width: ' + size);\n }\n return util.setLengthRight(arg, 32);\n } else if (type.startsWith('uint')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid uint width: ' + size);\n }\n num = parseNumber(arg);\n if (num.bitLength() > size) {\n throw new Error('Supplied uint exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n if (num < 0) {\n throw new Error('Supplied uint is negative');\n }\n return num.toArrayLike(Buffer, 'be', 32);\n } else if (type.startsWith('int')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid int width: ' + size);\n }\n num = parseNumber(arg);\n if (num.bitLength() > size) {\n throw new Error('Supplied int exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n return num.toTwos(256).toArrayLike(Buffer, 'be', 32);\n } else if (type.startsWith('ufixed')) {\n size = parseTypeNxM(type);\n num = parseNumber(arg);\n if (num < 0) {\n throw new Error('Supplied ufixed is negative');\n }\n return encodeSingle('uint256', num.mul(new BN(2).pow(new BN(size[1]))));\n } else if (type.startsWith('fixed')) {\n size = parseTypeNxM(type);\n return encodeSingle('int256', parseNumber(arg).mul(new BN(2).pow(new BN(size[1]))));\n }\n throw new Error('Unsupported or invalid type: ' + type);\n}\n\n// Is a type dynamic?\nfunction isDynamic(type) {\n // FIXME: handle all types? I don't think anything is missing now\n return type === 'string' || type === 'bytes' || parseTypeArray(type) === 'dynamic';\n}\n\n// Is a type an array?\nfunction isArray(type) {\n return type.lastIndexOf(']') === type.length - 1;\n}\n\n// Encode a method/event with arguments\n// @types an array of string type names\n// @args an array of the appropriate values\nfunction rawEncode(types, values) {\n var output = [];\n var data = [];\n var headLength = 32 * types.length;\n for (var i in types) {\n var type = elementaryName(types[i]);\n var value = values[i];\n var cur = encodeSingle(type, value);\n\n // Use the head/tail method for storing dynamic data\n if (isDynamic(type)) {\n output.push(encodeSingle('uint256', headLength));\n data.push(cur);\n headLength += cur.length;\n } else {\n output.push(cur);\n }\n }\n return Buffer.concat(output.concat(data));\n}\nfunction solidityPack(types, values) {\n if (types.length !== values.length) {\n throw new Error('Number of types are not matching the values');\n }\n var size, num;\n var ret = [];\n for (var i = 0; i < types.length; i++) {\n var type = elementaryName(types[i]);\n var value = values[i];\n if (type === 'bytes') {\n ret.push(value);\n } else if (type === 'string') {\n ret.push(new Buffer(value, 'utf8'));\n } else if (type === 'bool') {\n ret.push(new Buffer(value ? '01' : '00', 'hex'));\n } else if (type === 'address') {\n ret.push(util.setLength(value, 20));\n } else if (type.startsWith('bytes')) {\n size = parseTypeN(type);\n if (size < 1 || size > 32) {\n throw new Error('Invalid bytes width: ' + size);\n }\n ret.push(util.setLengthRight(value, size));\n } else if (type.startsWith('uint')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid uint width: ' + size);\n }\n num = parseNumber(value);\n if (num.bitLength() > size) {\n throw new Error('Supplied uint exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n ret.push(num.toArrayLike(Buffer, 'be', size / 8));\n } else if (type.startsWith('int')) {\n size = parseTypeN(type);\n if (size % 8 || size < 8 || size > 256) {\n throw new Error('Invalid int width: ' + size);\n }\n num = parseNumber(value);\n if (num.bitLength() > size) {\n throw new Error('Supplied int exceeds width: ' + size + ' vs ' + num.bitLength());\n }\n ret.push(num.toTwos(size).toArrayLike(Buffer, 'be', size / 8));\n } else {\n // FIXME: support all other types\n throw new Error('Unsupported or invalid type: ' + type);\n }\n }\n return Buffer.concat(ret);\n}\nfunction soliditySHA3(types, values) {\n return util.keccak(solidityPack(types, values));\n}\nmodule.exports = {\n rawEncode,\n solidityPack,\n soliditySHA3\n};","const util = require('./util');\nconst abi = require('./abi');\nconst TYPED_MESSAGE_SCHEMA = {\n type: 'object',\n properties: {\n types: {\n type: 'object',\n additionalProperties: {\n type: 'array',\n items: {\n type: 'object',\n properties: {\n name: {\n type: 'string'\n },\n type: {\n type: 'string'\n }\n },\n required: ['name', 'type']\n }\n }\n },\n primaryType: {\n type: 'string'\n },\n domain: {\n type: 'object'\n },\n message: {\n type: 'object'\n }\n },\n required: ['types', 'primaryType', 'domain', 'message']\n};\n\n/**\n * A collection of utility functions used for signing typed data\n */\nconst TypedDataUtils = {\n /**\n * Encodes an object by encoding and concatenating each of its members\n *\n * @param {string} primaryType - Root type\n * @param {Object} data - Object to encode\n * @param {Object} types - Type definitions\n * @returns {string} - Encoded representation of an object\n */\n encodeData(primaryType, data, types, useV4 = true) {\n const encodedTypes = ['bytes32'];\n const encodedValues = [this.hashType(primaryType, types)];\n if (useV4) {\n const encodeField = (name, type, value) => {\n if (types[type] !== undefined) {\n return ['bytes32', value == null ? '0x0000000000000000000000000000000000000000000000000000000000000000' : util.keccak(this.encodeData(type, value, types, useV4))];\n }\n if (value === undefined) throw new Error(`missing value for field ${name} of type ${type}`);\n if (type === 'bytes') {\n return ['bytes32', util.keccak(value)];\n }\n if (type === 'string') {\n // convert string to buffer - prevents ethUtil from interpreting strings like '0xabcd' as hex\n if (typeof value === 'string') {\n value = Buffer.from(value, 'utf8');\n }\n return ['bytes32', util.keccak(value)];\n }\n if (type.lastIndexOf(']') === type.length - 1) {\n const parsedType = type.slice(0, type.lastIndexOf('['));\n const typeValuePairs = value.map(item => encodeField(name, parsedType, item));\n return ['bytes32', util.keccak(abi.rawEncode(typeValuePairs.map(([type]) => type), typeValuePairs.map(([, value]) => value)))];\n }\n return [type, value];\n };\n for (const field of types[primaryType]) {\n const [type, value] = encodeField(field.name, field.type, data[field.name]);\n encodedTypes.push(type);\n encodedValues.push(value);\n }\n } else {\n for (const field of types[primaryType]) {\n let value = data[field.name];\n if (value !== undefined) {\n if (field.type === 'bytes') {\n encodedTypes.push('bytes32');\n value = util.keccak(value);\n encodedValues.push(value);\n } else if (field.type === 'string') {\n encodedTypes.push('bytes32');\n // convert string to buffer - prevents ethUtil from interpreting strings like '0xabcd' as hex\n if (typeof value === 'string') {\n value = Buffer.from(value, 'utf8');\n }\n value = util.keccak(value);\n encodedValues.push(value);\n } else if (types[field.type] !== undefined) {\n encodedTypes.push('bytes32');\n value = util.keccak(this.encodeData(field.type, value, types, useV4));\n encodedValues.push(value);\n } else if (field.type.lastIndexOf(']') === field.type.length - 1) {\n throw new Error('Arrays currently unimplemented in encodeData');\n } else {\n encodedTypes.push(field.type);\n encodedValues.push(value);\n }\n }\n }\n }\n return abi.rawEncode(encodedTypes, encodedValues);\n },\n /**\n * Encodes the type of an object by encoding a comma delimited list of its members\n *\n * @param {string} primaryType - Root type to encode\n * @param {Object} types - Type definitions\n * @returns {string} - Encoded representation of the type of an object\n */\n encodeType(primaryType, types) {\n let result = '';\n let deps = this.findTypeDependencies(primaryType, types).filter(dep => dep !== primaryType);\n deps = [primaryType].concat(deps.sort());\n for (const type of deps) {\n const children = types[type];\n if (!children) {\n throw new Error('No type definition specified: ' + type);\n }\n result += type + '(' + types[type].map(({\n name,\n type\n }) => type + ' ' + name).join(',') + ')';\n }\n return result;\n },\n /**\n * Finds all types within a type defintion object\n *\n * @param {string} primaryType - Root type\n * @param {Object} types - Type definitions\n * @param {Array} results - current set of accumulated types\n * @returns {Array} - Set of all types found in the type definition\n */\n findTypeDependencies(primaryType, types, results = []) {\n primaryType = primaryType.match(/^\\w*/)[0];\n if (results.includes(primaryType) || types[primaryType] === undefined) {\n return results;\n }\n results.push(primaryType);\n for (const field of types[primaryType]) {\n for (const dep of this.findTypeDependencies(field.type, types, results)) {\n !results.includes(dep) && results.push(dep);\n }\n }\n return results;\n },\n /**\n * Hashes an object\n *\n * @param {string} primaryType - Root type\n * @param {Object} data - Object to hash\n * @param {Object} types - Type definitions\n * @returns {Buffer} - Hash of an object\n */\n hashStruct(primaryType, data, types, useV4 = true) {\n return util.keccak(this.encodeData(primaryType, data, types, useV4));\n },\n /**\n * Hashes the type of an object\n *\n * @param {string} primaryType - Root type to hash\n * @param {Object} types - Type definitions\n * @returns {string} - Hash of an object\n */\n hashType(primaryType, types) {\n return util.keccak(this.encodeType(primaryType, types));\n },\n /**\n * Removes properties from a message object that are not defined per EIP-712\n *\n * @param {Object} data - typed message object\n * @returns {Object} - typed message object with only allowed fields\n */\n sanitizeData(data) {\n const sanitizedData = {};\n for (const key in TYPED_MESSAGE_SCHEMA.properties) {\n data[key] && (sanitizedData[key] = data[key]);\n }\n if (sanitizedData.types) {\n sanitizedData.types = Object.assign({\n EIP712Domain: []\n }, sanitizedData.types);\n }\n return sanitizedData;\n },\n /**\n * Returns the hash of a typed message as per EIP-712 for signing\n *\n * @param {Object} typedData - Types message data to sign\n * @returns {string} - sha3 hash for signing\n */\n hash(typedData, useV4 = true) {\n const sanitizedData = this.sanitizeData(typedData);\n const parts = [Buffer.from('1901', 'hex')];\n parts.push(this.hashStruct('EIP712Domain', sanitizedData.domain, sanitizedData.types, useV4));\n if (sanitizedData.primaryType !== 'EIP712Domain') {\n parts.push(this.hashStruct(sanitizedData.primaryType, sanitizedData.message, sanitizedData.types, useV4));\n }\n return util.keccak(Buffer.concat(parts));\n }\n};\nmodule.exports = {\n TYPED_MESSAGE_SCHEMA,\n TypedDataUtils,\n hashForSignTypedDataLegacy: function (msgParams) {\n return typedSignatureHashLegacy(msgParams.data);\n },\n hashForSignTypedData_v3: function (msgParams) {\n return TypedDataUtils.hash(msgParams.data, false);\n },\n hashForSignTypedData_v4: function (msgParams) {\n return TypedDataUtils.hash(msgParams.data);\n }\n};\n\n/**\n * @param typedData - Array of data along with types, as per EIP712.\n * @returns Buffer\n */\nfunction typedSignatureHashLegacy(typedData) {\n const error = new Error('Expect argument to be non-empty array');\n if (typeof typedData !== 'object' || !typedData.length) throw error;\n const data = typedData.map(function (e) {\n return e.type === 'bytes' ? util.toBuffer(e.value) : e.value;\n });\n const types = typedData.map(function (e) {\n return e.type;\n });\n const schema = typedData.map(function (e) {\n if (!e.name) throw error;\n return e.type + ' ' + e.name;\n });\n return abi.soliditySHA3(['bytes32', 'bytes32'], [abi.soliditySHA3(new Array(typedData.length).fill('string'), schema), abi.soliditySHA3(types, data)]);\n}","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.filterFromParam = exports.FilterPolyfill = void 0;\nconst types_1 = require(\"../types\");\nconst util_1 = require(\"../util\");\nconst TIMEOUT = 5 * 60 * 1000; // 5 minutes\nconst JSONRPC_TEMPLATE = {\n jsonrpc: \"2.0\",\n id: 0\n};\nclass FilterPolyfill {\n constructor(provider) {\n this.logFilters = new Map(); // \n this.blockFilters = new Set(); // \n this.pendingTransactionFilters = new Set(); // \n this.cursors = new Map(); // \n this.timeouts = new Map(); // \n this.nextFilterId = (0, types_1.IntNumber)(1);\n this.provider = provider;\n }\n async newFilter(param) {\n const filter = filterFromParam(param);\n const id = this.makeFilterId();\n const cursor = await this.setInitialCursorPosition(id, filter.fromBlock);\n console.log(`Installing new log filter(${id}):`, filter, \"initial cursor position:\", cursor);\n this.logFilters.set(id, filter);\n this.setFilterTimeout(id);\n return (0, util_1.hexStringFromIntNumber)(id);\n }\n async newBlockFilter() {\n const id = this.makeFilterId();\n const cursor = await this.setInitialCursorPosition(id, \"latest\");\n console.log(`Installing new block filter (${id}) with initial cursor position:`, cursor);\n this.blockFilters.add(id);\n this.setFilterTimeout(id);\n return (0, util_1.hexStringFromIntNumber)(id);\n }\n async newPendingTransactionFilter() {\n const id = this.makeFilterId();\n const cursor = await this.setInitialCursorPosition(id, \"latest\");\n console.log(`Installing new block filter (${id}) with initial cursor position:`, cursor);\n this.pendingTransactionFilters.add(id);\n this.setFilterTimeout(id);\n return (0, util_1.hexStringFromIntNumber)(id);\n }\n uninstallFilter(filterId) {\n const id = (0, util_1.intNumberFromHexString)(filterId);\n console.log(`Uninstalling filter (${id})`);\n this.deleteFilter(id);\n return true;\n }\n getFilterChanges(filterId) {\n const id = (0, util_1.intNumberFromHexString)(filterId);\n if (this.timeouts.has(id)) {\n // extend timeout\n this.setFilterTimeout(id);\n }\n if (this.logFilters.has(id)) {\n return this.getLogFilterChanges(id);\n } else if (this.blockFilters.has(id)) {\n return this.getBlockFilterChanges(id);\n } else if (this.pendingTransactionFilters.has(id)) {\n return this.getPendingTransactionFilterChanges(id);\n }\n return Promise.resolve(filterNotFoundError());\n }\n async getFilterLogs(filterId) {\n const id = (0, util_1.intNumberFromHexString)(filterId);\n const filter = this.logFilters.get(id);\n if (!filter) {\n return filterNotFoundError();\n }\n return this.sendAsyncPromise(Object.assign(Object.assign({}, JSONRPC_TEMPLATE), {\n method: \"eth_getLogs\",\n params: [paramFromFilter(filter)]\n }));\n }\n makeFilterId() {\n return (0, types_1.IntNumber)(++this.nextFilterId);\n }\n sendAsyncPromise(request) {\n return new Promise((resolve, reject) => {\n this.provider.sendAsync(request, (err, response) => {\n if (err) {\n return reject(err);\n }\n if (Array.isArray(response) || response == null) {\n return reject(new Error(`unexpected response received: ${JSON.stringify(response)}`));\n }\n resolve(response);\n });\n });\n }\n deleteFilter(id) {\n console.log(`Deleting filter (${id})`);\n this.logFilters.delete(id);\n this.blockFilters.delete(id);\n this.pendingTransactionFilters.delete(id);\n this.cursors.delete(id);\n this.timeouts.delete(id);\n }\n async getLogFilterChanges(id) {\n const filter = this.logFilters.get(id);\n const cursorPosition = this.cursors.get(id);\n if (!cursorPosition || !filter) {\n return filterNotFoundError();\n }\n const currentBlockHeight = await this.getCurrentBlockHeight();\n const toBlock = filter.toBlock === \"latest\" ? currentBlockHeight : filter.toBlock;\n if (cursorPosition > currentBlockHeight) {\n return emptyResult();\n }\n if (cursorPosition > filter.toBlock) {\n return emptyResult();\n }\n console.log(`Fetching logs from ${cursorPosition} to ${toBlock} for filter ${id}`);\n const response = await this.sendAsyncPromise(Object.assign(Object.assign({}, JSONRPC_TEMPLATE), {\n method: \"eth_getLogs\",\n params: [paramFromFilter(Object.assign(Object.assign({}, filter), {\n fromBlock: cursorPosition,\n toBlock\n }))]\n }));\n if (Array.isArray(response.result)) {\n const blocks = response.result.map(log => (0, util_1.intNumberFromHexString)(log.blockNumber || \"0x0\"));\n const highestBlock = Math.max(...blocks);\n if (highestBlock && highestBlock > cursorPosition) {\n const newCursorPosition = (0, types_1.IntNumber)(highestBlock + 1);\n console.log(`Moving cursor position for filter (${id}) from ${cursorPosition} to ${newCursorPosition}`);\n this.cursors.set(id, newCursorPosition);\n }\n }\n return response;\n }\n async getBlockFilterChanges(id) {\n const cursorPosition = this.cursors.get(id);\n if (!cursorPosition) {\n return filterNotFoundError();\n }\n const currentBlockHeight = await this.getCurrentBlockHeight();\n if (cursorPosition > currentBlockHeight) {\n return emptyResult();\n }\n console.log(`Fetching blocks from ${cursorPosition} to ${currentBlockHeight} for filter (${id})`);\n const blocks = (await Promise.all(\n // eslint-disable-next-line @typescript-eslint/restrict-plus-operands\n (0, util_1.range)(cursorPosition, currentBlockHeight + 1).map(i => this.getBlockHashByNumber((0, types_1.IntNumber)(i))))).filter(hash => !!hash);\n // eslint-disable-next-line @typescript-eslint/restrict-plus-operands\n const newCursorPosition = (0, types_1.IntNumber)(cursorPosition + blocks.length);\n console.log(`Moving cursor position for filter (${id}) from ${cursorPosition} to ${newCursorPosition}`);\n this.cursors.set(id, newCursorPosition);\n return Object.assign(Object.assign({}, JSONRPC_TEMPLATE), {\n result: blocks\n });\n }\n async getPendingTransactionFilterChanges(_id) {\n // pending transaction filters are not supported\n return Promise.resolve(emptyResult());\n }\n async setInitialCursorPosition(id, startBlock) {\n const currentBlockHeight = await this.getCurrentBlockHeight();\n const initialCursorPosition = typeof startBlock === \"number\" && startBlock > currentBlockHeight ? startBlock : currentBlockHeight;\n this.cursors.set(id, initialCursorPosition);\n return initialCursorPosition;\n }\n setFilterTimeout(id) {\n const existing = this.timeouts.get(id);\n if (existing) {\n window.clearTimeout(existing);\n }\n const timeout = window.setTimeout(() => {\n console.log(`Filter (${id}) timed out`);\n this.deleteFilter(id);\n }, TIMEOUT);\n this.timeouts.set(id, timeout);\n }\n async getCurrentBlockHeight() {\n const {\n result\n } = await this.sendAsyncPromise(Object.assign(Object.assign({}, JSONRPC_TEMPLATE), {\n method: \"eth_blockNumber\",\n params: []\n }));\n return (0, util_1.intNumberFromHexString)((0, util_1.ensureHexString)(result));\n }\n async getBlockHashByNumber(blockNumber) {\n const response = await this.sendAsyncPromise(Object.assign(Object.assign({}, JSONRPC_TEMPLATE), {\n method: \"eth_getBlockByNumber\",\n params: [(0, util_1.hexStringFromIntNumber)(blockNumber), false]\n }));\n if (response.result && typeof response.result.hash === \"string\") {\n return (0, util_1.ensureHexString)(response.result.hash);\n }\n return null;\n }\n}\nexports.FilterPolyfill = FilterPolyfill;\nfunction filterFromParam(param) {\n return {\n fromBlock: intBlockHeightFromHexBlockHeight(param.fromBlock),\n toBlock: intBlockHeightFromHexBlockHeight(param.toBlock),\n addresses: param.address === undefined ? null : Array.isArray(param.address) ? param.address : [param.address],\n topics: param.topics || []\n };\n}\nexports.filterFromParam = filterFromParam;\nfunction paramFromFilter(filter) {\n const param = {\n fromBlock: hexBlockHeightFromIntBlockHeight(filter.fromBlock),\n toBlock: hexBlockHeightFromIntBlockHeight(filter.toBlock),\n topics: filter.topics\n };\n if (filter.addresses !== null) {\n param.address = filter.addresses;\n }\n return param;\n}\nfunction intBlockHeightFromHexBlockHeight(value) {\n if (value === undefined || value === \"latest\" || value === \"pending\") {\n return \"latest\";\n } else if (value === \"earliest\") {\n return (0, types_1.IntNumber)(0);\n } else if ((0, util_1.isHexString)(value)) {\n return (0, util_1.intNumberFromHexString)(value);\n }\n throw new Error(`Invalid block option: ${String(value)}`);\n}\nfunction hexBlockHeightFromIntBlockHeight(value) {\n if (value === \"latest\") {\n return value;\n }\n return (0, util_1.hexStringFromIntNumber)(value);\n}\nfunction filterNotFoundError() {\n return Object.assign(Object.assign({}, JSONRPC_TEMPLATE), {\n error: {\n code: -32000,\n message: \"filter not found\"\n }\n });\n}\nfunction emptyResult() {\n return Object.assign(Object.assign({}, JSONRPC_TEMPLATE), {\n result: []\n });\n}","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.JSONRPCMethod = void 0;\nvar JSONRPCMethod;\n(function (JSONRPCMethod) {\n // synchronous or asynchronous\n JSONRPCMethod[\"eth_accounts\"] = \"eth_accounts\";\n JSONRPCMethod[\"eth_coinbase\"] = \"eth_coinbase\";\n JSONRPCMethod[\"net_version\"] = \"net_version\";\n JSONRPCMethod[\"eth_chainId\"] = \"eth_chainId\";\n JSONRPCMethod[\"eth_uninstallFilter\"] = \"eth_uninstallFilter\";\n // asynchronous only\n JSONRPCMethod[\"eth_requestAccounts\"] = \"eth_requestAccounts\";\n JSONRPCMethod[\"eth_sign\"] = \"eth_sign\";\n JSONRPCMethod[\"eth_ecRecover\"] = \"eth_ecRecover\";\n JSONRPCMethod[\"personal_sign\"] = \"personal_sign\";\n JSONRPCMethod[\"personal_ecRecover\"] = \"personal_ecRecover\";\n JSONRPCMethod[\"eth_signTransaction\"] = \"eth_signTransaction\";\n JSONRPCMethod[\"eth_sendRawTransaction\"] = \"eth_sendRawTransaction\";\n JSONRPCMethod[\"eth_sendTransaction\"] = \"eth_sendTransaction\";\n JSONRPCMethod[\"eth_signTypedData_v1\"] = \"eth_signTypedData_v1\";\n JSONRPCMethod[\"eth_signTypedData_v2\"] = \"eth_signTypedData_v2\";\n JSONRPCMethod[\"eth_signTypedData_v3\"] = \"eth_signTypedData_v3\";\n JSONRPCMethod[\"eth_signTypedData_v4\"] = \"eth_signTypedData_v4\";\n JSONRPCMethod[\"eth_signTypedData\"] = \"eth_signTypedData\";\n JSONRPCMethod[\"cbWallet_arbitrary\"] = \"walletlink_arbitrary\";\n JSONRPCMethod[\"wallet_addEthereumChain\"] = \"wallet_addEthereumChain\";\n JSONRPCMethod[\"wallet_switchEthereumChain\"] = \"wallet_switchEthereumChain\";\n JSONRPCMethod[\"wallet_watchAsset\"] = \"wallet_watchAsset\";\n // asynchronous pub/sub\n JSONRPCMethod[\"eth_subscribe\"] = \"eth_subscribe\";\n JSONRPCMethod[\"eth_unsubscribe\"] = \"eth_unsubscribe\";\n // asynchronous filter methods\n JSONRPCMethod[\"eth_newFilter\"] = \"eth_newFilter\";\n JSONRPCMethod[\"eth_newBlockFilter\"] = \"eth_newBlockFilter\";\n JSONRPCMethod[\"eth_newPendingTransactionFilter\"] = \"eth_newPendingTransactionFilter\";\n JSONRPCMethod[\"eth_getFilterChanges\"] = \"eth_getFilterChanges\";\n JSONRPCMethod[\"eth_getFilterLogs\"] = \"eth_getFilterLogs\";\n})(JSONRPCMethod = exports.JSONRPCMethod || (exports.JSONRPCMethod = {}));","module.exports = IdIterator;\nfunction IdIterator(opts) {\n opts = opts || {};\n var max = opts.max || Number.MAX_SAFE_INTEGER;\n var idCounter = typeof opts.start !== 'undefined' ? opts.start : Math.floor(Math.random() * max);\n return function createRandomId() {\n idCounter = idCounter % max;\n return idCounter++;\n };\n}","'use strict';\n\nconst processFn = (fn, opts) => function () {\n const P = opts.promiseModule;\n const args = new Array(arguments.length);\n for (let i = 0; i < arguments.length; i++) {\n args[i] = arguments[i];\n }\n return new P((resolve, reject) => {\n if (opts.errorFirst) {\n args.push(function (err, result) {\n if (opts.multiArgs) {\n const results = new Array(arguments.length - 1);\n for (let i = 1; i < arguments.length; i++) {\n results[i - 1] = arguments[i];\n }\n if (err) {\n results.unshift(err);\n reject(results);\n } else {\n resolve(results);\n }\n } else if (err) {\n reject(err);\n } else {\n resolve(result);\n }\n });\n } else {\n args.push(function (result) {\n if (opts.multiArgs) {\n const results = new Array(arguments.length - 1);\n for (let i = 0; i < arguments.length; i++) {\n results[i] = arguments[i];\n }\n resolve(results);\n } else {\n resolve(result);\n }\n });\n }\n fn.apply(this, args);\n });\n};\nmodule.exports = (obj, opts) => {\n opts = Object.assign({\n exclude: [/.+(Sync|Stream)$/],\n errorFirst: true,\n promiseModule: Promise\n }, opts);\n const filter = key => {\n const match = pattern => typeof pattern === 'string' ? key === pattern : pattern.test(key);\n return opts.include ? opts.include.some(match) : !opts.exclude.some(match);\n };\n let ret;\n if (typeof obj === 'function') {\n ret = function () {\n if (opts.excludeMain) {\n return obj.apply(this, arguments);\n }\n return processFn(obj, opts).apply(this, arguments);\n };\n } else {\n ret = Object.create(Object.getPrototypeOf(obj));\n }\n for (const key in obj) {\n // eslint-disable-line guard-for-in\n const x = obj[key];\n ret[key] = typeof x === 'function' && filter(key) ? processFn(x, opts) : x;\n }\n return ret;\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst events_1 = require(\"events\");\nfunction safeApply(handler, context, args) {\n try {\n Reflect.apply(handler, context, args);\n } catch (err) {\n // Throw error after timeout so as not to interrupt the stack\n setTimeout(() => {\n throw err;\n });\n }\n}\nfunction arrayClone(arr) {\n const n = arr.length;\n const copy = new Array(n);\n for (let i = 0; i < n; i += 1) {\n copy[i] = arr[i];\n }\n return copy;\n}\nclass SafeEventEmitter extends events_1.EventEmitter {\n emit(type, ...args) {\n let doError = type === 'error';\n const events = this._events;\n if (events !== undefined) {\n doError = doError && events.error === undefined;\n } else if (!doError) {\n return false;\n }\n // If there is no 'error' event listener then throw.\n if (doError) {\n let er;\n if (args.length > 0) {\n [er] = args;\n }\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n const err = new Error(`Unhandled error.${er ? ` (${er.message})` : ''}`);\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n const handler = events[type];\n if (handler === undefined) {\n return false;\n }\n if (typeof handler === 'function') {\n safeApply(handler, this, args);\n } else {\n const len = handler.length;\n const listeners = arrayClone(handler);\n for (let i = 0; i < len; i += 1) {\n safeApply(listeners[i], this, args);\n }\n }\n return true;\n }\n}\nexports.default = SafeEventEmitter;\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.BaseBlockTracker = void 0;\nconst safe_event_emitter_1 = __importDefault(require(\"@metamask/safe-event-emitter\"));\nconst sec = 1000;\nconst calculateSum = (accumulator, currentValue) => accumulator + currentValue;\nconst blockTrackerEvents = ['sync', 'latest'];\nclass BaseBlockTracker extends safe_event_emitter_1.default {\n constructor(opts) {\n super();\n // config\n this._blockResetDuration = opts.blockResetDuration || 20 * sec;\n // state\n this._currentBlock = null;\n this._isRunning = false;\n // bind functions for internal use\n this._onNewListener = this._onNewListener.bind(this);\n this._onRemoveListener = this._onRemoveListener.bind(this);\n this._resetCurrentBlock = this._resetCurrentBlock.bind(this);\n // listen for handler changes\n this._setupInternalEvents();\n }\n async destroy() {\n this._cancelBlockResetTimeout();\n await this._maybeEnd();\n super.removeAllListeners();\n }\n isRunning() {\n return this._isRunning;\n }\n getCurrentBlock() {\n return this._currentBlock;\n }\n async getLatestBlock() {\n // return if available\n if (this._currentBlock) {\n return this._currentBlock;\n }\n // wait for a new latest block\n const latestBlock = await new Promise(resolve => this.once('latest', resolve));\n // return newly set current block\n return latestBlock;\n }\n // dont allow module consumer to remove our internal event listeners\n removeAllListeners(eventName) {\n // perform default behavior, preserve fn arity\n if (eventName) {\n super.removeAllListeners(eventName);\n } else {\n super.removeAllListeners();\n }\n // re-add internal events\n this._setupInternalEvents();\n // trigger stop check just in case\n this._onRemoveListener();\n return this;\n }\n _setupInternalEvents() {\n // first remove listeners for idempotence\n this.removeListener('newListener', this._onNewListener);\n this.removeListener('removeListener', this._onRemoveListener);\n // then add them\n this.on('newListener', this._onNewListener);\n this.on('removeListener', this._onRemoveListener);\n }\n _onNewListener(eventName) {\n // `newListener` is called *before* the listener is added\n if (blockTrackerEvents.includes(eventName)) {\n this._maybeStart();\n }\n }\n _onRemoveListener() {\n // `removeListener` is called *after* the listener is removed\n if (this._getBlockTrackerEventCount() > 0) {\n return;\n }\n this._maybeEnd();\n }\n async _maybeStart() {\n if (this._isRunning) {\n return;\n }\n this._isRunning = true;\n // cancel setting latest block to stale\n this._cancelBlockResetTimeout();\n await this._start();\n this.emit('_started');\n }\n async _maybeEnd() {\n if (!this._isRunning) {\n return;\n }\n this._isRunning = false;\n this._setupBlockResetTimeout();\n await this._end();\n this.emit('_ended');\n }\n _getBlockTrackerEventCount() {\n return blockTrackerEvents.map(eventName => this.listenerCount(eventName)).reduce(calculateSum);\n }\n _newPotentialLatest(newBlock) {\n const currentBlock = this._currentBlock;\n // only update if blok number is higher\n if (currentBlock && hexToInt(newBlock) <= hexToInt(currentBlock)) {\n return;\n }\n this._setCurrentBlock(newBlock);\n }\n _setCurrentBlock(newBlock) {\n const oldBlock = this._currentBlock;\n this._currentBlock = newBlock;\n this.emit('latest', newBlock);\n this.emit('sync', {\n oldBlock,\n newBlock\n });\n }\n _setupBlockResetTimeout() {\n // clear any existing timeout\n this._cancelBlockResetTimeout();\n // clear latest block when stale\n this._blockResetTimeout = setTimeout(this._resetCurrentBlock, this._blockResetDuration);\n // nodejs - dont hold process open\n if (this._blockResetTimeout.unref) {\n this._blockResetTimeout.unref();\n }\n }\n _cancelBlockResetTimeout() {\n if (this._blockResetTimeout) {\n clearTimeout(this._blockResetTimeout);\n }\n }\n _resetCurrentBlock() {\n this._currentBlock = null;\n }\n}\nexports.BaseBlockTracker = BaseBlockTracker;\n/**\n * Converts a number represented as a string in hexadecimal format into a native\n * number.\n *\n * @param hexInt - The hex string.\n * @returns The number.\n */\nfunction hexToInt(hexInt) {\n return Number.parseInt(hexInt, 16);\n}\n","/**\n * A `StructFailure` represents a single specific failure in validation.\n */\n/**\n * `StructError` objects are thrown (or returned) when validation fails.\n *\n * Validation logic is design to exit early for maximum performance. The error\n * represents the first error encountered during validation. For more detail,\n * the `error.failures` property is a generator function that can be run to\n * continue validation and receive all the failures in the data.\n */\nclass StructError extends TypeError {\n constructor(failure, failures) {\n let cached;\n const {\n message,\n explanation,\n ...rest\n } = failure;\n const {\n path\n } = failure;\n const msg = path.length === 0 ? message : `At path: ${path.join('.')} -- ${message}`;\n super(explanation ?? msg);\n if (explanation != null) this.cause = msg;\n Object.assign(this, rest);\n this.name = this.constructor.name;\n this.failures = () => {\n return cached ?? (cached = [failure, ...failures()]);\n };\n }\n}\n\n/**\n * Check if a value is an iterator.\n */\nfunction isIterable(x) {\n return isObject(x) && typeof x[Symbol.iterator] === 'function';\n}\n/**\n * Check if a value is a plain object.\n */\nfunction isObject(x) {\n return typeof x === 'object' && x != null;\n}\n/**\n * Check if a value is a plain object.\n */\nfunction isPlainObject(x) {\n if (Object.prototype.toString.call(x) !== '[object Object]') {\n return false;\n }\n const prototype = Object.getPrototypeOf(x);\n return prototype === null || prototype === Object.prototype;\n}\n/**\n * Return a value as a printable string.\n */\nfunction print(value) {\n if (typeof value === 'symbol') {\n return value.toString();\n }\n return typeof value === 'string' ? JSON.stringify(value) : `${value}`;\n}\n/**\n * Shifts (removes and returns) the first value from the `input` iterator.\n * Like `Array.prototype.shift()` but for an `Iterator`.\n */\nfunction shiftIterator(input) {\n const {\n done,\n value\n } = input.next();\n return done ? undefined : value;\n}\n/**\n * Convert a single validation result to a failure.\n */\nfunction toFailure(result, context, struct, value) {\n if (result === true) {\n return;\n } else if (result === false) {\n result = {};\n } else if (typeof result === 'string') {\n result = {\n message: result\n };\n }\n const {\n path,\n branch\n } = context;\n const {\n type\n } = struct;\n const {\n refinement,\n message = `Expected a value of type \\`${type}\\`${refinement ? ` with refinement \\`${refinement}\\`` : ''}, but received: \\`${print(value)}\\``\n } = result;\n return {\n value,\n type,\n refinement,\n key: path[path.length - 1],\n path,\n branch,\n ...result,\n message\n };\n}\n/**\n * Convert a validation result to an iterable of failures.\n */\nfunction* toFailures(result, context, struct, value) {\n if (!isIterable(result)) {\n result = [result];\n }\n for (const r of result) {\n const failure = toFailure(r, context, struct, value);\n if (failure) {\n yield failure;\n }\n }\n}\n/**\n * Check a value against a struct, traversing deeply into nested values, and\n * returning an iterator of failures or success.\n */\nfunction* run(value, struct, options = {}) {\n const {\n path = [],\n branch = [value],\n coerce = false,\n mask = false\n } = options;\n const ctx = {\n path,\n branch\n };\n if (coerce) {\n value = struct.coercer(value, ctx);\n if (mask && struct.type !== 'type' && isObject(struct.schema) && isObject(value) && !Array.isArray(value)) {\n for (const key in value) {\n if (struct.schema[key] === undefined) {\n delete value[key];\n }\n }\n }\n }\n let status = 'valid';\n for (const failure of struct.validator(value, ctx)) {\n failure.explanation = options.message;\n status = 'not_valid';\n yield [failure, undefined];\n }\n for (let [k, v, s] of struct.entries(value, ctx)) {\n const ts = run(v, s, {\n path: k === undefined ? path : [...path, k],\n branch: k === undefined ? branch : [...branch, v],\n coerce,\n mask,\n message: options.message\n });\n for (const t of ts) {\n if (t[0]) {\n status = t[0].refinement != null ? 'not_refined' : 'not_valid';\n yield [t[0], undefined];\n } else if (coerce) {\n v = t[1];\n if (k === undefined) {\n value = v;\n } else if (value instanceof Map) {\n value.set(k, v);\n } else if (value instanceof Set) {\n value.add(v);\n } else if (isObject(value)) {\n if (v !== undefined || k in value) value[k] = v;\n }\n }\n }\n }\n if (status !== 'not_valid') {\n for (const failure of struct.refiner(value, ctx)) {\n failure.explanation = options.message;\n status = 'not_refined';\n yield [failure, undefined];\n }\n }\n if (status === 'valid') {\n yield [undefined, value];\n }\n}\n\n/**\n * `Struct` objects encapsulate the validation logic for a specific type of\n * values. Once constructed, you use the `assert`, `is` or `validate` helpers to\n * validate unknown input data against the struct.\n */\nclass Struct {\n constructor(props) {\n const {\n type,\n schema,\n validator,\n refiner,\n coercer = value => value,\n entries = function* () {}\n } = props;\n this.type = type;\n this.schema = schema;\n this.entries = entries;\n this.coercer = coercer;\n if (validator) {\n this.validator = (value, context) => {\n const result = validator(value, context);\n return toFailures(result, context, this, value);\n };\n } else {\n this.validator = () => [];\n }\n if (refiner) {\n this.refiner = (value, context) => {\n const result = refiner(value, context);\n return toFailures(result, context, this, value);\n };\n } else {\n this.refiner = () => [];\n }\n }\n /**\n * Assert that a value passes the struct's validation, throwing if it doesn't.\n */\n assert(value, message) {\n return assert(value, this, message);\n }\n /**\n * Create a value with the struct's coercion logic, then validate it.\n */\n create(value, message) {\n return create(value, this, message);\n }\n /**\n * Check if a value passes the struct's validation.\n */\n is(value) {\n return is(value, this);\n }\n /**\n * Mask a value, coercing and validating it, but returning only the subset of\n * properties defined by the struct's schema.\n */\n mask(value, message) {\n return mask(value, this, message);\n }\n /**\n * Validate a value with the struct's validation logic, returning a tuple\n * representing the result.\n *\n * You may optionally pass `true` for the `withCoercion` argument to coerce\n * the value before attempting to validate it. If you do, the result will\n * contain the coerced result when successful.\n */\n validate(value, options = {}) {\n return validate(value, this, options);\n }\n}\n/**\n * Assert that a value passes a struct, throwing if it doesn't.\n */\nfunction assert(value, struct, message) {\n const result = validate(value, struct, {\n message\n });\n if (result[0]) {\n throw result[0];\n }\n}\n/**\n * Create a value with the coercion logic of struct and validate it.\n */\nfunction create(value, struct, message) {\n const result = validate(value, struct, {\n coerce: true,\n message\n });\n if (result[0]) {\n throw result[0];\n } else {\n return result[1];\n }\n}\n/**\n * Mask a value, returning only the subset of properties defined by a struct.\n */\nfunction mask(value, struct, message) {\n const result = validate(value, struct, {\n coerce: true,\n mask: true,\n message\n });\n if (result[0]) {\n throw result[0];\n } else {\n return result[1];\n }\n}\n/**\n * Check if a value passes a struct.\n */\nfunction is(value, struct) {\n const result = validate(value, struct);\n return !result[0];\n}\n/**\n * Validate a value against a struct, returning an error if invalid, or the\n * value (with potential coercion) if valid.\n */\nfunction validate(value, struct, options = {}) {\n const tuples = run(value, struct, options);\n const tuple = shiftIterator(tuples);\n if (tuple[0]) {\n const error = new StructError(tuple[0], function* () {\n for (const t of tuples) {\n if (t[0]) {\n yield t[0];\n }\n }\n });\n return [error, undefined];\n } else {\n const v = tuple[1];\n return [undefined, v];\n }\n}\nfunction assign(...Structs) {\n const isType = Structs[0].type === 'type';\n const schemas = Structs.map(s => s.schema);\n const schema = Object.assign({}, ...schemas);\n return isType ? type(schema) : object(schema);\n}\n/**\n * Define a new struct type with a custom validation function.\n */\nfunction define(name, validator) {\n return new Struct({\n type: name,\n schema: null,\n validator\n });\n}\n/**\n * Create a new struct based on an existing struct, but the value is allowed to\n * be `undefined`. `log` will be called if the value is not `undefined`.\n */\nfunction deprecated(struct, log) {\n return new Struct({\n ...struct,\n refiner: (value, ctx) => value === undefined || struct.refiner(value, ctx),\n validator(value, ctx) {\n if (value === undefined) {\n return true;\n } else {\n log(value, ctx);\n return struct.validator(value, ctx);\n }\n }\n });\n}\n/**\n * Create a struct with dynamic validation logic.\n *\n * The callback will receive the value currently being validated, and must\n * return a struct object to validate it with. This can be useful to model\n * validation logic that changes based on its input.\n */\nfunction dynamic(fn) {\n return new Struct({\n type: 'dynamic',\n schema: null,\n *entries(value, ctx) {\n const struct = fn(value, ctx);\n yield* struct.entries(value, ctx);\n },\n validator(value, ctx) {\n const struct = fn(value, ctx);\n return struct.validator(value, ctx);\n },\n coercer(value, ctx) {\n const struct = fn(value, ctx);\n return struct.coercer(value, ctx);\n },\n refiner(value, ctx) {\n const struct = fn(value, ctx);\n return struct.refiner(value, ctx);\n }\n });\n}\n/**\n * Create a struct with lazily evaluated validation logic.\n *\n * The first time validation is run with the struct, the callback will be called\n * and must return a struct object to use. This is useful for cases where you\n * want to have self-referential structs for nested data structures to avoid a\n * circular definition problem.\n */\nfunction lazy(fn) {\n let struct;\n return new Struct({\n type: 'lazy',\n schema: null,\n *entries(value, ctx) {\n struct ?? (struct = fn());\n yield* struct.entries(value, ctx);\n },\n validator(value, ctx) {\n struct ?? (struct = fn());\n return struct.validator(value, ctx);\n },\n coercer(value, ctx) {\n struct ?? (struct = fn());\n return struct.coercer(value, ctx);\n },\n refiner(value, ctx) {\n struct ?? (struct = fn());\n return struct.refiner(value, ctx);\n }\n });\n}\n/**\n * Create a new struct based on an existing object struct, but excluding\n * specific properties.\n *\n * Like TypeScript's `Omit` utility.\n */\nfunction omit(struct, keys) {\n const {\n schema\n } = struct;\n const subschema = {\n ...schema\n };\n for (const key of keys) {\n delete subschema[key];\n }\n switch (struct.type) {\n case 'type':\n return type(subschema);\n default:\n return object(subschema);\n }\n}\n/**\n * Create a new struct based on an existing object struct, but with all of its\n * properties allowed to be `undefined`.\n *\n * Like TypeScript's `Partial` utility.\n */\nfunction partial(struct) {\n const isStruct = struct instanceof Struct;\n const schema = isStruct ? {\n ...struct.schema\n } : {\n ...struct\n };\n for (const key in schema) {\n schema[key] = optional(schema[key]);\n }\n if (isStruct && struct.type === 'type') {\n return type(schema);\n }\n return object(schema);\n}\n/**\n * Create a new struct based on an existing object struct, but only including\n * specific properties.\n *\n * Like TypeScript's `Pick` utility.\n */\nfunction pick(struct, keys) {\n const {\n schema\n } = struct;\n const subschema = {};\n for (const key of keys) {\n subschema[key] = schema[key];\n }\n switch (struct.type) {\n case 'type':\n return type(subschema);\n default:\n return object(subschema);\n }\n}\n/**\n * Define a new struct type with a custom validation function.\n *\n * @deprecated This function has been renamed to `define`.\n */\nfunction struct(name, validator) {\n console.warn('superstruct@0.11 - The `struct` helper has been renamed to `define`.');\n return define(name, validator);\n}\n\n/**\n * Ensure that any value passes validation.\n */\nfunction any() {\n return define('any', () => true);\n}\nfunction array(Element) {\n return new Struct({\n type: 'array',\n schema: Element,\n *entries(value) {\n if (Element && Array.isArray(value)) {\n for (const [i, v] of value.entries()) {\n yield [i, v, Element];\n }\n }\n },\n coercer(value) {\n return Array.isArray(value) ? value.slice() : value;\n },\n validator(value) {\n return Array.isArray(value) || `Expected an array value, but received: ${print(value)}`;\n }\n });\n}\n/**\n * Ensure that a value is a bigint.\n */\nfunction bigint() {\n return define('bigint', value => {\n return typeof value === 'bigint';\n });\n}\n/**\n * Ensure that a value is a boolean.\n */\nfunction boolean() {\n return define('boolean', value => {\n return typeof value === 'boolean';\n });\n}\n/**\n * Ensure that a value is a valid `Date`.\n *\n * Note: this also ensures that the value is *not* an invalid `Date` object,\n * which can occur when parsing a date fails but still returns a `Date`.\n */\nfunction date() {\n return define('date', value => {\n return value instanceof Date && !isNaN(value.getTime()) || `Expected a valid \\`Date\\` object, but received: ${print(value)}`;\n });\n}\nfunction enums(values) {\n const schema = {};\n const description = values.map(v => print(v)).join();\n for (const key of values) {\n schema[key] = key;\n }\n return new Struct({\n type: 'enums',\n schema,\n validator(value) {\n return values.includes(value) || `Expected one of \\`${description}\\`, but received: ${print(value)}`;\n }\n });\n}\n/**\n * Ensure that a value is a function.\n */\nfunction func() {\n return define('func', value => {\n return typeof value === 'function' || `Expected a function, but received: ${print(value)}`;\n });\n}\n/**\n * Ensure that a value is an instance of a specific class.\n */\nfunction instance(Class) {\n return define('instance', value => {\n return value instanceof Class || `Expected a \\`${Class.name}\\` instance, but received: ${print(value)}`;\n });\n}\n/**\n * Ensure that a value is an integer.\n */\nfunction integer() {\n return define('integer', value => {\n return typeof value === 'number' && !isNaN(value) && Number.isInteger(value) || `Expected an integer, but received: ${print(value)}`;\n });\n}\n/**\n * Ensure that a value matches all of a set of types.\n */\nfunction intersection(Structs) {\n return new Struct({\n type: 'intersection',\n schema: null,\n *entries(value, ctx) {\n for (const S of Structs) {\n yield* S.entries(value, ctx);\n }\n },\n *validator(value, ctx) {\n for (const S of Structs) {\n yield* S.validator(value, ctx);\n }\n },\n *refiner(value, ctx) {\n for (const S of Structs) {\n yield* S.refiner(value, ctx);\n }\n }\n });\n}\nfunction literal(constant) {\n const description = print(constant);\n const t = typeof constant;\n return new Struct({\n type: 'literal',\n schema: t === 'string' || t === 'number' || t === 'boolean' ? constant : null,\n validator(value) {\n return value === constant || `Expected the literal \\`${description}\\`, but received: ${print(value)}`;\n }\n });\n}\nfunction map(Key, Value) {\n return new Struct({\n type: 'map',\n schema: null,\n *entries(value) {\n if (Key && Value && value instanceof Map) {\n for (const [k, v] of value.entries()) {\n yield [k, k, Key];\n yield [k, v, Value];\n }\n }\n },\n coercer(value) {\n return value instanceof Map ? new Map(value) : value;\n },\n validator(value) {\n return value instanceof Map || `Expected a \\`Map\\` object, but received: ${print(value)}`;\n }\n });\n}\n/**\n * Ensure that no value ever passes validation.\n */\nfunction never() {\n return define('never', () => false);\n}\n/**\n * Augment an existing struct to allow `null` values.\n */\nfunction nullable(struct) {\n return new Struct({\n ...struct,\n validator: (value, ctx) => value === null || struct.validator(value, ctx),\n refiner: (value, ctx) => value === null || struct.refiner(value, ctx)\n });\n}\n/**\n * Ensure that a value is a number.\n */\nfunction number() {\n return define('number', value => {\n return typeof value === 'number' && !isNaN(value) || `Expected a number, but received: ${print(value)}`;\n });\n}\nfunction object(schema) {\n const knowns = schema ? Object.keys(schema) : [];\n const Never = never();\n return new Struct({\n type: 'object',\n schema: schema ? schema : null,\n *entries(value) {\n if (schema && isObject(value)) {\n const unknowns = new Set(Object.keys(value));\n for (const key of knowns) {\n unknowns.delete(key);\n yield [key, value[key], schema[key]];\n }\n for (const key of unknowns) {\n yield [key, value[key], Never];\n }\n }\n },\n validator(value) {\n return isObject(value) || `Expected an object, but received: ${print(value)}`;\n },\n coercer(value) {\n return isObject(value) ? {\n ...value\n } : value;\n }\n });\n}\n/**\n * Augment a struct to allow `undefined` values.\n */\nfunction optional(struct) {\n return new Struct({\n ...struct,\n validator: (value, ctx) => value === undefined || struct.validator(value, ctx),\n refiner: (value, ctx) => value === undefined || struct.refiner(value, ctx)\n });\n}\n/**\n * Ensure that a value is an object with keys and values of specific types, but\n * without ensuring any specific shape of properties.\n *\n * Like TypeScript's `Record` utility.\n */\nfunction record(Key, Value) {\n return new Struct({\n type: 'record',\n schema: null,\n *entries(value) {\n if (isObject(value)) {\n for (const k in value) {\n const v = value[k];\n yield [k, k, Key];\n yield [k, v, Value];\n }\n }\n },\n validator(value) {\n return isObject(value) || `Expected an object, but received: ${print(value)}`;\n }\n });\n}\n/**\n * Ensure that a value is a `RegExp`.\n *\n * Note: this does not test the value against the regular expression! For that\n * you need to use the `pattern()` refinement.\n */\nfunction regexp() {\n return define('regexp', value => {\n return value instanceof RegExp;\n });\n}\nfunction set(Element) {\n return new Struct({\n type: 'set',\n schema: null,\n *entries(value) {\n if (Element && value instanceof Set) {\n for (const v of value) {\n yield [v, v, Element];\n }\n }\n },\n coercer(value) {\n return value instanceof Set ? new Set(value) : value;\n },\n validator(value) {\n return value instanceof Set || `Expected a \\`Set\\` object, but received: ${print(value)}`;\n }\n });\n}\n/**\n * Ensure that a value is a string.\n */\nfunction string() {\n return define('string', value => {\n return typeof value === 'string' || `Expected a string, but received: ${print(value)}`;\n });\n}\n/**\n * Ensure that a value is a tuple of a specific length, and that each of its\n * elements is of a specific type.\n */\nfunction tuple(Structs) {\n const Never = never();\n return new Struct({\n type: 'tuple',\n schema: null,\n *entries(value) {\n if (Array.isArray(value)) {\n const length = Math.max(Structs.length, value.length);\n for (let i = 0; i < length; i++) {\n yield [i, value[i], Structs[i] || Never];\n }\n }\n },\n validator(value) {\n return Array.isArray(value) || `Expected an array, but received: ${print(value)}`;\n }\n });\n}\n/**\n * Ensure that a value has a set of known properties of specific types.\n *\n * Note: Unrecognized properties are allowed and untouched. This is similar to\n * how TypeScript's structural typing works.\n */\nfunction type(schema) {\n const keys = Object.keys(schema);\n return new Struct({\n type: 'type',\n schema,\n *entries(value) {\n if (isObject(value)) {\n for (const k of keys) {\n yield [k, value[k], schema[k]];\n }\n }\n },\n validator(value) {\n return isObject(value) || `Expected an object, but received: ${print(value)}`;\n },\n coercer(value) {\n return isObject(value) ? {\n ...value\n } : value;\n }\n });\n}\n/**\n * Ensure that a value matches one of a set of types.\n */\nfunction union(Structs) {\n const description = Structs.map(s => s.type).join(' | ');\n return new Struct({\n type: 'union',\n schema: null,\n coercer(value) {\n for (const S of Structs) {\n const [error, coerced] = S.validate(value, {\n coerce: true\n });\n if (!error) {\n return coerced;\n }\n }\n return value;\n },\n validator(value, ctx) {\n const failures = [];\n for (const S of Structs) {\n const [...tuples] = run(value, S, ctx);\n const [first] = tuples;\n if (!first[0]) {\n return [];\n } else {\n for (const [failure] of tuples) {\n if (failure) {\n failures.push(failure);\n }\n }\n }\n }\n return [`Expected the value to satisfy a union of \\`${description}\\`, but received: ${print(value)}`, ...failures];\n }\n });\n}\n/**\n * Ensure that any value passes validation, without widening its type to `any`.\n */\nfunction unknown() {\n return define('unknown', () => true);\n}\n\n/**\n * Augment a `Struct` to add an additional coercion step to its input.\n *\n * This allows you to transform input data before validating it, to increase the\n * likelihood that it passes validation—for example for default values, parsing\n * different formats, etc.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\nfunction coerce(struct, condition, coercer) {\n return new Struct({\n ...struct,\n coercer: (value, ctx) => {\n return is(value, condition) ? struct.coercer(coercer(value, ctx), ctx) : struct.coercer(value, ctx);\n }\n });\n}\n/**\n * Augment a struct to replace `undefined` values with a default.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\nfunction defaulted(struct, fallback, options = {}) {\n return coerce(struct, unknown(), x => {\n const f = typeof fallback === 'function' ? fallback() : fallback;\n if (x === undefined) {\n return f;\n }\n if (!options.strict && isPlainObject(x) && isPlainObject(f)) {\n const ret = {\n ...x\n };\n let changed = false;\n for (const key in f) {\n if (ret[key] === undefined) {\n ret[key] = f[key];\n changed = true;\n }\n }\n if (changed) {\n return ret;\n }\n }\n return x;\n });\n}\n/**\n * Augment a struct to trim string inputs.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\nfunction trimmed(struct) {\n return coerce(struct, string(), x => x.trim());\n}\n\n/**\n * Ensure that a string, array, map, or set is empty.\n */\nfunction empty(struct) {\n return refine(struct, 'empty', value => {\n const size = getSize(value);\n return size === 0 || `Expected an empty ${struct.type} but received one with a size of \\`${size}\\``;\n });\n}\nfunction getSize(value) {\n if (value instanceof Map || value instanceof Set) {\n return value.size;\n } else {\n return value.length;\n }\n}\n/**\n * Ensure that a number or date is below a threshold.\n */\nfunction max(struct, threshold, options = {}) {\n const {\n exclusive\n } = options;\n return refine(struct, 'max', value => {\n return exclusive ? value < threshold : value <= threshold || `Expected a ${struct.type} less than ${exclusive ? '' : 'or equal to '}${threshold} but received \\`${value}\\``;\n });\n}\n/**\n * Ensure that a number or date is above a threshold.\n */\nfunction min(struct, threshold, options = {}) {\n const {\n exclusive\n } = options;\n return refine(struct, 'min', value => {\n return exclusive ? value > threshold : value >= threshold || `Expected a ${struct.type} greater than ${exclusive ? '' : 'or equal to '}${threshold} but received \\`${value}\\``;\n });\n}\n/**\n * Ensure that a string, array, map or set is not empty.\n */\nfunction nonempty(struct) {\n return refine(struct, 'nonempty', value => {\n const size = getSize(value);\n return size > 0 || `Expected a nonempty ${struct.type} but received an empty one`;\n });\n}\n/**\n * Ensure that a string matches a regular expression.\n */\nfunction pattern(struct, regexp) {\n return refine(struct, 'pattern', value => {\n return regexp.test(value) || `Expected a ${struct.type} matching \\`/${regexp.source}/\\` but received \"${value}\"`;\n });\n}\n/**\n * Ensure that a string, array, number, date, map, or set has a size (or length, or time) between `min` and `max`.\n */\nfunction size(struct, min, max = min) {\n const expected = `Expected a ${struct.type}`;\n const of = min === max ? `of \\`${min}\\`` : `between \\`${min}\\` and \\`${max}\\``;\n return refine(struct, 'size', value => {\n if (typeof value === 'number' || value instanceof Date) {\n return min <= value && value <= max || `${expected} ${of} but received \\`${value}\\``;\n } else if (value instanceof Map || value instanceof Set) {\n const {\n size\n } = value;\n return min <= size && size <= max || `${expected} with a size ${of} but received one with a size of \\`${size}\\``;\n } else {\n const {\n length\n } = value;\n return min <= length && length <= max || `${expected} with a length ${of} but received one with a length of \\`${length}\\``;\n }\n });\n}\n/**\n * Augment a `Struct` to add an additional refinement to the validation.\n *\n * The refiner function is guaranteed to receive a value of the struct's type,\n * because the struct's existing validation will already have passed. This\n * allows you to layer additional validation on top of existing structs.\n */\nfunction refine(struct, name, refiner) {\n return new Struct({\n ...struct,\n *refiner(value, ctx) {\n yield* struct.refiner(value, ctx);\n const result = refiner(value, ctx);\n const failures = toFailures(result, ctx, struct, value);\n for (const failure of failures) {\n yield {\n ...failure,\n refinement: name\n };\n }\n }\n });\n}\nexport { Struct, StructError, any, array, assert, assign, bigint, boolean, coerce, create, date, defaulted, define, deprecated, dynamic, empty, enums, func, instance, integer, intersection, is, lazy, literal, map, mask, max, min, never, nonempty, nullable, number, object, omit, optional, partial, pattern, pick, record, refine, regexp, set, size, string, struct, trimmed, tuple, type, union, unknown, validate };\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.assertExhaustive = exports.assertStruct = exports.assert = exports.AssertionError = void 0;\nconst superstruct_1 = require(\"superstruct\");\n/**\n * Type guard for determining whether the given value is an error object with a\n * `message` property, such as an instance of Error.\n *\n * @param error - The object to check.\n * @returns True or false, depending on the result.\n */\nfunction isErrorWithMessage(error) {\n return typeof error === 'object' && error !== null && 'message' in error;\n}\n/**\n * Check if a value is a constructor, i.e., a function that can be called with\n * the `new` keyword.\n *\n * @param fn - The value to check.\n * @returns `true` if the value is a constructor, or `false` otherwise.\n */\nfunction isConstructable(fn) {\n var _a, _b;\n /* istanbul ignore next */\n return Boolean(typeof ((_b = (_a = fn === null || fn === void 0 ? void 0 : fn.prototype) === null || _a === void 0 ? void 0 : _a.constructor) === null || _b === void 0 ? void 0 : _b.name) === 'string');\n}\n/**\n * Get the error message from an unknown error object. If the error object has\n * a `message` property, that property is returned. Otherwise, the stringified\n * error object is returned.\n *\n * @param error - The error object to get the message from.\n * @returns The error message.\n */\nfunction getErrorMessage(error) {\n const message = isErrorWithMessage(error) ? error.message : String(error);\n // If the error ends with a period, remove it, as we'll add our own period.\n if (message.endsWith('.')) {\n return message.slice(0, -1);\n }\n return message;\n}\n/**\n * Initialise an {@link AssertionErrorConstructor} error.\n *\n * @param ErrorWrapper - The error class to use.\n * @param message - The error message.\n * @returns The error object.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nfunction getError(ErrorWrapper, message) {\n if (isConstructable(ErrorWrapper)) {\n return new ErrorWrapper({\n message\n });\n }\n return ErrorWrapper({\n message\n });\n}\n/**\n * The default error class that is thrown if an assertion fails.\n */\nclass AssertionError extends Error {\n constructor(options) {\n super(options.message);\n this.code = 'ERR_ASSERTION';\n }\n}\nexports.AssertionError = AssertionError;\n/**\n * Same as Node.js assert.\n * If the value is falsy, throws an error, does nothing otherwise.\n *\n * @throws {@link AssertionError} If value is falsy.\n * @param value - The test that should be truthy to pass.\n * @param message - Message to be passed to {@link AssertionError} or an\n * {@link Error} instance to throw.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}. If a custom error class is provided for\n * the `message` argument, this argument is ignored.\n */\nfunction assert(value, message = 'Assertion failed.',\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper = AssertionError) {\n if (!value) {\n if (message instanceof Error) {\n throw message;\n }\n throw getError(ErrorWrapper, message);\n }\n}\nexports.assert = assert;\n/**\n * Assert a value against a Superstruct struct.\n *\n * @param value - The value to validate.\n * @param struct - The struct to validate against.\n * @param errorPrefix - A prefix to add to the error message. Defaults to\n * \"Assertion failed\".\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the value is not valid.\n */\nfunction assertStruct(value, struct, errorPrefix = 'Assertion failed',\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper = AssertionError) {\n try {\n (0, superstruct_1.assert)(value, struct);\n } catch (error) {\n throw getError(ErrorWrapper, `${errorPrefix}: ${getErrorMessage(error)}.`);\n }\n}\nexports.assertStruct = assertStruct;\n/**\n * Use in the default case of a switch that you want to be fully exhaustive.\n * Using this function forces the compiler to enforce exhaustivity during\n * compile-time.\n *\n * @example\n * ```\n * const number = 1;\n * switch (number) {\n * case 0:\n * ...\n * case 1:\n * ...\n * default:\n * assertExhaustive(snapPrefix);\n * }\n * ```\n * @param _object - The object on which the switch is being operated.\n */\nfunction assertExhaustive(_object) {\n throw new Error('Invalid branch reached. Should be detected during compilation.');\n}\nexports.assertExhaustive = assertExhaustive;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.base64 = void 0;\nconst superstruct_1 = require(\"superstruct\");\nconst assert_1 = require(\"./assert\");\n/**\n * Ensure that a provided string-based struct is valid base64.\n *\n * @param struct - The string based struct.\n * @param options - Optional options to specialize base64 validation. See {@link Base64Options} documentation.\n * @returns A superstruct validating base64.\n */\nconst base64 = (struct, options = {}) => {\n var _a, _b;\n const paddingRequired = (_a = options.paddingRequired) !== null && _a !== void 0 ? _a : false;\n const characterSet = (_b = options.characterSet) !== null && _b !== void 0 ? _b : 'base64';\n let letters;\n if (characterSet === 'base64') {\n letters = String.raw`[A-Za-z0-9+\\/]`;\n } else {\n (0, assert_1.assert)(characterSet === 'base64url');\n letters = String.raw`[-_A-Za-z0-9]`;\n }\n let re;\n if (paddingRequired) {\n re = new RegExp(`^(?:${letters}{4})*(?:${letters}{3}=|${letters}{2}==)?$`, 'u');\n } else {\n re = new RegExp(`^(?:${letters}{4})*(?:${letters}{2,3}|${letters}{3}=|${letters}{2}==)?$`, 'u');\n }\n return (0, superstruct_1.pattern)(struct, re);\n};\nexports.base64 = base64;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.remove0x = exports.add0x = exports.assertIsStrictHexString = exports.assertIsHexString = exports.isStrictHexString = exports.isHexString = exports.StrictHexStruct = exports.HexStruct = void 0;\nconst superstruct_1 = require(\"superstruct\");\nconst assert_1 = require(\"./assert\");\nexports.HexStruct = (0, superstruct_1.pattern)((0, superstruct_1.string)(), /^(?:0x)?[0-9a-f]+$/iu);\nexports.StrictHexStruct = (0, superstruct_1.pattern)((0, superstruct_1.string)(), /^0x[0-9a-f]+$/iu);\n/**\n * Check if a string is a valid hex string.\n *\n * @param value - The value to check.\n * @returns Whether the value is a valid hex string.\n */\nfunction isHexString(value) {\n return (0, superstruct_1.is)(value, exports.HexStruct);\n}\nexports.isHexString = isHexString;\n/**\n * Strictly check if a string is a valid hex string. A valid hex string must\n * start with the \"0x\"-prefix.\n *\n * @param value - The value to check.\n * @returns Whether the value is a valid hex string.\n */\nfunction isStrictHexString(value) {\n return (0, superstruct_1.is)(value, exports.StrictHexStruct);\n}\nexports.isStrictHexString = isStrictHexString;\n/**\n * Assert that a value is a valid hex string.\n *\n * @param value - The value to check.\n * @throws If the value is not a valid hex string.\n */\nfunction assertIsHexString(value) {\n (0, assert_1.assert)(isHexString(value), 'Value must be a hexadecimal string.');\n}\nexports.assertIsHexString = assertIsHexString;\n/**\n * Assert that a value is a valid hex string. A valid hex string must start with\n * the \"0x\"-prefix.\n *\n * @param value - The value to check.\n * @throws If the value is not a valid hex string.\n */\nfunction assertIsStrictHexString(value) {\n (0, assert_1.assert)(isStrictHexString(value), 'Value must be a hexadecimal string, starting with \"0x\".');\n}\nexports.assertIsStrictHexString = assertIsStrictHexString;\n/**\n * Add the `0x`-prefix to a hexadecimal string. If the string already has the\n * prefix, it is returned as-is.\n *\n * @param hexadecimal - The hexadecimal string to add the prefix to.\n * @returns The prefixed hexadecimal string.\n */\nfunction add0x(hexadecimal) {\n if (hexadecimal.startsWith('0x')) {\n return hexadecimal;\n }\n if (hexadecimal.startsWith('0X')) {\n return `0x${hexadecimal.substring(2)}`;\n }\n return `0x${hexadecimal}`;\n}\nexports.add0x = add0x;\n/**\n * Remove the `0x`-prefix from a hexadecimal string. If the string doesn't have\n * the prefix, it is returned as-is.\n *\n * @param hexadecimal - The hexadecimal string to remove the prefix from.\n * @returns The un-prefixed hexadecimal string.\n */\nfunction remove0x(hexadecimal) {\n if (hexadecimal.startsWith('0x') || hexadecimal.startsWith('0X')) {\n return hexadecimal.substring(2);\n }\n return hexadecimal;\n}\nexports.remove0x = remove0x;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createDataView = exports.concatBytes = exports.valueToBytes = exports.stringToBytes = exports.numberToBytes = exports.signedBigIntToBytes = exports.bigIntToBytes = exports.hexToBytes = exports.bytesToString = exports.bytesToNumber = exports.bytesToSignedBigInt = exports.bytesToBigInt = exports.bytesToHex = exports.assertIsBytes = exports.isBytes = void 0;\nconst assert_1 = require(\"./assert\");\nconst hex_1 = require(\"./hex\");\n// '0'.charCodeAt(0) === 48\nconst HEX_MINIMUM_NUMBER_CHARACTER = 48;\n// '9'.charCodeAt(0) === 57\nconst HEX_MAXIMUM_NUMBER_CHARACTER = 58;\nconst HEX_CHARACTER_OFFSET = 87;\n/**\n * Memoized function that returns an array to be used as a lookup table for\n * converting bytes to hexadecimal values.\n *\n * The array is created lazily and then cached for future use. The benefit of\n * this approach is that the performance of converting bytes to hex is much\n * better than if we were to call `toString(16)` on each byte.\n *\n * The downside is that the array is created once and then never garbage\n * collected. This is not a problem in practice because the array is only 256\n * elements long.\n *\n * @returns A function that returns the lookup table.\n */\nfunction getPrecomputedHexValuesBuilder() {\n // To avoid issues with tree shaking, we need to use a function to return the\n // array. This is because the array is only used in the `bytesToHex` function\n // and if we were to use a global variable, the array might be removed by the\n // tree shaker.\n const lookupTable = [];\n return () => {\n if (lookupTable.length === 0) {\n for (let i = 0; i < 256; i++) {\n lookupTable.push(i.toString(16).padStart(2, '0'));\n }\n }\n return lookupTable;\n };\n}\n/**\n * Function implementation of the {@link getPrecomputedHexValuesBuilder}\n * function.\n */\nconst getPrecomputedHexValues = getPrecomputedHexValuesBuilder();\n/**\n * Check if a value is a `Uint8Array`.\n *\n * @param value - The value to check.\n * @returns Whether the value is a `Uint8Array`.\n */\nfunction isBytes(value) {\n return value instanceof Uint8Array;\n}\nexports.isBytes = isBytes;\n/**\n * Assert that a value is a `Uint8Array`.\n *\n * @param value - The value to check.\n * @throws If the value is not a `Uint8Array`.\n */\nfunction assertIsBytes(value) {\n (0, assert_1.assert)(isBytes(value), 'Value must be a Uint8Array.');\n}\nexports.assertIsBytes = assertIsBytes;\n/**\n * Convert a `Uint8Array` to a hexadecimal string.\n *\n * @param bytes - The bytes to convert to a hexadecimal string.\n * @returns The hexadecimal string.\n */\nfunction bytesToHex(bytes) {\n assertIsBytes(bytes);\n if (bytes.length === 0) {\n return '0x';\n }\n const lookupTable = getPrecomputedHexValues();\n const hexadecimal = new Array(bytes.length);\n for (let i = 0; i < bytes.length; i++) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n hexadecimal[i] = lookupTable[bytes[i]];\n }\n return (0, hex_1.add0x)(hexadecimal.join(''));\n}\nexports.bytesToHex = bytesToHex;\n/**\n * Convert a `Uint8Array` to a `bigint`.\n *\n * To convert a `Uint8Array` to a `number` instead, use {@link bytesToNumber}.\n * To convert a two's complement encoded `Uint8Array` to a `bigint`, use\n * {@link bytesToSignedBigInt}.\n *\n * @param bytes - The bytes to convert to a `bigint`.\n * @returns The `bigint`.\n */\nfunction bytesToBigInt(bytes) {\n assertIsBytes(bytes);\n const hexadecimal = bytesToHex(bytes);\n return BigInt(hexadecimal);\n}\nexports.bytesToBigInt = bytesToBigInt;\n/**\n * Convert a `Uint8Array` to a signed `bigint`. This assumes that the bytes are\n * encoded in two's complement.\n *\n * To convert a `Uint8Array` to an unsigned `bigint` instead, use\n * {@link bytesToBigInt}.\n *\n * @see https://en.wikipedia.org/wiki/Two%27s_complement\n * @param bytes - The bytes to convert to a signed `bigint`.\n * @returns The signed `bigint`.\n */\nfunction bytesToSignedBigInt(bytes) {\n assertIsBytes(bytes);\n let value = BigInt(0);\n for (const byte of bytes) {\n // eslint-disable-next-line no-bitwise\n value = (value << BigInt(8)) + BigInt(byte);\n }\n return BigInt.asIntN(bytes.length * 8, value);\n}\nexports.bytesToSignedBigInt = bytesToSignedBigInt;\n/**\n * Convert a `Uint8Array` to a `number`.\n *\n * To convert a `Uint8Array` to a `bigint` instead, use {@link bytesToBigInt}.\n *\n * @param bytes - The bytes to convert to a number.\n * @returns The number.\n * @throws If the resulting number is not a safe integer.\n */\nfunction bytesToNumber(bytes) {\n assertIsBytes(bytes);\n const bigint = bytesToBigInt(bytes);\n (0, assert_1.assert)(bigint <= BigInt(Number.MAX_SAFE_INTEGER), 'Number is not a safe integer. Use `bytesToBigInt` instead.');\n return Number(bigint);\n}\nexports.bytesToNumber = bytesToNumber;\n/**\n * Convert a UTF-8 encoded `Uint8Array` to a `string`.\n *\n * @param bytes - The bytes to convert to a string.\n * @returns The string.\n */\nfunction bytesToString(bytes) {\n assertIsBytes(bytes);\n return new TextDecoder().decode(bytes);\n}\nexports.bytesToString = bytesToString;\n/**\n * Convert a hexadecimal string to a `Uint8Array`. The string can optionally be\n * prefixed with `0x`. It accepts even and odd length strings.\n *\n * If the value is \"0x\", an empty `Uint8Array` is returned.\n *\n * @param value - The hexadecimal string to convert to bytes.\n * @returns The bytes as `Uint8Array`.\n */\nfunction hexToBytes(value) {\n var _a;\n // \"0x\" is often used as empty byte array.\n if (((_a = value === null || value === void 0 ? void 0 : value.toLowerCase) === null || _a === void 0 ? void 0 : _a.call(value)) === '0x') {\n return new Uint8Array();\n }\n (0, hex_1.assertIsHexString)(value);\n // Remove the `0x` prefix if it exists, and pad the string to have an even\n // number of characters.\n const strippedValue = (0, hex_1.remove0x)(value).toLowerCase();\n const normalizedValue = strippedValue.length % 2 === 0 ? strippedValue : `0${strippedValue}`;\n const bytes = new Uint8Array(normalizedValue.length / 2);\n for (let i = 0; i < bytes.length; i++) {\n // While this is not the prettiest way to convert a hexadecimal string to a\n // `Uint8Array`, it is a lot faster than using `parseInt` to convert each\n // character.\n const c1 = normalizedValue.charCodeAt(i * 2);\n const c2 = normalizedValue.charCodeAt(i * 2 + 1);\n const n1 = c1 - (c1 < HEX_MAXIMUM_NUMBER_CHARACTER ? HEX_MINIMUM_NUMBER_CHARACTER : HEX_CHARACTER_OFFSET);\n const n2 = c2 - (c2 < HEX_MAXIMUM_NUMBER_CHARACTER ? HEX_MINIMUM_NUMBER_CHARACTER : HEX_CHARACTER_OFFSET);\n bytes[i] = n1 * 16 + n2;\n }\n return bytes;\n}\nexports.hexToBytes = hexToBytes;\n/**\n * Convert a `bigint` to a `Uint8Array`.\n *\n * This assumes that the `bigint` is an unsigned integer. To convert a signed\n * `bigint` instead, use {@link signedBigIntToBytes}.\n *\n * @param value - The bigint to convert to bytes.\n * @returns The bytes as `Uint8Array`.\n */\nfunction bigIntToBytes(value) {\n (0, assert_1.assert)(typeof value === 'bigint', 'Value must be a bigint.');\n (0, assert_1.assert)(value >= BigInt(0), 'Value must be a non-negative bigint.');\n const hexadecimal = value.toString(16);\n return hexToBytes(hexadecimal);\n}\nexports.bigIntToBytes = bigIntToBytes;\n/**\n * Check if a `bigint` fits in a certain number of bytes.\n *\n * @param value - The `bigint` to check.\n * @param bytes - The number of bytes.\n * @returns Whether the `bigint` fits in the number of bytes.\n */\nfunction bigIntFits(value, bytes) {\n (0, assert_1.assert)(bytes > 0);\n /* eslint-disable no-bitwise */\n const mask = value >> BigInt(31);\n return !((~value & mask) + (value & ~mask) >> BigInt(bytes * 8 + ~0));\n /* eslint-enable no-bitwise */\n}\n/**\n * Convert a signed `bigint` to a `Uint8Array`. This uses two's complement\n * encoding to represent negative numbers.\n *\n * To convert an unsigned `bigint` to a `Uint8Array` instead, use\n * {@link bigIntToBytes}.\n *\n * @see https://en.wikipedia.org/wiki/Two%27s_complement\n * @param value - The number to convert to bytes.\n * @param byteLength - The length of the resulting `Uint8Array`. If the number\n * is larger than the maximum value that can be represented by the given length,\n * an error is thrown.\n * @returns The bytes as `Uint8Array`.\n */\nfunction signedBigIntToBytes(value, byteLength) {\n (0, assert_1.assert)(typeof value === 'bigint', 'Value must be a bigint.');\n (0, assert_1.assert)(typeof byteLength === 'number', 'Byte length must be a number.');\n (0, assert_1.assert)(byteLength > 0, 'Byte length must be greater than 0.');\n (0, assert_1.assert)(bigIntFits(value, byteLength), 'Byte length is too small to represent the given value.');\n // ESLint doesn't like mutating function parameters, so to avoid having to\n // disable the rule, we create a new variable.\n let numberValue = value;\n const bytes = new Uint8Array(byteLength);\n for (let i = 0; i < bytes.length; i++) {\n bytes[i] = Number(BigInt.asUintN(8, numberValue));\n // eslint-disable-next-line no-bitwise\n numberValue >>= BigInt(8);\n }\n return bytes.reverse();\n}\nexports.signedBigIntToBytes = signedBigIntToBytes;\n/**\n * Convert a `number` to a `Uint8Array`.\n *\n * @param value - The number to convert to bytes.\n * @returns The bytes as `Uint8Array`.\n * @throws If the number is not a safe integer.\n */\nfunction numberToBytes(value) {\n (0, assert_1.assert)(typeof value === 'number', 'Value must be a number.');\n (0, assert_1.assert)(value >= 0, 'Value must be a non-negative number.');\n (0, assert_1.assert)(Number.isSafeInteger(value), 'Value is not a safe integer. Use `bigIntToBytes` instead.');\n const hexadecimal = value.toString(16);\n return hexToBytes(hexadecimal);\n}\nexports.numberToBytes = numberToBytes;\n/**\n * Convert a `string` to a UTF-8 encoded `Uint8Array`.\n *\n * @param value - The string to convert to bytes.\n * @returns The bytes as `Uint8Array`.\n */\nfunction stringToBytes(value) {\n (0, assert_1.assert)(typeof value === 'string', 'Value must be a string.');\n return new TextEncoder().encode(value);\n}\nexports.stringToBytes = stringToBytes;\n/**\n * Convert a byte-like value to a `Uint8Array`. The value can be a `Uint8Array`,\n * a `bigint`, a `number`, or a `string`.\n *\n * This will attempt to guess the type of the value based on its type and\n * contents. For more control over the conversion, use the more specific\n * conversion functions, such as {@link hexToBytes} or {@link stringToBytes}.\n *\n * If the value is a `string`, and it is prefixed with `0x`, it will be\n * interpreted as a hexadecimal string. Otherwise, it will be interpreted as a\n * UTF-8 string. To convert a hexadecimal string to bytes without interpreting\n * it as a UTF-8 string, use {@link hexToBytes} instead.\n *\n * If the value is a `bigint`, it is assumed to be unsigned. To convert a signed\n * `bigint` to bytes, use {@link signedBigIntToBytes} instead.\n *\n * If the value is a `Uint8Array`, it will be returned as-is.\n *\n * @param value - The value to convert to bytes.\n * @returns The bytes as `Uint8Array`.\n */\nfunction valueToBytes(value) {\n if (typeof value === 'bigint') {\n return bigIntToBytes(value);\n }\n if (typeof value === 'number') {\n return numberToBytes(value);\n }\n if (typeof value === 'string') {\n if (value.startsWith('0x')) {\n return hexToBytes(value);\n }\n return stringToBytes(value);\n }\n if (isBytes(value)) {\n return value;\n }\n throw new TypeError(`Unsupported value type: \"${typeof value}\".`);\n}\nexports.valueToBytes = valueToBytes;\n/**\n * Concatenate multiple byte-like values into a single `Uint8Array`. The values\n * can be `Uint8Array`, `bigint`, `number`, or `string`. This uses\n * {@link valueToBytes} under the hood to convert each value to bytes. Refer to\n * the documentation of that function for more information.\n *\n * @param values - The values to concatenate.\n * @returns The concatenated bytes as `Uint8Array`.\n */\nfunction concatBytes(values) {\n const normalizedValues = new Array(values.length);\n let byteLength = 0;\n for (let i = 0; i < values.length; i++) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const value = valueToBytes(values[i]);\n normalizedValues[i] = value;\n byteLength += value.length;\n }\n const bytes = new Uint8Array(byteLength);\n for (let i = 0, offset = 0; i < normalizedValues.length; i++) {\n // While we could simply spread the values into an array and use\n // `Uint8Array.from`, that is a lot slower than using `Uint8Array.set`.\n bytes.set(normalizedValues[i], offset);\n offset += normalizedValues[i].length;\n }\n return bytes;\n}\nexports.concatBytes = concatBytes;\n/**\n * Create a {@link DataView} from a {@link Uint8Array}. This is a convenience\n * function that avoids having to create a {@link DataView} manually, which\n * requires passing the `byteOffset` and `byteLength` parameters every time.\n *\n * Not passing the `byteOffset` and `byteLength` parameters can result in\n * unexpected behavior when the {@link Uint8Array} is a view of a larger\n * {@link ArrayBuffer}, e.g., when using {@link Uint8Array.subarray}.\n *\n * This function also supports Node.js {@link Buffer}s.\n *\n * @example\n * ```typescript\n * const bytes = new Uint8Array([1, 2, 3]);\n *\n * // This is equivalent to:\n * // const dataView = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n * const dataView = createDataView(bytes);\n * ```\n * @param bytes - The bytes to create the {@link DataView} from.\n * @returns The {@link DataView}.\n */\nfunction createDataView(bytes) {\n // To maintain compatibility with Node.js, we need to check if the bytes are\n // a Buffer. If so, we need to slice the buffer to get the underlying\n // ArrayBuffer.\n // eslint-disable-next-line no-restricted-globals\n if (typeof Buffer !== 'undefined' && bytes instanceof Buffer) {\n const buffer = bytes.buffer.slice(bytes.byteOffset, bytes.byteOffset + bytes.byteLength);\n return new DataView(buffer);\n }\n return new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n}\nexports.createDataView = createDataView;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ChecksumStruct = void 0;\nconst superstruct_1 = require(\"superstruct\");\nconst base64_1 = require(\"./base64\");\nexports.ChecksumStruct = (0, superstruct_1.size)((0, base64_1.base64)((0, superstruct_1.string)(), {\n paddingRequired: true\n}), 44, 44);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createHex = exports.createBytes = exports.createBigInt = exports.createNumber = void 0;\nconst superstruct_1 = require(\"superstruct\");\nconst assert_1 = require(\"./assert\");\nconst bytes_1 = require(\"./bytes\");\nconst hex_1 = require(\"./hex\");\nconst NumberLikeStruct = (0, superstruct_1.union)([(0, superstruct_1.number)(), (0, superstruct_1.bigint)(), (0, superstruct_1.string)(), hex_1.StrictHexStruct]);\nconst NumberCoercer = (0, superstruct_1.coerce)((0, superstruct_1.number)(), NumberLikeStruct, Number);\nconst BigIntCoercer = (0, superstruct_1.coerce)((0, superstruct_1.bigint)(), NumberLikeStruct, BigInt);\nconst BytesLikeStruct = (0, superstruct_1.union)([hex_1.StrictHexStruct, (0, superstruct_1.instance)(Uint8Array)]);\nconst BytesCoercer = (0, superstruct_1.coerce)((0, superstruct_1.instance)(Uint8Array), (0, superstruct_1.union)([hex_1.StrictHexStruct]), bytes_1.hexToBytes);\nconst HexCoercer = (0, superstruct_1.coerce)(hex_1.StrictHexStruct, (0, superstruct_1.instance)(Uint8Array), bytes_1.bytesToHex);\n/**\n * Create a number from a number-like value.\n *\n * - If the value is a number, it is returned as-is.\n * - If the value is a `bigint`, it is converted to a number.\n * - If the value is a string, it is interpreted as a decimal number.\n * - If the value is a hex string (i.e., it starts with \"0x\"), it is\n * interpreted as a hexadecimal number.\n *\n * This validates that the value is a number-like value, and that the resulting\n * number is not `NaN` or `Infinity`.\n *\n * @example\n * ```typescript\n * const value = createNumber('0x010203');\n * console.log(value); // 66051\n *\n * const otherValue = createNumber(123n);\n * console.log(otherValue); // 123\n * ```\n * @param value - The value to create the number from.\n * @returns The created number.\n * @throws If the value is not a number-like value, or if the resulting number\n * is `NaN` or `Infinity`.\n */\nfunction createNumber(value) {\n try {\n const result = (0, superstruct_1.create)(value, NumberCoercer);\n (0, assert_1.assert)(Number.isFinite(result), `Expected a number-like value, got \"${value}\".`);\n return result;\n } catch (error) {\n if (error instanceof superstruct_1.StructError) {\n throw new Error(`Expected a number-like value, got \"${value}\".`);\n }\n /* istanbul ignore next */\n throw error;\n }\n}\nexports.createNumber = createNumber;\n/**\n * Create a `bigint` from a number-like value.\n *\n * - If the value is a number, it is converted to a `bigint`.\n * - If the value is a `bigint`, it is returned as-is.\n * - If the value is a string, it is interpreted as a decimal number and\n * converted to a `bigint`.\n * - If the value is a hex string (i.e., it starts with \"0x\"), it is\n * interpreted as a hexadecimal number and converted to a `bigint`.\n *\n * @example\n * ```typescript\n * const value = createBigInt('0x010203');\n * console.log(value); // 16909060n\n *\n * const otherValue = createBigInt(123);\n * console.log(otherValue); // 123n\n * ```\n * @param value - The value to create the bigint from.\n * @returns The created bigint.\n * @throws If the value is not a number-like value.\n */\nfunction createBigInt(value) {\n try {\n // The `BigInt` constructor throws if the value is not a number-like value.\n // There is no need to validate the value manually.\n return (0, superstruct_1.create)(value, BigIntCoercer);\n } catch (error) {\n if (error instanceof superstruct_1.StructError) {\n throw new Error(`Expected a number-like value, got \"${String(error.value)}\".`);\n }\n /* istanbul ignore next */\n throw error;\n }\n}\nexports.createBigInt = createBigInt;\n/**\n * Create a byte array from a bytes-like value.\n *\n * - If the value is a byte array, it is returned as-is.\n * - If the value is a hex string (i.e., it starts with \"0x\"), it is interpreted\n * as a hexadecimal number and converted to a byte array.\n *\n * @example\n * ```typescript\n * const value = createBytes('0x010203');\n * console.log(value); // Uint8Array [ 1, 2, 3 ]\n *\n * const otherValue = createBytes('0x010203');\n * console.log(otherValue); // Uint8Array [ 1, 2, 3 ]\n * ```\n * @param value - The value to create the byte array from.\n * @returns The created byte array.\n * @throws If the value is not a bytes-like value.\n */\nfunction createBytes(value) {\n if (typeof value === 'string' && value.toLowerCase() === '0x') {\n return new Uint8Array();\n }\n try {\n return (0, superstruct_1.create)(value, BytesCoercer);\n } catch (error) {\n if (error instanceof superstruct_1.StructError) {\n throw new Error(`Expected a bytes-like value, got \"${String(error.value)}\".`);\n }\n /* istanbul ignore next */\n throw error;\n }\n}\nexports.createBytes = createBytes;\n/**\n * Create a hexadecimal string from a bytes-like value.\n *\n * - If the value is a hex string (i.e., it starts with \"0x\"), it is returned\n * as-is.\n * - If the value is a `Uint8Array`, it is converted to a hex string.\n *\n * @example\n * ```typescript\n * const value = createHex(new Uint8Array([1, 2, 3]));\n * console.log(value); // '0x010203'\n *\n * const otherValue = createHex('0x010203');\n * console.log(otherValue); // '0x010203'\n * ```\n * @param value - The value to create the hex string from.\n * @returns The created hex string.\n * @throws If the value is not a bytes-like value.\n */\nfunction createHex(value) {\n if (value instanceof Uint8Array && value.length === 0 || typeof value === 'string' && value.toLowerCase() === '0x') {\n return '0x';\n }\n try {\n return (0, superstruct_1.create)(value, HexCoercer);\n } catch (error) {\n if (error instanceof superstruct_1.StructError) {\n throw new Error(`Expected a bytes-like value, got \"${String(error.value)}\".`);\n }\n /* istanbul ignore next */\n throw error;\n }\n}\nexports.createHex = createHex;\n","\"use strict\";\n\nvar __classPrivateFieldSet = this && this.__classPrivateFieldSet || function (receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value), value;\n};\nvar __classPrivateFieldGet = this && this.__classPrivateFieldGet || function (receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n};\nvar _FrozenMap_map, _FrozenSet_set;\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.FrozenSet = exports.FrozenMap = void 0;\n/**\n * A {@link ReadonlyMap} that cannot be modified after instantiation.\n * The implementation uses an inner map hidden via a private field, and the\n * immutability guarantee relies on it being impossible to get a reference\n * to this map.\n */\nclass FrozenMap {\n constructor(entries) {\n _FrozenMap_map.set(this, void 0);\n __classPrivateFieldSet(this, _FrozenMap_map, new Map(entries), \"f\");\n Object.freeze(this);\n }\n get size() {\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\").size;\n }\n [(_FrozenMap_map = new WeakMap(), Symbol.iterator)]() {\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\")[Symbol.iterator]();\n }\n entries() {\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\").entries();\n }\n forEach(callbackfn, thisArg) {\n // We have to wrap the specified callback in order to prevent it from\n // receiving a reference to the inner map.\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\").forEach((value, key, _map) => callbackfn.call(thisArg, value, key, this));\n }\n get(key) {\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\").get(key);\n }\n has(key) {\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\").has(key);\n }\n keys() {\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\").keys();\n }\n values() {\n return __classPrivateFieldGet(this, _FrozenMap_map, \"f\").values();\n }\n toString() {\n return `FrozenMap(${this.size}) {${this.size > 0 ? ` ${[...this.entries()].map(([key, value]) => `${String(key)} => ${String(value)}`).join(', ')} ` : ''}}`;\n }\n}\nexports.FrozenMap = FrozenMap;\n/**\n * A {@link ReadonlySet} that cannot be modified after instantiation.\n * The implementation uses an inner set hidden via a private field, and the\n * immutability guarantee relies on it being impossible to get a reference\n * to this set.\n */\nclass FrozenSet {\n constructor(values) {\n _FrozenSet_set.set(this, void 0);\n __classPrivateFieldSet(this, _FrozenSet_set, new Set(values), \"f\");\n Object.freeze(this);\n }\n get size() {\n return __classPrivateFieldGet(this, _FrozenSet_set, \"f\").size;\n }\n [(_FrozenSet_set = new WeakMap(), Symbol.iterator)]() {\n return __classPrivateFieldGet(this, _FrozenSet_set, \"f\")[Symbol.iterator]();\n }\n entries() {\n return __classPrivateFieldGet(this, _FrozenSet_set, \"f\").entries();\n }\n forEach(callbackfn, thisArg) {\n // We have to wrap the specified callback in order to prevent it from\n // receiving a reference to the inner set.\n return __classPrivateFieldGet(this, _FrozenSet_set, \"f\").forEach((value, value2, _set) => callbackfn.call(thisArg, value, value2, this));\n }\n has(value) {\n return __classPrivateFieldGet(this, _FrozenSet_set, \"f\").has(value);\n }\n keys() {\n return __classPrivateFieldGet(this, _FrozenSet_set, \"f\").keys();\n }\n values() {\n return __classPrivateFieldGet(this, _FrozenSet_set, \"f\").values();\n }\n toString() {\n return `FrozenSet(${this.size}) {${this.size > 0 ? ` ${[...this.values()].map(member => String(member)).join(', ')} ` : ''}}`;\n }\n}\nexports.FrozenSet = FrozenSet;\nObject.freeze(FrozenMap);\nObject.freeze(FrozenMap.prototype);\nObject.freeze(FrozenSet);\nObject.freeze(FrozenSet.prototype);\n","\"use strict\";\n\n//\n// Types\n//\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.calculateNumberSize = exports.calculateStringSize = exports.isASCII = exports.isPlainObject = exports.ESCAPE_CHARACTERS_REGEXP = exports.JsonSize = exports.hasProperty = exports.isObject = exports.isNullOrUndefined = exports.isNonEmptyArray = void 0;\n//\n// Type Guards\n//\n/**\n * A {@link NonEmptyArray} type guard.\n *\n * @template Element - The non-empty array member type.\n * @param value - The value to check.\n * @returns Whether the value is a non-empty array.\n */\nfunction isNonEmptyArray(value) {\n return Array.isArray(value) && value.length > 0;\n}\nexports.isNonEmptyArray = isNonEmptyArray;\n/**\n * Type guard for \"nullishness\".\n *\n * @param value - Any value.\n * @returns `true` if the value is null or undefined, `false` otherwise.\n */\nfunction isNullOrUndefined(value) {\n return value === null || value === undefined;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n/**\n * A type guard for {@link RuntimeObject}.\n *\n * @param value - The value to check.\n * @returns Whether the specified value has a runtime type of `object` and is\n * neither `null` nor an `Array`.\n */\nfunction isObject(value) {\n return Boolean(value) && typeof value === 'object' && !Array.isArray(value);\n}\nexports.isObject = isObject;\n//\n// Other utility functions\n//\n/**\n * A type guard for ensuring an object has a property.\n *\n * @param objectToCheck - The object to check.\n * @param name - The property name to check for.\n * @returns Whether the specified object has an own property with the specified\n * name, regardless of whether it is enumerable or not.\n */\nconst hasProperty = (objectToCheck, name) => Object.hasOwnProperty.call(objectToCheck, name);\nexports.hasProperty = hasProperty;\n/**\n * Predefined sizes (in Bytes) of specific parts of JSON structure.\n */\nvar JsonSize;\n(function (JsonSize) {\n JsonSize[JsonSize[\"Null\"] = 4] = \"Null\";\n JsonSize[JsonSize[\"Comma\"] = 1] = \"Comma\";\n JsonSize[JsonSize[\"Wrapper\"] = 1] = \"Wrapper\";\n JsonSize[JsonSize[\"True\"] = 4] = \"True\";\n JsonSize[JsonSize[\"False\"] = 5] = \"False\";\n JsonSize[JsonSize[\"Quote\"] = 1] = \"Quote\";\n JsonSize[JsonSize[\"Colon\"] = 1] = \"Colon\";\n // eslint-disable-next-line @typescript-eslint/no-shadow\n JsonSize[JsonSize[\"Date\"] = 24] = \"Date\";\n})(JsonSize = exports.JsonSize || (exports.JsonSize = {}));\n/**\n * Regular expression with pattern matching for (special) escaped characters.\n */\nexports.ESCAPE_CHARACTERS_REGEXP = /\"|\\\\|\\n|\\r|\\t/gu;\n/**\n * Check if the value is plain object.\n *\n * @param value - Value to be checked.\n * @returns True if an object is the plain JavaScript object,\n * false if the object is not plain (e.g. function).\n */\nfunction isPlainObject(value) {\n if (typeof value !== 'object' || value === null) {\n return false;\n }\n try {\n let proto = value;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(value) === proto;\n } catch (_) {\n return false;\n }\n}\nexports.isPlainObject = isPlainObject;\n/**\n * Check if character is ASCII.\n *\n * @param character - Character.\n * @returns True if a character code is ASCII, false if not.\n */\nfunction isASCII(character) {\n return character.charCodeAt(0) <= 127;\n}\nexports.isASCII = isASCII;\n/**\n * Calculate string size.\n *\n * @param value - String value to calculate size.\n * @returns Number of bytes used to store whole string value.\n */\nfunction calculateStringSize(value) {\n var _a;\n const size = value.split('').reduce((total, character) => {\n if (isASCII(character)) {\n return total + 1;\n }\n return total + 2;\n }, 0);\n // Also detect characters that need backslash escape\n return size + ((_a = value.match(exports.ESCAPE_CHARACTERS_REGEXP)) !== null && _a !== void 0 ? _a : []).length;\n}\nexports.calculateStringSize = calculateStringSize;\n/**\n * Calculate size of a number ofter JSON serialization.\n *\n * @param value - Number value to calculate size.\n * @returns Number of bytes used to store whole number in JSON.\n */\nfunction calculateNumberSize(value) {\n return value.toString().length;\n}\nexports.calculateNumberSize = calculateNumberSize;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.validateJsonAndGetSize = exports.getJsonRpcIdValidator = exports.assertIsJsonRpcError = exports.isJsonRpcError = exports.assertIsJsonRpcFailure = exports.isJsonRpcFailure = exports.assertIsJsonRpcSuccess = exports.isJsonRpcSuccess = exports.assertIsJsonRpcResponse = exports.isJsonRpcResponse = exports.assertIsPendingJsonRpcResponse = exports.isPendingJsonRpcResponse = exports.JsonRpcResponseStruct = exports.JsonRpcFailureStruct = exports.JsonRpcSuccessStruct = exports.PendingJsonRpcResponseStruct = exports.assertIsJsonRpcRequest = exports.isJsonRpcRequest = exports.assertIsJsonRpcNotification = exports.isJsonRpcNotification = exports.JsonRpcNotificationStruct = exports.JsonRpcRequestStruct = exports.JsonRpcParamsStruct = exports.JsonRpcErrorStruct = exports.JsonRpcIdStruct = exports.JsonRpcVersionStruct = exports.jsonrpc2 = exports.isValidJson = exports.JsonStruct = void 0;\nconst superstruct_1 = require(\"superstruct\");\nconst assert_1 = require(\"./assert\");\nconst misc_1 = require(\"./misc\");\nexports.JsonStruct = (0, superstruct_1.define)('Json', value => {\n const [isValid] = validateJsonAndGetSize(value, true);\n if (!isValid) {\n return 'Expected a valid JSON-serializable value';\n }\n return true;\n});\n/**\n * Check if the given value is a valid {@link Json} value, i.e., a value that is\n * serializable to JSON.\n *\n * @param value - The value to check.\n * @returns Whether the value is a valid {@link Json} value.\n */\nfunction isValidJson(value) {\n return (0, superstruct_1.is)(value, exports.JsonStruct);\n}\nexports.isValidJson = isValidJson;\n/**\n * The string '2.0'.\n */\nexports.jsonrpc2 = '2.0';\nexports.JsonRpcVersionStruct = (0, superstruct_1.literal)(exports.jsonrpc2);\nexports.JsonRpcIdStruct = (0, superstruct_1.nullable)((0, superstruct_1.union)([(0, superstruct_1.number)(), (0, superstruct_1.string)()]));\nexports.JsonRpcErrorStruct = (0, superstruct_1.object)({\n code: (0, superstruct_1.integer)(),\n message: (0, superstruct_1.string)(),\n data: (0, superstruct_1.optional)(exports.JsonStruct),\n stack: (0, superstruct_1.optional)((0, superstruct_1.string)())\n});\nexports.JsonRpcParamsStruct = (0, superstruct_1.optional)((0, superstruct_1.union)([(0, superstruct_1.record)((0, superstruct_1.string)(), exports.JsonStruct), (0, superstruct_1.array)(exports.JsonStruct)]));\nexports.JsonRpcRequestStruct = (0, superstruct_1.object)({\n id: exports.JsonRpcIdStruct,\n jsonrpc: exports.JsonRpcVersionStruct,\n method: (0, superstruct_1.string)(),\n params: exports.JsonRpcParamsStruct\n});\nexports.JsonRpcNotificationStruct = (0, superstruct_1.omit)(exports.JsonRpcRequestStruct, ['id']);\n/**\n * Check if the given value is a valid {@link JsonRpcNotification} object.\n *\n * @param value - The value to check.\n * @returns Whether the given value is a valid {@link JsonRpcNotification}\n * object.\n */\nfunction isJsonRpcNotification(value) {\n return (0, superstruct_1.is)(value, exports.JsonRpcNotificationStruct);\n}\nexports.isJsonRpcNotification = isJsonRpcNotification;\n/**\n * Assert that the given value is a valid {@link JsonRpcNotification} object.\n *\n * @param value - The value to check.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the given value is not a valid {@link JsonRpcNotification} object.\n */\nfunction assertIsJsonRpcNotification(value,\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper) {\n (0, assert_1.assertStruct)(value, exports.JsonRpcNotificationStruct, 'Invalid JSON-RPC notification', ErrorWrapper);\n}\nexports.assertIsJsonRpcNotification = assertIsJsonRpcNotification;\n/**\n * Check if the given value is a valid {@link JsonRpcRequest} object.\n *\n * @param value - The value to check.\n * @returns Whether the given value is a valid {@link JsonRpcRequest} object.\n */\nfunction isJsonRpcRequest(value) {\n return (0, superstruct_1.is)(value, exports.JsonRpcRequestStruct);\n}\nexports.isJsonRpcRequest = isJsonRpcRequest;\n/**\n * Assert that the given value is a valid {@link JsonRpcRequest} object.\n *\n * @param value - The JSON-RPC request or notification to check.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the given value is not a valid {@link JsonRpcRequest} object.\n */\nfunction assertIsJsonRpcRequest(value,\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper) {\n (0, assert_1.assertStruct)(value, exports.JsonRpcRequestStruct, 'Invalid JSON-RPC request', ErrorWrapper);\n}\nexports.assertIsJsonRpcRequest = assertIsJsonRpcRequest;\nexports.PendingJsonRpcResponseStruct = (0, superstruct_1.object)({\n id: exports.JsonRpcIdStruct,\n jsonrpc: exports.JsonRpcVersionStruct,\n result: (0, superstruct_1.optional)((0, superstruct_1.unknown)()),\n error: (0, superstruct_1.optional)(exports.JsonRpcErrorStruct)\n});\nexports.JsonRpcSuccessStruct = (0, superstruct_1.object)({\n id: exports.JsonRpcIdStruct,\n jsonrpc: exports.JsonRpcVersionStruct,\n result: exports.JsonStruct\n});\nexports.JsonRpcFailureStruct = (0, superstruct_1.object)({\n id: exports.JsonRpcIdStruct,\n jsonrpc: exports.JsonRpcVersionStruct,\n error: exports.JsonRpcErrorStruct\n});\nexports.JsonRpcResponseStruct = (0, superstruct_1.union)([exports.JsonRpcSuccessStruct, exports.JsonRpcFailureStruct]);\n/**\n * Type guard to check whether specified JSON-RPC response is a\n * {@link PendingJsonRpcResponse}.\n *\n * @param response - The JSON-RPC response to check.\n * @returns Whether the specified JSON-RPC response is pending.\n */\nfunction isPendingJsonRpcResponse(response) {\n return (0, superstruct_1.is)(response, exports.PendingJsonRpcResponseStruct);\n}\nexports.isPendingJsonRpcResponse = isPendingJsonRpcResponse;\n/**\n * Assert that the given value is a valid {@link PendingJsonRpcResponse} object.\n *\n * @param response - The JSON-RPC response to check.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the given value is not a valid {@link PendingJsonRpcResponse}\n * object.\n */\nfunction assertIsPendingJsonRpcResponse(response,\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper) {\n (0, assert_1.assertStruct)(response, exports.PendingJsonRpcResponseStruct, 'Invalid pending JSON-RPC response', ErrorWrapper);\n}\nexports.assertIsPendingJsonRpcResponse = assertIsPendingJsonRpcResponse;\n/**\n * Type guard to check if a value is a {@link JsonRpcResponse}.\n *\n * @param response - The object to check.\n * @returns Whether the object is a JsonRpcResponse.\n */\nfunction isJsonRpcResponse(response) {\n return (0, superstruct_1.is)(response, exports.JsonRpcResponseStruct);\n}\nexports.isJsonRpcResponse = isJsonRpcResponse;\n/**\n * Assert that the given value is a valid {@link JsonRpcResponse} object.\n *\n * @param value - The value to check.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the given value is not a valid {@link JsonRpcResponse} object.\n */\nfunction assertIsJsonRpcResponse(value,\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper) {\n (0, assert_1.assertStruct)(value, exports.JsonRpcResponseStruct, 'Invalid JSON-RPC response', ErrorWrapper);\n}\nexports.assertIsJsonRpcResponse = assertIsJsonRpcResponse;\n/**\n * Check if the given value is a valid {@link JsonRpcSuccess} object.\n *\n * @param value - The value to check.\n * @returns Whether the given value is a valid {@link JsonRpcSuccess} object.\n */\nfunction isJsonRpcSuccess(value) {\n return (0, superstruct_1.is)(value, exports.JsonRpcSuccessStruct);\n}\nexports.isJsonRpcSuccess = isJsonRpcSuccess;\n/**\n * Assert that the given value is a valid {@link JsonRpcSuccess} object.\n *\n * @param value - The value to check.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the given value is not a valid {@link JsonRpcSuccess} object.\n */\nfunction assertIsJsonRpcSuccess(value,\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper) {\n (0, assert_1.assertStruct)(value, exports.JsonRpcSuccessStruct, 'Invalid JSON-RPC success response', ErrorWrapper);\n}\nexports.assertIsJsonRpcSuccess = assertIsJsonRpcSuccess;\n/**\n * Check if the given value is a valid {@link JsonRpcFailure} object.\n *\n * @param value - The value to check.\n * @returns Whether the given value is a valid {@link JsonRpcFailure} object.\n */\nfunction isJsonRpcFailure(value) {\n return (0, superstruct_1.is)(value, exports.JsonRpcFailureStruct);\n}\nexports.isJsonRpcFailure = isJsonRpcFailure;\n/**\n * Assert that the given value is a valid {@link JsonRpcFailure} object.\n *\n * @param value - The value to check.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the given value is not a valid {@link JsonRpcFailure} object.\n */\nfunction assertIsJsonRpcFailure(value,\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper) {\n (0, assert_1.assertStruct)(value, exports.JsonRpcFailureStruct, 'Invalid JSON-RPC failure response', ErrorWrapper);\n}\nexports.assertIsJsonRpcFailure = assertIsJsonRpcFailure;\n/**\n * Check if the given value is a valid {@link JsonRpcError} object.\n *\n * @param value - The value to check.\n * @returns Whether the given value is a valid {@link JsonRpcError} object.\n */\nfunction isJsonRpcError(value) {\n return (0, superstruct_1.is)(value, exports.JsonRpcErrorStruct);\n}\nexports.isJsonRpcError = isJsonRpcError;\n/**\n * Assert that the given value is a valid {@link JsonRpcError} object.\n *\n * @param value - The value to check.\n * @param ErrorWrapper - The error class to throw if the assertion fails.\n * Defaults to {@link AssertionError}.\n * @throws If the given value is not a valid {@link JsonRpcError} object.\n */\nfunction assertIsJsonRpcError(value,\n// eslint-disable-next-line @typescript-eslint/naming-convention\nErrorWrapper) {\n (0, assert_1.assertStruct)(value, exports.JsonRpcErrorStruct, 'Invalid JSON-RPC error', ErrorWrapper);\n}\nexports.assertIsJsonRpcError = assertIsJsonRpcError;\n/**\n * Gets a function for validating JSON-RPC request / response `id` values.\n *\n * By manipulating the options of this factory, you can control the behavior\n * of the resulting validator for some edge cases. This is useful because e.g.\n * `null` should sometimes but not always be permitted.\n *\n * Note that the empty string (`''`) is always permitted by the JSON-RPC\n * specification, but that kind of sucks and you may want to forbid it in some\n * instances anyway.\n *\n * For more details, see the\n * [JSON-RPC Specification](https://www.jsonrpc.org/specification).\n *\n * @param options - An options object.\n * @param options.permitEmptyString - Whether the empty string (i.e. `''`)\n * should be treated as a valid ID. Default: `true`\n * @param options.permitFractions - Whether fractional numbers (e.g. `1.2`)\n * should be treated as valid IDs. Default: `false`\n * @param options.permitNull - Whether `null` should be treated as a valid ID.\n * Default: `true`\n * @returns The JSON-RPC ID validator function.\n */\nfunction getJsonRpcIdValidator(options) {\n const {\n permitEmptyString,\n permitFractions,\n permitNull\n } = Object.assign({\n permitEmptyString: true,\n permitFractions: false,\n permitNull: true\n }, options);\n /**\n * Type guard for {@link JsonRpcId}.\n *\n * @param id - The JSON-RPC ID value to check.\n * @returns Whether the given ID is valid per the options given to the\n * factory.\n */\n const isValidJsonRpcId = id => {\n return Boolean(typeof id === 'number' && (permitFractions || Number.isInteger(id)) || typeof id === 'string' && (permitEmptyString || id.length > 0) || permitNull && id === null);\n };\n return isValidJsonRpcId;\n}\nexports.getJsonRpcIdValidator = getJsonRpcIdValidator;\n/**\n * Checks whether a value is JSON serializable and counts the total number\n * of bytes needed to store the serialized version of the value.\n *\n * @param jsObject - Potential JSON serializable object.\n * @param skipSizingProcess - Skip JSON size calculation (default: false).\n * @returns Tuple [isValid, plainTextSizeInBytes] containing a boolean that signals whether\n * the value was serializable and a number of bytes that it will use when serialized to JSON.\n */\nfunction validateJsonAndGetSize(jsObject, skipSizingProcess = false) {\n const seenObjects = new Set();\n /**\n * Checks whether a value is JSON serializable and counts the total number\n * of bytes needed to store the serialized version of the value.\n *\n * This function assumes the encoding of the JSON is done in UTF-8.\n *\n * @param value - Potential JSON serializable value.\n * @param skipSizing - Skip JSON size calculation (default: false).\n * @returns Tuple [isValid, plainTextSizeInBytes] containing a boolean that signals whether\n * the value was serializable and a number of bytes that it will use when serialized to JSON.\n */\n function getJsonSerializableInfo(value, skipSizing) {\n if (value === undefined) {\n return [false, 0];\n } else if (value === null) {\n // Return already specified constant size for null (special object)\n return [true, skipSizing ? 0 : misc_1.JsonSize.Null];\n }\n // Check and calculate sizes for basic (and some special) types\n const typeOfValue = typeof value;\n try {\n if (typeOfValue === 'function') {\n return [false, 0];\n } else if (typeOfValue === 'string' || value instanceof String) {\n return [true, skipSizing ? 0 : (0, misc_1.calculateStringSize)(value) + misc_1.JsonSize.Quote * 2];\n } else if (typeOfValue === 'boolean' || value instanceof Boolean) {\n if (skipSizing) {\n return [true, 0];\n }\n // eslint-disable-next-line eqeqeq\n return [true, value == true ? misc_1.JsonSize.True : misc_1.JsonSize.False];\n } else if (typeOfValue === 'number' || value instanceof Number) {\n if (skipSizing) {\n return [true, 0];\n }\n return [true, (0, misc_1.calculateNumberSize)(value)];\n } else if (value instanceof Date) {\n if (skipSizing) {\n return [true, 0];\n }\n return [true,\n // Note: Invalid dates will serialize to null\n isNaN(value.getDate()) ? misc_1.JsonSize.Null : misc_1.JsonSize.Date + misc_1.JsonSize.Quote * 2];\n }\n } catch (_) {\n return [false, 0];\n }\n // If object is not plain and cannot be serialized properly,\n // stop here and return false for serialization\n if (!(0, misc_1.isPlainObject)(value) && !Array.isArray(value)) {\n return [false, 0];\n }\n // Circular object detection (handling)\n // Check if the same object already exists\n if (seenObjects.has(value)) {\n return [false, 0];\n }\n // Add new object to the seen objects set\n // Only the plain objects should be added (Primitive types are skipped)\n seenObjects.add(value);\n // Continue object decomposition\n try {\n return [true, Object.entries(value).reduce((sum, [key, nestedValue], idx, arr) => {\n // Recursively process next nested object or primitive type\n // eslint-disable-next-line prefer-const\n let [valid, size] = getJsonSerializableInfo(nestedValue, skipSizing);\n if (!valid) {\n throw new Error('JSON validation did not pass. Validation process stopped.');\n }\n // Circular object detection\n // Once a child node is visited and processed remove it from the set.\n // This will prevent false positives with the same adjacent objects.\n seenObjects.delete(value);\n if (skipSizing) {\n return 0;\n }\n // Objects will have be serialized with \"key\": value,\n // therefore we include the key in the calculation here\n const keySize = Array.isArray(value) ? 0 : key.length + misc_1.JsonSize.Comma + misc_1.JsonSize.Colon * 2;\n const separator = idx < arr.length - 1 ? misc_1.JsonSize.Comma : 0;\n return sum + keySize + size + separator;\n },\n // Starts at 2 because the serialized JSON string data (plain text)\n // will minimally contain {}/[]\n skipSizing ? 0 : misc_1.JsonSize.Wrapper * 2)];\n } catch (_) {\n return [false, 0];\n }\n }\n return getJsonSerializableInfo(jsObject, skipSizingProcess);\n}\nexports.validateJsonAndGetSize = validateJsonAndGetSize;\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('val is not a non-empty string or a valid number. val=' + JSON.stringify(val));\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(str);\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 * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n createDebug.debug = createDebug;\n createDebug.default = createDebug;\n createDebug.coerce = coerce;\n createDebug.disable = disable;\n createDebug.enable = enable;\n createDebug.enabled = enabled;\n createDebug.humanize = require('ms');\n createDebug.destroy = destroy;\n Object.keys(env).forEach(key => {\n createDebug[key] = env[key];\n });\n\n /**\n * The currently active debug mode names, and names to skip.\n */\n\n createDebug.names = [];\n createDebug.skips = [];\n\n /**\n * Map of special \"%n\" handling functions, for the debug \"format\" argument.\n *\n * Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n */\n createDebug.formatters = {};\n\n /**\n * Selects a color for a debug namespace\n * @param {String} namespace The namespace string for the debug instance to be colored\n * @return {Number|String} An ANSI color code for the given namespace\n * @api private\n */\n function selectColor(namespace) {\n let hash = 0;\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i);\n hash |= 0; // Convert to 32bit integer\n }\n return createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n }\n createDebug.selectColor = selectColor;\n\n /**\n * Create a debugger with the given `namespace`.\n *\n * @param {String} namespace\n * @return {Function}\n * @api public\n */\n function createDebug(namespace) {\n let prevTime;\n let enableOverride = null;\n let namespacesCache;\n let enabledCache;\n function debug(...args) {\n // Disabled?\n if (!debug.enabled) {\n return;\n }\n const self = debug;\n\n // Set `diff` timestamp\n const curr = Number(new Date());\n const ms = curr - (prevTime || curr);\n self.diff = ms;\n self.prev = prevTime;\n self.curr = curr;\n prevTime = curr;\n args[0] = createDebug.coerce(args[0]);\n if (typeof args[0] !== 'string') {\n // Anything else let's inspect with %O\n args.unshift('%O');\n }\n\n // Apply any `formatters` transformations\n let index = 0;\n args[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n // If we encounter an escaped % then don't increase the array index\n if (match === '%%') {\n return '%';\n }\n index++;\n const formatter = createDebug.formatters[format];\n if (typeof formatter === 'function') {\n const val = args[index];\n match = formatter.call(self, val);\n\n // Now we need to remove `args[index]` since it's inlined in the `format`\n args.splice(index, 1);\n index--;\n }\n return match;\n });\n\n // Apply env-specific formatting (colors, etc.)\n createDebug.formatArgs.call(self, args);\n const logFn = self.log || createDebug.log;\n logFn.apply(self, args);\n }\n debug.namespace = namespace;\n debug.useColors = createDebug.useColors();\n debug.color = createDebug.selectColor(namespace);\n debug.extend = extend;\n debug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n Object.defineProperty(debug, 'enabled', {\n enumerable: true,\n configurable: false,\n get: () => {\n if (enableOverride !== null) {\n return enableOverride;\n }\n if (namespacesCache !== createDebug.namespaces) {\n namespacesCache = createDebug.namespaces;\n enabledCache = createDebug.enabled(namespace);\n }\n return enabledCache;\n },\n set: v => {\n enableOverride = v;\n }\n });\n\n // Env-specific initialization logic for debug instances\n if (typeof createDebug.init === 'function') {\n createDebug.init(debug);\n }\n return debug;\n }\n function extend(namespace, delimiter) {\n const newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n newDebug.log = this.log;\n return newDebug;\n }\n\n /**\n * Enables a debug mode by namespaces. This can include modes\n * separated by a colon and wildcards.\n *\n * @param {String} namespaces\n * @api public\n */\n function enable(namespaces) {\n createDebug.save(namespaces);\n createDebug.namespaces = namespaces;\n createDebug.names = [];\n createDebug.skips = [];\n let i;\n const split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n const len = split.length;\n for (i = 0; i < len; i++) {\n if (!split[i]) {\n // ignore empty strings\n continue;\n }\n namespaces = split[i].replace(/\\*/g, '.*?');\n if (namespaces[0] === '-') {\n createDebug.skips.push(new RegExp('^' + namespaces.slice(1) + '$'));\n } else {\n createDebug.names.push(new RegExp('^' + namespaces + '$'));\n }\n }\n }\n\n /**\n * Disable debug output.\n *\n * @return {String} namespaces\n * @api public\n */\n function disable() {\n const namespaces = [...createDebug.names.map(toNamespace), ...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)].join(',');\n createDebug.enable('');\n return namespaces;\n }\n\n /**\n * Returns true if the given mode name is enabled, false otherwise.\n *\n * @param {String} name\n * @return {Boolean}\n * @api public\n */\n function enabled(name) {\n if (name[name.length - 1] === '*') {\n return true;\n }\n let i;\n let len;\n for (i = 0, len = createDebug.skips.length; i < len; i++) {\n if (createDebug.skips[i].test(name)) {\n return false;\n }\n }\n for (i = 0, len = createDebug.names.length; i < len; i++) {\n if (createDebug.names[i].test(name)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Convert regexp to namespace\n *\n * @param {RegExp} regxep\n * @return {String} namespace\n * @api private\n */\n function toNamespace(regexp) {\n return regexp.toString().substring(2, regexp.toString().length - 2).replace(/\\.\\*\\?$/, '*');\n }\n\n /**\n * Coerce `val`.\n *\n * @param {Mixed} val\n * @return {Mixed}\n * @api private\n */\n function coerce(val) {\n if (val instanceof Error) {\n return val.stack || val.message;\n }\n return val;\n }\n\n /**\n * XXX DO NOT USE. This is a temporary stub function.\n * XXX It WILL be removed in the next major release.\n */\n function destroy() {\n console.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n }\n createDebug.enable(createDebug.load());\n return createDebug;\n}\nmodule.exports = setup;","/* 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 let warned = false;\n return () => {\n if (!warned) {\n warned = true;\n console.warn('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\n/**\n * Colors.\n */\n\nexports.colors = ['#0000CC', '#0000FF', '#0033CC', '#0033FF', '#0066CC', '#0066FF', '#0099CC', '#0099FF', '#00CC00', '#00CC33', '#00CC66', '#00CC99', '#00CCCC', '#00CCFF', '#3300CC', '#3300FF', '#3333CC', '#3333FF', '#3366CC', '#3366FF', '#3399CC', '#3399FF', '#33CC00', '#33CC33', '#33CC66', '#33CC99', '#33CCCC', '#33CCFF', '#6600CC', '#6600FF', '#6633CC', '#6633FF', '#66CC00', '#66CC33', '#9900CC', '#9900FF', '#9933CC', '#9933FF', '#99CC00', '#99CC33', '#CC0000', '#CC0033', '#CC0066', '#CC0099', '#CC00CC', '#CC00FF', '#CC3300', '#CC3333', '#CC3366', '#CC3399', '#CC33CC', '#CC33FF', '#CC6600', '#CC6633', '#CC9900', '#CC9933', '#CCCC00', '#CCCC33', '#FF0000', '#FF0033', '#FF0066', '#FF0099', '#FF00CC', '#FF00FF', '#FF3300', '#FF3333', '#FF3366', '#FF3399', '#FF33CC', '#FF33FF', '#FF6600', '#FF6633', '#FF9900', '#FF9933', '#FFCC00', '#FFCC33'];\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 // NB: In an Electron preload script, document will be defined but not fully\n // initialized. Since we know we're in Chrome, we'll just detect this case\n // explicitly\n if (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n return true;\n }\n\n // Internet Explorer and Edge do not support colors.\n if (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n return false;\n }\n let m;\n\n // Is webkit? http://stackoverflow.com/a/16459606/376773\n // document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n return typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance ||\n // Is firebug? http://stackoverflow.com/a/398120/376773\n typeof window !== 'undefined' && window.console && (window.console.firebug || window.console.exception && window.console.table) ||\n // Is firefox >= v31?\n // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31 ||\n // Double check webkit in userAgent just in case we are in a worker\n 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 args[0] = (this.useColors ? '%c' : '') + this.namespace + (this.useColors ? ' %c' : ' ') + args[0] + (this.useColors ? '%c ' : ' ') + '+' + module.exports.humanize(this.diff);\n if (!this.useColors) {\n return;\n }\n const c = 'color: ' + this.color;\n args.splice(1, 0, c, 'color: inherit');\n\n // The final \"%c\" is somewhat tricky, because there could be other\n // arguments passed either before or after the %c, so we need to\n // figure out the correct index to insert the CSS into\n let index = 0;\n let lastC = 0;\n args[0].replace(/%[a-zA-Z%]/g, match => {\n if (match === '%%') {\n return;\n }\n index++;\n if (match === '%c') {\n // We only are interested in the *last* %c\n // (the user may have provided their own)\n lastC = index;\n }\n });\n args.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 try {\n if (namespaces) {\n exports.storage.setItem('debug', namespaces);\n } else {\n exports.storage.removeItem('debug');\n }\n } catch (error) {\n // Swallow\n // XXX (@Qix-) should we be logging these?\n }\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n let r;\n try {\n r = exports.storage.getItem('debug');\n } catch (error) {\n // Swallow\n // XXX (@Qix-) should we be logging these?\n }\n\n // If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n if (!r && typeof process !== 'undefined' && 'env' in process) {\n r = process.env.DEBUG;\n }\n return 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 try {\n // TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n // The Browser also has localStorage in the global context.\n return localStorage;\n } catch (error) {\n // Swallow\n // XXX (@Qix-) should we be logging these?\n }\n}\nmodule.exports = require('./common')(exports);\nconst {\n formatters\n} = 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 try {\n return JSON.stringify(v);\n } catch (error) {\n return '[UnexpectedJSONParseError]: ' + error.message;\n }\n};","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createModuleLogger = exports.createProjectLogger = void 0;\nconst debug_1 = __importDefault(require(\"debug\"));\nconst globalLogger = (0, debug_1.default)('metamask');\n/**\n * Creates a logger via the `debug` library whose log messages will be tagged\n * using the name of your project. By default, such messages will be\n * suppressed, but you can reveal them by setting the `DEBUG` environment\n * variable to `metamask:`. You can also set this variable to\n * `metamask:*` if you want to see log messages from all MetaMask projects that\n * are also using this function to create their loggers.\n *\n * @param projectName - The name of your project. This should be the name of\n * your NPM package if you're developing one.\n * @returns An instance of `debug`.\n */\nfunction createProjectLogger(projectName) {\n return globalLogger.extend(projectName);\n}\nexports.createProjectLogger = createProjectLogger;\n/**\n * Creates a logger via the `debug` library which is derived from the logger for\n * the whole project whose log messages will be tagged using the name of your\n * module. By default, such messages will be suppressed, but you can reveal them\n * by setting the `DEBUG` environment variable to\n * `metamask::`. You can also set this variable to\n * `metamask::*` if you want to see log messages from the project,\n * or `metamask:*` if you want to see log messages from all MetaMask projects.\n *\n * @param projectLogger - The logger created via {@link createProjectLogger}.\n * @param moduleName - The name of your module. You could use the name of the\n * file where you're using this logger or some other name.\n * @returns An instance of `debug`.\n */\nfunction createModuleLogger(projectLogger, moduleName) {\n return projectLogger.extend(moduleName);\n}\nexports.createModuleLogger = createModuleLogger;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.hexToBigInt = exports.hexToNumber = exports.bigIntToHex = exports.numberToHex = void 0;\nconst assert_1 = require(\"./assert\");\nconst hex_1 = require(\"./hex\");\n/**\n * Convert a number to a hexadecimal string. This verifies that the number is a\n * non-negative safe integer.\n *\n * To convert a `bigint` to a hexadecimal string instead, use\n * {@link bigIntToHex}.\n *\n * @example\n * ```typescript\n * numberToHex(0); // '0x0'\n * numberToHex(1); // '0x1'\n * numberToHex(16); // '0x10'\n * ```\n * @param value - The number to convert to a hexadecimal string.\n * @returns The hexadecimal string, with the \"0x\"-prefix.\n * @throws If the number is not a non-negative safe integer.\n */\nconst numberToHex = value => {\n (0, assert_1.assert)(typeof value === 'number', 'Value must be a number.');\n (0, assert_1.assert)(value >= 0, 'Value must be a non-negative number.');\n (0, assert_1.assert)(Number.isSafeInteger(value), 'Value is not a safe integer. Use `bigIntToHex` instead.');\n return (0, hex_1.add0x)(value.toString(16));\n};\nexports.numberToHex = numberToHex;\n/**\n * Convert a `bigint` to a hexadecimal string. This verifies that the `bigint`\n * is a non-negative integer.\n *\n * To convert a number to a hexadecimal string instead, use {@link numberToHex}.\n *\n * @example\n * ```typescript\n * bigIntToHex(0n); // '0x0'\n * bigIntToHex(1n); // '0x1'\n * bigIntToHex(16n); // '0x10'\n * ```\n * @param value - The `bigint` to convert to a hexadecimal string.\n * @returns The hexadecimal string, with the \"0x\"-prefix.\n * @throws If the `bigint` is not a non-negative integer.\n */\nconst bigIntToHex = value => {\n (0, assert_1.assert)(typeof value === 'bigint', 'Value must be a bigint.');\n (0, assert_1.assert)(value >= 0, 'Value must be a non-negative bigint.');\n return (0, hex_1.add0x)(value.toString(16));\n};\nexports.bigIntToHex = bigIntToHex;\n/**\n * Convert a hexadecimal string to a number. This verifies that the string is a\n * valid hex string, and that the resulting number is a safe integer. Both\n * \"0x\"-prefixed and unprefixed strings are supported.\n *\n * To convert a hexadecimal string to a `bigint` instead, use\n * {@link hexToBigInt}.\n *\n * @example\n * ```typescript\n * hexToNumber('0x0'); // 0\n * hexToNumber('0x1'); // 1\n * hexToNumber('0x10'); // 16\n * ```\n * @param value - The hexadecimal string to convert to a number.\n * @returns The number.\n * @throws If the value is not a valid hexadecimal string, or if the resulting\n * number is not a safe integer.\n */\nconst hexToNumber = value => {\n (0, hex_1.assertIsHexString)(value);\n // `parseInt` accepts values without the \"0x\"-prefix, whereas `Number` does\n // not. Using this is slightly faster than `Number(add0x(value))`.\n const numberValue = parseInt(value, 16);\n (0, assert_1.assert)(Number.isSafeInteger(numberValue), 'Value is not a safe integer. Use `hexToBigInt` instead.');\n return numberValue;\n};\nexports.hexToNumber = hexToNumber;\n/**\n * Convert a hexadecimal string to a `bigint`. This verifies that the string is\n * a valid hex string. Both \"0x\"-prefixed and unprefixed strings are supported.\n *\n * To convert a hexadecimal string to a number instead, use {@link hexToNumber}.\n *\n * @example\n * ```typescript\n * hexToBigInt('0x0'); // 0n\n * hexToBigInt('0x1'); // 1n\n * hexToBigInt('0x10'); // 16n\n * ```\n * @param value - The hexadecimal string to convert to a `bigint`.\n * @returns The `bigint`.\n * @throws If the value is not a valid hexadecimal string.\n */\nconst hexToBigInt = value => {\n (0, hex_1.assertIsHexString)(value);\n // The `BigInt` constructor requires the \"0x\"-prefix to parse a hex string.\n return BigInt((0, hex_1.add0x)(value));\n};\nexports.hexToBigInt = hexToBigInt;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.timeSince = exports.inMilliseconds = exports.Duration = void 0;\n/**\n * Common duration constants, in milliseconds.\n */\nvar Duration;\n(function (Duration) {\n /**\n * A millisecond.\n */\n Duration[Duration[\"Millisecond\"] = 1] = \"Millisecond\";\n /**\n * A second, in milliseconds.\n */\n Duration[Duration[\"Second\"] = 1000] = \"Second\";\n /**\n * A minute, in milliseconds.\n */\n Duration[Duration[\"Minute\"] = 60000] = \"Minute\";\n /**\n * An hour, in milliseconds.\n */\n Duration[Duration[\"Hour\"] = 3600000] = \"Hour\";\n /**\n * A day, in milliseconds.\n */\n Duration[Duration[\"Day\"] = 86400000] = \"Day\";\n /**\n * A week, in milliseconds.\n */\n Duration[Duration[\"Week\"] = 604800000] = \"Week\";\n /**\n * A year, in milliseconds.\n */\n Duration[Duration[\"Year\"] = 31536000000] = \"Year\";\n})(Duration = exports.Duration || (exports.Duration = {}));\nconst isNonNegativeInteger = number => Number.isInteger(number) && number >= 0;\nconst assertIsNonNegativeInteger = (number, name) => {\n if (!isNonNegativeInteger(number)) {\n throw new Error(`\"${name}\" must be a non-negative integer. Received: \"${number}\".`);\n }\n};\n/**\n * Calculates the millisecond value of the specified number of units of time.\n *\n * @param count - The number of units of time.\n * @param duration - The unit of time to count.\n * @returns The count multiplied by the specified duration.\n */\nfunction inMilliseconds(count, duration) {\n assertIsNonNegativeInteger(count, 'count');\n return count * duration;\n}\nexports.inMilliseconds = inMilliseconds;\n/**\n * Gets the milliseconds since a particular Unix epoch timestamp.\n *\n * @param timestamp - A Unix millisecond timestamp.\n * @returns The number of milliseconds elapsed since the specified timestamp.\n */\nfunction timeSince(timestamp) {\n assertIsNonNegativeInteger(timestamp, 'timestamp');\n return Date.now() - timestamp;\n}\nexports.timeSince = timeSince;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.satisfiesVersionRange = exports.gtRange = exports.gtVersion = exports.assertIsSemVerRange = exports.assertIsSemVerVersion = exports.isValidSemVerRange = exports.isValidSemVerVersion = exports.VersionRangeStruct = exports.VersionStruct = void 0;\nconst semver_1 = require(\"semver\");\nconst superstruct_1 = require(\"superstruct\");\nconst assert_1 = require(\"./assert\");\n/**\n * A struct for validating a version string.\n */\nexports.VersionStruct = (0, superstruct_1.refine)((0, superstruct_1.string)(), 'Version', value => {\n if ((0, semver_1.valid)(value) === null) {\n return `Expected SemVer version, got \"${value}\"`;\n }\n return true;\n});\nexports.VersionRangeStruct = (0, superstruct_1.refine)((0, superstruct_1.string)(), 'Version range', value => {\n if ((0, semver_1.validRange)(value) === null) {\n return `Expected SemVer range, got \"${value}\"`;\n }\n return true;\n});\n/**\n * Checks whether a SemVer version is valid.\n *\n * @param version - A potential version.\n * @returns `true` if the version is valid, and `false` otherwise.\n */\nfunction isValidSemVerVersion(version) {\n return (0, superstruct_1.is)(version, exports.VersionStruct);\n}\nexports.isValidSemVerVersion = isValidSemVerVersion;\n/**\n * Checks whether a SemVer version range is valid.\n *\n * @param versionRange - A potential version range.\n * @returns `true` if the version range is valid, and `false` otherwise.\n */\nfunction isValidSemVerRange(versionRange) {\n return (0, superstruct_1.is)(versionRange, exports.VersionRangeStruct);\n}\nexports.isValidSemVerRange = isValidSemVerRange;\n/**\n * Asserts that a value is a valid concrete SemVer version.\n *\n * @param version - A potential SemVer concrete version.\n */\nfunction assertIsSemVerVersion(version) {\n (0, assert_1.assertStruct)(version, exports.VersionStruct);\n}\nexports.assertIsSemVerVersion = assertIsSemVerVersion;\n/**\n * Asserts that a value is a valid SemVer range.\n *\n * @param range - A potential SemVer range.\n */\nfunction assertIsSemVerRange(range) {\n (0, assert_1.assertStruct)(range, exports.VersionRangeStruct);\n}\nexports.assertIsSemVerRange = assertIsSemVerRange;\n/**\n * Checks whether a SemVer version is greater than another.\n *\n * @param version1 - The left-hand version.\n * @param version2 - The right-hand version.\n * @returns `version1 > version2`.\n */\nfunction gtVersion(version1, version2) {\n return (0, semver_1.gt)(version1, version2);\n}\nexports.gtVersion = gtVersion;\n/**\n * Checks whether a SemVer version is greater than all possibilities in a range.\n *\n * @param version - A SemvVer version.\n * @param range - The range to check against.\n * @returns `version > range`.\n */\nfunction gtRange(version, range) {\n return (0, semver_1.gtr)(version, range);\n}\nexports.gtRange = gtRange;\n/**\n * Returns whether a SemVer version satisfies a SemVer range.\n *\n * @param version - The SemVer version to check.\n * @param versionRange - The SemVer version range to check against.\n * @returns Whether the version satisfied the version range.\n */\nfunction satisfiesVersionRange(version, versionRange) {\n return (0, semver_1.satisfies)(version, versionRange, {\n includePrerelease: true\n });\n}\nexports.satisfiesVersionRange = satisfiesVersionRange;\n","\"use strict\";\n\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 = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\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\", {\n value: true\n});\n__exportStar(require(\"./assert\"), exports);\n__exportStar(require(\"./base64\"), exports);\n__exportStar(require(\"./bytes\"), exports);\n__exportStar(require(\"./checksum\"), exports);\n__exportStar(require(\"./coercers\"), exports);\n__exportStar(require(\"./collections\"), exports);\n__exportStar(require(\"./hex\"), exports);\n__exportStar(require(\"./json\"), exports);\n__exportStar(require(\"./logging\"), exports);\n__exportStar(require(\"./misc\"), exports);\n__exportStar(require(\"./number\"), exports);\n__exportStar(require(\"./opaque\"), exports);\n__exportStar(require(\"./time\"), exports);\n__exportStar(require(\"./versions\"), exports);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createModuleLogger = exports.projectLogger = void 0;\nconst utils_1 = require(\"@metamask/utils\");\nObject.defineProperty(exports, \"createModuleLogger\", {\n enumerable: true,\n get: function () {\n return utils_1.createModuleLogger;\n }\n});\nexports.projectLogger = (0, utils_1.createProjectLogger)('eth-block-tracker');\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.PollingBlockTracker = void 0;\nconst json_rpc_random_id_1 = __importDefault(require(\"json-rpc-random-id\"));\nconst pify_1 = __importDefault(require(\"pify\"));\nconst BaseBlockTracker_1 = require(\"./BaseBlockTracker\");\nconst logging_utils_1 = require(\"./logging-utils\");\nconst log = (0, logging_utils_1.createModuleLogger)(logging_utils_1.projectLogger, 'polling-block-tracker');\nconst createRandomId = (0, json_rpc_random_id_1.default)();\nconst sec = 1000;\nclass PollingBlockTracker extends BaseBlockTracker_1.BaseBlockTracker {\n constructor(opts = {}) {\n var _a;\n // parse + validate args\n if (!opts.provider) {\n throw new Error('PollingBlockTracker - no provider specified.');\n }\n super({\n blockResetDuration: (_a = opts.blockResetDuration) !== null && _a !== void 0 ? _a : opts.pollingInterval\n });\n // config\n this._provider = opts.provider;\n this._pollingInterval = opts.pollingInterval || 20 * sec;\n this._retryTimeout = opts.retryTimeout || this._pollingInterval / 10;\n this._keepEventLoopActive = opts.keepEventLoopActive === undefined ? true : opts.keepEventLoopActive;\n this._setSkipCacheFlag = opts.setSkipCacheFlag || false;\n }\n // trigger block polling\n async checkForLatestBlock() {\n await this._updateLatestBlock();\n return await this.getLatestBlock();\n }\n async _start() {\n this._synchronize();\n }\n async _end() {\n // No-op\n }\n async _synchronize() {\n var _a;\n while (this._isRunning) {\n try {\n await this._updateLatestBlock();\n const promise = timeout(this._pollingInterval, !this._keepEventLoopActive);\n this.emit('_waitingForNextIteration');\n await promise;\n } catch (err) {\n const newErr = new Error(`PollingBlockTracker - encountered an error while attempting to update latest block:\\n${(_a = err.stack) !== null && _a !== void 0 ? _a : err}`);\n try {\n this.emit('error', newErr);\n } catch (emitErr) {\n console.error(newErr);\n }\n const promise = timeout(this._retryTimeout, !this._keepEventLoopActive);\n this.emit('_waitingForNextIteration');\n await promise;\n }\n }\n }\n async _updateLatestBlock() {\n // fetch + set latest block\n const latestBlock = await this._fetchLatestBlock();\n this._newPotentialLatest(latestBlock);\n }\n async _fetchLatestBlock() {\n const req = {\n jsonrpc: '2.0',\n id: createRandomId(),\n method: 'eth_blockNumber',\n params: []\n };\n if (this._setSkipCacheFlag) {\n req.skipCache = true;\n }\n log('Making request', req);\n const res = await (0, pify_1.default)(cb => this._provider.sendAsync(req, cb))();\n log('Got response', res);\n if (res.error) {\n throw new Error(`PollingBlockTracker - encountered error fetching block:\\n${res.error.message}`);\n }\n return res.result;\n }\n}\nexports.PollingBlockTracker = PollingBlockTracker;\n/**\n * Waits for the specified amount of time.\n *\n * @param duration - The amount of time in milliseconds.\n * @param unref - Assuming this function is run in a Node context, governs\n * whether Node should wait before the `setTimeout` has completed before ending\n * the process (true for no, false for yes). Defaults to false.\n * @returns A promise that can be used to wait.\n */\nfunction timeout(duration, unref) {\n return new Promise(resolve => {\n const timeoutRef = setTimeout(resolve, duration);\n // don't keep process open\n if (timeoutRef.unref && unref) {\n timeoutRef.unref();\n }\n });\n}\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SubscribeBlockTracker = void 0;\nconst json_rpc_random_id_1 = __importDefault(require(\"json-rpc-random-id\"));\nconst BaseBlockTracker_1 = require(\"./BaseBlockTracker\");\nconst createRandomId = (0, json_rpc_random_id_1.default)();\nclass SubscribeBlockTracker extends BaseBlockTracker_1.BaseBlockTracker {\n constructor(opts = {}) {\n // parse + validate args\n if (!opts.provider) {\n throw new Error('SubscribeBlockTracker - no provider specified.');\n }\n // BaseBlockTracker constructor\n super(opts);\n // config\n this._provider = opts.provider;\n this._subscriptionId = null;\n }\n async checkForLatestBlock() {\n return await this.getLatestBlock();\n }\n async _start() {\n if (this._subscriptionId === undefined || this._subscriptionId === null) {\n try {\n const blockNumber = await this._call('eth_blockNumber');\n this._subscriptionId = await this._call('eth_subscribe', 'newHeads');\n this._provider.on('data', this._handleSubData.bind(this));\n this._newPotentialLatest(blockNumber);\n } catch (e) {\n this.emit('error', e);\n }\n }\n }\n async _end() {\n if (this._subscriptionId !== null && this._subscriptionId !== undefined) {\n try {\n await this._call('eth_unsubscribe', this._subscriptionId);\n this._subscriptionId = null;\n } catch (e) {\n this.emit('error', e);\n }\n }\n }\n _call(method, ...params) {\n return new Promise((resolve, reject) => {\n this._provider.sendAsync({\n id: createRandomId(),\n method,\n params,\n jsonrpc: '2.0'\n }, (err, res) => {\n if (err) {\n reject(err);\n } else {\n resolve(res.result);\n }\n });\n });\n }\n _handleSubData(_, response) {\n var _a;\n if (response.method === 'eth_subscription' && ((_a = response.params) === null || _a === void 0 ? void 0 : _a.subscription) === this._subscriptionId) {\n this._newPotentialLatest(response.params.result.number);\n }\n }\n}\nexports.SubscribeBlockTracker = SubscribeBlockTracker;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\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\", {\n value: true\n});\n__exportStar(require(\"./PollingBlockTracker\"), exports);\n__exportStar(require(\"./SubscribeBlockTracker\"), exports);\n__exportStar(require(\"./types\"), exports);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst events_1 = require(\"events\");\nfunction safeApply(handler, context, args) {\n try {\n Reflect.apply(handler, context, args);\n } catch (err) {\n // Throw error after timeout so as not to interrupt the stack\n setTimeout(() => {\n throw err;\n });\n }\n}\nfunction arrayClone(arr) {\n const n = arr.length;\n const copy = new Array(n);\n for (let i = 0; i < n; i += 1) {\n copy[i] = arr[i];\n }\n return copy;\n}\nclass SafeEventEmitter extends events_1.EventEmitter {\n emit(type, ...args) {\n let doError = type === 'error';\n const events = this._events;\n if (events !== undefined) {\n doError = doError && events.error === undefined;\n } else if (!doError) {\n return false;\n }\n // If there is no 'error' event listener then throw.\n if (doError) {\n let er;\n if (args.length > 0) {\n [er] = args;\n }\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n const err = new Error(`Unhandled error.${er ? ` (${er.message})` : ''}`);\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n const handler = events[type];\n if (handler === undefined) {\n return false;\n }\n if (typeof handler === 'function') {\n safeApply(handler, this, args);\n } else {\n const len = handler.length;\n const listeners = arrayClone(handler);\n for (let i = 0; i < len; i += 1) {\n safeApply(listeners[i], this, args);\n }\n }\n return true;\n }\n}\nexports.default = SafeEventEmitter;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getUniqueId = void 0;\n// uint32 (two's complement) max\n// more conservative than Number.MAX_SAFE_INTEGER\nconst MAX = 4294967295;\nlet idCounter = Math.floor(Math.random() * MAX);\nfunction getUniqueId() {\n idCounter = (idCounter + 1) % MAX;\n return idCounter;\n}\nexports.getUniqueId = getUniqueId;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createIdRemapMiddleware = void 0;\nconst getUniqueId_1 = require(\"./getUniqueId\");\nfunction createIdRemapMiddleware() {\n return (req, res, next, _end) => {\n const originalId = req.id;\n const newId = getUniqueId_1.getUniqueId();\n req.id = newId;\n res.id = newId;\n next(done => {\n req.id = originalId;\n res.id = originalId;\n done();\n });\n };\n}\nexports.createIdRemapMiddleware = createIdRemapMiddleware;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createAsyncMiddleware = void 0;\n/**\n * JsonRpcEngine only accepts callback-based middleware directly.\n * createAsyncMiddleware exists to enable consumers to pass in async middleware\n * functions.\n *\n * Async middleware have no \"end\" function. Instead, they \"end\" if they return\n * without calling \"next\". Rather than passing in explicit return handlers,\n * async middleware can simply await \"next\", and perform operations on the\n * response object when execution resumes.\n *\n * To accomplish this, createAsyncMiddleware passes the async middleware a\n * wrapped \"next\" function. That function calls the internal JsonRpcEngine\n * \"next\" function with a return handler that resolves a promise when called.\n *\n * The return handler will always be called. Its resolution of the promise\n * enables the control flow described above.\n */\nfunction createAsyncMiddleware(asyncMiddleware) {\n return async (req, res, next, end) => {\n // nextPromise is the key to the implementation\n // it is resolved by the return handler passed to the\n // \"next\" function\n let resolveNextPromise;\n const nextPromise = new Promise(resolve => {\n resolveNextPromise = resolve;\n });\n let returnHandlerCallback = null;\n let nextWasCalled = false;\n // This will be called by the consumer's async middleware.\n const asyncNext = async () => {\n nextWasCalled = true;\n // We pass a return handler to next(). When it is called by the engine,\n // the consumer's async middleware will resume executing.\n // eslint-disable-next-line node/callback-return\n next(runReturnHandlersCallback => {\n // This callback comes from JsonRpcEngine._runReturnHandlers\n returnHandlerCallback = runReturnHandlersCallback;\n resolveNextPromise();\n });\n await nextPromise;\n };\n try {\n await asyncMiddleware(req, res, asyncNext);\n if (nextWasCalled) {\n await nextPromise; // we must wait until the return handler is called\n returnHandlerCallback(null);\n } else {\n end(null);\n }\n } catch (error) {\n if (returnHandlerCallback) {\n returnHandlerCallback(error);\n } else {\n end(error);\n }\n }\n };\n}\nexports.createAsyncMiddleware = createAsyncMiddleware;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.createScaffoldMiddleware = void 0;\nfunction createScaffoldMiddleware(handlers) {\n return (req, res, next, end) => {\n const handler = handlers[req.method];\n // if no handler, return\n if (handler === undefined) {\n return next();\n }\n // if handler is fn, call as middleware\n if (typeof handler === 'function') {\n return handler(req, res, next, end);\n }\n // if handler is some other value, use as result\n res.result = handler;\n return end();\n };\n}\nexports.createScaffoldMiddleware = createScaffoldMiddleware;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst events_1 = require(\"events\");\nfunction safeApply(handler, context, args) {\n try {\n Reflect.apply(handler, context, args);\n } catch (err) {\n // Throw error after timeout so as not to interrupt the stack\n setTimeout(() => {\n throw err;\n });\n }\n}\nfunction arrayClone(arr) {\n const n = arr.length;\n const copy = new Array(n);\n for (let i = 0; i < n; i += 1) {\n copy[i] = arr[i];\n }\n return copy;\n}\nclass SafeEventEmitter extends events_1.EventEmitter {\n emit(type, ...args) {\n let doError = type === 'error';\n const events = this._events;\n if (events !== undefined) {\n doError = doError && events.error === undefined;\n } else if (!doError) {\n return false;\n }\n // If there is no 'error' event listener then throw.\n if (doError) {\n let er;\n if (args.length > 0) {\n [er] = args;\n }\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n const err = new Error(`Unhandled error.${er ? ` (${er.message})` : ''}`);\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n const handler = events[type];\n if (handler === undefined) {\n return false;\n }\n if (typeof handler === 'function') {\n safeApply(handler, this, args);\n } else {\n const len = handler.length;\n const listeners = arrayClone(handler);\n for (let i = 0; i < len; i += 1) {\n safeApply(listeners[i], this, args);\n }\n }\n return true;\n }\n}\nexports.default = SafeEventEmitter;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.EthereumProviderError = exports.EthereumRpcError = void 0;\nconst fast_safe_stringify_1 = require(\"fast-safe-stringify\");\n/**\n * Error subclass implementing JSON RPC 2.0 errors and Ethereum RPC errors\n * per EIP-1474.\n * Permits any integer error code.\n */\nclass EthereumRpcError extends Error {\n constructor(code, message, data) {\n if (!Number.isInteger(code)) {\n throw new Error('\"code\" must be an integer.');\n }\n if (!message || typeof message !== 'string') {\n throw new Error('\"message\" must be a nonempty string.');\n }\n super(message);\n this.code = code;\n if (data !== undefined) {\n this.data = data;\n }\n }\n /**\n * Returns a plain object with all public class properties.\n */\n serialize() {\n const serialized = {\n code: this.code,\n message: this.message\n };\n if (this.data !== undefined) {\n serialized.data = this.data;\n }\n if (this.stack) {\n serialized.stack = this.stack;\n }\n return serialized;\n }\n /**\n * Return a string representation of the serialized error, omitting\n * any circular references.\n */\n toString() {\n return fast_safe_stringify_1.default(this.serialize(), stringifyReplacer, 2);\n }\n}\nexports.EthereumRpcError = EthereumRpcError;\n/**\n * Error subclass implementing Ethereum Provider errors per EIP-1193.\n * Permits integer error codes in the [ 1000 <= 4999 ] range.\n */\nclass EthereumProviderError extends EthereumRpcError {\n /**\n * Create an Ethereum Provider JSON-RPC error.\n * `code` must be an integer in the 1000 <= 4999 range.\n */\n constructor(code, message, data) {\n if (!isValidEthProviderCode(code)) {\n throw new Error('\"code\" must be an integer such that: 1000 <= code <= 4999');\n }\n super(code, message, data);\n }\n}\nexports.EthereumProviderError = EthereumProviderError;\n// Internal\nfunction isValidEthProviderCode(code) {\n return Number.isInteger(code) && code >= 1000 && code <= 4999;\n}\nfunction stringifyReplacer(_, value) {\n if (value === '[Circular]') {\n return undefined;\n }\n return value;\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.errorValues = exports.errorCodes = void 0;\nexports.errorCodes = {\n rpc: {\n invalidInput: -32000,\n resourceNotFound: -32001,\n resourceUnavailable: -32002,\n transactionRejected: -32003,\n methodNotSupported: -32004,\n limitExceeded: -32005,\n parse: -32700,\n invalidRequest: -32600,\n methodNotFound: -32601,\n invalidParams: -32602,\n internal: -32603\n },\n provider: {\n userRejectedRequest: 4001,\n unauthorized: 4100,\n unsupportedMethod: 4200,\n disconnected: 4900,\n chainDisconnected: 4901\n }\n};\nexports.errorValues = {\n '-32700': {\n standard: 'JSON RPC 2.0',\n message: 'Invalid JSON was received by the server. An error occurred on the server while parsing the JSON text.'\n },\n '-32600': {\n standard: 'JSON RPC 2.0',\n message: 'The JSON sent is not a valid Request object.'\n },\n '-32601': {\n standard: 'JSON RPC 2.0',\n message: 'The method does not exist / is not available.'\n },\n '-32602': {\n standard: 'JSON RPC 2.0',\n message: 'Invalid method parameter(s).'\n },\n '-32603': {\n standard: 'JSON RPC 2.0',\n message: 'Internal JSON-RPC error.'\n },\n '-32000': {\n standard: 'EIP-1474',\n message: 'Invalid input.'\n },\n '-32001': {\n standard: 'EIP-1474',\n message: 'Resource not found.'\n },\n '-32002': {\n standard: 'EIP-1474',\n message: 'Resource unavailable.'\n },\n '-32003': {\n standard: 'EIP-1474',\n message: 'Transaction rejected.'\n },\n '-32004': {\n standard: 'EIP-1474',\n message: 'Method not supported.'\n },\n '-32005': {\n standard: 'EIP-1474',\n message: 'Request limit exceeded.'\n },\n '4001': {\n standard: 'EIP-1193',\n message: 'User rejected the request.'\n },\n '4100': {\n standard: 'EIP-1193',\n message: 'The requested account and/or method has not been authorized by the user.'\n },\n '4200': {\n standard: 'EIP-1193',\n message: 'The requested method is not supported by this Ethereum provider.'\n },\n '4900': {\n standard: 'EIP-1193',\n message: 'The provider is disconnected from all chains.'\n },\n '4901': {\n standard: 'EIP-1193',\n message: 'The provider is disconnected from the specified chain.'\n }\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.serializeError = exports.isValidCode = exports.getMessageFromCode = exports.JSON_RPC_SERVER_ERROR_MESSAGE = void 0;\nconst error_constants_1 = require(\"./error-constants\");\nconst classes_1 = require(\"./classes\");\nconst FALLBACK_ERROR_CODE = error_constants_1.errorCodes.rpc.internal;\nconst FALLBACK_MESSAGE = 'Unspecified error message. This is a bug, please report it.';\nconst FALLBACK_ERROR = {\n code: FALLBACK_ERROR_CODE,\n message: getMessageFromCode(FALLBACK_ERROR_CODE)\n};\nexports.JSON_RPC_SERVER_ERROR_MESSAGE = 'Unspecified server error.';\n/**\n * Gets the message for a given code, or a fallback message if the code has\n * no corresponding message.\n */\nfunction getMessageFromCode(code, fallbackMessage = FALLBACK_MESSAGE) {\n if (Number.isInteger(code)) {\n const codeString = code.toString();\n if (hasKey(error_constants_1.errorValues, codeString)) {\n return error_constants_1.errorValues[codeString].message;\n }\n if (isJsonRpcServerError(code)) {\n return exports.JSON_RPC_SERVER_ERROR_MESSAGE;\n }\n }\n return fallbackMessage;\n}\nexports.getMessageFromCode = getMessageFromCode;\n/**\n * Returns whether the given code is valid.\n * A code is only valid if it has a message.\n */\nfunction isValidCode(code) {\n if (!Number.isInteger(code)) {\n return false;\n }\n const codeString = code.toString();\n if (error_constants_1.errorValues[codeString]) {\n return true;\n }\n if (isJsonRpcServerError(code)) {\n return true;\n }\n return false;\n}\nexports.isValidCode = isValidCode;\n/**\n * Serializes the given error to an Ethereum JSON RPC-compatible error object.\n * Merely copies the given error's values if it is already compatible.\n * If the given error is not fully compatible, it will be preserved on the\n * returned object's data.originalError property.\n */\nfunction serializeError(error, {\n fallbackError = FALLBACK_ERROR,\n shouldIncludeStack = false\n} = {}) {\n var _a, _b;\n if (!fallbackError || !Number.isInteger(fallbackError.code) || typeof fallbackError.message !== 'string') {\n throw new Error('Must provide fallback error with integer number code and string message.');\n }\n if (error instanceof classes_1.EthereumRpcError) {\n return error.serialize();\n }\n const serialized = {};\n if (error && typeof error === 'object' && !Array.isArray(error) && hasKey(error, 'code') && isValidCode(error.code)) {\n const _error = error;\n serialized.code = _error.code;\n if (_error.message && typeof _error.message === 'string') {\n serialized.message = _error.message;\n if (hasKey(_error, 'data')) {\n serialized.data = _error.data;\n }\n } else {\n serialized.message = getMessageFromCode(serialized.code);\n serialized.data = {\n originalError: assignOriginalError(error)\n };\n }\n } else {\n serialized.code = fallbackError.code;\n const message = (_a = error) === null || _a === void 0 ? void 0 : _a.message;\n serialized.message = message && typeof message === 'string' ? message : fallbackError.message;\n serialized.data = {\n originalError: assignOriginalError(error)\n };\n }\n const stack = (_b = error) === null || _b === void 0 ? void 0 : _b.stack;\n if (shouldIncludeStack && error && stack && typeof stack === 'string') {\n serialized.stack = stack;\n }\n return serialized;\n}\nexports.serializeError = serializeError;\n// Internal\nfunction isJsonRpcServerError(code) {\n return code >= -32099 && code <= -32000;\n}\nfunction assignOriginalError(error) {\n if (error && typeof error === 'object' && !Array.isArray(error)) {\n return Object.assign({}, error);\n }\n return error;\n}\nfunction hasKey(obj, key) {\n return Object.prototype.hasOwnProperty.call(obj, key);\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ethErrors = void 0;\nconst classes_1 = require(\"./classes\");\nconst utils_1 = require(\"./utils\");\nconst error_constants_1 = require(\"./error-constants\");\nexports.ethErrors = {\n rpc: {\n /**\n * Get a JSON RPC 2.0 Parse (-32700) error.\n */\n parse: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.parse, arg),\n /**\n * Get a JSON RPC 2.0 Invalid Request (-32600) error.\n */\n invalidRequest: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.invalidRequest, arg),\n /**\n * Get a JSON RPC 2.0 Invalid Params (-32602) error.\n */\n invalidParams: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.invalidParams, arg),\n /**\n * Get a JSON RPC 2.0 Method Not Found (-32601) error.\n */\n methodNotFound: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.methodNotFound, arg),\n /**\n * Get a JSON RPC 2.0 Internal (-32603) error.\n */\n internal: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.internal, arg),\n /**\n * Get a JSON RPC 2.0 Server error.\n * Permits integer error codes in the [ -32099 <= -32005 ] range.\n * Codes -32000 through -32004 are reserved by EIP-1474.\n */\n server: opts => {\n if (!opts || typeof opts !== 'object' || Array.isArray(opts)) {\n throw new Error('Ethereum RPC Server errors must provide single object argument.');\n }\n const {\n code\n } = opts;\n if (!Number.isInteger(code) || code > -32005 || code < -32099) {\n throw new Error('\"code\" must be an integer such that: -32099 <= code <= -32005');\n }\n return getEthJsonRpcError(code, opts);\n },\n /**\n * Get an Ethereum JSON RPC Invalid Input (-32000) error.\n */\n invalidInput: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.invalidInput, arg),\n /**\n * Get an Ethereum JSON RPC Resource Not Found (-32001) error.\n */\n resourceNotFound: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.resourceNotFound, arg),\n /**\n * Get an Ethereum JSON RPC Resource Unavailable (-32002) error.\n */\n resourceUnavailable: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.resourceUnavailable, arg),\n /**\n * Get an Ethereum JSON RPC Transaction Rejected (-32003) error.\n */\n transactionRejected: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.transactionRejected, arg),\n /**\n * Get an Ethereum JSON RPC Method Not Supported (-32004) error.\n */\n methodNotSupported: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.methodNotSupported, arg),\n /**\n * Get an Ethereum JSON RPC Limit Exceeded (-32005) error.\n */\n limitExceeded: arg => getEthJsonRpcError(error_constants_1.errorCodes.rpc.limitExceeded, arg)\n },\n provider: {\n /**\n * Get an Ethereum Provider User Rejected Request (4001) error.\n */\n userRejectedRequest: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.userRejectedRequest, arg);\n },\n /**\n * Get an Ethereum Provider Unauthorized (4100) error.\n */\n unauthorized: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.unauthorized, arg);\n },\n /**\n * Get an Ethereum Provider Unsupported Method (4200) error.\n */\n unsupportedMethod: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.unsupportedMethod, arg);\n },\n /**\n * Get an Ethereum Provider Not Connected (4900) error.\n */\n disconnected: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.disconnected, arg);\n },\n /**\n * Get an Ethereum Provider Chain Not Connected (4901) error.\n */\n chainDisconnected: arg => {\n return getEthProviderError(error_constants_1.errorCodes.provider.chainDisconnected, arg);\n },\n /**\n * Get a custom Ethereum Provider error.\n */\n custom: opts => {\n if (!opts || typeof opts !== 'object' || Array.isArray(opts)) {\n throw new Error('Ethereum Provider custom errors must provide single object argument.');\n }\n const {\n code,\n message,\n data\n } = opts;\n if (!message || typeof message !== 'string') {\n throw new Error('\"message\" must be a nonempty string');\n }\n return new classes_1.EthereumProviderError(code, message, data);\n }\n }\n};\n// Internal\nfunction getEthJsonRpcError(code, arg) {\n const [message, data] = parseOpts(arg);\n return new classes_1.EthereumRpcError(code, message || utils_1.getMessageFromCode(code), data);\n}\nfunction getEthProviderError(code, arg) {\n const [message, data] = parseOpts(arg);\n return new classes_1.EthereumProviderError(code, message || utils_1.getMessageFromCode(code), data);\n}\nfunction parseOpts(arg) {\n if (arg) {\n if (typeof arg === 'string') {\n return [arg];\n } else if (typeof arg === 'object' && !Array.isArray(arg)) {\n const {\n message,\n data\n } = arg;\n if (message && typeof message !== 'string') {\n throw new Error('Must specify string message.');\n }\n return [message || undefined, data];\n }\n }\n return [];\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getMessageFromCode = exports.serializeError = exports.EthereumProviderError = exports.EthereumRpcError = exports.ethErrors = exports.errorCodes = void 0;\nconst classes_1 = require(\"./classes\");\nObject.defineProperty(exports, \"EthereumRpcError\", {\n enumerable: true,\n get: function () {\n return classes_1.EthereumRpcError;\n }\n});\nObject.defineProperty(exports, \"EthereumProviderError\", {\n enumerable: true,\n get: function () {\n return classes_1.EthereumProviderError;\n }\n});\nconst utils_1 = require(\"./utils\");\nObject.defineProperty(exports, \"serializeError\", {\n enumerable: true,\n get: function () {\n return utils_1.serializeError;\n }\n});\nObject.defineProperty(exports, \"getMessageFromCode\", {\n enumerable: true,\n get: function () {\n return utils_1.getMessageFromCode;\n }\n});\nconst errors_1 = require(\"./errors\");\nObject.defineProperty(exports, \"ethErrors\", {\n enumerable: true,\n get: function () {\n return errors_1.ethErrors;\n }\n});\nconst error_constants_1 = require(\"./error-constants\");\nObject.defineProperty(exports, \"errorCodes\", {\n enumerable: true,\n get: function () {\n return error_constants_1.errorCodes;\n }\n});\n","\"use strict\";\n\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.JsonRpcEngine = void 0;\nconst safe_event_emitter_1 = __importDefault(require(\"@metamask/safe-event-emitter\"));\nconst eth_rpc_errors_1 = require(\"eth-rpc-errors\");\n/**\n * A JSON-RPC request and response processor.\n * Give it a stack of middleware, pass it requests, and get back responses.\n */\nclass JsonRpcEngine extends safe_event_emitter_1.default {\n constructor() {\n super();\n this._middleware = [];\n }\n /**\n * Add a middleware function to the engine's middleware stack.\n *\n * @param middleware - The middleware function to add.\n */\n push(middleware) {\n this._middleware.push(middleware);\n }\n handle(req, cb) {\n if (cb && typeof cb !== 'function') {\n throw new Error('\"callback\" must be a function if provided.');\n }\n if (Array.isArray(req)) {\n if (cb) {\n return this._handleBatch(req, cb);\n }\n return this._handleBatch(req);\n }\n if (cb) {\n return this._handle(req, cb);\n }\n return this._promiseHandle(req);\n }\n /**\n * Returns this engine as a middleware function that can be pushed to other\n * engines.\n *\n * @returns This engine as a middleware function.\n */\n asMiddleware() {\n return async (req, res, next, end) => {\n try {\n const [middlewareError, isComplete, returnHandlers] = await JsonRpcEngine._runAllMiddleware(req, res, this._middleware);\n if (isComplete) {\n await JsonRpcEngine._runReturnHandlers(returnHandlers);\n return end(middlewareError);\n }\n return next(async handlerCallback => {\n try {\n await JsonRpcEngine._runReturnHandlers(returnHandlers);\n } catch (error) {\n return handlerCallback(error);\n }\n return handlerCallback();\n });\n } catch (error) {\n return end(error);\n }\n };\n }\n async _handleBatch(reqs, cb) {\n // The order here is important\n try {\n // 2. Wait for all requests to finish, or throw on some kind of fatal\n // error\n const responses = await Promise.all(\n // 1. Begin executing each request in the order received\n reqs.map(this._promiseHandle.bind(this)));\n // 3. Return batch response\n if (cb) {\n return cb(null, responses);\n }\n return responses;\n } catch (error) {\n if (cb) {\n return cb(error);\n }\n throw error;\n }\n }\n /**\n * A promise-wrapped _handle.\n */\n _promiseHandle(req) {\n return new Promise(resolve => {\n this._handle(req, (_err, res) => {\n // There will always be a response, and it will always have any error\n // that is caught and propagated.\n resolve(res);\n });\n });\n }\n /**\n * Ensures that the request object is valid, processes it, and passes any\n * error and the response object to the given callback.\n *\n * Does not reject.\n */\n async _handle(callerReq, cb) {\n if (!callerReq || Array.isArray(callerReq) || typeof callerReq !== 'object') {\n const error = new eth_rpc_errors_1.EthereumRpcError(eth_rpc_errors_1.errorCodes.rpc.invalidRequest, `Requests must be plain objects. Received: ${typeof callerReq}`, {\n request: callerReq\n });\n return cb(error, {\n id: undefined,\n jsonrpc: '2.0',\n error\n });\n }\n if (typeof callerReq.method !== 'string') {\n const error = new eth_rpc_errors_1.EthereumRpcError(eth_rpc_errors_1.errorCodes.rpc.invalidRequest, `Must specify a string method. Received: ${typeof callerReq.method}`, {\n request: callerReq\n });\n return cb(error, {\n id: callerReq.id,\n jsonrpc: '2.0',\n error\n });\n }\n const req = Object.assign({}, callerReq);\n const res = {\n id: req.id,\n jsonrpc: req.jsonrpc\n };\n let error = null;\n try {\n await this._processRequest(req, res);\n } catch (_error) {\n // A request handler error, a re-thrown middleware error, or something\n // unexpected.\n error = _error;\n }\n if (error) {\n // Ensure no result is present on an errored response\n delete res.result;\n if (!res.error) {\n res.error = eth_rpc_errors_1.serializeError(error);\n }\n }\n return cb(error, res);\n }\n /**\n * For the given request and response, runs all middleware and their return\n * handlers, if any, and ensures that internal request processing semantics\n * are satisfied.\n */\n async _processRequest(req, res) {\n const [error, isComplete, returnHandlers] = await JsonRpcEngine._runAllMiddleware(req, res, this._middleware);\n // Throw if \"end\" was not called, or if the response has neither a result\n // nor an error.\n JsonRpcEngine._checkForCompletion(req, res, isComplete);\n // The return handlers should run even if an error was encountered during\n // middleware processing.\n await JsonRpcEngine._runReturnHandlers(returnHandlers);\n // Now we re-throw the middleware processing error, if any, to catch it\n // further up the call chain.\n if (error) {\n throw error;\n }\n }\n /**\n * Serially executes the given stack of middleware.\n *\n * @returns An array of any error encountered during middleware execution,\n * a boolean indicating whether the request was completed, and an array of\n * middleware-defined return handlers.\n */\n static async _runAllMiddleware(req, res, middlewareStack) {\n const returnHandlers = [];\n let error = null;\n let isComplete = false;\n // Go down stack of middleware, call and collect optional returnHandlers\n for (const middleware of middlewareStack) {\n [error, isComplete] = await JsonRpcEngine._runMiddleware(req, res, middleware, returnHandlers);\n if (isComplete) {\n break;\n }\n }\n return [error, isComplete, returnHandlers.reverse()];\n }\n /**\n * Runs an individual middleware.\n *\n * @returns An array of any error encountered during middleware exection,\n * and a boolean indicating whether the request should end.\n */\n static _runMiddleware(req, res, middleware, returnHandlers) {\n return new Promise(resolve => {\n const end = err => {\n const error = err || res.error;\n if (error) {\n res.error = eth_rpc_errors_1.serializeError(error);\n }\n // True indicates that the request should end\n resolve([error, true]);\n };\n const next = returnHandler => {\n if (res.error) {\n end(res.error);\n } else {\n if (returnHandler) {\n if (typeof returnHandler !== 'function') {\n end(new eth_rpc_errors_1.EthereumRpcError(eth_rpc_errors_1.errorCodes.rpc.internal, `JsonRpcEngine: \"next\" return handlers must be functions. ` + `Received \"${typeof returnHandler}\" for request:\\n${jsonify(req)}`, {\n request: req\n }));\n }\n returnHandlers.push(returnHandler);\n }\n // False indicates that the request should not end\n resolve([null, false]);\n }\n };\n try {\n middleware(req, res, next, end);\n } catch (error) {\n end(error);\n }\n });\n }\n /**\n * Serially executes array of return handlers. The request and response are\n * assumed to be in their scope.\n */\n static async _runReturnHandlers(handlers) {\n for (const handler of handlers) {\n await new Promise((resolve, reject) => {\n handler(err => err ? reject(err) : resolve());\n });\n }\n }\n /**\n * Throws an error if the response has neither a result nor an error, or if\n * the \"isComplete\" flag is falsy.\n */\n static _checkForCompletion(req, res, isComplete) {\n if (!('result' in res) && !('error' in res)) {\n throw new eth_rpc_errors_1.EthereumRpcError(eth_rpc_errors_1.errorCodes.rpc.internal, `JsonRpcEngine: Response has no error or result for request:\\n${jsonify(req)}`, {\n request: req\n });\n }\n if (!isComplete) {\n throw new eth_rpc_errors_1.EthereumRpcError(eth_rpc_errors_1.errorCodes.rpc.internal, `JsonRpcEngine: Nothing ended request:\\n${jsonify(req)}`, {\n request: req\n });\n }\n }\n}\nexports.JsonRpcEngine = JsonRpcEngine;\nfunction jsonify(request) {\n return JSON.stringify(request, null, 2);\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.mergeMiddleware = void 0;\nconst JsonRpcEngine_1 = require(\"./JsonRpcEngine\");\nfunction mergeMiddleware(middlewareStack) {\n const engine = new JsonRpcEngine_1.JsonRpcEngine();\n middlewareStack.forEach(middleware => engine.push(middleware));\n return engine.asMiddleware();\n}\nexports.mergeMiddleware = mergeMiddleware;\n","\"use strict\";\n\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\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\", {\n value: true\n});\n__exportStar(require(\"./idRemapMiddleware\"), exports);\n__exportStar(require(\"./createAsyncMiddleware\"), exports);\n__exportStar(require(\"./createScaffoldMiddleware\"), exports);\n__exportStar(require(\"./getUniqueId\"), exports);\n__exportStar(require(\"./JsonRpcEngine\"), exports);\n__exportStar(require(\"./mergeMiddleware\"), exports);\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar tslib_1 = require(\"tslib\");\nvar Semaphore = /** @class */function () {\n function Semaphore(_maxConcurrency) {\n this._maxConcurrency = _maxConcurrency;\n this._queue = [];\n if (_maxConcurrency <= 0) {\n throw new Error('semaphore must be initialized to a positive value');\n }\n this._value = _maxConcurrency;\n }\n Semaphore.prototype.acquire = function () {\n var _this = this;\n var locked = this.isLocked();\n var ticket = new Promise(function (r) {\n return _this._queue.push(r);\n });\n if (!locked) this._dispatch();\n return ticket;\n };\n Semaphore.prototype.runExclusive = function (callback) {\n return tslib_1.__awaiter(this, void 0, void 0, function () {\n var _a, value, release;\n return tslib_1.__generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n return [4 /*yield*/, this.acquire()];\n case 1:\n _a = _b.sent(), value = _a[0], release = _a[1];\n _b.label = 2;\n case 2:\n _b.trys.push([2,, 4, 5]);\n return [4 /*yield*/, callback(value)];\n case 3:\n return [2 /*return*/, _b.sent()];\n case 4:\n release();\n return [7 /*endfinally*/];\n case 5:\n return [2 /*return*/];\n }\n });\n });\n };\n Semaphore.prototype.isLocked = function () {\n return this._value <= 0;\n };\n Semaphore.prototype.release = function () {\n if (this._maxConcurrency > 1) {\n throw new Error('this method is unavailabel on semaphores with concurrency > 1; use the scoped release returned by acquire instead');\n }\n if (this._currentReleaser) {\n var releaser = this._currentReleaser;\n this._currentReleaser = undefined;\n releaser();\n }\n };\n Semaphore.prototype._dispatch = function () {\n var _this = this;\n var nextConsumer = this._queue.shift();\n if (!nextConsumer) return;\n var released = false;\n this._currentReleaser = function () {\n if (released) return;\n released = true;\n _this._value++;\n _this._dispatch();\n };\n nextConsumer([this._value--, this._currentReleaser]);\n };\n return Semaphore;\n}();\nexports.default = Semaphore;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar tslib_1 = require(\"tslib\");\nvar Semaphore_1 = require(\"./Semaphore\");\nvar Mutex = /** @class */function () {\n function Mutex() {\n this._semaphore = new Semaphore_1.default(1);\n }\n Mutex.prototype.acquire = function () {\n return tslib_1.__awaiter(this, void 0, void 0, function () {\n var _a, releaser;\n return tslib_1.__generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n return [4 /*yield*/, this._semaphore.acquire()];\n case 1:\n _a = _b.sent(), releaser = _a[1];\n return [2 /*return*/, releaser];\n }\n });\n });\n };\n Mutex.prototype.runExclusive = function (callback) {\n return this._semaphore.runExclusive(function () {\n return callback();\n });\n };\n Mutex.prototype.isLocked = function () {\n return this._semaphore.isLocked();\n };\n Mutex.prototype.release = function () {\n this._semaphore.release();\n };\n return Mutex;\n}();\nexports.default = Mutex;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.withTimeout = void 0;\nvar tslib_1 = require(\"tslib\");\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nfunction withTimeout(sync, timeout, timeoutError) {\n var _this = this;\n if (timeoutError === void 0) {\n timeoutError = new Error('timeout');\n }\n return {\n acquire: function () {\n return new Promise(function (resolve, reject) {\n return tslib_1.__awaiter(_this, void 0, void 0, function () {\n var isTimeout, ticket, release;\n return tslib_1.__generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n isTimeout = false;\n setTimeout(function () {\n isTimeout = true;\n reject(timeoutError);\n }, timeout);\n return [4 /*yield*/, sync.acquire()];\n case 1:\n ticket = _a.sent();\n if (isTimeout) {\n release = Array.isArray(ticket) ? ticket[1] : ticket;\n release();\n } else {\n resolve(ticket);\n }\n return [2 /*return*/];\n }\n });\n });\n });\n },\n runExclusive: function (callback) {\n return tslib_1.__awaiter(this, void 0, void 0, function () {\n var release, ticket;\n return tslib_1.__generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n release = function () {\n return undefined;\n };\n _a.label = 1;\n case 1:\n _a.trys.push([1,, 7, 8]);\n return [4 /*yield*/, this.acquire()];\n case 2:\n ticket = _a.sent();\n if (!Array.isArray(ticket)) return [3 /*break*/, 4];\n release = ticket[1];\n return [4 /*yield*/, callback(ticket[0])];\n case 3:\n return [2 /*return*/, _a.sent()];\n case 4:\n release = ticket;\n return [4 /*yield*/, callback()];\n case 5:\n return [2 /*return*/, _a.sent()];\n case 6:\n return [3 /*break*/, 8];\n case 7:\n release();\n return [7 /*endfinally*/];\n case 8:\n return [2 /*return*/];\n }\n });\n });\n },\n release: function () {\n sync.release();\n },\n isLocked: function () {\n return sync.isLocked();\n }\n };\n}\nexports.withTimeout = withTimeout;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.withTimeout = exports.Semaphore = exports.Mutex = void 0;\nvar Mutex_1 = require(\"./Mutex\");\nObject.defineProperty(exports, \"Mutex\", {\n enumerable: true,\n get: function () {\n return Mutex_1.default;\n }\n});\nvar Semaphore_1 = require(\"./Semaphore\");\nObject.defineProperty(exports, \"Semaphore\", {\n enumerable: true,\n get: function () {\n return Semaphore_1.default;\n }\n});\nvar withTimeout_1 = require(\"./withTimeout\");\nObject.defineProperty(exports, \"withTimeout\", {\n enumerable: true,\n get: function () {\n return withTimeout_1.withTimeout;\n }\n});","module.exports = extend;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction extend() {\n var target = {};\n for (var i = 0; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n}","const extend = require('xtend');\nconst createRandomId = require('json-rpc-random-id')();\nmodule.exports = EthQuery;\nfunction EthQuery(provider) {\n const self = this;\n self.currentProvider = provider;\n}\n\n//\n// base queries\n//\n\n// default block\nEthQuery.prototype.getBalance = generateFnWithDefaultBlockFor(2, 'eth_getBalance');\nEthQuery.prototype.getCode = generateFnWithDefaultBlockFor(2, 'eth_getCode');\nEthQuery.prototype.getTransactionCount = generateFnWithDefaultBlockFor(2, 'eth_getTransactionCount');\nEthQuery.prototype.getStorageAt = generateFnWithDefaultBlockFor(3, 'eth_getStorageAt');\nEthQuery.prototype.call = generateFnWithDefaultBlockFor(2, 'eth_call');\n// standard\nEthQuery.prototype.protocolVersion = generateFnFor('eth_protocolVersion');\nEthQuery.prototype.syncing = generateFnFor('eth_syncing');\nEthQuery.prototype.coinbase = generateFnFor('eth_coinbase');\nEthQuery.prototype.mining = generateFnFor('eth_mining');\nEthQuery.prototype.hashrate = generateFnFor('eth_hashrate');\nEthQuery.prototype.gasPrice = generateFnFor('eth_gasPrice');\nEthQuery.prototype.accounts = generateFnFor('eth_accounts');\nEthQuery.prototype.blockNumber = generateFnFor('eth_blockNumber');\nEthQuery.prototype.getBlockTransactionCountByHash = generateFnFor('eth_getBlockTransactionCountByHash');\nEthQuery.prototype.getBlockTransactionCountByNumber = generateFnFor('eth_getBlockTransactionCountByNumber');\nEthQuery.prototype.getUncleCountByBlockHash = generateFnFor('eth_getUncleCountByBlockHash');\nEthQuery.prototype.getUncleCountByBlockNumber = generateFnFor('eth_getUncleCountByBlockNumber');\nEthQuery.prototype.sign = generateFnFor('eth_sign');\nEthQuery.prototype.sendTransaction = generateFnFor('eth_sendTransaction');\nEthQuery.prototype.sendRawTransaction = generateFnFor('eth_sendRawTransaction');\nEthQuery.prototype.estimateGas = generateFnFor('eth_estimateGas');\nEthQuery.prototype.getBlockByHash = generateFnFor('eth_getBlockByHash');\nEthQuery.prototype.getBlockByNumber = generateFnFor('eth_getBlockByNumber');\nEthQuery.prototype.getTransactionByHash = generateFnFor('eth_getTransactionByHash');\nEthQuery.prototype.getTransactionByBlockHashAndIndex = generateFnFor('eth_getTransactionByBlockHashAndIndex');\nEthQuery.prototype.getTransactionByBlockNumberAndIndex = generateFnFor('eth_getTransactionByBlockNumberAndIndex');\nEthQuery.prototype.getTransactionReceipt = generateFnFor('eth_getTransactionReceipt');\nEthQuery.prototype.getUncleByBlockHashAndIndex = generateFnFor('eth_getUncleByBlockHashAndIndex');\nEthQuery.prototype.getUncleByBlockNumberAndIndex = generateFnFor('eth_getUncleByBlockNumberAndIndex');\nEthQuery.prototype.getCompilers = generateFnFor('eth_getCompilers');\nEthQuery.prototype.compileLLL = generateFnFor('eth_compileLLL');\nEthQuery.prototype.compileSolidity = generateFnFor('eth_compileSolidity');\nEthQuery.prototype.compileSerpent = generateFnFor('eth_compileSerpent');\nEthQuery.prototype.newFilter = generateFnFor('eth_newFilter');\nEthQuery.prototype.newBlockFilter = generateFnFor('eth_newBlockFilter');\nEthQuery.prototype.newPendingTransactionFilter = generateFnFor('eth_newPendingTransactionFilter');\nEthQuery.prototype.uninstallFilter = generateFnFor('eth_uninstallFilter');\nEthQuery.prototype.getFilterChanges = generateFnFor('eth_getFilterChanges');\nEthQuery.prototype.getFilterLogs = generateFnFor('eth_getFilterLogs');\nEthQuery.prototype.getLogs = generateFnFor('eth_getLogs');\nEthQuery.prototype.getWork = generateFnFor('eth_getWork');\nEthQuery.prototype.submitWork = generateFnFor('eth_submitWork');\nEthQuery.prototype.submitHashrate = generateFnFor('eth_submitHashrate');\n\n// network level\n\nEthQuery.prototype.sendAsync = function (opts, cb) {\n const self = this;\n self.currentProvider.sendAsync(createPayload(opts), function (err, response) {\n if (!err && response.error) err = new Error('EthQuery - RPC Error - ' + response.error.message);\n if (err) return cb(err);\n cb(null, response.result);\n });\n};\n\n// util\n\nfunction generateFnFor(methodName) {\n return function () {\n const self = this;\n var args = [].slice.call(arguments);\n var cb = args.pop();\n self.sendAsync({\n method: methodName,\n params: args\n }, cb);\n };\n}\nfunction generateFnWithDefaultBlockFor(argCount, methodName) {\n return function () {\n const self = this;\n var args = [].slice.call(arguments);\n var cb = args.pop();\n // set optional default block param\n if (args.length < argCount) args.push('latest');\n self.sendAsync({\n method: methodName,\n params: args\n }, cb);\n };\n}\nfunction createPayload(data) {\n return extend({\n // defaults\n id: createRandomId(),\n jsonrpc: '2.0',\n params: []\n // user-specified\n }, data);\n}","'use strict';\n\nconst processFn = (fn, options, proxy, unwrapped) => function (...arguments_) {\n const P = options.promiseModule;\n return new P((resolve, reject) => {\n if (options.multiArgs) {\n arguments_.push((...result) => {\n if (options.errorFirst) {\n if (result[0]) {\n reject(result);\n } else {\n result.shift();\n resolve(result);\n }\n } else {\n resolve(result);\n }\n });\n } else if (options.errorFirst) {\n arguments_.push((error, result) => {\n if (error) {\n reject(error);\n } else {\n resolve(result);\n }\n });\n } else {\n arguments_.push(resolve);\n }\n const self = this === proxy ? unwrapped : this;\n Reflect.apply(fn, self, arguments_);\n });\n};\nconst filterCache = new WeakMap();\nmodule.exports = (input, options) => {\n options = {\n exclude: [/.+(?:Sync|Stream)$/],\n errorFirst: true,\n promiseModule: Promise,\n ...options\n };\n const objectType = typeof input;\n if (!(input !== null && (objectType === 'object' || objectType === 'function'))) {\n throw new TypeError(`Expected \\`input\\` to be a \\`Function\\` or \\`Object\\`, got \\`${input === null ? 'null' : objectType}\\``);\n }\n const filter = (target, key) => {\n let cached = filterCache.get(target);\n if (!cached) {\n cached = {};\n filterCache.set(target, cached);\n }\n if (key in cached) {\n return cached[key];\n }\n const match = pattern => typeof pattern === 'string' || typeof key === 'symbol' ? key === pattern : pattern.test(key);\n const desc = Reflect.getOwnPropertyDescriptor(target, key);\n const writableOrConfigurableOwn = desc === undefined || desc.writable || desc.configurable;\n const included = options.include ? options.include.some(match) : !options.exclude.some(match);\n const shouldFilter = included && writableOrConfigurableOwn;\n cached[key] = shouldFilter;\n return shouldFilter;\n };\n const cache = new WeakMap();\n const proxy = new Proxy(input, {\n apply(target, thisArg, args) {\n const cached = cache.get(target);\n if (cached) {\n return Reflect.apply(cached, thisArg, args);\n }\n const pified = options.excludeMain ? target : processFn(target, options, proxy, target);\n cache.set(target, pified);\n return Reflect.apply(pified, thisArg, args);\n },\n get(target, key) {\n const property = target[key];\n\n // eslint-disable-next-line no-use-extend-native/no-use-extend-native\n if (!filter(target, key) || property === Function.prototype[key]) {\n return property;\n }\n const cached = cache.get(property);\n if (cached) {\n return cached;\n }\n if (typeof property === 'function') {\n const pified = processFn(property, options, proxy, target);\n cache.set(property, pified);\n return pified;\n }\n return property;\n }\n });\n return proxy;\n};","const SafeEventEmitter = require('@metamask/safe-event-emitter').default;\nclass BaseFilter extends SafeEventEmitter {\n constructor() {\n super();\n this.updates = [];\n }\n async initialize() {}\n async update() {\n throw new Error('BaseFilter - no update method specified');\n }\n addResults(newResults) {\n this.updates = this.updates.concat(newResults);\n newResults.forEach(result => this.emit('update', result));\n }\n addInitialResults(newResults) {}\n getChangesAndClear() {\n const updates = this.updates;\n this.updates = [];\n return updates;\n }\n}\nmodule.exports = BaseFilter;","const BaseFilter = require('./base-filter');\n\n// tracks all results ever recorded\nclass BaseFilterWithHistory extends BaseFilter {\n constructor() {\n super();\n this.allResults = [];\n }\n async update() {\n throw new Error('BaseFilterWithHistory - no update method specified');\n }\n addResults(newResults) {\n this.allResults = this.allResults.concat(newResults);\n super.addResults(newResults);\n }\n addInitialResults(newResults) {\n this.allResults = this.allResults.concat(newResults);\n super.addInitialResults(newResults);\n }\n getAllResults() {\n return this.allResults;\n }\n}\nmodule.exports = BaseFilterWithHistory;","module.exports = {\n minBlockRef,\n maxBlockRef,\n sortBlockRefs,\n bnToHex,\n blockRefIsNumber,\n hexToInt,\n incrementHexInt,\n intToHex,\n unsafeRandomBytes\n};\nfunction minBlockRef(...refs) {\n const sortedRefs = sortBlockRefs(refs);\n return sortedRefs[0];\n}\nfunction maxBlockRef(...refs) {\n const sortedRefs = sortBlockRefs(refs);\n return sortedRefs[sortedRefs.length - 1];\n}\nfunction sortBlockRefs(refs) {\n return refs.sort((refA, refB) => {\n if (refA === 'latest' || refB === 'earliest') return 1;\n if (refB === 'latest' || refA === 'earliest') return -1;\n return hexToInt(refA) - hexToInt(refB);\n });\n}\nfunction bnToHex(bn) {\n return '0x' + bn.toString(16);\n}\nfunction blockRefIsNumber(blockRef) {\n return blockRef && !['earliest', 'latest', 'pending'].includes(blockRef);\n}\nfunction hexToInt(hexString) {\n if (hexString === undefined || hexString === null) return hexString;\n return Number.parseInt(hexString, 16);\n}\nfunction incrementHexInt(hexString) {\n if (hexString === undefined || hexString === null) return hexString;\n const value = hexToInt(hexString);\n return intToHex(value + 1);\n}\nfunction intToHex(int) {\n if (int === undefined || int === null) return int;\n let hexString = int.toString(16);\n const needsLeftPad = hexString.length % 2;\n if (needsLeftPad) hexString = '0' + hexString;\n return '0x' + hexString;\n}\nfunction unsafeRandomBytes(byteCount) {\n let result = '0x';\n for (let i = 0; i < byteCount; i++) {\n result += unsafeRandomNibble();\n result += unsafeRandomNibble();\n }\n return result;\n}\nfunction unsafeRandomNibble() {\n return Math.floor(Math.random() * 16).toString(16);\n}","const EthQuery = require('eth-query');\nconst pify = require('pify');\nconst BaseFilterWithHistory = require('./base-filter-history');\nconst {\n bnToHex,\n hexToInt,\n incrementHexInt,\n minBlockRef,\n blockRefIsNumber\n} = require('./hexUtils');\nclass LogFilter extends BaseFilterWithHistory {\n constructor({\n provider,\n params\n }) {\n super();\n this.type = 'log';\n this.ethQuery = new EthQuery(provider);\n this.params = Object.assign({\n fromBlock: 'latest',\n toBlock: 'latest',\n address: undefined,\n topics: []\n }, params);\n // normalize address parameter\n if (this.params.address) {\n // ensure array\n if (!Array.isArray(this.params.address)) {\n this.params.address = [this.params.address];\n }\n // ensure lowercase\n this.params.address = this.params.address.map(address => address.toLowerCase());\n }\n }\n async initialize({\n currentBlock\n }) {\n // resolve params.fromBlock\n let fromBlock = this.params.fromBlock;\n if (['latest', 'pending'].includes(fromBlock)) fromBlock = currentBlock;\n if ('earliest' === fromBlock) fromBlock = '0x0';\n this.params.fromBlock = fromBlock;\n // set toBlock for initial lookup\n const toBlock = minBlockRef(this.params.toBlock, currentBlock);\n const params = Object.assign({}, this.params, {\n toBlock\n });\n // fetch logs and add to results\n const newLogs = await this._fetchLogs(params);\n this.addInitialResults(newLogs);\n }\n async update({\n oldBlock,\n newBlock\n }) {\n // configure params for this update\n const toBlock = newBlock;\n let fromBlock;\n // oldBlock is empty on first sync\n if (oldBlock) {\n fromBlock = incrementHexInt(oldBlock);\n } else {\n fromBlock = newBlock;\n }\n // fetch logs\n const params = Object.assign({}, this.params, {\n fromBlock,\n toBlock\n });\n const newLogs = await this._fetchLogs(params);\n const matchingLogs = newLogs.filter(log => this.matchLog(log));\n\n // add to results\n this.addResults(matchingLogs);\n }\n async _fetchLogs(params) {\n const newLogs = await pify(cb => this.ethQuery.getLogs(params, cb))();\n // add to results\n return newLogs;\n }\n matchLog(log) {\n // check if block number in bounds:\n if (hexToInt(this.params.fromBlock) >= hexToInt(log.blockNumber)) return false;\n if (blockRefIsNumber(this.params.toBlock) && hexToInt(this.params.toBlock) <= hexToInt(log.blockNumber)) return false;\n\n // address is correct:\n const normalizedLogAddress = log.address && log.address.toLowerCase();\n if (this.params.address && normalizedLogAddress && !this.params.address.includes(normalizedLogAddress)) return false;\n\n // topics match:\n // topics are position-dependant\n // topics can be nested to represent `or` [[a || b], c]\n // topics can be null, representing a wild card for that position\n const topicsMatch = this.params.topics.every((topicPattern, index) => {\n // pattern is longer than actual topics\n let logTopic = log.topics[index];\n if (!logTopic) return false;\n logTopic = logTopic.toLowerCase();\n // normalize subTopics\n let subtopicsToMatch = Array.isArray(topicPattern) ? topicPattern : [topicPattern];\n // check for wild card\n const subtopicsIncludeWildcard = subtopicsToMatch.includes(null);\n if (subtopicsIncludeWildcard) return true;\n subtopicsToMatch = subtopicsToMatch.map(topic => topic.toLowerCase());\n // check each possible matching topic\n const topicDoesMatch = subtopicsToMatch.includes(logTopic);\n return topicDoesMatch;\n });\n return topicsMatch;\n }\n}\nmodule.exports = LogFilter;","module.exports = getBlocksForRange;\nasync function getBlocksForRange({\n provider,\n fromBlock,\n toBlock\n}) {\n if (!fromBlock) fromBlock = toBlock;\n const fromBlockNumber = hexToInt(fromBlock);\n const toBlockNumber = hexToInt(toBlock);\n const blockCountToQuery = toBlockNumber - fromBlockNumber + 1;\n // load all blocks from old to new (inclusive)\n const missingBlockNumbers = Array(blockCountToQuery).fill().map((_, index) => fromBlockNumber + index).map(intToHex);\n const blockBodies = await Promise.all(missingBlockNumbers.map(blockNum => query(provider, 'eth_getBlockByNumber', [blockNum, false])));\n return blockBodies;\n}\nfunction hexToInt(hexString) {\n if (hexString === undefined || hexString === null) return hexString;\n return Number.parseInt(hexString, 16);\n}\nfunction incrementHexInt(hexString) {\n if (hexString === undefined || hexString === null) return hexString;\n const value = hexToInt(hexString);\n return intToHex(value + 1);\n}\nfunction intToHex(int) {\n if (int === undefined || int === null) return int;\n const hexString = int.toString(16);\n return '0x' + hexString;\n}\nfunction sendAsync(provider, request) {\n return new Promise((resolve, reject) => {\n provider.sendAsync(request, (error, response) => {\n if (error) {\n reject(error);\n } else if (response.error) {\n reject(response.error);\n } else if (response.result) {\n resolve(response.result);\n } else {\n reject(new Error(\"Result was empty\"));\n }\n });\n });\n}\nasync function query(provider, method, params) {\n for (let i = 0; i < 3; i++) {\n try {\n return await sendAsync(provider, {\n id: 1,\n jsonrpc: \"2.0\",\n method,\n params\n });\n } catch (error) {\n console.error(`provider.sendAsync failed: ${error.stack || error.message || error}`);\n }\n }\n throw new Error(`Block not found for params: ${JSON.stringify(params)}`);\n}","const BaseFilter = require('./base-filter');\nconst getBlocksForRange = require('./getBlocksForRange');\nconst {\n incrementHexInt\n} = require('./hexUtils');\nclass BlockFilter extends BaseFilter {\n constructor({\n provider,\n params\n }) {\n super();\n this.type = 'block';\n this.provider = provider;\n }\n async update({\n oldBlock,\n newBlock\n }) {\n const toBlock = newBlock;\n const fromBlock = incrementHexInt(oldBlock);\n const blockBodies = await getBlocksForRange({\n provider: this.provider,\n fromBlock,\n toBlock\n });\n const blockHashes = blockBodies.map(block => block.hash);\n this.addResults(blockHashes);\n }\n}\nmodule.exports = BlockFilter;","const BaseFilter = require('./base-filter');\nconst getBlocksForRange = require('./getBlocksForRange');\nconst {\n incrementHexInt\n} = require('./hexUtils');\nclass TxFilter extends BaseFilter {\n constructor({\n provider\n }) {\n super();\n this.type = 'tx';\n this.provider = provider;\n }\n async update({\n oldBlock\n }) {\n const toBlock = oldBlock;\n const fromBlock = incrementHexInt(oldBlock);\n const blocks = await getBlocksForRange({\n provider: this.provider,\n fromBlock,\n toBlock\n });\n const blockTxHashes = [];\n for (const block of blocks) {\n blockTxHashes.push(...block.transactions);\n }\n // add to results\n this.addResults(blockTxHashes);\n }\n}\nmodule.exports = TxFilter;","const Mutex = require('async-mutex').Mutex;\nconst {\n createAsyncMiddleware,\n createScaffoldMiddleware\n} = require('json-rpc-engine');\nconst LogFilter = require('./log-filter.js');\nconst BlockFilter = require('./block-filter.js');\nconst TxFilter = require('./tx-filter.js');\nconst {\n intToHex,\n hexToInt\n} = require('./hexUtils');\nmodule.exports = createEthFilterMiddleware;\nfunction createEthFilterMiddleware({\n blockTracker,\n provider\n}) {\n // create filter collection\n let filterIndex = 0;\n let filters = {};\n // create update mutex\n const mutex = new Mutex();\n const waitForFree = mutexMiddlewareWrapper({\n mutex\n });\n const middleware = createScaffoldMiddleware({\n // install filters\n eth_newFilter: waitForFree(toFilterCreationMiddleware(newLogFilter)),\n eth_newBlockFilter: waitForFree(toFilterCreationMiddleware(newBlockFilter)),\n eth_newPendingTransactionFilter: waitForFree(toFilterCreationMiddleware(newPendingTransactionFilter)),\n // uninstall filters\n eth_uninstallFilter: waitForFree(toAsyncRpcMiddleware(uninstallFilterHandler)),\n // checking filter changes\n eth_getFilterChanges: waitForFree(toAsyncRpcMiddleware(getFilterChanges)),\n eth_getFilterLogs: waitForFree(toAsyncRpcMiddleware(getFilterLogs))\n });\n\n // setup filter updating and destroy handler\n const filterUpdater = async ({\n oldBlock,\n newBlock\n }) => {\n if (filters.length === 0) return;\n // lock update reads\n const releaseLock = await mutex.acquire();\n try {\n // process all filters in parallel\n await Promise.all(objValues(filters).map(async filter => {\n try {\n await filter.update({\n oldBlock,\n newBlock\n });\n } catch (err) {\n // handle each error individually so filter update errors don't affect other filters\n console.error(err);\n }\n }));\n } catch (err) {\n // log error so we don't skip the releaseLock\n console.error(err);\n }\n // unlock update reads\n releaseLock();\n };\n\n // expose filter methods directly\n middleware.newLogFilter = newLogFilter;\n middleware.newBlockFilter = newBlockFilter;\n middleware.newPendingTransactionFilter = newPendingTransactionFilter;\n middleware.uninstallFilter = uninstallFilterHandler;\n middleware.getFilterChanges = getFilterChanges;\n middleware.getFilterLogs = getFilterLogs;\n\n // expose destroy method for cleanup\n middleware.destroy = () => {\n uninstallAllFilters();\n };\n return middleware;\n\n //\n // new filters\n //\n\n async function newLogFilter(params) {\n const filter = new LogFilter({\n provider,\n params\n });\n const filterIndex = await installFilter(filter);\n return filter;\n }\n async function newBlockFilter() {\n const filter = new BlockFilter({\n provider\n });\n const filterIndex = await installFilter(filter);\n return filter;\n }\n async function newPendingTransactionFilter() {\n const filter = new TxFilter({\n provider\n });\n const filterIndex = await installFilter(filter);\n return filter;\n }\n\n //\n // get filter changes\n //\n\n async function getFilterChanges(filterIndexHex) {\n const filterIndex = hexToInt(filterIndexHex);\n const filter = filters[filterIndex];\n if (!filter) {\n throw new Error(`No filter for index \"${filterIndex}\"`);\n }\n const results = filter.getChangesAndClear();\n return results;\n }\n async function getFilterLogs(filterIndexHex) {\n const filterIndex = hexToInt(filterIndexHex);\n const filter = filters[filterIndex];\n if (!filter) {\n throw new Error(`No filter for index \"${filterIndex}\"`);\n }\n // only return results for log filters\n let results = [];\n if (filter.type === 'log') {\n results = filter.getAllResults();\n }\n return results;\n }\n\n //\n // remove filters\n //\n\n async function uninstallFilterHandler(filterIndexHex) {\n // check filter exists\n const filterIndex = hexToInt(filterIndexHex);\n const filter = filters[filterIndex];\n const result = Boolean(filter);\n // uninstall filter\n if (result) {\n await uninstallFilter(filterIndex);\n }\n return result;\n }\n\n //\n // utils\n //\n\n async function installFilter(filter) {\n const prevFilterCount = objValues(filters).length;\n // install filter\n const currentBlock = await blockTracker.getLatestBlock();\n await filter.initialize({\n currentBlock\n });\n filterIndex++;\n filters[filterIndex] = filter;\n filter.id = filterIndex;\n filter.idHex = intToHex(filterIndex);\n // update block tracker subs\n const newFilterCount = objValues(filters).length;\n updateBlockTrackerSubs({\n prevFilterCount,\n newFilterCount\n });\n return filterIndex;\n }\n async function uninstallFilter(filterIndex) {\n const prevFilterCount = objValues(filters).length;\n delete filters[filterIndex];\n // update block tracker subs\n const newFilterCount = objValues(filters).length;\n updateBlockTrackerSubs({\n prevFilterCount,\n newFilterCount\n });\n }\n async function uninstallAllFilters() {\n const prevFilterCount = objValues(filters).length;\n filters = {};\n // update block tracker subs\n updateBlockTrackerSubs({\n prevFilterCount,\n newFilterCount: 0\n });\n }\n function updateBlockTrackerSubs({\n prevFilterCount,\n newFilterCount\n }) {\n // subscribe\n if (prevFilterCount === 0 && newFilterCount > 0) {\n blockTracker.on('sync', filterUpdater);\n return;\n }\n // unsubscribe\n if (prevFilterCount > 0 && newFilterCount === 0) {\n blockTracker.removeListener('sync', filterUpdater);\n return;\n }\n }\n}\n\n// helper for turning filter constructors into rpc middleware\nfunction toFilterCreationMiddleware(createFilterFn) {\n return toAsyncRpcMiddleware(async (...args) => {\n const filter = await createFilterFn(...args);\n const result = intToHex(filter.id);\n return result;\n });\n}\n\n// helper for pulling out req.params and setting res.result\nfunction toAsyncRpcMiddleware(asyncFn) {\n return createAsyncMiddleware(async (req, res) => {\n const result = await asyncFn.apply(null, req.params);\n res.result = result;\n });\n}\nfunction mutexMiddlewareWrapper({\n mutex\n}) {\n return middleware => {\n return async (req, res, next, end) => {\n // wait for mutex available\n // we can release immediately because\n // we just need to make sure updates aren't active\n const releaseLock = await mutex.acquire();\n releaseLock();\n middleware(req, res, next, end);\n };\n };\n}\nfunction objValues(obj, fn) {\n const values = [];\n for (let key in obj) {\n values.push(obj[key]);\n }\n return values;\n}","const SafeEventEmitter = require('@metamask/safe-event-emitter').default;\nconst {\n createAsyncMiddleware,\n createScaffoldMiddleware\n} = require('json-rpc-engine');\nconst createFilterMiddleware = require('./index.js');\nconst {\n unsafeRandomBytes,\n incrementHexInt\n} = require('./hexUtils.js');\nconst getBlocksForRange = require('./getBlocksForRange.js');\nmodule.exports = createSubscriptionMiddleware;\nfunction createSubscriptionMiddleware({\n blockTracker,\n provider\n}) {\n // state and utilities for handling subscriptions\n const subscriptions = {};\n const filterManager = createFilterMiddleware({\n blockTracker,\n provider\n });\n\n // internal flag\n let isDestroyed = false;\n\n // create subscriptionManager api object\n const events = new SafeEventEmitter();\n const middleware = createScaffoldMiddleware({\n eth_subscribe: createAsyncMiddleware(subscribe),\n eth_unsubscribe: createAsyncMiddleware(unsubscribe)\n });\n middleware.destroy = destroy;\n return {\n events,\n middleware\n };\n async function subscribe(req, res) {\n if (isDestroyed) throw new Error('SubscriptionManager - attempting to use after destroying');\n const subscriptionType = req.params[0];\n // subId is 16 byte hex string\n const subId = unsafeRandomBytes(16);\n\n // create sub\n let sub;\n switch (subscriptionType) {\n case 'newHeads':\n sub = createSubNewHeads({\n subId\n });\n break;\n case 'logs':\n const filterParams = req.params[1];\n const filter = await filterManager.newLogFilter(filterParams);\n sub = createSubFromFilter({\n subId,\n filter\n });\n break;\n default:\n throw new Error(`SubscriptionManager - unsupported subscription type \"${subscriptionType}\"`);\n }\n subscriptions[subId] = sub;\n res.result = subId;\n return;\n function createSubNewHeads({\n subId\n }) {\n const sub = {\n type: subscriptionType,\n destroy: async () => {\n blockTracker.removeListener('sync', sub.update);\n },\n update: async ({\n oldBlock,\n newBlock\n }) => {\n // for newHeads\n const toBlock = newBlock;\n const fromBlock = incrementHexInt(oldBlock);\n const rawBlocks = await getBlocksForRange({\n provider,\n fromBlock,\n toBlock\n });\n const results = rawBlocks.map(normalizeBlock).filter(block => block !== null);\n results.forEach(value => {\n _emitSubscriptionResult(subId, value);\n });\n }\n };\n // check for subscription updates on new block\n blockTracker.on('sync', sub.update);\n return sub;\n }\n function createSubFromFilter({\n subId,\n filter\n }) {\n filter.on('update', result => _emitSubscriptionResult(subId, result));\n const sub = {\n type: subscriptionType,\n destroy: async () => {\n return await filterManager.uninstallFilter(filter.idHex);\n }\n };\n return sub;\n }\n }\n async function unsubscribe(req, res) {\n if (isDestroyed) throw new Error('SubscriptionManager - attempting to use after destroying');\n const id = req.params[0];\n const subscription = subscriptions[id];\n // if missing, return \"false\" to indicate it was not removed\n if (!subscription) {\n res.result = false;\n return;\n }\n // cleanup subscription\n delete subscriptions[id];\n await subscription.destroy();\n res.result = true;\n }\n function _emitSubscriptionResult(filterIdHex, value) {\n events.emit('notification', {\n jsonrpc: '2.0',\n method: 'eth_subscription',\n params: {\n subscription: filterIdHex,\n result: value\n }\n });\n }\n function destroy() {\n events.removeAllListeners();\n for (const id in subscriptions) {\n subscriptions[id].destroy();\n delete subscriptions[id];\n }\n isDestroyed = true;\n }\n}\nfunction normalizeBlock(block) {\n if (block === null || block === undefined) {\n return null;\n }\n return {\n hash: block.hash,\n parentHash: block.parentHash,\n sha3Uncles: block.sha3Uncles,\n miner: block.miner,\n stateRoot: block.stateRoot,\n transactionsRoot: block.transactionsRoot,\n receiptsRoot: block.receiptsRoot,\n logsBloom: block.logsBloom,\n difficulty: block.difficulty,\n number: block.number,\n gasLimit: block.gasLimit,\n gasUsed: block.gasUsed,\n nonce: block.nonce,\n mixHash: block.mixHash,\n timestamp: block.timestamp,\n extraData: block.extraData\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SubscriptionManager = void 0;\nconst eth_block_tracker_1 = require(\"eth-block-tracker\");\nconst createSubscriptionManager = require(\"eth-json-rpc-filters/subscriptionManager\");\nconst noop = () => {};\nclass SubscriptionManager {\n constructor(provider) {\n const blockTracker = new eth_block_tracker_1.PollingBlockTracker({\n provider: provider,\n pollingInterval: 15 * 1000,\n setSkipCacheFlag: true\n });\n const {\n events,\n middleware\n } = createSubscriptionManager({\n blockTracker,\n provider\n });\n this.events = events;\n this.subscriptionMiddleware = middleware;\n }\n async handleRequest(request) {\n const result = {};\n await this.subscriptionMiddleware(request, result, noop, noop);\n return result;\n }\n destroy() {\n this.subscriptionMiddleware.destroy();\n }\n}\nexports.SubscriptionManager = SubscriptionManager;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.CoinbaseWalletProvider = void 0;\nconst safe_event_emitter_1 = __importDefault(require(\"@metamask/safe-event-emitter\"));\nconst bn_js_1 = __importDefault(require(\"bn.js\"));\nconst DiagnosticLogger_1 = require(\"../connection/DiagnosticLogger\");\nconst errors_1 = require(\"../errors\");\nconst Session_1 = require(\"../relay/Session\");\nconst WalletSDKRelayAbstract_1 = require(\"../relay/WalletSDKRelayAbstract\");\nconst Web3Method_1 = require(\"../relay/Web3Method\");\nconst Web3Response_1 = require(\"../relay/Web3Response\");\nconst util_1 = require(\"../util\");\nconst eth_eip712_util_1 = __importDefault(require(\"../vendor-js/eth-eip712-util\"));\nconst FilterPolyfill_1 = require(\"./FilterPolyfill\");\nconst JSONRPC_1 = require(\"./JSONRPC\");\nconst SubscriptionManager_1 = require(\"./SubscriptionManager\");\nconst DEFAULT_CHAIN_ID_KEY = \"DefaultChainId\";\nconst DEFAULT_JSON_RPC_URL = \"DefaultJsonRpcUrl\";\nclass CoinbaseWalletProvider extends safe_event_emitter_1.default {\n constructor(options) {\n var _a, _b;\n super();\n this._filterPolyfill = new FilterPolyfill_1.FilterPolyfill(this);\n this._subscriptionManager = new SubscriptionManager_1.SubscriptionManager(this);\n this._relay = null;\n this._addresses = [];\n this.hasMadeFirstChainChangedEmission = false;\n this.setProviderInfo = this.setProviderInfo.bind(this);\n this.updateProviderInfo = this.updateProviderInfo.bind(this);\n this.getChainId = this.getChainId.bind(this);\n this.setAppInfo = this.setAppInfo.bind(this);\n this.enable = this.enable.bind(this);\n this.close = this.close.bind(this);\n this.send = this.send.bind(this);\n this.sendAsync = this.sendAsync.bind(this);\n this.request = this.request.bind(this);\n this._setAddresses = this._setAddresses.bind(this);\n this.scanQRCode = this.scanQRCode.bind(this);\n this.genericRequest = this.genericRequest.bind(this);\n this._chainIdFromOpts = options.chainId;\n this._jsonRpcUrlFromOpts = options.jsonRpcUrl;\n this._overrideIsMetaMask = options.overrideIsMetaMask;\n this._relayProvider = options.relayProvider;\n this._storage = options.storage;\n this._relayEventManager = options.relayEventManager;\n this.diagnostic = options.diagnosticLogger;\n this.reloadOnDisconnect = true;\n this.isCoinbaseWallet = (_a = options.overrideIsCoinbaseWallet) !== null && _a !== void 0 ? _a : true;\n this.isCoinbaseBrowser = (_b = options.overrideIsCoinbaseBrowser) !== null && _b !== void 0 ? _b : false;\n this.qrUrl = options.qrUrl;\n const chainId = this.getChainId();\n const chainIdStr = (0, util_1.prepend0x)(chainId.toString(16));\n // indicate that we've connected, for EIP-1193 compliance\n this.emit(\"connect\", {\n chainIdStr\n });\n const cachedAddresses = this._storage.getItem(WalletSDKRelayAbstract_1.LOCAL_STORAGE_ADDRESSES_KEY);\n if (cachedAddresses) {\n const addresses = cachedAddresses.split(\" \");\n if (addresses[0] !== \"\") {\n this._addresses = addresses.map(address => (0, util_1.ensureAddressString)(address));\n this.emit(\"accountsChanged\", addresses);\n }\n }\n this._subscriptionManager.events.on(\"notification\", notification => {\n this.emit(\"message\", {\n type: notification.method,\n data: notification.params\n });\n });\n if (this._isAuthorized()) {\n void this.initializeRelay();\n }\n window.addEventListener(\"message\", event => {\n var _a;\n // Used to verify the source and window are correct before proceeding\n if (event.origin !== location.origin || event.source !== window) {\n return;\n }\n if (event.data.type !== \"walletLinkMessage\") return; // compatibility with CBW extension\n if (event.data.data.action === \"dappChainSwitched\") {\n const _chainId = event.data.data.chainId;\n const jsonRpcUrl = (_a = event.data.data.jsonRpcUrl) !== null && _a !== void 0 ? _a : this.jsonRpcUrl;\n this.updateProviderInfo(jsonRpcUrl, Number(_chainId));\n }\n if (event.data.data.action === \"addressChanged\") {\n this._setAddresses([event.data.data.address]);\n }\n });\n }\n /** @deprecated Use `.request({ method: 'eth_accounts' })` instead. */\n get selectedAddress() {\n return this._addresses[0] || undefined;\n }\n /** @deprecated Use the chain ID. If you still need the network ID, use `.request({ method: 'net_version' })`. */\n get networkVersion() {\n return this.getChainId().toString(10);\n }\n /** @deprecated Use `.request({ method: 'eth_chainId' })` instead. */\n get chainId() {\n return (0, util_1.prepend0x)(this.getChainId().toString(16));\n }\n get isWalletLink() {\n // backward compatibility\n return true;\n }\n /**\n * Some DApps (i.e. Alpha Homora) seem to require the window.ethereum object return\n * true for this method.\n */\n get isMetaMask() {\n return this._overrideIsMetaMask;\n }\n get host() {\n return this.jsonRpcUrl;\n }\n get connected() {\n return true;\n }\n isConnected() {\n return true;\n }\n get jsonRpcUrl() {\n var _a;\n return (_a = this._storage.getItem(DEFAULT_JSON_RPC_URL)) !== null && _a !== void 0 ? _a : this._jsonRpcUrlFromOpts;\n }\n set jsonRpcUrl(value) {\n this._storage.setItem(DEFAULT_JSON_RPC_URL, value);\n }\n disableReloadOnDisconnect() {\n this.reloadOnDisconnect = false;\n }\n setProviderInfo(jsonRpcUrl, chainId) {\n if (!this.isCoinbaseBrowser) {\n this._chainIdFromOpts = chainId;\n this._jsonRpcUrlFromOpts = jsonRpcUrl;\n }\n this.updateProviderInfo(this.jsonRpcUrl, this.getChainId());\n }\n updateProviderInfo(jsonRpcUrl, chainId) {\n this.jsonRpcUrl = jsonRpcUrl;\n // emit chainChanged event if necessary\n const originalChainId = this.getChainId();\n this._storage.setItem(DEFAULT_CHAIN_ID_KEY, chainId.toString(10));\n const chainChanged = (0, util_1.ensureIntNumber)(chainId) !== originalChainId;\n if (chainChanged || !this.hasMadeFirstChainChangedEmission) {\n this.emit(\"chainChanged\", this.getChainId());\n this.hasMadeFirstChainChangedEmission = true;\n }\n }\n async watchAsset(type, address, symbol, decimals, image, chainId) {\n const relay = await this.initializeRelay();\n const result = await relay.watchAsset(type, address, symbol, decimals, image, chainId === null || chainId === void 0 ? void 0 : chainId.toString()).promise;\n return !!result.result;\n }\n async addEthereumChain(chainId, rpcUrls, blockExplorerUrls, chainName, iconUrls, nativeCurrency) {\n var _a, _b;\n if ((0, util_1.ensureIntNumber)(chainId) === this.getChainId()) {\n return false;\n }\n const relay = await this.initializeRelay();\n const isWhitelistedNetworkOrStandalone = relay.inlineAddEthereumChain(chainId.toString());\n if (!this._isAuthorized() && !isWhitelistedNetworkOrStandalone) {\n await relay.requestEthereumAccounts().promise;\n }\n const res = await relay.addEthereumChain(chainId.toString(), rpcUrls, iconUrls, blockExplorerUrls, chainName, nativeCurrency).promise;\n if (((_a = res.result) === null || _a === void 0 ? void 0 : _a.isApproved) === true) {\n this.updateProviderInfo(rpcUrls[0], chainId);\n }\n return ((_b = res.result) === null || _b === void 0 ? void 0 : _b.isApproved) === true;\n }\n async switchEthereumChain(chainId) {\n const relay = await this.initializeRelay();\n const res = await relay.switchEthereumChain(chainId.toString(10), this.selectedAddress || undefined).promise;\n // backward compatibility\n if ((0, Web3Response_1.isErrorResponse)(res) && res.errorCode) {\n if (res.errorCode === errors_1.standardErrorCodes.provider.unsupportedChain) {\n throw errors_1.standardErrors.provider.unsupportedChain(chainId);\n } else {\n throw errors_1.standardErrors.provider.custom({\n message: res.errorMessage,\n code: res.errorCode\n });\n }\n }\n const switchResponse = res.result;\n if (switchResponse.isApproved && switchResponse.rpcUrl.length > 0) {\n this.updateProviderInfo(switchResponse.rpcUrl, chainId);\n }\n }\n setAppInfo(appName, appLogoUrl) {\n void this.initializeRelay().then(relay => relay.setAppInfo(appName, appLogoUrl));\n }\n /** @deprecated Use `.request({ method: 'eth_requestAccounts' })` instead. */\n async enable() {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.ETH_ACCOUNTS_STATE, {\n method: \"provider::enable\",\n addresses_length: this._addresses.length,\n sessionIdHash: this._relay ? Session_1.Session.hash(this._relay.session.id) : undefined\n });\n if (this._isAuthorized()) {\n return [...this._addresses];\n }\n return await this.send(JSONRPC_1.JSONRPCMethod.eth_requestAccounts);\n }\n async close() {\n const relay = await this.initializeRelay();\n relay.resetAndReload();\n }\n send(requestOrMethod, callbackOrParams) {\n // send(method, params): Promise\n try {\n const result = this._send(requestOrMethod, callbackOrParams);\n if (result instanceof Promise) {\n return result.catch(error => {\n throw (0, errors_1.serializeError)(error, requestOrMethod);\n });\n }\n } catch (error) {\n throw (0, errors_1.serializeError)(error, requestOrMethod);\n }\n }\n _send(requestOrMethod, callbackOrParams) {\n if (typeof requestOrMethod === \"string\") {\n const method = requestOrMethod;\n const params = Array.isArray(callbackOrParams) ? callbackOrParams : callbackOrParams !== undefined ? [callbackOrParams] : [];\n const request = {\n jsonrpc: \"2.0\",\n id: 0,\n method,\n params\n };\n return this._sendRequestAsync(request).then(res => res.result);\n }\n // send(JSONRPCRequest | JSONRPCRequest[], callback): void\n if (typeof callbackOrParams === \"function\") {\n const request = requestOrMethod;\n const callback = callbackOrParams;\n return this._sendAsync(request, callback);\n }\n // send(JSONRPCRequest[]): JSONRPCResponse[]\n if (Array.isArray(requestOrMethod)) {\n const requests = requestOrMethod;\n return requests.map(r => this._sendRequest(r));\n }\n // send(JSONRPCRequest): JSONRPCResponse\n const req = requestOrMethod;\n return this._sendRequest(req);\n }\n async sendAsync(request, callback) {\n try {\n return this._sendAsync(request, callback).catch(error => {\n throw (0, errors_1.serializeError)(error, request);\n });\n } catch (error) {\n return Promise.reject((0, errors_1.serializeError)(error, request));\n }\n }\n async _sendAsync(request, callback) {\n if (typeof callback !== \"function\") {\n throw new Error(\"callback is required\");\n }\n // send(JSONRPCRequest[], callback): void\n if (Array.isArray(request)) {\n const arrayCb = callback;\n this._sendMultipleRequestsAsync(request).then(responses => arrayCb(null, responses)).catch(err => arrayCb(err, null));\n return;\n }\n // send(JSONRPCRequest, callback): void\n const cb = callback;\n return this._sendRequestAsync(request).then(response => cb(null, response)).catch(err => cb(err, null));\n }\n async request(args) {\n try {\n return this._request(args).catch(error => {\n throw (0, errors_1.serializeError)(error, args.method);\n });\n } catch (error) {\n return Promise.reject((0, errors_1.serializeError)(error, args.method));\n }\n }\n async _request(args) {\n if (!args || typeof args !== \"object\" || Array.isArray(args)) {\n throw errors_1.standardErrors.rpc.invalidRequest({\n message: \"Expected a single, non-array, object argument.\",\n data: args\n });\n }\n const {\n method,\n params\n } = args;\n if (typeof method !== \"string\" || method.length === 0) {\n throw errors_1.standardErrors.rpc.invalidRequest({\n message: \"'args.method' must be a non-empty string.\",\n data: args\n });\n }\n if (params !== undefined && !Array.isArray(params) && (typeof params !== \"object\" || params === null)) {\n throw errors_1.standardErrors.rpc.invalidRequest({\n message: \"'args.params' must be an object or array if provided.\",\n data: args\n });\n }\n const newParams = params === undefined ? [] : params;\n // Coinbase Wallet Requests\n const id = this._relayEventManager.makeRequestId();\n const result = await this._sendRequestAsync({\n method,\n params: newParams,\n jsonrpc: \"2.0\",\n id\n });\n return result.result;\n }\n async scanQRCode(match) {\n var _a;\n const relay = await this.initializeRelay();\n const res = await relay.scanQRCode((0, util_1.ensureRegExpString)(match)).promise;\n if (typeof res.result !== \"string\") {\n throw (0, errors_1.serializeError)((_a = res.errorMessage) !== null && _a !== void 0 ? _a : \"result was not a string\", Web3Method_1.Web3Method.scanQRCode);\n }\n return res.result;\n }\n async genericRequest(data, action) {\n var _a;\n const relay = await this.initializeRelay();\n const res = await relay.genericRequest(data, action).promise;\n if (typeof res.result !== \"string\") {\n throw (0, errors_1.serializeError)((_a = res.errorMessage) !== null && _a !== void 0 ? _a : \"result was not a string\", Web3Method_1.Web3Method.generic);\n }\n return res.result;\n }\n async selectProvider(providerOptions) {\n var _a;\n const relay = await this.initializeRelay();\n const res = await relay.selectProvider(providerOptions).promise;\n if (typeof res.result !== \"string\") {\n throw (0, errors_1.serializeError)((_a = res.errorMessage) !== null && _a !== void 0 ? _a : \"result was not a string\", Web3Method_1.Web3Method.selectProvider);\n }\n return res.result;\n }\n supportsSubscriptions() {\n return false;\n }\n subscribe() {\n throw new Error(\"Subscriptions are not supported\");\n }\n unsubscribe() {\n throw new Error(\"Subscriptions are not supported\");\n }\n disconnect() {\n return true;\n }\n _sendRequest(request) {\n const response = {\n jsonrpc: \"2.0\",\n id: request.id\n };\n const {\n method\n } = request;\n response.result = this._handleSynchronousMethods(request);\n if (response.result === undefined) {\n throw new Error(`Coinbase Wallet does not support calling ${method} synchronously without ` + `a callback. Please provide a callback parameter to call ${method} ` + `asynchronously.`);\n }\n return response;\n }\n _setAddresses(addresses, _) {\n if (!Array.isArray(addresses)) {\n throw new Error(\"addresses is not an array\");\n }\n const newAddresses = addresses.map(address => (0, util_1.ensureAddressString)(address));\n if (JSON.stringify(newAddresses) === JSON.stringify(this._addresses)) {\n return;\n }\n this._addresses = newAddresses;\n this.emit(\"accountsChanged\", this._addresses);\n this._storage.setItem(WalletSDKRelayAbstract_1.LOCAL_STORAGE_ADDRESSES_KEY, newAddresses.join(\" \"));\n }\n _sendRequestAsync(request) {\n return new Promise((resolve, reject) => {\n try {\n const syncResult = this._handleSynchronousMethods(request);\n if (syncResult !== undefined) {\n return resolve({\n jsonrpc: \"2.0\",\n id: request.id,\n result: syncResult\n });\n }\n const filterPromise = this._handleAsynchronousFilterMethods(request);\n if (filterPromise !== undefined) {\n filterPromise.then(res => resolve(Object.assign(Object.assign({}, res), {\n id: request.id\n }))).catch(err => reject(err));\n return;\n }\n const subscriptionPromise = this._handleSubscriptionMethods(request);\n if (subscriptionPromise !== undefined) {\n subscriptionPromise.then(res => resolve({\n jsonrpc: \"2.0\",\n id: request.id,\n result: res.result\n })).catch(err => reject(err));\n return;\n }\n } catch (err) {\n return reject(err);\n }\n this._handleAsynchronousMethods(request).then(res => res && resolve(Object.assign(Object.assign({}, res), {\n id: request.id\n }))).catch(err => reject(err));\n });\n }\n _sendMultipleRequestsAsync(requests) {\n return Promise.all(requests.map(r => this._sendRequestAsync(r)));\n }\n _handleSynchronousMethods(request) {\n const {\n method\n } = request;\n const params = request.params || [];\n switch (method) {\n case JSONRPC_1.JSONRPCMethod.eth_accounts:\n return this._eth_accounts();\n case JSONRPC_1.JSONRPCMethod.eth_coinbase:\n return this._eth_coinbase();\n case JSONRPC_1.JSONRPCMethod.eth_uninstallFilter:\n return this._eth_uninstallFilter(params);\n case JSONRPC_1.JSONRPCMethod.net_version:\n return this._net_version();\n case JSONRPC_1.JSONRPCMethod.eth_chainId:\n return this._eth_chainId();\n default:\n return undefined;\n }\n }\n async _handleAsynchronousMethods(request) {\n const {\n method\n } = request;\n const params = request.params || [];\n switch (method) {\n case JSONRPC_1.JSONRPCMethod.eth_requestAccounts:\n return this._eth_requestAccounts();\n case JSONRPC_1.JSONRPCMethod.eth_sign:\n return this._eth_sign(params);\n case JSONRPC_1.JSONRPCMethod.eth_ecRecover:\n return this._eth_ecRecover(params);\n case JSONRPC_1.JSONRPCMethod.personal_sign:\n return this._personal_sign(params);\n case JSONRPC_1.JSONRPCMethod.personal_ecRecover:\n return this._personal_ecRecover(params);\n case JSONRPC_1.JSONRPCMethod.eth_signTransaction:\n return this._eth_signTransaction(params);\n case JSONRPC_1.JSONRPCMethod.eth_sendRawTransaction:\n return this._eth_sendRawTransaction(params);\n case JSONRPC_1.JSONRPCMethod.eth_sendTransaction:\n return this._eth_sendTransaction(params);\n case JSONRPC_1.JSONRPCMethod.eth_signTypedData_v1:\n return this._eth_signTypedData_v1(params);\n case JSONRPC_1.JSONRPCMethod.eth_signTypedData_v2:\n return this._throwUnsupportedMethodError();\n case JSONRPC_1.JSONRPCMethod.eth_signTypedData_v3:\n return this._eth_signTypedData_v3(params);\n case JSONRPC_1.JSONRPCMethod.eth_signTypedData_v4:\n case JSONRPC_1.JSONRPCMethod.eth_signTypedData:\n return this._eth_signTypedData_v4(params);\n case JSONRPC_1.JSONRPCMethod.cbWallet_arbitrary:\n return this._cbwallet_arbitrary(params);\n case JSONRPC_1.JSONRPCMethod.wallet_addEthereumChain:\n return this._wallet_addEthereumChain(params);\n case JSONRPC_1.JSONRPCMethod.wallet_switchEthereumChain:\n return this._wallet_switchEthereumChain(params);\n case JSONRPC_1.JSONRPCMethod.wallet_watchAsset:\n return this._wallet_watchAsset(params);\n }\n const relay = await this.initializeRelay();\n return relay.makeEthereumJSONRPCRequest(request, this.jsonRpcUrl);\n }\n _handleAsynchronousFilterMethods(request) {\n const {\n method\n } = request;\n const params = request.params || [];\n switch (method) {\n case JSONRPC_1.JSONRPCMethod.eth_newFilter:\n return this._eth_newFilter(params);\n case JSONRPC_1.JSONRPCMethod.eth_newBlockFilter:\n return this._eth_newBlockFilter();\n case JSONRPC_1.JSONRPCMethod.eth_newPendingTransactionFilter:\n return this._eth_newPendingTransactionFilter();\n case JSONRPC_1.JSONRPCMethod.eth_getFilterChanges:\n return this._eth_getFilterChanges(params);\n case JSONRPC_1.JSONRPCMethod.eth_getFilterLogs:\n return this._eth_getFilterLogs(params);\n }\n return undefined;\n }\n _handleSubscriptionMethods(request) {\n switch (request.method) {\n case JSONRPC_1.JSONRPCMethod.eth_subscribe:\n case JSONRPC_1.JSONRPCMethod.eth_unsubscribe:\n return this._subscriptionManager.handleRequest(request);\n }\n return undefined;\n }\n _isKnownAddress(addressString) {\n try {\n const addressStr = (0, util_1.ensureAddressString)(addressString);\n const lowercaseAddresses = this._addresses.map(address => (0, util_1.ensureAddressString)(address));\n return lowercaseAddresses.includes(addressStr);\n } catch (_a) {}\n return false;\n }\n _ensureKnownAddress(addressString) {\n var _a;\n if (!this._isKnownAddress(addressString)) {\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.UNKNOWN_ADDRESS_ENCOUNTERED);\n throw new Error(\"Unknown Ethereum address\");\n }\n }\n _prepareTransactionParams(tx) {\n const fromAddress = tx.from ? (0, util_1.ensureAddressString)(tx.from) : this.selectedAddress;\n if (!fromAddress) {\n throw new Error(\"Ethereum address is unavailable\");\n }\n this._ensureKnownAddress(fromAddress);\n const toAddress = tx.to ? (0, util_1.ensureAddressString)(tx.to) : null;\n const weiValue = tx.value != null ? (0, util_1.ensureBN)(tx.value) : new bn_js_1.default(0);\n const data = tx.data ? (0, util_1.ensureBuffer)(tx.data) : Buffer.alloc(0);\n const nonce = tx.nonce != null ? (0, util_1.ensureIntNumber)(tx.nonce) : null;\n const gasPriceInWei = tx.gasPrice != null ? (0, util_1.ensureBN)(tx.gasPrice) : null;\n const maxFeePerGas = tx.maxFeePerGas != null ? (0, util_1.ensureBN)(tx.maxFeePerGas) : null;\n const maxPriorityFeePerGas = tx.maxPriorityFeePerGas != null ? (0, util_1.ensureBN)(tx.maxPriorityFeePerGas) : null;\n const gasLimit = tx.gas != null ? (0, util_1.ensureBN)(tx.gas) : null;\n const chainId = this.getChainId();\n return {\n fromAddress,\n toAddress,\n weiValue,\n data,\n nonce,\n gasPriceInWei,\n maxFeePerGas,\n maxPriorityFeePerGas,\n gasLimit,\n chainId\n };\n }\n _isAuthorized() {\n return this._addresses.length > 0;\n }\n _requireAuthorization() {\n if (!this._isAuthorized()) {\n throw errors_1.standardErrors.provider.unauthorized({});\n }\n }\n _throwUnsupportedMethodError() {\n throw errors_1.standardErrors.provider.unsupportedMethod({});\n }\n async _signEthereumMessage(message, address, addPrefix, typedDataJson) {\n this._ensureKnownAddress(address);\n try {\n const relay = await this.initializeRelay();\n const res = await relay.signEthereumMessage(message, address, addPrefix, typedDataJson).promise;\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: res.result\n };\n } catch (err) {\n if (typeof err.message === \"string\" && err.message.match(/(denied|rejected)/i)) {\n throw errors_1.standardErrors.provider.userRejectedRequest(\"User denied message signature\");\n }\n throw err;\n }\n }\n async _ethereumAddressFromSignedMessage(message, signature, addPrefix) {\n const relay = await this.initializeRelay();\n const res = await relay.ethereumAddressFromSignedMessage(message, signature, addPrefix).promise;\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: res.result\n };\n }\n _eth_accounts() {\n return [...this._addresses];\n }\n _eth_coinbase() {\n return this.selectedAddress || null;\n }\n _net_version() {\n return this.getChainId().toString(10);\n }\n _eth_chainId() {\n return (0, util_1.hexStringFromIntNumber)(this.getChainId());\n }\n getChainId() {\n const chainIdStr = this._storage.getItem(DEFAULT_CHAIN_ID_KEY);\n if (!chainIdStr) {\n return (0, util_1.ensureIntNumber)(this._chainIdFromOpts);\n }\n const chainId = parseInt(chainIdStr, 10);\n return (0, util_1.ensureIntNumber)(chainId);\n }\n async _eth_requestAccounts() {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.ETH_ACCOUNTS_STATE, {\n method: \"provider::_eth_requestAccounts\",\n addresses_length: this._addresses.length,\n sessionIdHash: this._relay ? Session_1.Session.hash(this._relay.session.id) : undefined\n });\n if (this._isAuthorized()) {\n return Promise.resolve({\n jsonrpc: \"2.0\",\n id: 0,\n result: this._addresses\n });\n }\n let res;\n try {\n const relay = await this.initializeRelay();\n res = await relay.requestEthereumAccounts().promise;\n } catch (err) {\n if (typeof err.message === \"string\" && err.message.match(/(denied|rejected)/i)) {\n throw errors_1.standardErrors.provider.userRejectedRequest(\"User denied account authorization\");\n }\n throw err;\n }\n if (!res.result) {\n throw new Error(\"accounts received is empty\");\n }\n this._setAddresses(res.result);\n if (!this.isCoinbaseBrowser) {\n await this.switchEthereumChain(this.getChainId());\n }\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: this._addresses\n };\n }\n _eth_sign(params) {\n this._requireAuthorization();\n const address = (0, util_1.ensureAddressString)(params[0]);\n const message = (0, util_1.ensureBuffer)(params[1]);\n return this._signEthereumMessage(message, address, false);\n }\n _eth_ecRecover(params) {\n const message = (0, util_1.ensureBuffer)(params[0]);\n const signature = (0, util_1.ensureBuffer)(params[1]);\n return this._ethereumAddressFromSignedMessage(message, signature, false);\n }\n _personal_sign(params) {\n this._requireAuthorization();\n const message = (0, util_1.ensureBuffer)(params[0]);\n const address = (0, util_1.ensureAddressString)(params[1]);\n return this._signEthereumMessage(message, address, true);\n }\n _personal_ecRecover(params) {\n const message = (0, util_1.ensureBuffer)(params[0]);\n const signature = (0, util_1.ensureBuffer)(params[1]);\n return this._ethereumAddressFromSignedMessage(message, signature, true);\n }\n async _eth_signTransaction(params) {\n this._requireAuthorization();\n const tx = this._prepareTransactionParams(params[0] || {});\n try {\n const relay = await this.initializeRelay();\n const res = await relay.signEthereumTransaction(tx).promise;\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: res.result\n };\n } catch (err) {\n if (typeof err.message === \"string\" && err.message.match(/(denied|rejected)/i)) {\n throw errors_1.standardErrors.provider.userRejectedRequest(\"User denied transaction signature\");\n }\n throw err;\n }\n }\n async _eth_sendRawTransaction(params) {\n const signedTransaction = (0, util_1.ensureBuffer)(params[0]);\n const relay = await this.initializeRelay();\n const res = await relay.submitEthereumTransaction(signedTransaction, this.getChainId()).promise;\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: res.result\n };\n }\n async _eth_sendTransaction(params) {\n this._requireAuthorization();\n const tx = this._prepareTransactionParams(params[0] || {});\n try {\n const relay = await this.initializeRelay();\n const res = await relay.signAndSubmitEthereumTransaction(tx).promise;\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: res.result\n };\n } catch (err) {\n if (typeof err.message === \"string\" && err.message.match(/(denied|rejected)/i)) {\n throw errors_1.standardErrors.provider.userRejectedRequest(\"User denied transaction signature\");\n }\n throw err;\n }\n }\n async _eth_signTypedData_v1(params) {\n this._requireAuthorization();\n const typedData = (0, util_1.ensureParsedJSONObject)(params[0]);\n const address = (0, util_1.ensureAddressString)(params[1]);\n this._ensureKnownAddress(address);\n const message = eth_eip712_util_1.default.hashForSignTypedDataLegacy({\n data: typedData\n });\n const typedDataJSON = JSON.stringify(typedData, null, 2);\n return this._signEthereumMessage(message, address, false, typedDataJSON);\n }\n async _eth_signTypedData_v3(params) {\n this._requireAuthorization();\n const address = (0, util_1.ensureAddressString)(params[0]);\n const typedData = (0, util_1.ensureParsedJSONObject)(params[1]);\n this._ensureKnownAddress(address);\n const message = eth_eip712_util_1.default.hashForSignTypedData_v3({\n data: typedData\n });\n const typedDataJSON = JSON.stringify(typedData, null, 2);\n return this._signEthereumMessage(message, address, false, typedDataJSON);\n }\n async _eth_signTypedData_v4(params) {\n this._requireAuthorization();\n const address = (0, util_1.ensureAddressString)(params[0]);\n const typedData = (0, util_1.ensureParsedJSONObject)(params[1]);\n this._ensureKnownAddress(address);\n const message = eth_eip712_util_1.default.hashForSignTypedData_v4({\n data: typedData\n });\n const typedDataJSON = JSON.stringify(typedData, null, 2);\n return this._signEthereumMessage(message, address, false, typedDataJSON);\n }\n /** @deprecated */\n async _cbwallet_arbitrary(params) {\n const action = params[0];\n const data = params[1];\n if (typeof data !== \"string\") {\n throw new Error(\"parameter must be a string\");\n }\n if (typeof action !== \"object\" || action === null) {\n throw new Error(\"parameter must be an object\");\n }\n const result = await this.genericRequest(action, data);\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result\n };\n }\n async _wallet_addEthereumChain(params) {\n var _a, _b, _c, _d;\n const request = params[0];\n if (((_a = request.rpcUrls) === null || _a === void 0 ? void 0 : _a.length) === 0) {\n return {\n jsonrpc: \"2.0\",\n id: 0,\n error: {\n code: 2,\n message: `please pass in at least 1 rpcUrl`\n }\n };\n }\n if (!request.chainName || request.chainName.trim() === \"\") {\n throw errors_1.standardErrors.rpc.invalidParams(\"chainName is a required field\");\n }\n if (!request.nativeCurrency) {\n throw errors_1.standardErrors.rpc.invalidParams(\"nativeCurrency is a required field\");\n }\n const chainIdNumber = parseInt(request.chainId, 16);\n const success = await this.addEthereumChain(chainIdNumber, (_b = request.rpcUrls) !== null && _b !== void 0 ? _b : [], (_c = request.blockExplorerUrls) !== null && _c !== void 0 ? _c : [], request.chainName, (_d = request.iconUrls) !== null && _d !== void 0 ? _d : [], request.nativeCurrency);\n if (success) {\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: null\n };\n } else {\n return {\n jsonrpc: \"2.0\",\n id: 0,\n error: {\n code: 2,\n message: `unable to add ethereum chain`\n }\n };\n }\n }\n async _wallet_switchEthereumChain(params) {\n const request = params[0];\n await this.switchEthereumChain(parseInt(request.chainId, 16));\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: null\n };\n }\n async _wallet_watchAsset(params) {\n const request = Array.isArray(params) ? params[0] : params;\n if (!request.type) {\n throw errors_1.standardErrors.rpc.invalidParams(\"Type is required\");\n }\n if ((request === null || request === void 0 ? void 0 : request.type) !== \"ERC20\") {\n throw errors_1.standardErrors.rpc.invalidParams(`Asset of type '${request.type}' is not supported`);\n }\n if (!(request === null || request === void 0 ? void 0 : request.options)) {\n throw errors_1.standardErrors.rpc.invalidParams(\"Options are required\");\n }\n if (!(request === null || request === void 0 ? void 0 : request.options.address)) {\n throw errors_1.standardErrors.rpc.invalidParams(\"Address is required\");\n }\n const chainId = this.getChainId();\n const {\n address,\n symbol,\n image,\n decimals\n } = request.options;\n const res = await this.watchAsset(request.type, address, symbol, decimals, image, chainId);\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: res\n };\n }\n _eth_uninstallFilter(params) {\n const filterId = (0, util_1.ensureHexString)(params[0]);\n return this._filterPolyfill.uninstallFilter(filterId);\n }\n async _eth_newFilter(params) {\n const param = params[0];\n const filterId = await this._filterPolyfill.newFilter(param);\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: filterId\n };\n }\n async _eth_newBlockFilter() {\n const filterId = await this._filterPolyfill.newBlockFilter();\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: filterId\n };\n }\n async _eth_newPendingTransactionFilter() {\n const filterId = await this._filterPolyfill.newPendingTransactionFilter();\n return {\n jsonrpc: \"2.0\",\n id: 0,\n result: filterId\n };\n }\n _eth_getFilterChanges(params) {\n const filterId = (0, util_1.ensureHexString)(params[0]);\n return this._filterPolyfill.getFilterChanges(filterId);\n }\n _eth_getFilterLogs(params) {\n const filterId = (0, util_1.ensureHexString)(params[0]);\n return this._filterPolyfill.getFilterLogs(filterId);\n }\n initializeRelay() {\n if (this._relay) {\n return Promise.resolve(this._relay);\n }\n return this._relayProvider().then(relay => {\n relay.setAccountsCallback((accounts, isDisconnect) => this._setAddresses(accounts, isDisconnect));\n relay.setChainCallback((chainId, jsonRpcUrl) => {\n this.updateProviderInfo(jsonRpcUrl, parseInt(chainId, 10));\n });\n relay.setDappDefaultChainCallback(this._chainIdFromOpts);\n this._relay = relay;\n return relay;\n });\n }\n}\nexports.CoinbaseWalletProvider = CoinbaseWalletProvider;","var n,\n l,\n u,\n t,\n i,\n o,\n r,\n f,\n e,\n c,\n s,\n a,\n h = {},\n v = [],\n p = /acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,\n y = Array.isArray;\nfunction d(n, l) {\n for (var u in l) n[u] = l[u];\n return n;\n}\nfunction w(n) {\n n && n.parentNode && n.parentNode.removeChild(n);\n}\nfunction _(l, u, t) {\n var i,\n o,\n r,\n f = {};\n for (r in u) \"key\" == r ? i = u[r] : \"ref\" == r ? o = u[r] : f[r] = u[r];\n if (arguments.length > 2 && (f.children = arguments.length > 3 ? n.call(arguments, 2) : t), \"function\" == typeof l && null != l.defaultProps) for (r in l.defaultProps) void 0 === f[r] && (f[r] = l.defaultProps[r]);\n return g(l, f, i, o, null);\n}\nfunction g(n, t, i, o, r) {\n var f = {\n type: n,\n props: t,\n key: i,\n ref: o,\n __k: null,\n __: null,\n __b: 0,\n __e: null,\n __d: void 0,\n __c: null,\n constructor: void 0,\n __v: null == r ? ++u : r,\n __i: -1,\n __u: 0\n };\n return null == r && null != l.vnode && l.vnode(f), f;\n}\nfunction m() {\n return {\n current: null\n };\n}\nfunction b(n) {\n return n.children;\n}\nfunction k(n, l) {\n this.props = n, this.context = l;\n}\nfunction x(n, l) {\n if (null == l) return n.__ ? x(n.__, n.__i + 1) : null;\n for (var u; l < n.__k.length; l++) if (null != (u = n.__k[l]) && null != u.__e) return u.__e;\n return \"function\" == typeof n.type ? x(n) : null;\n}\nfunction C(n) {\n var l, u;\n if (null != (n = n.__) && null != n.__c) {\n for (n.__e = n.__c.base = null, l = 0; l < n.__k.length; l++) if (null != (u = n.__k[l]) && null != u.__e) {\n n.__e = n.__c.base = u.__e;\n break;\n }\n return C(n);\n }\n}\nfunction S(n) {\n (!n.__d && (n.__d = !0) && i.push(n) && !M.__r++ || o !== l.debounceRendering) && ((o = l.debounceRendering) || r)(M);\n}\nfunction M() {\n var n, u, t, o, r, e, c, s;\n for (i.sort(f); n = i.shift();) n.__d && (u = i.length, o = void 0, e = (r = (t = n).__v).__e, c = [], s = [], t.__P && ((o = d({}, r)).__v = r.__v + 1, l.vnode && l.vnode(o), O(t.__P, o, r, t.__n, t.__P.namespaceURI, 32 & r.__u ? [e] : null, c, null == e ? x(r) : e, !!(32 & r.__u), s), o.__v = r.__v, o.__.__k[o.__i] = o, j(c, o, s), o.__e != e && C(o)), i.length > u && i.sort(f));\n M.__r = 0;\n}\nfunction P(n, l, u, t, i, o, r, f, e, c, s) {\n var a,\n p,\n y,\n d,\n w,\n _ = t && t.__k || v,\n g = l.length;\n for (u.__d = e, $(u, l, _), e = u.__d, a = 0; a < g; a++) null != (y = u.__k[a]) && (p = -1 === y.__i ? h : _[y.__i] || h, y.__i = a, O(n, y, p, i, o, r, f, e, c, s), d = y.__e, y.ref && p.ref != y.ref && (p.ref && E(p.ref, null, y), s.push(y.ref, y.__c || d, y)), null == w && null != d && (w = d), 65536 & y.__u || p.__k === y.__k ? e = I(y, e, n) : \"function\" == typeof y.type && void 0 !== y.__d ? e = y.__d : d && (e = d.nextSibling), y.__d = void 0, y.__u &= -196609);\n u.__d = e, u.__e = w;\n}\nfunction $(n, l, u) {\n var t,\n i,\n o,\n r,\n f,\n e = l.length,\n c = u.length,\n s = c,\n a = 0;\n for (n.__k = [], t = 0; t < e; t++) null != (i = l[t]) && \"boolean\" != typeof i && \"function\" != typeof i ? (r = t + a, (i = n.__k[t] = \"string\" == typeof i || \"number\" == typeof i || \"bigint\" == typeof i || i.constructor == String ? g(null, i, null, null, null) : y(i) ? g(b, {\n children: i\n }, null, null, null) : void 0 === i.constructor && i.__b > 0 ? g(i.type, i.props, i.key, i.ref ? i.ref : null, i.__v) : i).__ = n, i.__b = n.__b + 1, o = null, -1 !== (f = i.__i = L(i, u, r, s)) && (s--, (o = u[f]) && (o.__u |= 131072)), null == o || null === o.__v ? (-1 == f && a--, \"function\" != typeof i.type && (i.__u |= 65536)) : f !== r && (f == r - 1 ? a-- : f == r + 1 ? a++ : (f > r ? a-- : a++, i.__u |= 65536))) : i = n.__k[t] = null;\n if (s) for (t = 0; t < c; t++) null != (o = u[t]) && 0 == (131072 & o.__u) && (o.__e == n.__d && (n.__d = x(o)), N(o, o));\n}\nfunction I(n, l, u) {\n var t, i;\n if (\"function\" == typeof n.type) {\n for (t = n.__k, i = 0; t && i < t.length; i++) t[i] && (t[i].__ = n, l = I(t[i], l, u));\n return l;\n }\n n.__e != l && (l && n.type && !u.contains(l) && (l = x(n)), u.insertBefore(n.__e, l || null), l = n.__e);\n do {\n l = l && l.nextSibling;\n } while (null != l && 8 === l.nodeType);\n return l;\n}\nfunction H(n, l) {\n return l = l || [], null == n || \"boolean\" == typeof n || (y(n) ? n.some(function (n) {\n H(n, l);\n }) : l.push(n)), l;\n}\nfunction L(n, l, u, t) {\n var i = n.key,\n o = n.type,\n r = u - 1,\n f = u + 1,\n e = l[u];\n if (null === e || e && i == e.key && o === e.type && 0 == (131072 & e.__u)) return u;\n if ((\"function\" != typeof o || o === b || i) && t > (null != e && 0 == (131072 & e.__u) ? 1 : 0)) for (; r >= 0 || f < l.length;) {\n if (r >= 0) {\n if ((e = l[r]) && 0 == (131072 & e.__u) && i == e.key && o === e.type) return r;\n r--;\n }\n if (f < l.length) {\n if ((e = l[f]) && 0 == (131072 & e.__u) && i == e.key && o === e.type) return f;\n f++;\n }\n }\n return -1;\n}\nfunction T(n, l, u) {\n \"-\" === l[0] ? n.setProperty(l, null == u ? \"\" : u) : n[l] = null == u ? \"\" : \"number\" != typeof u || p.test(l) ? u : u + \"px\";\n}\nfunction A(n, l, u, t, i) {\n var o;\n n: if (\"style\" === l) {\n if (\"string\" == typeof u) n.style.cssText = u;else {\n if (\"string\" == typeof t && (n.style.cssText = t = \"\"), t) for (l in t) u && l in u || T(n.style, l, \"\");\n if (u) for (l in u) t && u[l] === t[l] || T(n.style, l, u[l]);\n }\n } else if (\"o\" === l[0] && \"n\" === l[1]) o = l !== (l = l.replace(/(PointerCapture)$|Capture$/i, \"$1\")), l = l.toLowerCase() in n || \"onFocusOut\" === l || \"onFocusIn\" === l ? l.toLowerCase().slice(2) : l.slice(2), n.l || (n.l = {}), n.l[l + o] = u, u ? t ? u.u = t.u : (u.u = e, n.addEventListener(l, o ? s : c, o)) : n.removeEventListener(l, o ? s : c, o);else {\n if (\"http://www.w3.org/2000/svg\" == i) l = l.replace(/xlink(H|:h)/, \"h\").replace(/sName$/, \"s\");else if (\"width\" != l && \"height\" != l && \"href\" != l && \"list\" != l && \"form\" != l && \"tabIndex\" != l && \"download\" != l && \"rowSpan\" != l && \"colSpan\" != l && \"role\" != l && \"popover\" != l && l in n) try {\n n[l] = null == u ? \"\" : u;\n break n;\n } catch (n) {}\n \"function\" == typeof u || (null == u || !1 === u && \"-\" !== l[4] ? n.removeAttribute(l) : n.setAttribute(l, \"popover\" == l && 1 == u ? \"\" : u));\n }\n}\nfunction F(n) {\n return function (u) {\n if (this.l) {\n var t = this.l[u.type + n];\n if (null == u.t) u.t = e++;else if (u.t < t.u) return;\n return l.event && (u = l.event(u)), \"handleEvent\" in t ? t.handleEvent(u) : t(u);\n }\n };\n}\nfunction O(n, u, t, i, o, r, f, e, c, s) {\n var a,\n h,\n v,\n p,\n w,\n _,\n g,\n m,\n x,\n C,\n S,\n M,\n $,\n I,\n H,\n L,\n T = u.type;\n if (void 0 !== u.constructor) return null;\n 128 & t.__u && (c = !!(32 & t.__u), r = [e = u.__e = t.__e]), (a = l.__b) && a(u);\n n: if (\"function\" == typeof T) try {\n if (m = u.props, x = \"prototype\" in T && T.prototype.render, C = (a = T.contextType) && i[a.__c], S = a ? C ? C.props.value : a.__ : i, t.__c ? g = (h = u.__c = t.__c).__ = h.__E : (x ? u.__c = h = new T(m, S) : (u.__c = h = new k(m, S), h.constructor = T, h.render = V), C && C.sub(h), h.props = m, h.state || (h.state = {}), h.context = S, h.__n = i, v = h.__d = !0, h.__h = [], h._sb = []), x && null == h.__s && (h.__s = h.state), x && null != T.getDerivedStateFromProps && (h.__s == h.state && (h.__s = d({}, h.__s)), d(h.__s, T.getDerivedStateFromProps(m, h.__s))), p = h.props, w = h.state, h.__v = u, v) x && null == T.getDerivedStateFromProps && null != h.componentWillMount && h.componentWillMount(), x && null != h.componentDidMount && h.__h.push(h.componentDidMount);else {\n if (x && null == T.getDerivedStateFromProps && m !== p && null != h.componentWillReceiveProps && h.componentWillReceiveProps(m, S), !h.__e && (null != h.shouldComponentUpdate && !1 === h.shouldComponentUpdate(m, h.__s, S) || u.__v === t.__v)) {\n for (u.__v !== t.__v && (h.props = m, h.state = h.__s, h.__d = !1), u.__e = t.__e, u.__k = t.__k, u.__k.some(function (n) {\n n && (n.__ = u);\n }), M = 0; M < h._sb.length; M++) h.__h.push(h._sb[M]);\n h._sb = [], h.__h.length && f.push(h);\n break n;\n }\n null != h.componentWillUpdate && h.componentWillUpdate(m, h.__s, S), x && null != h.componentDidUpdate && h.__h.push(function () {\n h.componentDidUpdate(p, w, _);\n });\n }\n if (h.context = S, h.props = m, h.__P = n, h.__e = !1, $ = l.__r, I = 0, x) {\n for (h.state = h.__s, h.__d = !1, $ && $(u), a = h.render(h.props, h.state, h.context), H = 0; H < h._sb.length; H++) h.__h.push(h._sb[H]);\n h._sb = [];\n } else do {\n h.__d = !1, $ && $(u), a = h.render(h.props, h.state, h.context), h.state = h.__s;\n } while (h.__d && ++I < 25);\n h.state = h.__s, null != h.getChildContext && (i = d(d({}, i), h.getChildContext())), x && !v && null != h.getSnapshotBeforeUpdate && (_ = h.getSnapshotBeforeUpdate(p, w)), P(n, y(L = null != a && a.type === b && null == a.key ? a.props.children : a) ? L : [L], u, t, i, o, r, f, e, c, s), h.base = u.__e, u.__u &= -161, h.__h.length && f.push(h), g && (h.__E = h.__ = null);\n } catch (n) {\n if (u.__v = null, c || null != r) {\n for (u.__u |= c ? 160 : 128; e && 8 === e.nodeType && e.nextSibling;) e = e.nextSibling;\n r[r.indexOf(e)] = null, u.__e = e;\n } else u.__e = t.__e, u.__k = t.__k;\n l.__e(n, u, t);\n } else null == r && u.__v === t.__v ? (u.__k = t.__k, u.__e = t.__e) : u.__e = z(t.__e, u, t, i, o, r, f, c, s);\n (a = l.diffed) && a(u);\n}\nfunction j(n, u, t) {\n u.__d = void 0;\n for (var i = 0; i < t.length; i++) E(t[i], t[++i], t[++i]);\n l.__c && l.__c(u, n), n.some(function (u) {\n try {\n n = u.__h, u.__h = [], n.some(function (n) {\n n.call(u);\n });\n } catch (n) {\n l.__e(n, u.__v);\n }\n });\n}\nfunction z(u, t, i, o, r, f, e, c, s) {\n var a,\n v,\n p,\n d,\n _,\n g,\n m,\n b = i.props,\n k = t.props,\n C = t.type;\n if (\"svg\" === C ? r = \"http://www.w3.org/2000/svg\" : \"math\" === C ? r = \"http://www.w3.org/1998/Math/MathML\" : r || (r = \"http://www.w3.org/1999/xhtml\"), null != f) for (a = 0; a < f.length; a++) if ((_ = f[a]) && \"setAttribute\" in _ == !!C && (C ? _.localName === C : 3 === _.nodeType)) {\n u = _, f[a] = null;\n break;\n }\n if (null == u) {\n if (null === C) return document.createTextNode(k);\n u = document.createElementNS(r, C, k.is && k), c && (l.__m && l.__m(t, f), c = !1), f = null;\n }\n if (null === C) b === k || c && u.data === k || (u.data = k);else {\n if (f = f && n.call(u.childNodes), b = i.props || h, !c && null != f) for (b = {}, a = 0; a < u.attributes.length; a++) b[(_ = u.attributes[a]).name] = _.value;\n for (a in b) if (_ = b[a], \"children\" == a) ;else if (\"dangerouslySetInnerHTML\" == a) p = _;else if (!(a in k)) {\n if (\"value\" == a && \"defaultValue\" in k || \"checked\" == a && \"defaultChecked\" in k) continue;\n A(u, a, null, _, r);\n }\n for (a in k) _ = k[a], \"children\" == a ? d = _ : \"dangerouslySetInnerHTML\" == a ? v = _ : \"value\" == a ? g = _ : \"checked\" == a ? m = _ : c && \"function\" != typeof _ || b[a] === _ || A(u, a, _, b[a], r);\n if (v) c || p && (v.__html === p.__html || v.__html === u.innerHTML) || (u.innerHTML = v.__html), t.__k = [];else if (p && (u.innerHTML = \"\"), P(u, y(d) ? d : [d], t, i, o, \"foreignObject\" === C ? \"http://www.w3.org/1999/xhtml\" : r, f, e, f ? f[0] : i.__k && x(i, 0), c, s), null != f) for (a = f.length; a--;) w(f[a]);\n c || (a = \"value\", \"progress\" === C && null == g ? u.removeAttribute(\"value\") : void 0 !== g && (g !== u[a] || \"progress\" === C && !g || \"option\" === C && g !== b[a]) && A(u, a, g, b[a], r), a = \"checked\", void 0 !== m && m !== u[a] && A(u, a, m, b[a], r));\n }\n return u;\n}\nfunction E(n, u, t) {\n try {\n if (\"function\" == typeof n) {\n var i = \"function\" == typeof n.__u;\n i && n.__u(), i && null == u || (n.__u = n(u));\n } else n.current = u;\n } catch (n) {\n l.__e(n, t);\n }\n}\nfunction N(n, u, t) {\n var i, o;\n if (l.unmount && l.unmount(n), (i = n.ref) && (i.current && i.current !== n.__e || E(i, null, u)), null != (i = n.__c)) {\n if (i.componentWillUnmount) try {\n i.componentWillUnmount();\n } catch (n) {\n l.__e(n, u);\n }\n i.base = i.__P = null;\n }\n if (i = n.__k) for (o = 0; o < i.length; o++) i[o] && N(i[o], u, t || \"function\" != typeof n.type);\n t || w(n.__e), n.__c = n.__ = n.__e = n.__d = void 0;\n}\nfunction V(n, l, u) {\n return this.constructor(n, u);\n}\nfunction q(u, t, i) {\n var o, r, f, e;\n l.__ && l.__(u, t), r = (o = \"function\" == typeof i) ? null : i && i.__k || t.__k, f = [], e = [], O(t, u = (!o && i || t).__k = _(b, null, [u]), r || h, h, t.namespaceURI, !o && i ? [i] : r ? null : t.firstChild ? n.call(t.childNodes) : null, f, !o && i ? i : r ? r.__e : t.firstChild, o, e), j(f, u, e);\n}\nfunction B(n, l) {\n q(n, l, B);\n}\nfunction D(l, u, t) {\n var i,\n o,\n r,\n f,\n e = d({}, l.props);\n for (r in l.type && l.type.defaultProps && (f = l.type.defaultProps), u) \"key\" == r ? i = u[r] : \"ref\" == r ? o = u[r] : e[r] = void 0 === u[r] && void 0 !== f ? f[r] : u[r];\n return arguments.length > 2 && (e.children = arguments.length > 3 ? n.call(arguments, 2) : t), g(l.type, e, i || l.key, o || l.ref, null);\n}\nfunction G(n, l) {\n var u = {\n __c: l = \"__cC\" + a++,\n __: n,\n Consumer: function (n, l) {\n return n.children(l);\n },\n Provider: function (n) {\n var u, t;\n return this.getChildContext || (u = new Set(), (t = {})[l] = this, this.getChildContext = function () {\n return t;\n }, this.componentWillUnmount = function () {\n u = null;\n }, this.shouldComponentUpdate = function (n) {\n this.props.value !== n.value && u.forEach(function (n) {\n n.__e = !0, S(n);\n });\n }, this.sub = function (n) {\n u.add(n);\n var l = n.componentWillUnmount;\n n.componentWillUnmount = function () {\n u && u.delete(n), l && l.call(n);\n };\n }), n.children;\n }\n };\n return u.Provider.__ = u.Consumer.contextType = u;\n}\nn = v.slice, l = {\n __e: function (n, l, u, t) {\n for (var i, o, r; l = l.__;) if ((i = l.__c) && !i.__) try {\n if ((o = i.constructor) && null != o.getDerivedStateFromError && (i.setState(o.getDerivedStateFromError(n)), r = i.__d), null != i.componentDidCatch && (i.componentDidCatch(n, t || {}), r = i.__d), r) return i.__E = i;\n } catch (l) {\n n = l;\n }\n throw n;\n }\n}, u = 0, t = function (n) {\n return null != n && null == n.constructor;\n}, k.prototype.setState = function (n, l) {\n var u;\n u = null != this.__s && this.__s !== this.state ? this.__s : this.__s = d({}, this.state), \"function\" == typeof n && (n = n(d({}, u), this.props)), n && d(u, n), null != n && this.__v && (l && this._sb.push(l), S(this));\n}, k.prototype.forceUpdate = function (n) {\n this.__v && (this.__e = !0, n && this.__h.push(n), S(this));\n}, k.prototype.render = b, i = [], r = \"function\" == typeof Promise ? Promise.prototype.then.bind(Promise.resolve()) : setTimeout, f = function (n, l) {\n return n.__v.__b - l.__v.__b;\n}, M.__r = 0, e = 0, c = F(!1), s = F(!0), a = 0;\nexport { k as Component, b as Fragment, D as cloneElement, G as createContext, _ as createElement, m as createRef, _ as h, B as hydrate, t as isValidElement, l as options, q as render, H as toChildArray };\n","function r(e) {\n var t,\n f,\n n = \"\";\n if (\"string\" == typeof e || \"number\" == typeof e) n += e;else if (\"object\" == typeof e) if (Array.isArray(e)) for (t = 0; t < e.length; t++) e[t] && (f = r(e[t])) && (n && (n += \" \"), n += f);else for (t in e) e[t] && (n && (n += \" \"), n += t);\n return n;\n}\nexport function clsx() {\n for (var e, t, f = 0, n = \"\"; f < arguments.length;) (e = arguments[f++]) && (t = r(e)) && (n && (n += \" \"), n += t);\n return n;\n}\nexport default clsx;","import { options as n } from \"preact\";\nvar t,\n r,\n u,\n i,\n o = 0,\n f = [],\n c = n,\n e = c.__b,\n a = c.__r,\n v = c.diffed,\n l = c.__c,\n m = c.unmount,\n s = c.__;\nfunction d(n, t) {\n c.__h && c.__h(r, n, o || t), o = 0;\n var u = r.__H || (r.__H = {\n __: [],\n __h: []\n });\n return n >= u.__.length && u.__.push({}), u.__[n];\n}\nfunction h(n) {\n return o = 1, p(D, n);\n}\nfunction p(n, u, i) {\n var o = d(t++, 2);\n if (o.t = n, !o.__c && (o.__ = [i ? i(u) : D(void 0, u), function (n) {\n var t = o.__N ? o.__N[0] : o.__[0],\n r = o.t(t, n);\n t !== r && (o.__N = [r, o.__[1]], o.__c.setState({}));\n }], o.__c = r, !r.u)) {\n var f = function (n, t, r) {\n if (!o.__c.__H) return !0;\n var u = o.__c.__H.__.filter(function (n) {\n return !!n.__c;\n });\n if (u.every(function (n) {\n return !n.__N;\n })) return !c || c.call(this, n, t, r);\n var i = o.__c.props !== n;\n return u.forEach(function (n) {\n if (n.__N) {\n var t = n.__[0];\n n.__ = n.__N, n.__N = void 0, t !== n.__[0] && (i = !0);\n }\n }), c && c.call(this, n, t, r) || i;\n };\n r.u = !0;\n var c = r.shouldComponentUpdate,\n e = r.componentWillUpdate;\n r.componentWillUpdate = function (n, t, r) {\n if (this.__e) {\n var u = c;\n c = void 0, f(n, t, r), c = u;\n }\n e && e.call(this, n, t, r);\n }, r.shouldComponentUpdate = f;\n }\n return o.__N || o.__;\n}\nfunction y(n, u) {\n var i = d(t++, 3);\n !c.__s && C(i.__H, u) && (i.__ = n, i.i = u, r.__H.__h.push(i));\n}\nfunction _(n, u) {\n var i = d(t++, 4);\n !c.__s && C(i.__H, u) && (i.__ = n, i.i = u, r.__h.push(i));\n}\nfunction A(n) {\n return o = 5, T(function () {\n return {\n current: n\n };\n }, []);\n}\nfunction F(n, t, r) {\n o = 6, _(function () {\n return \"function\" == typeof n ? (n(t()), function () {\n return n(null);\n }) : n ? (n.current = t(), function () {\n return n.current = null;\n }) : void 0;\n }, null == r ? r : r.concat(n));\n}\nfunction T(n, r) {\n var u = d(t++, 7);\n return C(u.__H, r) && (u.__ = n(), u.__H = r, u.__h = n), u.__;\n}\nfunction q(n, t) {\n return o = 8, T(function () {\n return n;\n }, t);\n}\nfunction x(n) {\n var u = r.context[n.__c],\n i = d(t++, 9);\n return i.c = n, u ? (null == i.__ && (i.__ = !0, u.sub(r)), u.props.value) : n.__;\n}\nfunction P(n, t) {\n c.useDebugValue && c.useDebugValue(t ? t(n) : n);\n}\nfunction b(n) {\n var u = d(t++, 10),\n i = h();\n return u.__ = n, r.componentDidCatch || (r.componentDidCatch = function (n, t) {\n u.__ && u.__(n, t), i[1](n);\n }), [i[0], function () {\n i[1](void 0);\n }];\n}\nfunction g() {\n var n = d(t++, 11);\n if (!n.__) {\n for (var u = r.__v; null !== u && !u.__m && null !== u.__;) u = u.__;\n var i = u.__m || (u.__m = [0, 0]);\n n.__ = \"P\" + i[0] + \"-\" + i[1]++;\n }\n return n.__;\n}\nfunction j() {\n for (var n; n = f.shift();) if (n.__P && n.__H) try {\n n.__H.__h.forEach(z), n.__H.__h.forEach(B), n.__H.__h = [];\n } catch (t) {\n n.__H.__h = [], c.__e(t, n.__v);\n }\n}\nc.__b = function (n) {\n r = null, e && e(n);\n}, c.__ = function (n, t) {\n n && t.__k && t.__k.__m && (n.__m = t.__k.__m), s && s(n, t);\n}, c.__r = function (n) {\n a && a(n), t = 0;\n var i = (r = n.__c).__H;\n i && (u === r ? (i.__h = [], r.__h = [], i.__.forEach(function (n) {\n n.__N && (n.__ = n.__N), n.i = n.__N = void 0;\n })) : (i.__h.forEach(z), i.__h.forEach(B), i.__h = [], t = 0)), u = r;\n}, c.diffed = function (n) {\n v && v(n);\n var t = n.__c;\n t && t.__H && (t.__H.__h.length && (1 !== f.push(t) && i === c.requestAnimationFrame || ((i = c.requestAnimationFrame) || w)(j)), t.__H.__.forEach(function (n) {\n n.i && (n.__H = n.i), n.i = void 0;\n })), u = r = null;\n}, c.__c = function (n, t) {\n t.some(function (n) {\n try {\n n.__h.forEach(z), n.__h = n.__h.filter(function (n) {\n return !n.__ || B(n);\n });\n } catch (r) {\n t.some(function (n) {\n n.__h && (n.__h = []);\n }), t = [], c.__e(r, n.__v);\n }\n }), l && l(n, t);\n}, c.unmount = function (n) {\n m && m(n);\n var t,\n r = n.__c;\n r && r.__H && (r.__H.__.forEach(function (n) {\n try {\n z(n);\n } catch (n) {\n t = n;\n }\n }), r.__H = void 0, t && c.__e(t, r.__v));\n};\nvar k = \"function\" == typeof requestAnimationFrame;\nfunction w(n) {\n var t,\n r = function () {\n clearTimeout(u), k && cancelAnimationFrame(t), setTimeout(n);\n },\n u = setTimeout(r, 100);\n k && (t = requestAnimationFrame(r));\n}\nfunction z(n) {\n var t = r,\n u = n.__c;\n \"function\" == typeof u && (n.__c = void 0, u()), r = t;\n}\nfunction B(n) {\n var t = r;\n n.__c = n.__(), r = t;\n}\nfunction C(n, t) {\n return !n || n.length !== t.length || t.some(function (t, r) {\n return t !== n[r];\n });\n}\nfunction D(n, t) {\n return \"function\" == typeof t ? t(n) : t;\n}\nexport { q as useCallback, x as useContext, P as useDebugValue, y as useEffect, b as useErrorBoundary, g as useId, F as useImperativeHandle, _ as useLayoutEffect, T as useMemo, p as useReducer, A as useRef, h as useState };\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.CloseIcon = void 0;\nconst preact_1 = require(\"preact\");\nfunction CloseIcon(props) {\n return (0, preact_1.h)(\"svg\", Object.assign({\n width: \"40\",\n height: \"40\",\n viewBox: \"0 0 40 40\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), (0, preact_1.h)(\"path\", {\n d: \"M13.7677 13L12.3535 14.4142L18.3535 20.4142L12.3535 26.4142L13.7677 27.8284L19.7677 21.8284L25.7677 27.8284L27.1819 26.4142L21.1819 20.4142L27.1819 14.4142L25.7677 13L19.7677 19L13.7677 13Z\"\n }));\n}\nexports.CloseIcon = CloseIcon;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = ``;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = ``;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.QRCodeIcon = void 0;\nconst preact_1 = require(\"preact\");\nfunction QRCodeIcon(props) {\n return (0, preact_1.h)(\"svg\", Object.assign({\n width: \"10\",\n height: \"10\",\n viewBox: \"0 0 10 10\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), (0, preact_1.h)(\"path\", {\n d: \"M8.2271 1.77124L7.0271 1.77124V2.97124H8.2271V1.77124Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M5.44922 0.199219L5.44922 4.54922L9.79922 4.54922V0.199219L5.44922 0.199219ZM8.89922 3.64922L6.34922 3.64922L6.34922 1.09922L8.89922 1.09922V3.64922Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M2.97124 1.77124L1.77124 1.77124L1.77124 2.97124H2.97124V1.77124Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M0.199219 4.54922L4.54922 4.54922L4.54922 0.199219L0.199219 0.199219L0.199219 4.54922ZM1.09922 1.09922L3.64922 1.09922L3.64922 3.64922L1.09922 3.64922L1.09922 1.09922Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M2.97124 7.0271H1.77124L1.77124 8.2271H2.97124V7.0271Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M0.199219 9.79922H4.54922L4.54922 5.44922L0.199219 5.44922L0.199219 9.79922ZM1.09922 6.34922L3.64922 6.34922L3.64922 8.89922H1.09922L1.09922 6.34922Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M8.89922 7.39912H7.99922V5.40112H5.44922L5.44922 9.79912H6.34922L6.34922 6.30112H7.09922V8.29912H9.79922V5.40112H8.89922V7.39912Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M7.99912 8.89917H7.09912V9.79917H7.99912V8.89917Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M9.79917 8.89917H8.89917V9.79917H9.79917V8.89917Z\"\n }));\n}\nexports.QRCodeIcon = QRCodeIcon;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nconst svg = `\n \n \n \n \n \n`;\nexports.default = svg;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = `\n \n \n \n \n \n \n`;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.StatusDotIcon = void 0;\nconst preact_1 = require(\"preact\");\nfunction StatusDotIcon(props) {\n return (0, preact_1.h)(\"svg\", Object.assign({\n width: \"10\",\n height: \"10\",\n viewBox: \"0 0 10 10\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), (0, preact_1.h)(\"path\", {\n \"fill-rule\": \"evenodd\",\n \"clip-rule\": \"evenodd\",\n d: \"M2.29995 4.99995C2.29995 5.57985 1.82985 6.04995 1.24995 6.04995C0.670052 6.04995 0.199951 5.57985 0.199951 4.99995C0.199951 4.42005 0.670052 3.94995 1.24995 3.94995C1.82985 3.94995 2.29995 4.42005 2.29995 4.99995ZM4.99995 6.04995C5.57985 6.04995 6.04995 5.57985 6.04995 4.99995C6.04995 4.42005 5.57985 3.94995 4.99995 3.94995C4.42005 3.94995 3.94995 4.42005 3.94995 4.99995C3.94995 5.57985 4.42005 6.04995 4.99995 6.04995ZM8.74995 6.04995C9.32985 6.04995 9.79995 5.57985 9.79995 4.99995C9.79995 4.42005 9.32985 3.94995 8.74995 3.94995C8.17005 3.94995 7.69995 4.42005 7.69995 4.99995C7.69995 5.57985 8.17005 6.04995 8.74995 6.04995Z\"\n }));\n}\nexports.StatusDotIcon = StatusDotIcon;","/**\n * @fileoverview\n * - modified davidshimjs/qrcodejs library for use in node.js\n * - Using the 'QRCode for Javascript library'\n * - Fixed dataset of 'QRCode for Javascript library' for support full-spec.\n * - this library has no dependencies.\n *\n * @version 0.9.1 (2016-02-12)\n * @author davidshimjs, papnkukn\n * @see http://www.d-project.com/\n * @see http://jeromeetienne.github.com/jquery-qrcode/\n * @see https://github.com/davidshimjs/qrcodejs\n */\n\n//---------------------------------------------------------------------\n// QRCode for JavaScript\n//\n// Copyright (c) 2009 Kazuhiko Arase\n//\n// URL: http://www.d-project.com/\n//\n// Licensed under the MIT license:\n// http://www.opensource.org/licenses/mit-license.php\n//\n// The word \"QR Code\" is registered trademark of\n// DENSO WAVE INCORPORATED\n// http://www.denso-wave.com/qrcode/faqpatent-e.html\n//\n//---------------------------------------------------------------------\nfunction QR8bitByte(data) {\n this.mode = QRMode.MODE_8BIT_BYTE;\n this.data = data;\n this.parsedData = [];\n\n // Added to support UTF-8 Characters\n for (var i = 0, l = this.data.length; i < l; i++) {\n var byteArray = [];\n var code = this.data.charCodeAt(i);\n if (code > 0x10000) {\n byteArray[0] = 0xF0 | (code & 0x1C0000) >>> 18;\n byteArray[1] = 0x80 | (code & 0x3F000) >>> 12;\n byteArray[2] = 0x80 | (code & 0xFC0) >>> 6;\n byteArray[3] = 0x80 | code & 0x3F;\n } else if (code > 0x800) {\n byteArray[0] = 0xE0 | (code & 0xF000) >>> 12;\n byteArray[1] = 0x80 | (code & 0xFC0) >>> 6;\n byteArray[2] = 0x80 | code & 0x3F;\n } else if (code > 0x80) {\n byteArray[0] = 0xC0 | (code & 0x7C0) >>> 6;\n byteArray[1] = 0x80 | code & 0x3F;\n } else {\n byteArray[0] = code;\n }\n this.parsedData.push(byteArray);\n }\n this.parsedData = Array.prototype.concat.apply([], this.parsedData);\n if (this.parsedData.length != this.data.length) {\n this.parsedData.unshift(191);\n this.parsedData.unshift(187);\n this.parsedData.unshift(239);\n }\n}\nQR8bitByte.prototype = {\n getLength: function (buffer) {\n return this.parsedData.length;\n },\n write: function (buffer) {\n for (var i = 0, l = this.parsedData.length; i < l; i++) {\n buffer.put(this.parsedData[i], 8);\n }\n }\n};\nfunction QRCodeModel(typeNumber, errorCorrectLevel) {\n this.typeNumber = typeNumber;\n this.errorCorrectLevel = errorCorrectLevel;\n this.modules = null;\n this.moduleCount = 0;\n this.dataCache = null;\n this.dataList = [];\n}\nQRCodeModel.prototype = {\n addData: function (data) {\n var newData = new QR8bitByte(data);\n this.dataList.push(newData);\n this.dataCache = null;\n },\n isDark: function (row, col) {\n if (row < 0 || this.moduleCount <= row || col < 0 || this.moduleCount <= col) {\n throw new Error(row + \",\" + col);\n }\n return this.modules[row][col];\n },\n getModuleCount: function () {\n return this.moduleCount;\n },\n make: function () {\n this.makeImpl(false, this.getBestMaskPattern());\n },\n makeImpl: function (test, maskPattern) {\n this.moduleCount = this.typeNumber * 4 + 17;\n this.modules = new Array(this.moduleCount);\n for (var row = 0; row < this.moduleCount; row++) {\n this.modules[row] = new Array(this.moduleCount);\n for (var col = 0; col < this.moduleCount; col++) {\n this.modules[row][col] = null;\n }\n }\n this.setupPositionProbePattern(0, 0);\n this.setupPositionProbePattern(this.moduleCount - 7, 0);\n this.setupPositionProbePattern(0, this.moduleCount - 7);\n this.setupPositionAdjustPattern();\n this.setupTimingPattern();\n this.setupTypeInfo(test, maskPattern);\n if (this.typeNumber >= 7) {\n this.setupTypeNumber(test);\n }\n if (this.dataCache == null) {\n this.dataCache = QRCodeModel.createData(this.typeNumber, this.errorCorrectLevel, this.dataList);\n }\n this.mapData(this.dataCache, maskPattern);\n },\n setupPositionProbePattern: function (row, col) {\n for (var r = -1; r <= 7; r++) {\n if (row + r <= -1 || this.moduleCount <= row + r) continue;\n for (var c = -1; c <= 7; c++) {\n if (col + c <= -1 || this.moduleCount <= col + c) continue;\n if (0 <= r && r <= 6 && (c == 0 || c == 6) || 0 <= c && c <= 6 && (r == 0 || r == 6) || 2 <= r && r <= 4 && 2 <= c && c <= 4) {\n this.modules[row + r][col + c] = true;\n } else {\n this.modules[row + r][col + c] = false;\n }\n }\n }\n },\n getBestMaskPattern: function () {\n var minLostPoint = 0;\n var pattern = 0;\n for (var i = 0; i < 8; i++) {\n this.makeImpl(true, i);\n var lostPoint = QRUtil.getLostPoint(this);\n if (i == 0 || minLostPoint > lostPoint) {\n minLostPoint = lostPoint;\n pattern = i;\n }\n }\n return pattern;\n },\n createMovieClip: function (target_mc, instance_name, depth) {\n var qr_mc = target_mc.createEmptyMovieClip(instance_name, depth);\n var cs = 1;\n this.make();\n for (var row = 0; row < this.modules.length; row++) {\n var y = row * cs;\n for (var col = 0; col < this.modules[row].length; col++) {\n var x = col * cs;\n var dark = this.modules[row][col];\n if (dark) {\n qr_mc.beginFill(0, 100);\n qr_mc.moveTo(x, y);\n qr_mc.lineTo(x + cs, y);\n qr_mc.lineTo(x + cs, y + cs);\n qr_mc.lineTo(x, y + cs);\n qr_mc.endFill();\n }\n }\n }\n return qr_mc;\n },\n setupTimingPattern: function () {\n for (var r = 8; r < this.moduleCount - 8; r++) {\n if (this.modules[r][6] != null) {\n continue;\n }\n this.modules[r][6] = r % 2 == 0;\n }\n for (var c = 8; c < this.moduleCount - 8; c++) {\n if (this.modules[6][c] != null) {\n continue;\n }\n this.modules[6][c] = c % 2 == 0;\n }\n },\n setupPositionAdjustPattern: function () {\n var pos = QRUtil.getPatternPosition(this.typeNumber);\n for (var i = 0; i < pos.length; i++) {\n for (var j = 0; j < pos.length; j++) {\n var row = pos[i];\n var col = pos[j];\n if (this.modules[row][col] != null) {\n continue;\n }\n for (var r = -2; r <= 2; r++) {\n for (var c = -2; c <= 2; c++) {\n if (r == -2 || r == 2 || c == -2 || c == 2 || r == 0 && c == 0) {\n this.modules[row + r][col + c] = true;\n } else {\n this.modules[row + r][col + c] = false;\n }\n }\n }\n }\n }\n },\n setupTypeNumber: function (test) {\n var bits = QRUtil.getBCHTypeNumber(this.typeNumber);\n for (var i = 0; i < 18; i++) {\n var mod = !test && (bits >> i & 1) == 1;\n this.modules[Math.floor(i / 3)][i % 3 + this.moduleCount - 8 - 3] = mod;\n }\n for (var i = 0; i < 18; i++) {\n var mod = !test && (bits >> i & 1) == 1;\n this.modules[i % 3 + this.moduleCount - 8 - 3][Math.floor(i / 3)] = mod;\n }\n },\n setupTypeInfo: function (test, maskPattern) {\n var data = this.errorCorrectLevel << 3 | maskPattern;\n var bits = QRUtil.getBCHTypeInfo(data);\n for (var i = 0; i < 15; i++) {\n var mod = !test && (bits >> i & 1) == 1;\n if (i < 6) {\n this.modules[i][8] = mod;\n } else if (i < 8) {\n this.modules[i + 1][8] = mod;\n } else {\n this.modules[this.moduleCount - 15 + i][8] = mod;\n }\n }\n for (var i = 0; i < 15; i++) {\n var mod = !test && (bits >> i & 1) == 1;\n if (i < 8) {\n this.modules[8][this.moduleCount - i - 1] = mod;\n } else if (i < 9) {\n this.modules[8][15 - i - 1 + 1] = mod;\n } else {\n this.modules[8][15 - i - 1] = mod;\n }\n }\n this.modules[this.moduleCount - 8][8] = !test;\n },\n mapData: function (data, maskPattern) {\n var inc = -1;\n var row = this.moduleCount - 1;\n var bitIndex = 7;\n var byteIndex = 0;\n for (var col = this.moduleCount - 1; col > 0; col -= 2) {\n if (col == 6) col--;\n while (true) {\n for (var c = 0; c < 2; c++) {\n if (this.modules[row][col - c] == null) {\n var dark = false;\n if (byteIndex < data.length) {\n dark = (data[byteIndex] >>> bitIndex & 1) == 1;\n }\n var mask = QRUtil.getMask(maskPattern, row, col - c);\n if (mask) {\n dark = !dark;\n }\n this.modules[row][col - c] = dark;\n bitIndex--;\n if (bitIndex == -1) {\n byteIndex++;\n bitIndex = 7;\n }\n }\n }\n row += inc;\n if (row < 0 || this.moduleCount <= row) {\n row -= inc;\n inc = -inc;\n break;\n }\n }\n }\n }\n};\nQRCodeModel.PAD0 = 0xEC;\nQRCodeModel.PAD1 = 0x11;\nQRCodeModel.createData = function (typeNumber, errorCorrectLevel, dataList) {\n var rsBlocks = QRRSBlock.getRSBlocks(typeNumber, errorCorrectLevel);\n var buffer = new QRBitBuffer();\n for (var i = 0; i < dataList.length; i++) {\n var data = dataList[i];\n buffer.put(data.mode, 4);\n buffer.put(data.getLength(), QRUtil.getLengthInBits(data.mode, typeNumber));\n data.write(buffer);\n }\n var totalDataCount = 0;\n for (var i = 0; i < rsBlocks.length; i++) {\n totalDataCount += rsBlocks[i].dataCount;\n }\n if (buffer.getLengthInBits() > totalDataCount * 8) {\n throw new Error(\"code length overflow. (\" + buffer.getLengthInBits() + \">\" + totalDataCount * 8 + \")\");\n }\n if (buffer.getLengthInBits() + 4 <= totalDataCount * 8) {\n buffer.put(0, 4);\n }\n while (buffer.getLengthInBits() % 8 != 0) {\n buffer.putBit(false);\n }\n while (true) {\n if (buffer.getLengthInBits() >= totalDataCount * 8) {\n break;\n }\n buffer.put(QRCodeModel.PAD0, 8);\n if (buffer.getLengthInBits() >= totalDataCount * 8) {\n break;\n }\n buffer.put(QRCodeModel.PAD1, 8);\n }\n return QRCodeModel.createBytes(buffer, rsBlocks);\n};\nQRCodeModel.createBytes = function (buffer, rsBlocks) {\n var offset = 0;\n var maxDcCount = 0;\n var maxEcCount = 0;\n var dcdata = new Array(rsBlocks.length);\n var ecdata = new Array(rsBlocks.length);\n for (var r = 0; r < rsBlocks.length; r++) {\n var dcCount = rsBlocks[r].dataCount;\n var ecCount = rsBlocks[r].totalCount - dcCount;\n maxDcCount = Math.max(maxDcCount, dcCount);\n maxEcCount = Math.max(maxEcCount, ecCount);\n dcdata[r] = new Array(dcCount);\n for (var i = 0; i < dcdata[r].length; i++) {\n dcdata[r][i] = 0xff & buffer.buffer[i + offset];\n }\n offset += dcCount;\n var rsPoly = QRUtil.getErrorCorrectPolynomial(ecCount);\n var rawPoly = new QRPolynomial(dcdata[r], rsPoly.getLength() - 1);\n var modPoly = rawPoly.mod(rsPoly);\n ecdata[r] = new Array(rsPoly.getLength() - 1);\n for (var i = 0; i < ecdata[r].length; i++) {\n var modIndex = i + modPoly.getLength() - ecdata[r].length;\n ecdata[r][i] = modIndex >= 0 ? modPoly.get(modIndex) : 0;\n }\n }\n var totalCodeCount = 0;\n for (var i = 0; i < rsBlocks.length; i++) {\n totalCodeCount += rsBlocks[i].totalCount;\n }\n var data = new Array(totalCodeCount);\n var index = 0;\n for (var i = 0; i < maxDcCount; i++) {\n for (var r = 0; r < rsBlocks.length; r++) {\n if (i < dcdata[r].length) {\n data[index++] = dcdata[r][i];\n }\n }\n }\n for (var i = 0; i < maxEcCount; i++) {\n for (var r = 0; r < rsBlocks.length; r++) {\n if (i < ecdata[r].length) {\n data[index++] = ecdata[r][i];\n }\n }\n }\n return data;\n};\nvar QRMode = {\n MODE_NUMBER: 1 << 0,\n MODE_ALPHA_NUM: 1 << 1,\n MODE_8BIT_BYTE: 1 << 2,\n MODE_KANJI: 1 << 3\n};\nvar QRErrorCorrectLevel = {\n L: 1,\n M: 0,\n Q: 3,\n H: 2\n};\nvar QRMaskPattern = {\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};\nvar QRUtil = {\n PATTERN_POSITION_TABLE: [[], [6, 18], [6, 22], [6, 26], [6, 30], [6, 34], [6, 22, 38], [6, 24, 42], [6, 26, 46], [6, 28, 50], [6, 30, 54], [6, 32, 58], [6, 34, 62], [6, 26, 46, 66], [6, 26, 48, 70], [6, 26, 50, 74], [6, 30, 54, 78], [6, 30, 56, 82], [6, 30, 58, 86], [6, 34, 62, 90], [6, 28, 50, 72, 94], [6, 26, 50, 74, 98], [6, 30, 54, 78, 102], [6, 28, 54, 80, 106], [6, 32, 58, 84, 110], [6, 30, 58, 86, 114], [6, 34, 62, 90, 118], [6, 26, 50, 74, 98, 122], [6, 30, 54, 78, 102, 126], [6, 26, 52, 78, 104, 130], [6, 30, 56, 82, 108, 134], [6, 34, 60, 86, 112, 138], [6, 30, 58, 86, 114, 142], [6, 34, 62, 90, 118, 146], [6, 30, 54, 78, 102, 126, 150], [6, 24, 50, 76, 102, 128, 154], [6, 28, 54, 80, 106, 132, 158], [6, 32, 58, 84, 110, 136, 162], [6, 26, 54, 82, 110, 138, 166], [6, 30, 58, 86, 114, 142, 170]],\n G15: 1 << 10 | 1 << 8 | 1 << 5 | 1 << 4 | 1 << 2 | 1 << 1 | 1 << 0,\n G18: 1 << 12 | 1 << 11 | 1 << 10 | 1 << 9 | 1 << 8 | 1 << 5 | 1 << 2 | 1 << 0,\n G15_MASK: 1 << 14 | 1 << 12 | 1 << 10 | 1 << 4 | 1 << 1,\n getBCHTypeInfo: function (data) {\n var d = data << 10;\n while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15) >= 0) {\n d ^= QRUtil.G15 << QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15);\n }\n return (data << 10 | d) ^ QRUtil.G15_MASK;\n },\n getBCHTypeNumber: function (data) {\n var d = data << 12;\n while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18) >= 0) {\n d ^= QRUtil.G18 << QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18);\n }\n return data << 12 | d;\n },\n getBCHDigit: function (data) {\n var digit = 0;\n while (data != 0) {\n digit++;\n data >>>= 1;\n }\n return digit;\n },\n getPatternPosition: function (typeNumber) {\n return QRUtil.PATTERN_POSITION_TABLE[typeNumber - 1];\n },\n getMask: function (maskPattern, i, j) {\n switch (maskPattern) {\n case QRMaskPattern.PATTERN000:\n return (i + j) % 2 == 0;\n case QRMaskPattern.PATTERN001:\n return i % 2 == 0;\n case QRMaskPattern.PATTERN010:\n return j % 3 == 0;\n case QRMaskPattern.PATTERN011:\n return (i + j) % 3 == 0;\n case QRMaskPattern.PATTERN100:\n return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 == 0;\n case QRMaskPattern.PATTERN101:\n return i * j % 2 + i * j % 3 == 0;\n case QRMaskPattern.PATTERN110:\n return (i * j % 2 + i * j % 3) % 2 == 0;\n case QRMaskPattern.PATTERN111:\n return (i * j % 3 + (i + j) % 2) % 2 == 0;\n default:\n throw new Error(\"bad maskPattern:\" + maskPattern);\n }\n },\n getErrorCorrectPolynomial: function (errorCorrectLength) {\n var a = new QRPolynomial([1], 0);\n for (var i = 0; i < errorCorrectLength; i++) {\n a = a.multiply(new QRPolynomial([1, QRMath.gexp(i)], 0));\n }\n return a;\n },\n getLengthInBits: function (mode, type) {\n if (1 <= type && type < 10) {\n switch (mode) {\n case QRMode.MODE_NUMBER:\n return 10;\n case QRMode.MODE_ALPHA_NUM:\n return 9;\n case QRMode.MODE_8BIT_BYTE:\n return 8;\n case QRMode.MODE_KANJI:\n return 8;\n default:\n throw new Error(\"mode:\" + mode);\n }\n } else if (type < 27) {\n switch (mode) {\n case QRMode.MODE_NUMBER:\n return 12;\n case QRMode.MODE_ALPHA_NUM:\n return 11;\n case QRMode.MODE_8BIT_BYTE:\n return 16;\n case QRMode.MODE_KANJI:\n return 10;\n default:\n throw new Error(\"mode:\" + mode);\n }\n } else if (type < 41) {\n switch (mode) {\n case QRMode.MODE_NUMBER:\n return 14;\n case QRMode.MODE_ALPHA_NUM:\n return 13;\n case QRMode.MODE_8BIT_BYTE:\n return 16;\n case QRMode.MODE_KANJI:\n return 12;\n default:\n throw new Error(\"mode:\" + mode);\n }\n } else {\n throw new Error(\"type:\" + type);\n }\n },\n getLostPoint: function (qrCode) {\n var moduleCount = qrCode.getModuleCount();\n var lostPoint = 0;\n for (var row = 0; row < moduleCount; row++) {\n for (var col = 0; col < moduleCount; col++) {\n var sameCount = 0;\n var dark = qrCode.isDark(row, col);\n for (var r = -1; r <= 1; r++) {\n if (row + r < 0 || moduleCount <= row + r) {\n continue;\n }\n for (var c = -1; c <= 1; c++) {\n if (col + c < 0 || moduleCount <= col + c) {\n continue;\n }\n if (r == 0 && c == 0) {\n continue;\n }\n if (dark == qrCode.isDark(row + r, col + c)) {\n sameCount++;\n }\n }\n }\n if (sameCount > 5) {\n lostPoint += 3 + sameCount - 5;\n }\n }\n }\n for (var row = 0; row < moduleCount - 1; row++) {\n for (var col = 0; col < moduleCount - 1; col++) {\n var count = 0;\n if (qrCode.isDark(row, col)) count++;\n if (qrCode.isDark(row + 1, col)) count++;\n if (qrCode.isDark(row, col + 1)) count++;\n if (qrCode.isDark(row + 1, col + 1)) count++;\n if (count == 0 || count == 4) {\n lostPoint += 3;\n }\n }\n }\n for (var row = 0; row < moduleCount; row++) {\n for (var col = 0; col < moduleCount - 6; col++) {\n if (qrCode.isDark(row, col) && !qrCode.isDark(row, col + 1) && qrCode.isDark(row, col + 2) && qrCode.isDark(row, col + 3) && qrCode.isDark(row, col + 4) && !qrCode.isDark(row, col + 5) && qrCode.isDark(row, col + 6)) {\n lostPoint += 40;\n }\n }\n }\n for (var col = 0; col < moduleCount; col++) {\n for (var row = 0; row < moduleCount - 6; row++) {\n if (qrCode.isDark(row, col) && !qrCode.isDark(row + 1, col) && qrCode.isDark(row + 2, col) && qrCode.isDark(row + 3, col) && qrCode.isDark(row + 4, col) && !qrCode.isDark(row + 5, col) && qrCode.isDark(row + 6, col)) {\n lostPoint += 40;\n }\n }\n }\n var darkCount = 0;\n for (var col = 0; col < moduleCount; col++) {\n for (var row = 0; row < moduleCount; row++) {\n if (qrCode.isDark(row, col)) {\n darkCount++;\n }\n }\n }\n var ratio = Math.abs(100 * darkCount / moduleCount / moduleCount - 50) / 5;\n lostPoint += ratio * 10;\n return lostPoint;\n }\n};\nvar QRMath = {\n glog: function (n) {\n if (n < 1) {\n throw new Error(\"glog(\" + n + \")\");\n }\n return QRMath.LOG_TABLE[n];\n },\n gexp: function (n) {\n while (n < 0) {\n n += 255;\n }\n while (n >= 256) {\n n -= 255;\n }\n return QRMath.EXP_TABLE[n];\n },\n EXP_TABLE: new Array(256),\n LOG_TABLE: new Array(256)\n};\nfor (var i = 0; i < 8; i++) {\n QRMath.EXP_TABLE[i] = 1 << i;\n}\nfor (var i = 8; i < 256; i++) {\n QRMath.EXP_TABLE[i] = QRMath.EXP_TABLE[i - 4] ^ QRMath.EXP_TABLE[i - 5] ^ QRMath.EXP_TABLE[i - 6] ^ QRMath.EXP_TABLE[i - 8];\n}\nfor (var i = 0; i < 255; i++) {\n QRMath.LOG_TABLE[QRMath.EXP_TABLE[i]] = i;\n}\nfunction QRPolynomial(num, shift) {\n if (num.length == undefined) {\n throw new Error(num.length + \"/\" + shift);\n }\n var offset = 0;\n while (offset < num.length && num[offset] == 0) {\n offset++;\n }\n this.num = new Array(num.length - offset + shift);\n for (var i = 0; i < num.length - offset; i++) {\n this.num[i] = num[i + offset];\n }\n}\nQRPolynomial.prototype = {\n get: function (index) {\n return this.num[index];\n },\n getLength: function () {\n return this.num.length;\n },\n multiply: function (e) {\n var num = new Array(this.getLength() + e.getLength() - 1);\n for (var i = 0; i < this.getLength(); i++) {\n for (var j = 0; j < e.getLength(); j++) {\n num[i + j] ^= QRMath.gexp(QRMath.glog(this.get(i)) + QRMath.glog(e.get(j)));\n }\n }\n return new QRPolynomial(num, 0);\n },\n mod: function (e) {\n if (this.getLength() - e.getLength() < 0) {\n return this;\n }\n var ratio = QRMath.glog(this.get(0)) - QRMath.glog(e.get(0));\n var num = new Array(this.getLength());\n for (var i = 0; i < this.getLength(); i++) {\n num[i] = this.get(i);\n }\n for (var i = 0; i < e.getLength(); i++) {\n num[i] ^= QRMath.gexp(QRMath.glog(e.get(i)) + ratio);\n }\n return new QRPolynomial(num, 0).mod(e);\n }\n};\nfunction QRRSBlock(totalCount, dataCount) {\n this.totalCount = totalCount;\n this.dataCount = dataCount;\n}\nQRRSBlock.RS_BLOCK_TABLE = [[1, 26, 19], [1, 26, 16], [1, 26, 13], [1, 26, 9], [1, 44, 34], [1, 44, 28], [1, 44, 22], [1, 44, 16], [1, 70, 55], [1, 70, 44], [2, 35, 17], [2, 35, 13], [1, 100, 80], [2, 50, 32], [2, 50, 24], [4, 25, 9], [1, 134, 108], [2, 67, 43], [2, 33, 15, 2, 34, 16], [2, 33, 11, 2, 34, 12], [2, 86, 68], [4, 43, 27], [4, 43, 19], [4, 43, 15], [2, 98, 78], [4, 49, 31], [2, 32, 14, 4, 33, 15], [4, 39, 13, 1, 40, 14], [2, 121, 97], [2, 60, 38, 2, 61, 39], [4, 40, 18, 2, 41, 19], [4, 40, 14, 2, 41, 15], [2, 146, 116], [3, 58, 36, 2, 59, 37], [4, 36, 16, 4, 37, 17], [4, 36, 12, 4, 37, 13], [2, 86, 68, 2, 87, 69], [4, 69, 43, 1, 70, 44], [6, 43, 19, 2, 44, 20], [6, 43, 15, 2, 44, 16], [4, 101, 81], [1, 80, 50, 4, 81, 51], [4, 50, 22, 4, 51, 23], [3, 36, 12, 8, 37, 13], [2, 116, 92, 2, 117, 93], [6, 58, 36, 2, 59, 37], [4, 46, 20, 6, 47, 21], [7, 42, 14, 4, 43, 15], [4, 133, 107], [8, 59, 37, 1, 60, 38], [8, 44, 20, 4, 45, 21], [12, 33, 11, 4, 34, 12], [3, 145, 115, 1, 146, 116], [4, 64, 40, 5, 65, 41], [11, 36, 16, 5, 37, 17], [11, 36, 12, 5, 37, 13], [5, 109, 87, 1, 110, 88], [5, 65, 41, 5, 66, 42], [5, 54, 24, 7, 55, 25], [11, 36, 12], [5, 122, 98, 1, 123, 99], [7, 73, 45, 3, 74, 46], [15, 43, 19, 2, 44, 20], [3, 45, 15, 13, 46, 16], [1, 135, 107, 5, 136, 108], [10, 74, 46, 1, 75, 47], [1, 50, 22, 15, 51, 23], [2, 42, 14, 17, 43, 15], [5, 150, 120, 1, 151, 121], [9, 69, 43, 4, 70, 44], [17, 50, 22, 1, 51, 23], [2, 42, 14, 19, 43, 15], [3, 141, 113, 4, 142, 114], [3, 70, 44, 11, 71, 45], [17, 47, 21, 4, 48, 22], [9, 39, 13, 16, 40, 14], [3, 135, 107, 5, 136, 108], [3, 67, 41, 13, 68, 42], [15, 54, 24, 5, 55, 25], [15, 43, 15, 10, 44, 16], [4, 144, 116, 4, 145, 117], [17, 68, 42], [17, 50, 22, 6, 51, 23], [19, 46, 16, 6, 47, 17], [2, 139, 111, 7, 140, 112], [17, 74, 46], [7, 54, 24, 16, 55, 25], [34, 37, 13], [4, 151, 121, 5, 152, 122], [4, 75, 47, 14, 76, 48], [11, 54, 24, 14, 55, 25], [16, 45, 15, 14, 46, 16], [6, 147, 117, 4, 148, 118], [6, 73, 45, 14, 74, 46], [11, 54, 24, 16, 55, 25], [30, 46, 16, 2, 47, 17], [8, 132, 106, 4, 133, 107], [8, 75, 47, 13, 76, 48], [7, 54, 24, 22, 55, 25], [22, 45, 15, 13, 46, 16], [10, 142, 114, 2, 143, 115], [19, 74, 46, 4, 75, 47], [28, 50, 22, 6, 51, 23], [33, 46, 16, 4, 47, 17], [8, 152, 122, 4, 153, 123], [22, 73, 45, 3, 74, 46], [8, 53, 23, 26, 54, 24], [12, 45, 15, 28, 46, 16], [3, 147, 117, 10, 148, 118], [3, 73, 45, 23, 74, 46], [4, 54, 24, 31, 55, 25], [11, 45, 15, 31, 46, 16], [7, 146, 116, 7, 147, 117], [21, 73, 45, 7, 74, 46], [1, 53, 23, 37, 54, 24], [19, 45, 15, 26, 46, 16], [5, 145, 115, 10, 146, 116], [19, 75, 47, 10, 76, 48], [15, 54, 24, 25, 55, 25], [23, 45, 15, 25, 46, 16], [13, 145, 115, 3, 146, 116], [2, 74, 46, 29, 75, 47], [42, 54, 24, 1, 55, 25], [23, 45, 15, 28, 46, 16], [17, 145, 115], [10, 74, 46, 23, 75, 47], [10, 54, 24, 35, 55, 25], [19, 45, 15, 35, 46, 16], [17, 145, 115, 1, 146, 116], [14, 74, 46, 21, 75, 47], [29, 54, 24, 19, 55, 25], [11, 45, 15, 46, 46, 16], [13, 145, 115, 6, 146, 116], [14, 74, 46, 23, 75, 47], [44, 54, 24, 7, 55, 25], [59, 46, 16, 1, 47, 17], [12, 151, 121, 7, 152, 122], [12, 75, 47, 26, 76, 48], [39, 54, 24, 14, 55, 25], [22, 45, 15, 41, 46, 16], [6, 151, 121, 14, 152, 122], [6, 75, 47, 34, 76, 48], [46, 54, 24, 10, 55, 25], [2, 45, 15, 64, 46, 16], [17, 152, 122, 4, 153, 123], [29, 74, 46, 14, 75, 47], [49, 54, 24, 10, 55, 25], [24, 45, 15, 46, 46, 16], [4, 152, 122, 18, 153, 123], [13, 74, 46, 32, 75, 47], [48, 54, 24, 14, 55, 25], [42, 45, 15, 32, 46, 16], [20, 147, 117, 4, 148, 118], [40, 75, 47, 7, 76, 48], [43, 54, 24, 22, 55, 25], [10, 45, 15, 67, 46, 16], [19, 148, 118, 6, 149, 119], [18, 75, 47, 31, 76, 48], [34, 54, 24, 34, 55, 25], [20, 45, 15, 61, 46, 16]];\nQRRSBlock.getRSBlocks = function (typeNumber, errorCorrectLevel) {\n var rsBlock = QRRSBlock.getRsBlockTable(typeNumber, errorCorrectLevel);\n if (rsBlock == undefined) {\n throw new Error(\"bad rs block @ typeNumber:\" + typeNumber + \"/errorCorrectLevel:\" + errorCorrectLevel);\n }\n var length = rsBlock.length / 3;\n var list = [];\n for (var i = 0; i < length; i++) {\n var count = rsBlock[i * 3 + 0];\n var totalCount = rsBlock[i * 3 + 1];\n var dataCount = rsBlock[i * 3 + 2];\n for (var j = 0; j < count; j++) {\n list.push(new QRRSBlock(totalCount, dataCount));\n }\n }\n return list;\n};\nQRRSBlock.getRsBlockTable = function (typeNumber, errorCorrectLevel) {\n switch (errorCorrectLevel) {\n case QRErrorCorrectLevel.L:\n return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 0];\n case QRErrorCorrectLevel.M:\n return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 1];\n case QRErrorCorrectLevel.Q:\n return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 2];\n case QRErrorCorrectLevel.H:\n return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 3];\n default:\n return undefined;\n }\n};\nfunction QRBitBuffer() {\n this.buffer = [];\n this.length = 0;\n}\nQRBitBuffer.prototype = {\n get: function (index) {\n var bufIndex = Math.floor(index / 8);\n return (this.buffer[bufIndex] >>> 7 - index % 8 & 1) == 1;\n },\n put: function (num, length) {\n for (var i = 0; i < length; i++) {\n this.putBit((num >>> length - i - 1 & 1) == 1);\n }\n },\n getLengthInBits: function () {\n return this.length;\n },\n putBit: function (bit) {\n var bufIndex = Math.floor(this.length / 8);\n if (this.buffer.length <= bufIndex) {\n this.buffer.push(0);\n }\n if (bit) {\n this.buffer[bufIndex] |= 0x80 >>> this.length % 8;\n }\n this.length++;\n }\n};\nvar QRCodeLimitLength = [[17, 14, 11, 7], [32, 26, 20, 14], [53, 42, 32, 24], [78, 62, 46, 34], [106, 84, 60, 44], [134, 106, 74, 58], [154, 122, 86, 64], [192, 152, 108, 84], [230, 180, 130, 98], [271, 213, 151, 119], [321, 251, 177, 137], [367, 287, 203, 155], [425, 331, 241, 177], [458, 362, 258, 194], [520, 412, 292, 220], [586, 450, 322, 250], [644, 504, 364, 280], [718, 560, 394, 310], [792, 624, 442, 338], [858, 666, 482, 382], [929, 711, 509, 403], [1003, 779, 565, 439], [1091, 857, 611, 461], [1171, 911, 661, 511], [1273, 997, 715, 535], [1367, 1059, 751, 593], [1465, 1125, 805, 625], [1528, 1190, 868, 658], [1628, 1264, 908, 698], [1732, 1370, 982, 742], [1840, 1452, 1030, 790], [1952, 1538, 1112, 842], [2068, 1628, 1168, 898], [2188, 1722, 1228, 958], [2303, 1809, 1283, 983], [2431, 1911, 1351, 1051], [2563, 1989, 1423, 1093], [2699, 2099, 1499, 1139], [2809, 2213, 1579, 1219], [2953, 2331, 1663, 1273]];\n\n/** Constructor */\nfunction QRCode(options) {\n var instance = this;\n\n //Default options\n this.options = {\n padding: 4,\n width: 256,\n height: 256,\n typeNumber: 4,\n color: \"#000000\",\n background: \"#ffffff\",\n ecl: \"M\",\n image: {\n svg: \"\",\n width: 0,\n height: 0\n }\n };\n\n //In case the options is string\n if (typeof options === 'string') {\n options = {\n content: options\n };\n }\n\n //Merge options\n if (options) {\n for (var i in options) {\n this.options[i] = options[i];\n }\n }\n if (typeof this.options.content !== 'string') {\n throw new Error(\"Expected 'content' as string!\");\n }\n if (this.options.content.length === 0 /* || this.options.content.length > 7089 */) {\n throw new Error(\"Expected 'content' to be non-empty!\");\n }\n if (!(this.options.padding >= 0)) {\n throw new Error(\"Expected 'padding' value to be non-negative!\");\n }\n if (!(this.options.width > 0) || !(this.options.height > 0)) {\n throw new Error(\"Expected 'width' or 'height' value to be higher than zero!\");\n }\n\n //Gets the error correction level\n function _getErrorCorrectLevel(ecl) {\n switch (ecl) {\n case \"L\":\n return QRErrorCorrectLevel.L;\n case \"M\":\n return QRErrorCorrectLevel.M;\n case \"Q\":\n return QRErrorCorrectLevel.Q;\n case \"H\":\n return QRErrorCorrectLevel.H;\n default:\n throw new Error(\"Unknwon error correction level: \" + ecl);\n }\n }\n\n //Get type number\n function _getTypeNumber(content, ecl) {\n var length = _getUTF8Length(content);\n var type = 1;\n var limit = 0;\n for (var i = 0, len = QRCodeLimitLength.length; i <= len; i++) {\n var table = QRCodeLimitLength[i];\n if (!table) {\n throw new Error(\"Content too long: expected \" + limit + \" but got \" + length);\n }\n switch (ecl) {\n case \"L\":\n limit = table[0];\n break;\n case \"M\":\n limit = table[1];\n break;\n case \"Q\":\n limit = table[2];\n break;\n case \"H\":\n limit = table[3];\n break;\n default:\n throw new Error(\"Unknwon error correction level: \" + ecl);\n }\n if (length <= limit) {\n break;\n }\n type++;\n }\n if (type > QRCodeLimitLength.length) {\n throw new Error(\"Content too long\");\n }\n return type;\n }\n\n //Gets text length\n function _getUTF8Length(content) {\n var result = encodeURI(content).toString().replace(/\\%[0-9a-fA-F]{2}/g, 'a');\n return result.length + (result.length != content ? 3 : 0);\n }\n\n //Generate QR Code matrix\n var content = this.options.content;\n var type = _getTypeNumber(content, this.options.ecl);\n var ecl = _getErrorCorrectLevel(this.options.ecl);\n this.qrcode = new QRCodeModel(type, ecl);\n this.qrcode.addData(content);\n this.qrcode.make();\n}\n\n/** Generates QR Code as SVG image */\nQRCode.prototype.svg = function (opt) {\n var options = this.options || {};\n var modules = this.qrcode.modules;\n if (typeof opt == \"undefined\") {\n opt = {\n container: options.container || \"svg\"\n };\n }\n\n //Apply new lines and indents in SVG?\n var pretty = typeof options.pretty != \"undefined\" ? !!options.pretty : true;\n var indent = pretty ? ' ' : '';\n var EOL = pretty ? '\\r\\n' : '';\n var width = options.width;\n var height = options.height;\n var length = modules.length;\n var xsize = width / (length + 2 * options.padding);\n var ysize = height / (length + 2 * options.padding);\n\n //Join (union, merge) rectangles into one shape?\n var join = typeof options.join != \"undefined\" ? !!options.join : false;\n\n //Swap the X and Y modules, pull request #2\n var swap = typeof options.swap != \"undefined\" ? !!options.swap : false;\n\n //Apply declaration in SVG?\n var xmlDeclaration = typeof options.xmlDeclaration != \"undefined\" ? !!options.xmlDeclaration : true;\n\n //Populate with predefined shape instead of \"rect\" elements, thanks to @kkocdko\n var predefined = typeof options.predefined != \"undefined\" ? !!options.predefined : false;\n var defs = predefined ? indent + '' + EOL : '';\n\n //Background rectangle\n var bgrect = indent + '' + EOL;\n\n //Rectangles representing modules\n var modrect = '';\n var pathdata = '';\n for (var y = 0; y < length; y++) {\n for (var x = 0; x < length; x++) {\n var module = modules[x][y];\n if (module) {\n var px = x * xsize + options.padding * xsize;\n var py = y * ysize + options.padding * ysize;\n\n //Some users have had issues with the QR Code, thanks to @danioso for the solution\n if (swap) {\n var t = px;\n px = py;\n py = t;\n }\n if (join) {\n //Module as a part of svg path data, thanks to @danioso\n var w = xsize + px;\n var h = ysize + py;\n px = Number.isInteger(px) ? Number(px) : px.toFixed(2);\n py = Number.isInteger(py) ? Number(py) : py.toFixed(2);\n w = Number.isInteger(w) ? Number(w) : w.toFixed(2);\n h = Number.isInteger(h) ? Number(h) : h.toFixed(2);\n pathdata += 'M' + px + ',' + py + ' V' + h + ' H' + w + ' V' + py + ' H' + px + ' Z ';\n } else if (predefined) {\n //Module as a predefined shape, thanks to @kkocdko\n modrect += indent + '' + EOL;\n } else {\n //Module as rectangle element\n modrect += indent + '' + EOL;\n }\n }\n }\n }\n if (join) {\n modrect = indent + '';\n }\n let imgSvg = \"\";\n if (this.options.image !== undefined && this.options.image.svg) {\n const imgWidth = width * this.options.image.width / 100;\n const imgHeight = height * this.options.image.height / 100;\n const imgX = width / 2 - imgWidth / 2;\n const imgY = height / 2 - imgHeight / 2;\n imgSvg += ``;\n imgSvg += this.options.image.svg + EOL;\n imgSvg += '';\n }\n var svg = \"\";\n switch (opt.container) {\n //Wrapped in SVG document\n case \"svg\":\n if (xmlDeclaration) {\n svg += '' + EOL;\n }\n svg += '' + EOL;\n svg += defs + bgrect + modrect;\n svg += imgSvg;\n svg += '';\n break;\n\n //Viewbox for responsive use in a browser, thanks to @danioso\n case \"svg-viewbox\":\n if (xmlDeclaration) {\n svg += '' + EOL;\n }\n svg += '' + EOL;\n svg += defs + bgrect + modrect;\n svg += imgSvg;\n svg += '';\n break;\n\n //Wrapped in group element\n case \"g\":\n svg += '' + EOL;\n svg += defs + bgrect + modrect;\n svg += imgSvg;\n svg += '';\n break;\n\n //Without a container\n default:\n svg += (defs + bgrect + modrect + imgSvg).replace(/^\\s+/, \"\"); //Clear indents on each line\n break;\n }\n return svg;\n};\nmodule.exports = QRCode;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.QRCode = void 0;\nconst preact_1 = require(\"preact\");\nconst hooks_1 = require(\"preact/hooks\");\nconst qrcode_svg_1 = __importDefault(require(\"../vendor-js/qrcode-svg\"));\nconst QRCode = props => {\n const [svg, setSvg] = (0, hooks_1.useState)(\"\");\n (0, hooks_1.useEffect)(() => {\n var _a, _b;\n const qrcode = new qrcode_svg_1.default({\n content: props.content,\n background: props.bgColor || \"#ffffff\",\n color: props.fgColor || \"#000000\",\n container: \"svg\",\n ecl: \"M\",\n width: (_a = props.width) !== null && _a !== void 0 ? _a : 256,\n height: (_b = props.height) !== null && _b !== void 0 ? _b : 256,\n padding: 0,\n image: props.image\n });\n const base64 = Buffer.from(qrcode.svg(), \"utf8\").toString(\"base64\");\n setSvg(`data:image/svg+xml;base64,${base64}`);\n });\n return svg ? (0, preact_1.h)(\"img\", {\n src: svg,\n alt: \"QR Code\"\n }) : null;\n};\nexports.QRCode = QRCode;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = `.-cbwsdk-css-reset .-cbwsdk-spinner{display:inline-block}.-cbwsdk-css-reset .-cbwsdk-spinner svg{display:inline-block;animation:2s linear infinite -cbwsdk-spinner-svg}.-cbwsdk-css-reset .-cbwsdk-spinner svg circle{animation:1.9s ease-in-out infinite both -cbwsdk-spinner-circle;display:block;fill:rgba(0,0,0,0);stroke-dasharray:283;stroke-dashoffset:280;stroke-linecap:round;stroke-width:10px;transform-origin:50% 50%}@keyframes -cbwsdk-spinner-svg{0%{transform:rotateZ(0deg)}100%{transform:rotateZ(360deg)}}@keyframes -cbwsdk-spinner-circle{0%,25%{stroke-dashoffset:280;transform:rotate(0)}50%,75%{stroke-dashoffset:75;transform:rotate(45deg)}100%{stroke-dashoffset:280;transform:rotate(360deg)}}`;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Spinner = void 0;\nconst preact_1 = require(\"preact\");\nconst Spinner_css_1 = __importDefault(require(\"./Spinner-css\"));\nconst Spinner = props => {\n var _a;\n const size = (_a = props.size) !== null && _a !== void 0 ? _a : 64;\n const color = props.color || \"#000\";\n return (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-spinner\"\n }, (0, preact_1.h)(\"style\", null, Spinner_css_1.default), (0, preact_1.h)(\"svg\", {\n viewBox: \"0 0 100 100\",\n xmlns: \"http://www.w3.org/2000/svg\",\n style: {\n width: size,\n height: size\n }\n }, (0, preact_1.h)(\"circle\", {\n style: {\n cx: 50,\n cy: 50,\n r: 45,\n stroke: color\n }\n })));\n};\nexports.Spinner = Spinner;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = `.-cbwsdk-css-reset .-cbwsdk-connect-content{height:430px;width:700px;border-radius:12px;padding:30px}.-cbwsdk-css-reset .-cbwsdk-connect-content.light{background:#fff}.-cbwsdk-css-reset .-cbwsdk-connect-content.dark{background:#0a0b0d}.-cbwsdk-css-reset .-cbwsdk-connect-content-header{display:flex;align-items:center;justify-content:space-between;margin:0 0 30px}.-cbwsdk-css-reset .-cbwsdk-connect-content-heading{font-style:normal;font-weight:500;font-size:28px;line-height:36px;margin:0}.-cbwsdk-css-reset .-cbwsdk-connect-content-heading.light{color:#0a0b0d}.-cbwsdk-css-reset .-cbwsdk-connect-content-heading.dark{color:#fff}.-cbwsdk-css-reset .-cbwsdk-connect-content-layout{display:flex;flex-direction:row}.-cbwsdk-css-reset .-cbwsdk-connect-content-column-left{margin-right:30px;display:flex;flex-direction:column;justify-content:space-between}.-cbwsdk-css-reset .-cbwsdk-connect-content-column-right{flex:25%;margin-right:34px}.-cbwsdk-css-reset .-cbwsdk-connect-content-qr-wrapper{width:220px;height:220px;border-radius:12px;display:flex;justify-content:center;align-items:center;background:#fff}.-cbwsdk-css-reset .-cbwsdk-connect-content-qr-connecting{position:absolute;top:0;bottom:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.-cbwsdk-css-reset .-cbwsdk-connect-content-qr-connecting.light{background-color:rgba(255,255,255,.95)}.-cbwsdk-css-reset .-cbwsdk-connect-content-qr-connecting.light>p{color:#0a0b0d}.-cbwsdk-css-reset .-cbwsdk-connect-content-qr-connecting.dark{background-color:rgba(10,11,13,.9)}.-cbwsdk-css-reset .-cbwsdk-connect-content-qr-connecting.dark>p{color:#fff}.-cbwsdk-css-reset .-cbwsdk-connect-content-qr-connecting>p{font-size:12px;font-weight:bold;margin-top:16px}.-cbwsdk-css-reset .-cbwsdk-connect-content-update-app{border-radius:8px;font-size:14px;line-height:20px;padding:12px;width:339px}.-cbwsdk-css-reset .-cbwsdk-connect-content-update-app.light{background:#eef0f3;color:#5b636e}.-cbwsdk-css-reset .-cbwsdk-connect-content-update-app.dark{background:#1e2025;color:#8a919e}.-cbwsdk-css-reset .-cbwsdk-cancel-button{-webkit-appearance:none;border:none;background:none;cursor:pointer;padding:0;margin:0}.-cbwsdk-css-reset .-cbwsdk-cancel-button-x{position:relative;display:block;cursor:pointer}.-cbwsdk-css-reset .-cbwsdk-wallet-steps{padding:0 0 0 16px;margin:0;width:100%;list-style:decimal}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-item{list-style-type:decimal;display:list-item;font-style:normal;font-weight:400;font-size:16px;line-height:24px;margin-top:20px}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-item.light{color:#0a0b0d}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-item.dark{color:#fff}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-item-wrapper{display:flex;align-items:center}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-pad-left{margin-left:6px}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-icon{display:flex;border-radius:50%;height:24px;width:24px}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-icon svg{margin:auto;display:block}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-icon.light{background:#0052ff}.-cbwsdk-css-reset .-cbwsdk-wallet-steps-icon.dark{background:#588af5}.-cbwsdk-css-reset .-cbwsdk-connect-item{align-items:center;display:flex;flex-direction:row;padding:16px 24px;gap:12px;cursor:pointer}.-cbwsdk-css-reset .-cbwsdk-connect-item.light{color:#0a0b0d}.-cbwsdk-css-reset .-cbwsdk-connect-item.light.selected{background:#f5f8ff;color:#0052ff}.-cbwsdk-css-reset .-cbwsdk-connect-item.dark{color:#fff}.-cbwsdk-css-reset .-cbwsdk-connect-item.dark.selected{background:#001033;color:#588af5}.-cbwsdk-css-reset .-cbwsdk-connect-item.selected{border-radius:100px;font-weight:600}.-cbwsdk-css-reset .-cbwsdk-connect-item-copy-wrapper{margin:0 4px 0 8px}.-cbwsdk-css-reset .-cbwsdk-connect-item-title{margin:0 0 0;font-size:16px;line-height:24px;font-weight:500}.-cbwsdk-css-reset .-cbwsdk-connect-item-description{font-weight:400;font-size:14px;line-height:20px;margin:0}`;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.CoinbaseAppSteps = exports.CoinbaseWalletSteps = exports.ConnectItem = exports.ConnectContent = void 0;\nconst clsx_1 = __importDefault(require(\"clsx\"));\nconst preact_1 = require(\"preact\");\nconst hooks_1 = require(\"preact/hooks\");\nconst util_1 = require(\"../../util\");\nconst version_1 = require(\"../../version\");\nconst CloseIcon_1 = require(\"../icons/CloseIcon\");\nconst coinbase_round_svg_1 = __importDefault(require(\"../icons/coinbase-round-svg\"));\nconst coinbase_wallet_round_svg_1 = __importDefault(require(\"../icons/coinbase-wallet-round-svg\"));\nconst QRCodeIcon_1 = require(\"../icons/QRCodeIcon\");\nconst QRLogoCoinbase_1 = __importDefault(require(\"../icons/QRLogoCoinbase\"));\nconst QRLogoWallet_1 = __importDefault(require(\"../icons/QRLogoWallet\"));\nconst StatusDotIcon_1 = require(\"../icons/StatusDotIcon\");\nconst QRCode_1 = require(\"../QRCode\");\nconst Spinner_1 = require(\"../Spinner/Spinner\");\nconst ConnectContent_css_1 = __importDefault(require(\"./ConnectContent-css\"));\nconst wallets = {\n \"coinbase-wallet-app\": {\n title: \"Coinbase Wallet app\",\n description: \"Connect with your self-custody wallet\",\n icon: coinbase_wallet_round_svg_1.default,\n steps: CoinbaseWalletSteps\n },\n \"coinbase-app\": {\n title: \"Coinbase app\",\n description: \"Connect with your Coinbase account\",\n icon: coinbase_round_svg_1.default,\n steps: CoinbaseAppSteps\n }\n};\nconst makeQrCodeImage = app => {\n switch (app) {\n case \"coinbase-app\":\n return QRLogoCoinbase_1.default;\n case \"coinbase-wallet-app\":\n default:\n return QRLogoWallet_1.default;\n }\n};\nconst makeIconColor = theme => {\n return theme === \"light\" ? \"#FFFFFF\" : \"#0A0B0D\";\n};\nfunction ConnectContent(props) {\n const {\n theme\n } = props;\n const [selected, setSelected] = (0, hooks_1.useState)(\"coinbase-wallet-app\");\n const handleSelect = (0, hooks_1.useCallback)(id => {\n setSelected(id);\n }, []);\n const qrUrl = (0, util_1.createQrUrl)(props.sessionId, props.sessionSecret, props.linkAPIUrl, props.isParentConnection, props.version, props.chainId);\n const wallet = wallets[selected];\n if (!selected) {\n return null;\n }\n const WalletSteps = wallet.steps;\n const coinbaseApp = selected === \"coinbase-app\";\n return (0, preact_1.h)(\"div\", {\n \"data-testid\": \"connect-content\",\n class: (0, clsx_1.default)(\"-cbwsdk-connect-content\", theme)\n }, (0, preact_1.h)(\"style\", null, ConnectContent_css_1.default), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-connect-content-header\"\n }, (0, preact_1.h)(\"h2\", {\n class: (0, clsx_1.default)(\"-cbwsdk-connect-content-heading\", theme)\n }, \"Scan to connect with one of our mobile apps\"), props.onCancel && (0, preact_1.h)(\"button\", {\n type: \"button\",\n class: \"-cbwsdk-cancel-button\",\n onClick: props.onCancel\n }, (0, preact_1.h)(CloseIcon_1.CloseIcon, {\n fill: theme === \"light\" ? \"#0A0B0D\" : \"#FFFFFF\"\n }))), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-connect-content-layout\"\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-connect-content-column-left\"\n }, (0, preact_1.h)(\"div\", null, Object.entries(wallets).map(([key, value]) => {\n return (0, preact_1.h)(ConnectItem, {\n key: key,\n title: value.title,\n description: value.description,\n icon: value.icon,\n selected: selected === key,\n onClick: () => handleSelect(key),\n theme: theme\n });\n })), coinbaseApp && (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-connect-content-update-app\", theme)\n }, \"Don\\u2019t see a \", (0, preact_1.h)(\"strong\", null, \"Scan\"), \" option? Update your Coinbase app to the latest version and try again.\")), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-connect-content-column-right\"\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-connect-content-qr-wrapper\"\n }, (0, preact_1.h)(QRCode_1.QRCode, {\n content: qrUrl,\n width: 200,\n height: 200,\n fgColor: \"#000\",\n bgColor: \"transparent\",\n image: {\n svg: makeQrCodeImage(selected),\n width: 25,\n height: 25\n }\n }), (0, preact_1.h)(\"input\", {\n type: \"hidden\",\n name: \"cbw-cbwsdk-version\",\n value: version_1.LIB_VERSION\n }), (0, preact_1.h)(\"input\", {\n type: \"hidden\",\n value: qrUrl\n })), (0, preact_1.h)(WalletSteps, {\n theme: theme\n }), !props.isConnected && (0, preact_1.h)(\"div\", {\n \"data-testid\": \"connecting-spinner\",\n class: (0, clsx_1.default)(\"-cbwsdk-connect-content-qr-connecting\", theme)\n }, (0, preact_1.h)(Spinner_1.Spinner, {\n size: 36,\n color: theme === \"dark\" ? \"#FFF\" : \"#000\"\n }), (0, preact_1.h)(\"p\", null, \"Connecting...\")))));\n}\nexports.ConnectContent = ConnectContent;\nfunction ConnectItem({\n title,\n description,\n icon,\n selected,\n theme,\n onClick\n}) {\n return (0, preact_1.h)(\"div\", {\n onClick: onClick,\n class: (0, clsx_1.default)(\"-cbwsdk-connect-item\", theme, {\n selected\n })\n }, (0, preact_1.h)(\"div\", null, (0, preact_1.h)(\"img\", {\n src: icon,\n alt: title\n })), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-connect-item-copy-wrapper\"\n }, (0, preact_1.h)(\"h3\", {\n class: \"-cbwsdk-connect-item-title\"\n }, title), (0, preact_1.h)(\"p\", {\n class: \"-cbwsdk-connect-item-description\"\n }, description)));\n}\nexports.ConnectItem = ConnectItem;\nfunction CoinbaseWalletSteps({\n theme\n}) {\n return (0, preact_1.h)(\"ol\", {\n class: \"-cbwsdk-wallet-steps\"\n }, (0, preact_1.h)(\"li\", {\n class: (0, clsx_1.default)(\"-cbwsdk-wallet-steps-item\", theme)\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-wallet-steps-item-wrapper\"\n }, \"Open Coinbase Wallet app\")), (0, preact_1.h)(\"li\", {\n class: (0, clsx_1.default)(\"-cbwsdk-wallet-steps-item\", theme)\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-wallet-steps-item-wrapper\"\n }, (0, preact_1.h)(\"span\", null, \"Tap \", (0, preact_1.h)(\"strong\", null, \"Scan\"), \" \"), (0, preact_1.h)(\"span\", {\n class: (0, clsx_1.default)(\"-cbwsdk-wallet-steps-pad-left\", \"-cbwsdk-wallet-steps-icon\", theme)\n }, (0, preact_1.h)(QRCodeIcon_1.QRCodeIcon, {\n fill: makeIconColor(theme)\n })))));\n}\nexports.CoinbaseWalletSteps = CoinbaseWalletSteps;\nfunction CoinbaseAppSteps({\n theme\n}) {\n return (0, preact_1.h)(\"ol\", {\n class: \"-cbwsdk-wallet-steps\"\n }, (0, preact_1.h)(\"li\", {\n class: (0, clsx_1.default)(\"-cbwsdk-wallet-steps-item\", theme)\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-wallet-steps-item-wrapper\"\n }, \"Open Coinbase app\")), (0, preact_1.h)(\"li\", {\n class: (0, clsx_1.default)(\"-cbwsdk-wallet-steps-item\", theme)\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-wallet-steps-item-wrapper\"\n }, (0, preact_1.h)(\"span\", null, \"Tap \", (0, preact_1.h)(\"strong\", null, \"More\")), (0, preact_1.h)(\"span\", {\n class: (0, clsx_1.default)(\"-cbwsdk-wallet-steps-pad-left\", \"-cbwsdk-wallet-steps-icon\", theme)\n }, (0, preact_1.h)(StatusDotIcon_1.StatusDotIcon, {\n fill: makeIconColor(theme)\n })), (0, preact_1.h)(\"span\", {\n class: \"-cbwsdk-wallet-steps-pad-left\"\n }, \"then \", (0, preact_1.h)(\"strong\", null, \"Scan\")), (0, preact_1.h)(\"span\", {\n class: (0, clsx_1.default)(\"-cbwsdk-wallet-steps-pad-left\", \"-cbwsdk-wallet-steps-icon\", theme)\n }, (0, preact_1.h)(QRCodeIcon_1.QRCodeIcon, {\n fill: makeIconColor(theme)\n })))));\n}\nexports.CoinbaseAppSteps = CoinbaseAppSteps;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ArrowLeftIcon = void 0;\nconst preact_1 = require(\"preact\");\nfunction ArrowLeftIcon(props) {\n return (0, preact_1.h)(\"svg\", Object.assign({\n width: \"16\",\n height: \"16\",\n viewBox: \"0 0 16 16\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), (0, preact_1.h)(\"path\", {\n d: \"M8.60675 0.155884L7.37816 1.28209L12.7723 7.16662H0V8.83328H12.6548L6.82149 14.6666L8 15.8451L15.8201 8.02501L8.60675 0.155884Z\"\n }));\n}\nexports.ArrowLeftIcon = ArrowLeftIcon;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LaptopIcon = void 0;\nconst preact_1 = require(\"preact\");\nfunction LaptopIcon(props) {\n return (0, preact_1.h)(\"svg\", Object.assign({\n width: \"14\",\n height: \"14\",\n viewBox: \"0 0 14 14\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), (0, preact_1.h)(\"path\", {\n d: \"M1.8001 2.2002H12.2001V9.40019H1.8001V2.2002ZM3.4001 3.8002V7.80019H10.6001V3.8002H3.4001Z\"\n }), (0, preact_1.h)(\"path\", {\n d: \"M13.4001 10.2002H0.600098C0.600098 11.0838 1.31644 11.8002 2.2001 11.8002H11.8001C12.6838 11.8002 13.4001 11.0838 13.4001 10.2002Z\"\n }));\n}\nexports.LaptopIcon = LaptopIcon;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SafeIcon = void 0;\nconst preact_1 = require(\"preact\");\nfunction SafeIcon(props) {\n return (0, preact_1.h)(\"svg\", Object.assign({\n width: \"14\",\n height: \"14\",\n viewBox: \"0 0 14 14\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), (0, preact_1.h)(\"path\", {\n \"fill-rule\": \"evenodd\",\n \"clip-rule\": \"evenodd\",\n d: \"M0.600098 0.600098V11.8001H13.4001V0.600098H0.600098ZM7.0001 9.2001C5.3441 9.2001 4.0001 7.8561 4.0001 6.2001C4.0001 4.5441 5.3441 3.2001 7.0001 3.2001C8.6561 3.2001 10.0001 4.5441 10.0001 6.2001C10.0001 7.8561 8.6561 9.2001 7.0001 9.2001ZM0.600098 12.6001H3.8001V13.4001H0.600098V12.6001ZM10.2001 12.6001H13.4001V13.4001H10.2001V12.6001ZM8.8001 6.2001C8.8001 7.19421 7.99421 8.0001 7.0001 8.0001C6.00598 8.0001 5.2001 7.19421 5.2001 6.2001C5.2001 5.20598 6.00598 4.4001 7.0001 4.4001C7.99421 4.4001 8.8001 5.20598 8.8001 6.2001Z\"\n }));\n}\nexports.SafeIcon = SafeIcon;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = `.-cbwsdk-css-reset .-cbwsdk-try-extension{display:flex;margin-top:12px;height:202px;width:700px;border-radius:12px;padding:30px}.-cbwsdk-css-reset .-cbwsdk-try-extension.light{background:#fff}.-cbwsdk-css-reset .-cbwsdk-try-extension.dark{background:#0a0b0d}.-cbwsdk-css-reset .-cbwsdk-try-extension-column-half{flex:50%}.-cbwsdk-css-reset .-cbwsdk-try-extension-heading{font-style:normal;font-weight:500;font-size:25px;line-height:32px;margin:0;max-width:204px}.-cbwsdk-css-reset .-cbwsdk-try-extension-heading.light{color:#0a0b0d}.-cbwsdk-css-reset .-cbwsdk-try-extension-heading.dark{color:#fff}.-cbwsdk-css-reset .-cbwsdk-try-extension-cta{appearance:none;border:none;background:none;color:#0052ff;cursor:pointer;padding:0;text-decoration:none;display:block;font-weight:600;font-size:16px;line-height:24px}.-cbwsdk-css-reset .-cbwsdk-try-extension-cta.light{color:#0052ff}.-cbwsdk-css-reset .-cbwsdk-try-extension-cta.dark{color:#588af5}.-cbwsdk-css-reset .-cbwsdk-try-extension-cta-wrapper{display:flex;align-items:center;margin-top:12px}.-cbwsdk-css-reset .-cbwsdk-try-extension-cta-icon{display:block;margin-left:4px;height:14px}.-cbwsdk-css-reset .-cbwsdk-try-extension-list{display:flex;flex-direction:column;justify-content:center;align-items:center;margin:0;padding:0;list-style:none;height:100%}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item{display:flex;align-items:center;flex-flow:nowrap;margin-top:24px}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item:first-of-type{margin-top:0}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-icon-wrapper{display:block}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-icon{display:flex;height:32px;width:32px;border-radius:50%}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-icon svg{margin:auto;display:block}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-icon.light{background:#eef0f3}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-icon.dark{background:#1e2025}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-copy{display:block;font-weight:400;font-size:14px;line-height:20px;padding-left:12px}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-copy.light{color:#5b636e}.-cbwsdk-css-reset .-cbwsdk-try-extension-list-item-copy.dark{color:#8a919e}`;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.TryExtensionContent = void 0;\nconst clsx_1 = __importDefault(require(\"clsx\"));\nconst preact_1 = require(\"preact\");\nconst hooks_1 = require(\"preact/hooks\");\nconst ArrowLeftIcon_1 = require(\"../icons/ArrowLeftIcon\");\nconst LaptopIcon_1 = require(\"../icons/LaptopIcon\");\nconst SafeIcon_1 = require(\"../icons/SafeIcon\");\nconst TryExtensionContent_css_1 = __importDefault(require(\"./TryExtensionContent-css\"));\nfunction TryExtensionContent({\n theme\n}) {\n const [clicked, setClicked] = (0, hooks_1.useState)(false);\n const handleInstallClick = (0, hooks_1.useCallback)(() => {\n window.open(\"https://api.wallet.coinbase.com/rpc/v2/desktop/chrome\", \"_blank\");\n }, []);\n const handleClick = (0, hooks_1.useCallback)(() => {\n if (clicked) {\n window.location.reload();\n } else {\n handleInstallClick();\n setClicked(true);\n }\n }, [handleInstallClick, clicked]);\n return (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-try-extension\", theme)\n }, (0, preact_1.h)(\"style\", null, TryExtensionContent_css_1.default), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-try-extension-column-half\"\n }, (0, preact_1.h)(\"h3\", {\n class: (0, clsx_1.default)(\"-cbwsdk-try-extension-heading\", theme)\n }, \"Or try the Coinbase Wallet browser extension\"), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-try-extension-cta-wrapper\"\n }, (0, preact_1.h)(\"button\", {\n class: (0, clsx_1.default)(\"-cbwsdk-try-extension-cta\", theme),\n onClick: handleClick\n }, clicked ? \"Refresh\" : \"Install\"), (0, preact_1.h)(\"div\", null, !clicked && (0, preact_1.h)(ArrowLeftIcon_1.ArrowLeftIcon, {\n class: \"-cbwsdk-try-extension-cta-icon\",\n fill: theme === \"light\" ? \"#0052FF\" : \"#588AF5\"\n })))), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-try-extension-column-half\"\n }, (0, preact_1.h)(\"ul\", {\n class: \"-cbwsdk-try-extension-list\"\n }, (0, preact_1.h)(\"li\", {\n class: \"-cbwsdk-try-extension-list-item\"\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-try-extension-list-item-icon-wrapper\"\n }, (0, preact_1.h)(\"span\", {\n class: (0, clsx_1.default)(\"-cbwsdk-try-extension-list-item-icon\", theme)\n }, (0, preact_1.h)(LaptopIcon_1.LaptopIcon, {\n fill: theme === \"light\" ? \"#0A0B0D\" : \"#FFFFFF\"\n }))), (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-try-extension-list-item-copy\", theme)\n }, \"Connect with dapps with just one click on your desktop browser\")), (0, preact_1.h)(\"li\", {\n class: \"-cbwsdk-try-extension-list-item\"\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-try-extension-list-item-icon-wrapper\"\n }, (0, preact_1.h)(\"span\", {\n class: (0, clsx_1.default)(\"-cbwsdk-try-extension-list-item-icon\", theme)\n }, (0, preact_1.h)(SafeIcon_1.SafeIcon, {\n fill: theme === \"light\" ? \"#0A0B0D\" : \"#FFFFFF\"\n }))), (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-try-extension-list-item-copy\", theme)\n }, \"Add an additional layer of security by using a supported Ledger hardware wallet\")))));\n}\nexports.TryExtensionContent = TryExtensionContent;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = `.-cbwsdk-css-reset .-cbwsdk-connect-dialog{z-index:2147483647;position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-backdrop{z-index:2147483647;position:fixed;top:0;left:0;right:0;bottom:0;transition:opacity .25s}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-backdrop.light{background-color:rgba(0,0,0,.5)}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-backdrop.dark{background-color:rgba(50,53,61,.4)}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-backdrop-hidden{opacity:0}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-box{display:flex;position:relative;flex-direction:column;transform:scale(1);transition:opacity .25s,transform .25s}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-box-hidden{opacity:0;transform:scale(0.85)}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-container{display:block}.-cbwsdk-css-reset .-cbwsdk-connect-dialog-container-hidden{display:none}`;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ConnectDialog = void 0;\nconst clsx_1 = __importDefault(require(\"clsx\"));\nconst preact_1 = require(\"preact\");\nconst hooks_1 = require(\"preact/hooks\");\nconst ConnectContent_1 = require(\"../ConnectContent/ConnectContent\");\nconst TryExtensionContent_1 = require(\"../TryExtensionContent/TryExtensionContent\");\nconst ConnectDialog_css_1 = __importDefault(require(\"./ConnectDialog-css\"));\nconst ConnectDialog = props => {\n const {\n isOpen,\n darkMode\n } = props;\n const [containerHidden, setContainerHidden] = (0, hooks_1.useState)(!isOpen);\n const [dialogHidden, setDialogHidden] = (0, hooks_1.useState)(!isOpen);\n (0, hooks_1.useEffect)(() => {\n const timers = [window.setTimeout(() => {\n setDialogHidden(!isOpen);\n }, 10)];\n if (isOpen) {\n setContainerHidden(false);\n } else {\n timers.push(window.setTimeout(() => {\n setContainerHidden(true);\n }, 360));\n }\n return () => {\n timers.forEach(window.clearTimeout);\n };\n }, [props.isOpen]);\n const theme = darkMode ? \"dark\" : \"light\";\n return (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-connect-dialog-container\", containerHidden && \"-cbwsdk-connect-dialog-container-hidden\")\n }, (0, preact_1.h)(\"style\", null, ConnectDialog_css_1.default), (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-connect-dialog-backdrop\", theme, dialogHidden && \"-cbwsdk-connect-dialog-backdrop-hidden\")\n }), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-connect-dialog\"\n }, (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-connect-dialog-box\", dialogHidden && \"-cbwsdk-connect-dialog-box-hidden\")\n }, !props.connectDisabled ? (0, preact_1.h)(ConnectContent_1.ConnectContent, {\n theme: theme,\n version: props.version,\n sessionId: props.sessionId,\n sessionSecret: props.sessionSecret,\n linkAPIUrl: props.linkAPIUrl,\n isConnected: props.isConnected,\n isParentConnection: props.isParentConnection,\n chainId: props.chainId,\n onCancel: props.onCancel\n }) : null, (0, preact_1.h)(TryExtensionContent_1.TryExtensionContent, {\n theme: theme\n }))));\n};\nexports.ConnectDialog = ConnectDialog;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.LinkFlow = void 0;\nconst preact_1 = require(\"preact\");\nconst rxjs_1 = require(\"rxjs\");\nconst ConnectDialog_1 = require(\"../ConnectDialog/ConnectDialog\");\nclass LinkFlow {\n constructor(options) {\n this.extensionUI$ = new rxjs_1.BehaviorSubject({});\n this.subscriptions = new rxjs_1.Subscription();\n this.isConnected = false;\n this.chainId = 1;\n this.isOpen = false;\n this.onCancel = null;\n this.root = null;\n // if true, hide QR code in LinkFlow (which happens if no jsonRpcUrl is provided)\n this.connectDisabled = false;\n this.darkMode = options.darkMode;\n this.version = options.version;\n this.sessionId = options.sessionId;\n this.sessionSecret = options.sessionSecret;\n this.linkAPIUrl = options.linkAPIUrl;\n this.isParentConnection = options.isParentConnection;\n this.connected$ = options.connected$;\n this.chainId$ = options.chainId$;\n }\n attach(el) {\n this.root = document.createElement(\"div\");\n this.root.className = \"-cbwsdk-link-flow-root\";\n el.appendChild(this.root);\n this.render();\n this.subscriptions.add(this.connected$.subscribe(v => {\n if (this.isConnected !== v) {\n this.isConnected = v;\n this.render();\n }\n }));\n this.subscriptions.add(this.chainId$.subscribe(chainId => {\n if (this.chainId !== chainId) {\n this.chainId = chainId;\n this.render();\n }\n }));\n }\n detach() {\n var _a;\n if (!this.root) {\n return;\n }\n this.subscriptions.unsubscribe();\n (0, preact_1.render)(null, this.root);\n (_a = this.root.parentElement) === null || _a === void 0 ? void 0 : _a.removeChild(this.root);\n }\n setConnectDisabled(connectDisabled) {\n this.connectDisabled = connectDisabled;\n }\n open(options) {\n this.isOpen = true;\n this.onCancel = options.onCancel;\n this.render();\n }\n close() {\n this.isOpen = false;\n this.onCancel = null;\n this.render();\n }\n render() {\n if (!this.root) {\n return;\n }\n const subscription = this.extensionUI$.subscribe(() => {\n if (!this.root) {\n return;\n }\n (0, preact_1.render)((0, preact_1.h)(ConnectDialog_1.ConnectDialog, {\n darkMode: this.darkMode,\n version: this.version,\n sessionId: this.sessionId,\n sessionSecret: this.sessionSecret,\n linkAPIUrl: this.linkAPIUrl,\n isOpen: this.isOpen,\n isConnected: this.isConnected,\n isParentConnection: this.isParentConnection,\n chainId: this.chainId,\n onCancel: this.onCancel,\n connectDisabled: this.connectDisabled\n }), this.root);\n });\n this.subscriptions.add(subscription);\n }\n}\nexports.LinkFlow = LinkFlow;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = `.-cbwsdk-css-reset .-gear-container{margin-left:16px !important;margin-right:9px !important;display:flex;align-items:center;justify-content:center;width:24px;height:24px;transition:opacity .25s}.-cbwsdk-css-reset .-gear-container *{user-select:none}.-cbwsdk-css-reset .-gear-container svg{opacity:0;position:absolute}.-cbwsdk-css-reset .-gear-icon{height:12px;width:12px;z-index:10000}.-cbwsdk-css-reset .-cbwsdk-snackbar{align-items:flex-end;display:flex;flex-direction:column;position:fixed;right:0;top:0;z-index:2147483647}.-cbwsdk-css-reset .-cbwsdk-snackbar *{user-select:none}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance{display:flex;flex-direction:column;margin:8px 16px 0 16px;overflow:visible;text-align:left;transform:translateX(0);transition:opacity .25s,transform .25s}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-header:hover .-gear-container svg{opacity:1}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-header{display:flex;align-items:center;background:#fff;overflow:hidden;border:1px solid #e7ebee;box-sizing:border-box;border-radius:8px;cursor:pointer}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-header-cblogo{margin:8px 8px 8px 8px}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-header *{cursor:pointer}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-header-message{color:#000;font-size:13px;line-height:1.5;user-select:none}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu{background:#fff;transition:opacity .25s ease-in-out,transform .25s linear,visibility 0s;visibility:hidden;border:1px solid #e7ebee;box-sizing:border-box;border-radius:8px;opacity:0;flex-direction:column;padding-left:8px;padding-right:8px}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item:last-child{margin-bottom:8px !important}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item:hover{background:#f5f7f8;border-radius:6px;transition:background .25s}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item:hover span{color:#050f19;transition:color .25s}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item:hover svg path{fill:#000;transition:fill .25s}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item{visibility:inherit;height:35px;margin-top:8px;margin-bottom:0;display:flex;flex-direction:row;align-items:center;padding:8px;cursor:pointer}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item *{visibility:inherit;cursor:pointer}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item-is-red:hover{background:rgba(223,95,103,.2);transition:background .25s}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item-is-red:hover *{cursor:pointer}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item-is-red:hover svg path{fill:#df5f67;transition:fill .25s}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item-is-red:hover span{color:#df5f67;transition:color .25s}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-menu-item-info{color:#aaa;font-size:13px;margin:0 8px 0 32px;position:absolute}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-hidden{opacity:0;text-align:left;transform:translateX(25%);transition:opacity .5s linear}.-cbwsdk-css-reset .-cbwsdk-snackbar-instance-expanded .-cbwsdk-snackbar-instance-menu{opacity:1;display:flex;transform:translateY(8px);visibility:visible}`;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.SnackbarInstance = exports.SnackbarContainer = exports.Snackbar = void 0;\nconst clsx_1 = __importDefault(require(\"clsx\"));\nconst preact_1 = require(\"preact\");\nconst hooks_1 = require(\"preact/hooks\");\nconst Snackbar_css_1 = __importDefault(require(\"./Snackbar-css\"));\nconst gearIcon = ``;\nfunction makeSnackbarIcon(appSrc) {\n switch (appSrc) {\n case \"coinbase-app\":\n return ``;\n case \"coinbase-wallet-app\":\n default:\n return ``;\n }\n}\nclass Snackbar {\n constructor(options) {\n this.items = new Map();\n this.nextItemKey = 0;\n this.root = null;\n this.darkMode = options.darkMode;\n }\n attach(el) {\n this.root = document.createElement(\"div\");\n this.root.className = \"-cbwsdk-snackbar-root\";\n el.appendChild(this.root);\n this.render();\n }\n presentItem(itemProps) {\n const key = this.nextItemKey++;\n this.items.set(key, itemProps);\n this.render();\n return () => {\n this.items.delete(key);\n this.render();\n };\n }\n clear() {\n this.items.clear();\n this.render();\n }\n render() {\n if (!this.root) {\n return;\n }\n (0, preact_1.render)((0, preact_1.h)(\"div\", null, (0, preact_1.h)(exports.SnackbarContainer, {\n darkMode: this.darkMode\n }, Array.from(this.items.entries()).map(([key, itemProps]) => (0, preact_1.h)(exports.SnackbarInstance, Object.assign({}, itemProps, {\n key: key\n }))))), this.root);\n }\n}\nexports.Snackbar = Snackbar;\nconst SnackbarContainer = props => (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-snackbar-container\")\n}, (0, preact_1.h)(\"style\", null, Snackbar_css_1.default), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-snackbar\"\n}, props.children));\nexports.SnackbarContainer = SnackbarContainer;\nconst SnackbarInstance = ({\n autoExpand,\n message,\n menuItems,\n appSrc\n}) => {\n const [hidden, setHidden] = (0, hooks_1.useState)(true);\n const [expanded, setExpanded] = (0, hooks_1.useState)(autoExpand !== null && autoExpand !== void 0 ? autoExpand : false);\n (0, hooks_1.useEffect)(() => {\n const timers = [window.setTimeout(() => {\n setHidden(false);\n }, 1), window.setTimeout(() => {\n setExpanded(true);\n }, 10000)];\n return () => {\n timers.forEach(window.clearTimeout);\n };\n });\n const toggleExpanded = () => {\n setExpanded(!expanded);\n };\n return (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-snackbar-instance\", hidden && \"-cbwsdk-snackbar-instance-hidden\", expanded && \"-cbwsdk-snackbar-instance-expanded\")\n }, (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-snackbar-instance-header\",\n onClick: toggleExpanded\n }, (0, preact_1.h)(\"img\", {\n src: makeSnackbarIcon(appSrc),\n class: \"-cbwsdk-snackbar-instance-header-cblogo\"\n }), (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-snackbar-instance-header-message\"\n }, message), (0, preact_1.h)(\"div\", {\n class: \"-gear-container\"\n }, !expanded && (0, preact_1.h)(\"svg\", {\n width: \"24\",\n height: \"24\",\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, (0, preact_1.h)(\"circle\", {\n cx: \"12\",\n cy: \"12\",\n r: \"12\",\n fill: \"#F5F7F8\"\n })), (0, preact_1.h)(\"img\", {\n src: gearIcon,\n class: \"-gear-icon\",\n title: \"Expand\"\n }))), menuItems && menuItems.length > 0 && (0, preact_1.h)(\"div\", {\n class: \"-cbwsdk-snackbar-instance-menu\"\n }, menuItems.map((action, i) => (0, preact_1.h)(\"div\", {\n class: (0, clsx_1.default)(\"-cbwsdk-snackbar-instance-menu-item\", action.isRed && \"-cbwsdk-snackbar-instance-menu-item-is-red\"),\n onClick: action.onClick,\n key: i\n }, (0, preact_1.h)(\"svg\", {\n width: action.svgWidth,\n height: action.svgHeight,\n viewBox: \"0 0 10 11\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, (0, preact_1.h)(\"path\", {\n \"fill-rule\": action.defaultFillRule,\n \"clip-rule\": action.defaultClipRule,\n d: action.path,\n fill: \"#AAAAAA\"\n })), (0, preact_1.h)(\"span\", {\n class: (0, clsx_1.default)(\"-cbwsdk-snackbar-instance-menu-item-info\", action.isRed && \"-cbwsdk-snackbar-instance-menu-item-info-is-red\")\n }, action.info)))));\n};\nexports.SnackbarInstance = SnackbarInstance;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = `@namespace svg \"http://www.w3.org/2000/svg\";.-cbwsdk-css-reset,.-cbwsdk-css-reset *{animation:none;animation-delay:0;animation-direction:normal;animation-duration:0;animation-fill-mode:none;animation-iteration-count:1;animation-name:none;animation-play-state:running;animation-timing-function:ease;backface-visibility:visible;background:0;background-attachment:scroll;background-clip:border-box;background-color:rgba(0,0,0,0);background-image:none;background-origin:padding-box;background-position:0 0;background-position-x:0;background-position-y:0;background-repeat:repeat;background-size:auto auto;border:0;border-style:none;border-width:medium;border-color:inherit;border-bottom:0;border-bottom-color:inherit;border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-style:none;border-bottom-width:medium;border-collapse:separate;border-image:none;border-left:0;border-left-color:inherit;border-left-style:none;border-left-width:medium;border-radius:0;border-right:0;border-right-color:inherit;border-right-style:none;border-right-width:medium;border-spacing:0;border-top:0;border-top-color:inherit;border-top-left-radius:0;border-top-right-radius:0;border-top-style:none;border-top-width:medium;box-shadow:none;box-sizing:border-box;caption-side:top;clear:none;clip:auto;color:inherit;columns:auto;column-count:auto;column-fill:balance;column-gap:normal;column-rule:medium none currentColor;column-rule-color:currentColor;column-rule-style:none;column-rule-width:none;column-span:1;column-width:auto;counter-increment:none;counter-reset:none;direction:ltr;empty-cells:show;float:none;font:normal;font-family:-apple-system,BlinkMacSystemFont,\"Segoe UI\",\"Helvetica Neue\",Arial,sans-serif;font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;height:auto;hyphens:none;letter-spacing:normal;line-height:normal;list-style:none;list-style-image:none;list-style-position:outside;list-style-type:disc;margin:0;margin-bottom:0;margin-left:0;margin-right:0;margin-top:0;opacity:1;orphans:0;outline:0;outline-color:invert;outline-style:none;outline-width:medium;overflow:visible;overflow-x:visible;overflow-y:visible;padding:0;padding-bottom:0;padding-left:0;padding-right:0;padding-top:0;page-break-after:auto;page-break-before:auto;page-break-inside:auto;perspective:none;perspective-origin:50% 50%;pointer-events:auto;position:static;quotes:\"\\\\201C\" \"\\\\201D\" \"\\\\2018\" \"\\\\2019\";tab-size:8;table-layout:auto;text-align:inherit;text-align-last:auto;text-decoration:none;text-decoration-color:inherit;text-decoration-line:none;text-decoration-style:solid;text-indent:0;text-shadow:none;text-transform:none;transform:none;transform-style:flat;transition:none;transition-delay:0s;transition-duration:0s;transition-property:none;transition-timing-function:ease;unicode-bidi:normal;vertical-align:baseline;visibility:visible;white-space:normal;widows:0;word-spacing:normal;z-index:auto}.-cbwsdk-css-reset strong{font-weight:bold}.-cbwsdk-css-reset *{box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,\"Segoe UI\",\"Helvetica Neue\",Arial,sans-serif;line-height:1}.-cbwsdk-css-reset [class*=container]{margin:0;padding:0}.-cbwsdk-css-reset style{display:none}`;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.injectCssReset = void 0;\nconst cssReset_css_1 = __importDefault(require(\"./cssReset-css\"));\nfunction injectCssReset() {\n const styleEl = document.createElement(\"style\");\n styleEl.type = \"text/css\";\n styleEl.appendChild(document.createTextNode(cssReset_css_1.default));\n document.documentElement.appendChild(styleEl);\n}\nexports.injectCssReset = injectCssReset;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.WalletSDKUI = void 0;\nconst LinkFlow_1 = require(\"../components/LinkFlow/LinkFlow\");\nconst Snackbar_1 = require(\"../components/Snackbar/Snackbar\");\nconst cssReset_1 = require(\"../lib/cssReset\");\nclass WalletSDKUI {\n constructor(options) {\n this.standalone = null;\n this.attached = false;\n this.appSrc = null;\n this.snackbar = new Snackbar_1.Snackbar({\n darkMode: options.darkMode\n });\n this.linkFlow = new LinkFlow_1.LinkFlow({\n darkMode: options.darkMode,\n version: options.version,\n sessionId: options.session.id,\n sessionSecret: options.session.secret,\n linkAPIUrl: options.linkAPIUrl,\n connected$: options.connected$,\n chainId$: options.chainId$,\n isParentConnection: false\n });\n }\n attach() {\n if (this.attached) {\n throw new Error(\"Coinbase Wallet SDK UI is already attached\");\n }\n const el = document.documentElement;\n const container = document.createElement(\"div\");\n container.className = \"-cbwsdk-css-reset\";\n el.appendChild(container);\n this.linkFlow.attach(container);\n this.snackbar.attach(container);\n this.attached = true;\n (0, cssReset_1.injectCssReset)();\n }\n setConnectDisabled(connectDisabled) {\n this.linkFlow.setConnectDisabled(connectDisabled);\n }\n /* istanbul ignore next */\n addEthereumChain(_options) {\n // no-op\n }\n /* istanbul ignore next */\n watchAsset(_options) {\n // no-op\n }\n /* istanbul ignore next */\n switchEthereumChain(_options) {\n // no-op\n }\n requestEthereumAccounts(options) {\n this.linkFlow.open({\n onCancel: options.onCancel\n });\n }\n hideRequestEthereumAccounts() {\n this.linkFlow.close();\n }\n /* istanbul ignore next */\n signEthereumMessage(_) {\n // No-op\n }\n /* istanbul ignore next */\n signEthereumTransaction(_) {\n // No-op\n }\n /* istanbul ignore next */\n submitEthereumTransaction(_) {\n // No-op\n }\n /* istanbul ignore next */\n ethereumAddressFromSignedMessage(_) {\n // No-op\n }\n showConnecting(options) {\n let snackbarProps;\n if (options.isUnlinkedErrorState) {\n snackbarProps = {\n autoExpand: true,\n message: \"Connection lost\",\n appSrc: this.appSrc,\n menuItems: [{\n isRed: false,\n info: \"Reset connection\",\n svgWidth: \"10\",\n svgHeight: \"11\",\n path: \"M5.00008 0.96875C6.73133 0.96875 8.23758 1.94375 9.00008 3.375L10.0001 2.375V5.5H9.53133H7.96883H6.87508L7.80633 4.56875C7.41258 3.3875 6.31258 2.53125 5.00008 2.53125C3.76258 2.53125 2.70633 3.2875 2.25633 4.36875L0.812576 3.76875C1.50008 2.125 3.11258 0.96875 5.00008 0.96875ZM2.19375 6.43125C2.5875 7.6125 3.6875 8.46875 5 8.46875C6.2375 8.46875 7.29375 7.7125 7.74375 6.63125L9.1875 7.23125C8.5 8.875 6.8875 10.0312 5 10.0312C3.26875 10.0312 1.7625 9.05625 1 7.625L0 8.625V5.5H0.46875H2.03125H3.125L2.19375 6.43125Z\",\n defaultFillRule: \"evenodd\",\n defaultClipRule: \"evenodd\",\n onClick: options.onResetConnection\n }]\n };\n } else {\n snackbarProps = {\n message: \"Confirm on phone\",\n appSrc: this.appSrc,\n menuItems: [{\n isRed: true,\n info: \"Cancel transaction\",\n svgWidth: \"11\",\n svgHeight: \"11\",\n path: \"M10.3711 1.52346L9.21775 0.370117L5.37109 4.21022L1.52444 0.370117L0.371094 1.52346L4.2112 5.37012L0.371094 9.21677L1.52444 10.3701L5.37109 6.53001L9.21775 10.3701L10.3711 9.21677L6.53099 5.37012L10.3711 1.52346Z\",\n defaultFillRule: \"inherit\",\n defaultClipRule: \"inherit\",\n onClick: options.onCancel\n }, {\n isRed: false,\n info: \"Reset connection\",\n svgWidth: \"10\",\n svgHeight: \"11\",\n path: \"M5.00008 0.96875C6.73133 0.96875 8.23758 1.94375 9.00008 3.375L10.0001 2.375V5.5H9.53133H7.96883H6.87508L7.80633 4.56875C7.41258 3.3875 6.31258 2.53125 5.00008 2.53125C3.76258 2.53125 2.70633 3.2875 2.25633 4.36875L0.812576 3.76875C1.50008 2.125 3.11258 0.96875 5.00008 0.96875ZM2.19375 6.43125C2.5875 7.6125 3.6875 8.46875 5 8.46875C6.2375 8.46875 7.29375 7.7125 7.74375 6.63125L9.1875 7.23125C8.5 8.875 6.8875 10.0312 5 10.0312C3.26875 10.0312 1.7625 9.05625 1 7.625L0 8.625V5.5H0.46875H2.03125H3.125L2.19375 6.43125Z\",\n defaultFillRule: \"evenodd\",\n defaultClipRule: \"evenodd\",\n onClick: options.onResetConnection\n }]\n };\n }\n return this.snackbar.presentItem(snackbarProps);\n }\n /* istanbul ignore next */\n setAppSrc(appSrc) {\n this.appSrc = appSrc;\n }\n /* istanbul ignore next */\n reloadUI() {\n document.location.reload();\n }\n /* istanbul ignore next */\n inlineAccountsResponse() {\n return false;\n }\n /* istanbul ignore next */\n inlineAddEthereumChain(_chainId) {\n return false;\n }\n /* istanbul ignore next */\n inlineWatchAsset() {\n return false;\n }\n /* istanbul ignore next */\n inlineSwitchEthereumChain() {\n return false;\n }\n /* istanbul ignore next */\n setStandalone(status) {\n this.standalone = status;\n }\n /* istanbul ignore next */\n isStandalone() {\n var _a;\n return (_a = this.standalone) !== null && _a !== void 0 ? _a : false;\n }\n}\nexports.WalletSDKUI = WalletSDKUI;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar constants = /*#__PURE__*/function (constants) {\n constants.typeOfFunction = 'function';\n constants.boolTrue = true;\n return constants;\n}(constants || {});\nfunction bind(target, propertyKey, descriptor) {\n if (!descriptor || typeof descriptor.value !== constants.typeOfFunction) {\n throw new TypeError(\"Only methods can be decorated with @bind. <\" + propertyKey + \"> is not a method!\");\n }\n return {\n configurable: constants.boolTrue,\n get: function () {\n var bound = descriptor.value.bind(this);\n // Credits to https://github.com/andreypopp/autobind-decorator for memoizing the result of bind against a symbol on the instance.\n Object.defineProperty(this, propertyKey, {\n value: bound,\n configurable: constants.boolTrue,\n writable: constants.boolTrue\n });\n return bound;\n }\n };\n}\nexports.bind = bind;\nexports.default = bind;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ClientMessagePublishEvent = exports.ClientMessageSetSessionConfig = exports.ClientMessageGetSessionConfig = exports.ClientMessageIsLinked = exports.ClientMessageHostSession = void 0;\nfunction ClientMessageHostSession(params) {\n return Object.assign({\n type: \"HostSession\"\n }, params);\n}\nexports.ClientMessageHostSession = ClientMessageHostSession;\nfunction ClientMessageIsLinked(params) {\n return Object.assign({\n type: \"IsLinked\"\n }, params);\n}\nexports.ClientMessageIsLinked = ClientMessageIsLinked;\nfunction ClientMessageGetSessionConfig(params) {\n return Object.assign({\n type: \"GetSessionConfig\"\n }, params);\n}\nexports.ClientMessageGetSessionConfig = ClientMessageGetSessionConfig;\nfunction ClientMessageSetSessionConfig(params) {\n return Object.assign({\n type: \"SetSessionConfig\"\n }, params);\n}\nexports.ClientMessageSetSessionConfig = ClientMessageSetSessionConfig;\nfunction ClientMessagePublishEvent(params) {\n return Object.assign({\n type: \"PublishEvent\"\n }, params);\n}\nexports.ClientMessagePublishEvent = ClientMessagePublishEvent;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RxWebSocket = exports.ConnectionState = void 0;\nconst rxjs_1 = require(\"rxjs\");\nconst operators_1 = require(\"rxjs/operators\");\nvar ConnectionState;\n(function (ConnectionState) {\n ConnectionState[ConnectionState[\"DISCONNECTED\"] = 0] = \"DISCONNECTED\";\n ConnectionState[ConnectionState[\"CONNECTING\"] = 1] = \"CONNECTING\";\n ConnectionState[ConnectionState[\"CONNECTED\"] = 2] = \"CONNECTED\";\n})(ConnectionState = exports.ConnectionState || (exports.ConnectionState = {}));\n/**\n * Rx-ified WebSocket\n */\nclass RxWebSocket {\n /**\n * Constructor\n * @param url WebSocket server URL\n * @param [WebSocketClass] Custom WebSocket implementation\n */\n constructor(url, WebSocketClass = WebSocket) {\n this.WebSocketClass = WebSocketClass;\n this.webSocket = null;\n this.connectionStateSubject = new rxjs_1.BehaviorSubject(ConnectionState.DISCONNECTED);\n this.incomingDataSubject = new rxjs_1.Subject();\n this.url = url.replace(/^http/, \"ws\");\n }\n /**\n * Make a websocket connection\n * @returns an Observable that completes when connected\n */\n connect() {\n if (this.webSocket) {\n return (0, rxjs_1.throwError)(new Error(\"webSocket object is not null\"));\n }\n return new rxjs_1.Observable(obs => {\n let webSocket;\n try {\n this.webSocket = webSocket = new this.WebSocketClass(this.url);\n } catch (err) {\n obs.error(err);\n return;\n }\n this.connectionStateSubject.next(ConnectionState.CONNECTING);\n webSocket.onclose = evt => {\n this.clearWebSocket();\n obs.error(new Error(`websocket error ${evt.code}: ${evt.reason}`));\n this.connectionStateSubject.next(ConnectionState.DISCONNECTED);\n };\n webSocket.onopen = _ => {\n obs.next();\n obs.complete();\n this.connectionStateSubject.next(ConnectionState.CONNECTED);\n };\n webSocket.onmessage = evt => {\n this.incomingDataSubject.next(evt.data);\n };\n }).pipe((0, operators_1.take)(1));\n }\n /**\n * Disconnect from server\n */\n disconnect() {\n const {\n webSocket\n } = this;\n if (!webSocket) {\n return;\n }\n this.clearWebSocket();\n this.connectionStateSubject.next(ConnectionState.DISCONNECTED);\n try {\n webSocket.close();\n } catch (_a) {}\n }\n /**\n * Emit current connection state and subsequent changes\n * @returns an Observable for the connection state\n */\n get connectionState$() {\n return this.connectionStateSubject.asObservable();\n }\n /**\n * Emit incoming data from server\n * @returns an Observable for the data received\n */\n get incomingData$() {\n return this.incomingDataSubject.asObservable();\n }\n /**\n * Emit incoming JSON data from server. non-JSON data are ignored\n * @returns an Observable for parsed JSON data\n */\n get incomingJSONData$() {\n return this.incomingData$.pipe((0, operators_1.flatMap)(m => {\n let j;\n try {\n j = JSON.parse(m);\n } catch (err) {\n return (0, rxjs_1.empty)();\n }\n return (0, rxjs_1.of)(j);\n }));\n }\n /**\n * Send data to server\n * @param data text to send\n */\n sendData(data) {\n const {\n webSocket\n } = this;\n if (!webSocket) {\n throw new Error(\"websocket is not connected\");\n }\n webSocket.send(data);\n }\n clearWebSocket() {\n const {\n webSocket\n } = this;\n if (!webSocket) {\n return;\n }\n this.webSocket = null;\n webSocket.onclose = null;\n webSocket.onerror = null;\n webSocket.onmessage = null;\n webSocket.onopen = null;\n }\n}\nexports.RxWebSocket = RxWebSocket;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isServerMessageFail = void 0;\nfunction isServerMessageFail(msg) {\n return msg && msg.type === \"Fail\" && typeof msg.id === \"number\" && typeof msg.sessionId === \"string\" && typeof msg.error === \"string\";\n}\nexports.isServerMessageFail = isServerMessageFail;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.WalletSDKConnection = void 0;\nconst rxjs_1 = require(\"rxjs\");\nconst operators_1 = require(\"rxjs/operators\");\nconst Session_1 = require(\"../relay/Session\");\nconst types_1 = require(\"../types\");\nconst ClientMessage_1 = require(\"./ClientMessage\");\nconst DiagnosticLogger_1 = require(\"./DiagnosticLogger\");\nconst RxWebSocket_1 = require(\"./RxWebSocket\");\nconst ServerMessage_1 = require(\"./ServerMessage\");\nconst HEARTBEAT_INTERVAL = 10000;\nconst REQUEST_TIMEOUT = 60000;\n/**\n * Coinbase Wallet Connection\n */\nclass WalletSDKConnection {\n /**\n * Constructor\n * @param sessionId Session ID\n * @param sessionKey Session Key\n * @param linkAPIUrl Coinbase Wallet link server URL\n * @param [WebSocketClass] Custom WebSocket implementation\n */\n constructor(sessionId, sessionKey, linkAPIUrl, diagnostic, WebSocketClass = WebSocket) {\n this.sessionId = sessionId;\n this.sessionKey = sessionKey;\n this.diagnostic = diagnostic;\n this.subscriptions = new rxjs_1.Subscription();\n this.destroyed = false;\n this.lastHeartbeatResponse = 0;\n this.nextReqId = (0, types_1.IntNumber)(1);\n this.connectedSubject = new rxjs_1.BehaviorSubject(false);\n this.linkedSubject = new rxjs_1.BehaviorSubject(false);\n this.sessionConfigSubject = new rxjs_1.ReplaySubject(1);\n const ws = new RxWebSocket_1.RxWebSocket(linkAPIUrl + \"/rpc\", WebSocketClass);\n this.ws = ws;\n // attempt to reconnect every 5 seconds when disconnected\n this.subscriptions.add(ws.connectionState$.pipe((0, operators_1.tap)(state => {\n var _a;\n return (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.CONNECTED_STATE_CHANGE, {\n state,\n sessionIdHash: Session_1.Session.hash(sessionId)\n });\n }),\n // ignore initial DISCONNECTED state\n (0, operators_1.skip)(1),\n // if DISCONNECTED and not destroyed\n (0, operators_1.filter)(cs => cs === RxWebSocket_1.ConnectionState.DISCONNECTED && !this.destroyed),\n // wait 5 seconds\n (0, operators_1.delay)(5000),\n // check whether it's destroyed again\n (0, operators_1.filter)(_ => !this.destroyed),\n // reconnect\n (0, operators_1.flatMap)(_ => ws.connect()), (0, operators_1.retry)()).subscribe());\n // perform authentication upon connection\n this.subscriptions.add(ws.connectionState$.pipe(\n // ignore initial DISCONNECTED and CONNECTING states\n (0, operators_1.skip)(2), (0, operators_1.switchMap)(cs => (0, rxjs_1.iif)(() => cs === RxWebSocket_1.ConnectionState.CONNECTED,\n // if CONNECTED, authenticate, and then check link status\n this.authenticate().pipe((0, operators_1.tap)(_ => this.sendIsLinked()), (0, operators_1.tap)(_ => this.sendGetSessionConfig()), (0, operators_1.map)(_ => true)),\n // if not CONNECTED, emit false immediately\n (0, rxjs_1.of)(false))), (0, operators_1.distinctUntilChanged)(), (0, operators_1.catchError)(_ => (0, rxjs_1.of)(false))).subscribe(connected => this.connectedSubject.next(connected)));\n // send heartbeat every n seconds while connected\n this.subscriptions.add(ws.connectionState$.pipe(\n // ignore initial DISCONNECTED state\n (0, operators_1.skip)(1), (0, operators_1.switchMap)(cs => (0, rxjs_1.iif)(() => cs === RxWebSocket_1.ConnectionState.CONNECTED,\n // if CONNECTED, start the heartbeat timer\n (0, rxjs_1.timer)(0, HEARTBEAT_INTERVAL)))).subscribe(i =>\n // first timer event updates lastHeartbeat timestamp\n // subsequent calls send heartbeat message\n i === 0 ? this.updateLastHeartbeat() : this.heartbeat()));\n // handle server's heartbeat responses\n this.subscriptions.add(ws.incomingData$.pipe((0, operators_1.filter)(m => m === \"h\")).subscribe(_ => this.updateLastHeartbeat()));\n // handle link status updates\n this.subscriptions.add(ws.incomingJSONData$.pipe((0, operators_1.filter)(m => [\"IsLinkedOK\", \"Linked\"].includes(m.type))).subscribe(m => {\n var _a;\n const msg = m;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.LINKED, {\n sessionIdHash: Session_1.Session.hash(sessionId),\n linked: msg.linked,\n type: m.type,\n onlineGuests: msg.onlineGuests\n });\n this.linkedSubject.next(msg.linked || msg.onlineGuests > 0);\n }));\n // handle session config updates\n this.subscriptions.add(ws.incomingJSONData$.pipe((0, operators_1.filter)(m => [\"GetSessionConfigOK\", \"SessionConfigUpdated\"].includes(m.type))).subscribe(m => {\n var _a;\n const msg = m;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.SESSION_CONFIG_RECEIVED, {\n sessionIdHash: Session_1.Session.hash(sessionId),\n metadata_keys: msg && msg.metadata ? Object.keys(msg.metadata) : undefined\n });\n this.sessionConfigSubject.next({\n webhookId: msg.webhookId,\n webhookUrl: msg.webhookUrl,\n metadata: msg.metadata\n });\n }));\n }\n /**\n * Make a connection to the server\n */\n connect() {\n var _a;\n if (this.destroyed) {\n throw new Error(\"instance is destroyed\");\n }\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.STARTED_CONNECTING, {\n sessionIdHash: Session_1.Session.hash(this.sessionId)\n });\n this.ws.connect().subscribe();\n }\n /**\n * Terminate connection, and mark as destroyed. To reconnect, create a new\n * instance of WalletSDKConnection\n */\n destroy() {\n var _a;\n this.subscriptions.unsubscribe();\n this.ws.disconnect();\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.DISCONNECTED, {\n sessionIdHash: Session_1.Session.hash(this.sessionId)\n });\n this.destroyed = true;\n }\n get isDestroyed() {\n return this.destroyed;\n }\n /**\n * Emit true if connected and authenticated, else false\n * @returns an Observable\n */\n get connected$() {\n return this.connectedSubject.asObservable();\n }\n /**\n * Emit once connected\n * @returns an Observable\n */\n get onceConnected$() {\n return this.connected$.pipe((0, operators_1.filter)(v => v), (0, operators_1.take)(1), (0, operators_1.map)(() => void 0));\n }\n /**\n * Emit true if linked (a guest has joined before)\n * @returns an Observable\n */\n get linked$() {\n return this.linkedSubject.asObservable();\n }\n /**\n * Emit once when linked\n * @returns an Observable\n */\n get onceLinked$() {\n return this.linked$.pipe((0, operators_1.filter)(v => v), (0, operators_1.take)(1), (0, operators_1.map)(() => void 0));\n }\n /**\n * Emit current session config if available, and subsequent updates\n * @returns an Observable for the session config\n */\n get sessionConfig$() {\n return this.sessionConfigSubject.asObservable();\n }\n /**\n * Emit incoming Event messages\n * @returns an Observable for the messages\n */\n get incomingEvent$() {\n return this.ws.incomingJSONData$.pipe((0, operators_1.filter)(m => {\n if (m.type !== \"Event\") {\n return false;\n }\n const sme = m;\n return typeof sme.sessionId === \"string\" && typeof sme.eventId === \"string\" && typeof sme.event === \"string\" && typeof sme.data === \"string\";\n }), (0, operators_1.map)(m => m));\n }\n /**\n * Set session metadata in SessionConfig object\n * @param key\n * @param value\n * @returns an Observable that completes when successful\n */\n setSessionMetadata(key, value) {\n const message = (0, ClientMessage_1.ClientMessageSetSessionConfig)({\n id: (0, types_1.IntNumber)(this.nextReqId++),\n sessionId: this.sessionId,\n metadata: {\n [key]: value\n }\n });\n return this.onceConnected$.pipe((0, operators_1.flatMap)(_ => this.makeRequest(message)), (0, operators_1.map)(res => {\n if ((0, ServerMessage_1.isServerMessageFail)(res)) {\n throw new Error(res.error || \"failed to set session metadata\");\n }\n }));\n }\n /**\n * Publish an event and emit event ID when successful\n * @param event event name\n * @param data event data\n * @param callWebhook whether the webhook should be invoked\n * @returns an Observable that emits event ID when successful\n */\n publishEvent(event, data, callWebhook = false) {\n const message = (0, ClientMessage_1.ClientMessagePublishEvent)({\n id: (0, types_1.IntNumber)(this.nextReqId++),\n sessionId: this.sessionId,\n event,\n data,\n callWebhook\n });\n return this.onceLinked$.pipe((0, operators_1.flatMap)(_ => this.makeRequest(message)), (0, operators_1.map)(res => {\n if ((0, ServerMessage_1.isServerMessageFail)(res)) {\n throw new Error(res.error || \"failed to publish event\");\n }\n return res.eventId;\n }));\n }\n sendData(message) {\n this.ws.sendData(JSON.stringify(message));\n }\n updateLastHeartbeat() {\n this.lastHeartbeatResponse = Date.now();\n }\n heartbeat() {\n if (Date.now() - this.lastHeartbeatResponse > HEARTBEAT_INTERVAL * 2) {\n this.ws.disconnect();\n return;\n }\n try {\n this.ws.sendData(\"h\");\n } catch (_a) {}\n }\n makeRequest(message, timeout = REQUEST_TIMEOUT) {\n const reqId = message.id;\n try {\n this.sendData(message);\n } catch (err) {\n return (0, rxjs_1.throwError)(err);\n }\n // await server message with corresponding id\n return this.ws.incomingJSONData$.pipe((0, operators_1.timeoutWith)(timeout, (0, rxjs_1.throwError)(new Error(`request ${reqId} timed out`))), (0, operators_1.filter)(m => m.id === reqId), (0, operators_1.take)(1));\n }\n authenticate() {\n const msg = (0, ClientMessage_1.ClientMessageHostSession)({\n id: (0, types_1.IntNumber)(this.nextReqId++),\n sessionId: this.sessionId,\n sessionKey: this.sessionKey\n });\n return this.makeRequest(msg).pipe((0, operators_1.map)(res => {\n if ((0, ServerMessage_1.isServerMessageFail)(res)) {\n throw new Error(res.error || \"failed to authentcate\");\n }\n }));\n }\n sendIsLinked() {\n const msg = (0, ClientMessage_1.ClientMessageIsLinked)({\n id: (0, types_1.IntNumber)(this.nextReqId++),\n sessionId: this.sessionId\n });\n this.sendData(msg);\n }\n sendGetSessionConfig() {\n const msg = (0, ClientMessage_1.ClientMessageGetSessionConfig)({\n id: (0, types_1.IntNumber)(this.nextReqId++),\n sessionId: this.sessionId\n });\n this.sendData(msg);\n }\n}\nexports.WalletSDKConnection = WalletSDKConnection;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.decrypt = exports.encrypt = void 0;\nconst util_1 = require(\"../util\");\n/**\n *\n * @param plainText string to be encrypted\n * @param secret hex representation of 32-byte secret\n * returns hex string representation of bytes in the order: initialization vector (iv),\n * auth tag, encrypted plaintext. IV is 12 bytes. Auth tag is 16 bytes. Remaining bytes are the\n * encrypted plainText.\n */\nasync function encrypt(plainText, secret) {\n if (secret.length !== 64) throw Error(`secret must be 256 bits`);\n const ivBytes = crypto.getRandomValues(new Uint8Array(12));\n const secretKey = await crypto.subtle.importKey(\"raw\", (0, util_1.hexStringToUint8Array)(secret), {\n name: \"aes-gcm\"\n }, false, [\"encrypt\", \"decrypt\"]);\n const enc = new TextEncoder();\n // Will return encrypted plainText with auth tag (ie MAC or checksum) appended at the end\n const encryptedResult = await window.crypto.subtle.encrypt({\n name: \"AES-GCM\",\n iv: ivBytes\n }, secretKey, enc.encode(plainText));\n const tagLength = 16;\n const authTag = encryptedResult.slice(encryptedResult.byteLength - tagLength);\n const encryptedPlaintext = encryptedResult.slice(0, encryptedResult.byteLength - tagLength);\n const authTagBytes = new Uint8Array(authTag);\n const encryptedPlaintextBytes = new Uint8Array(encryptedPlaintext);\n const concatted = new Uint8Array([...ivBytes, ...authTagBytes, ...encryptedPlaintextBytes]);\n return (0, util_1.uint8ArrayToHex)(concatted);\n}\nexports.encrypt = encrypt;\n/**\n *\n * @param cipherText hex string representation of bytes in the order: initialization vector (iv),\n * auth tag, encrypted plaintext. IV is 12 bytes. Auth tag is 16 bytes.\n * @param secret hex string representation of 32-byte secret\n */\nfunction decrypt(cipherText, secret) {\n if (secret.length !== 64) throw Error(`secret must be 256 bits`);\n return new Promise((resolve, reject) => {\n void async function () {\n const secretKey = await crypto.subtle.importKey(\"raw\", (0, util_1.hexStringToUint8Array)(secret), {\n name: \"aes-gcm\"\n }, false, [\"encrypt\", \"decrypt\"]);\n const encrypted = (0, util_1.hexStringToUint8Array)(cipherText);\n const ivBytes = encrypted.slice(0, 12);\n const authTagBytes = encrypted.slice(12, 28);\n const encryptedPlaintextBytes = encrypted.slice(28);\n const concattedBytes = new Uint8Array([...encryptedPlaintextBytes, ...authTagBytes]);\n const algo = {\n name: \"AES-GCM\",\n iv: new Uint8Array(ivBytes)\n };\n try {\n const decrypted = await window.crypto.subtle.decrypt(algo, secretKey, concattedBytes);\n const decoder = new TextDecoder();\n resolve(decoder.decode(decrypted));\n } catch (err) {\n reject(err);\n }\n }();\n });\n}\nexports.decrypt = decrypt;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RelayMessageType = void 0;\nvar RelayMessageType;\n(function (RelayMessageType) {\n RelayMessageType[\"SESSION_ID_REQUEST\"] = \"SESSION_ID_REQUEST\";\n RelayMessageType[\"SESSION_ID_RESPONSE\"] = \"SESSION_ID_RESPONSE\";\n RelayMessageType[\"LINKED\"] = \"LINKED\";\n RelayMessageType[\"UNLINKED\"] = \"UNLINKED\";\n RelayMessageType[\"WEB3_REQUEST\"] = \"WEB3_REQUEST\";\n RelayMessageType[\"WEB3_REQUEST_CANCELED\"] = \"WEB3_REQUEST_CANCELED\";\n RelayMessageType[\"WEB3_RESPONSE\"] = \"WEB3_RESPONSE\";\n})(RelayMessageType = exports.RelayMessageType || (exports.RelayMessageType = {}));","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Web3RequestCanceledMessage = void 0;\nconst RelayMessage_1 = require(\"./RelayMessage\");\nfunction Web3RequestCanceledMessage(id) {\n return {\n type: RelayMessage_1.RelayMessageType.WEB3_REQUEST_CANCELED,\n id\n };\n}\nexports.Web3RequestCanceledMessage = Web3RequestCanceledMessage;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Web3RequestMessage = void 0;\nconst RelayMessage_1 = require(\"./RelayMessage\");\nfunction Web3RequestMessage(params) {\n return Object.assign({\n type: RelayMessage_1.RelayMessageType.WEB3_REQUEST\n }, params);\n}\nexports.Web3RequestMessage = Web3RequestMessage;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isWeb3ResponseMessage = exports.Web3ResponseMessage = void 0;\nconst RelayMessage_1 = require(\"./RelayMessage\");\nfunction Web3ResponseMessage(params) {\n return Object.assign({\n type: RelayMessage_1.RelayMessageType.WEB3_RESPONSE\n }, params);\n}\nexports.Web3ResponseMessage = Web3ResponseMessage;\nfunction isWeb3ResponseMessage(msg) {\n return msg && msg.type === RelayMessage_1.RelayMessageType.WEB3_RESPONSE;\n}\nexports.isWeb3ResponseMessage = isWeb3ResponseMessage;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nvar __createBinding = this && this.__createBinding || (Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, {\n enumerable: true,\n get: function () {\n return m[k];\n }\n });\n} : function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\nvar __setModuleDefault = this && this.__setModuleDefault || (Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n});\nvar __decorate = this && this.__decorate || function (decorators, target, key, desc) {\n var c = arguments.length,\n r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc,\n d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __importStar = this && this.__importStar || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __importDefault = this && this.__importDefault || function (mod) {\n return mod && mod.__esModule ? mod : {\n \"default\": mod\n };\n};\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.WalletSDKRelay = void 0;\nconst bind_decorator_1 = __importDefault(require(\"bind-decorator\"));\nconst rxjs_1 = require(\"rxjs\");\nconst operators_1 = require(\"rxjs/operators\");\nconst DiagnosticLogger_1 = require(\"../connection/DiagnosticLogger\");\nconst WalletSDKConnection_1 = require(\"../connection/WalletSDKConnection\");\nconst errors_1 = require(\"../errors\");\nconst types_1 = require(\"../types\");\nconst util_1 = require(\"../util\");\nconst aes256gcm = __importStar(require(\"./aes256gcm\"));\nconst Session_1 = require(\"./Session\");\nconst WalletSDKRelayAbstract_1 = require(\"./WalletSDKRelayAbstract\");\nconst Web3Method_1 = require(\"./Web3Method\");\nconst Web3RequestCanceledMessage_1 = require(\"./Web3RequestCanceledMessage\");\nconst Web3RequestMessage_1 = require(\"./Web3RequestMessage\");\nconst Web3Response_1 = require(\"./Web3Response\");\nconst Web3ResponseMessage_1 = require(\"./Web3ResponseMessage\");\nclass WalletSDKRelay extends WalletSDKRelayAbstract_1.WalletSDKRelayAbstract {\n constructor(options) {\n var _a;\n super();\n this.accountsCallback = null;\n this.chainCallback = null;\n this.dappDefaultChainSubject = new rxjs_1.BehaviorSubject(1);\n this.dappDefaultChain = 1;\n this.appName = \"\";\n this.appLogoUrl = null;\n this.subscriptions = new rxjs_1.Subscription();\n this.linkAPIUrl = options.linkAPIUrl;\n this.storage = options.storage;\n this.options = options;\n const {\n session,\n ui,\n connection\n } = this.subscribe();\n this._session = session;\n this.connection = connection;\n this.relayEventManager = options.relayEventManager;\n if (options.diagnosticLogger && options.eventListener) {\n throw new Error(\"Can't have both eventListener and diagnosticLogger options, use only diagnosticLogger\");\n }\n if (options.eventListener) {\n this.diagnostic = {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n log: options.eventListener.onEvent\n };\n } else {\n this.diagnostic = options.diagnosticLogger;\n }\n this._reloadOnDisconnect = (_a = options.reloadOnDisconnect) !== null && _a !== void 0 ? _a : true;\n this.ui = ui;\n }\n subscribe() {\n this.subscriptions.add(this.dappDefaultChainSubject.subscribe(chainId => {\n if (this.dappDefaultChain !== chainId) {\n this.dappDefaultChain = chainId;\n }\n }));\n const session = Session_1.Session.load(this.storage) || new Session_1.Session(this.storage).save();\n const connection = new WalletSDKConnection_1.WalletSDKConnection(session.id, session.key, this.linkAPIUrl, this.diagnostic);\n this.subscriptions.add(connection.sessionConfig$.subscribe({\n next: sessionConfig => {\n this.onSessionConfigChanged(sessionConfig);\n },\n error: () => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"error while invoking session config callback\"\n });\n }\n }));\n this.subscriptions.add(connection.incomingEvent$.pipe((0, operators_1.filter)(m => m.event === \"Web3Response\")).subscribe({\n next: this.handleIncomingEvent\n }));\n this.subscriptions.add(connection.linked$.pipe((0, operators_1.skip)(1), (0, operators_1.tap)(linked => {\n var _a;\n this.isLinked = linked;\n const cachedAddresses = this.storage.getItem(WalletSDKRelayAbstract_1.LOCAL_STORAGE_ADDRESSES_KEY);\n if (linked) {\n // Only set linked session variable one way\n this.session.linked = linked;\n }\n this.isUnlinkedErrorState = false;\n if (cachedAddresses) {\n const addresses = cachedAddresses.split(\" \");\n const wasConnectedViaStandalone = this.storage.getItem(\"IsStandaloneSigning\") === \"true\";\n if (addresses[0] !== \"\" && !linked && this.session.linked && !wasConnectedViaStandalone) {\n this.isUnlinkedErrorState = true;\n const sessionIdHash = this.getSessionIdHash();\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.UNLINKED_ERROR_STATE, {\n sessionIdHash\n });\n }\n }\n })).subscribe());\n // if session is marked destroyed, reset and reload\n this.subscriptions.add(connection.sessionConfig$.pipe((0, operators_1.filter)(c => !!c.metadata && c.metadata.__destroyed === \"1\")).subscribe(() => {\n var _a;\n const alreadyDestroyed = connection.isDestroyed;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.METADATA_DESTROYED, {\n alreadyDestroyed,\n sessionIdHash: this.getSessionIdHash()\n });\n return this.resetAndReload();\n }));\n this.subscriptions.add(connection.sessionConfig$.pipe((0, operators_1.filter)(c => c.metadata && c.metadata.WalletUsername !== undefined)).pipe((0, operators_1.mergeMap)(c => aes256gcm.decrypt(c.metadata.WalletUsername, session.secret))).subscribe({\n next: walletUsername => {\n this.storage.setItem(WalletSDKRelayAbstract_1.WALLET_USER_NAME_KEY, walletUsername);\n },\n error: () => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"Had error decrypting\",\n value: \"username\"\n });\n }\n }));\n this.subscriptions.add(connection.sessionConfig$.pipe((0, operators_1.filter)(c => c.metadata && c.metadata.AppVersion !== undefined)).pipe((0, operators_1.mergeMap)(c => aes256gcm.decrypt(c.metadata.AppVersion, session.secret))).subscribe({\n next: appVersion => {\n this.storage.setItem(WalletSDKRelayAbstract_1.APP_VERSION_KEY, appVersion);\n },\n error: () => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"Had error decrypting\",\n value: \"appversion\"\n });\n }\n }));\n this.subscriptions.add(connection.sessionConfig$.pipe((0, operators_1.filter)(c => c.metadata && c.metadata.ChainId !== undefined && c.metadata.JsonRpcUrl !== undefined)).pipe((0, operators_1.mergeMap)(c => (0, rxjs_1.zip)(aes256gcm.decrypt(c.metadata.ChainId, session.secret), aes256gcm.decrypt(c.metadata.JsonRpcUrl, session.secret)))).pipe((0, operators_1.distinctUntilChanged)()).subscribe({\n next: ([chainId, jsonRpcUrl]) => {\n if (this.chainCallback) {\n this.chainCallback(chainId, jsonRpcUrl);\n }\n },\n error: () => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"Had error decrypting\",\n value: \"chainId|jsonRpcUrl\"\n });\n }\n }));\n this.subscriptions.add(connection.sessionConfig$.pipe((0, operators_1.filter)(c => c.metadata && c.metadata.EthereumAddress !== undefined)).pipe((0, operators_1.mergeMap)(c => aes256gcm.decrypt(c.metadata.EthereumAddress, session.secret))).subscribe({\n next: selectedAddress => {\n if (this.accountsCallback) {\n this.accountsCallback([selectedAddress]);\n }\n if (WalletSDKRelay.accountRequestCallbackIds.size > 0) {\n // We get the ethereum address from the metadata. If for whatever\n // reason we don't get a response via an explicit web3 message\n // we can still fulfill the eip1102 request.\n Array.from(WalletSDKRelay.accountRequestCallbackIds.values()).forEach(id => {\n const message = (0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.RequestEthereumAccountsResponse)([selectedAddress])\n });\n this.invokeCallback(Object.assign(Object.assign({}, message), {\n id\n }));\n });\n WalletSDKRelay.accountRequestCallbackIds.clear();\n }\n },\n error: () => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"Had error decrypting\",\n value: \"selectedAddress\"\n });\n }\n }));\n this.subscriptions.add(connection.sessionConfig$.pipe((0, operators_1.filter)(c => c.metadata && c.metadata.AppSrc !== undefined)).pipe((0, operators_1.mergeMap)(c => aes256gcm.decrypt(c.metadata.AppSrc, session.secret))).subscribe({\n next: appSrc => {\n this.ui.setAppSrc(appSrc);\n },\n error: () => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"Had error decrypting\",\n value: \"appSrc\"\n });\n }\n }));\n const ui = this.options.uiConstructor({\n linkAPIUrl: this.options.linkAPIUrl,\n version: this.options.version,\n darkMode: this.options.darkMode,\n session,\n connected$: connection.connected$,\n chainId$: this.dappDefaultChainSubject\n });\n connection.connect();\n return {\n session,\n ui,\n connection\n };\n }\n attachUI() {\n this.ui.attach();\n }\n resetAndReload() {\n this.connection.setSessionMetadata(\"__destroyed\", \"1\").pipe((0, operators_1.timeout)(1000), (0, operators_1.catchError)(_ => (0, rxjs_1.of)(null))).subscribe(_ => {\n var _a, _b, _c;\n const isStandalone = this.ui.isStandalone();\n try {\n this.subscriptions.unsubscribe();\n } catch (err) {\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"Had error unsubscribing\"\n });\n }\n (_b = this.diagnostic) === null || _b === void 0 ? void 0 : _b.log(DiagnosticLogger_1.EVENTS.SESSION_STATE_CHANGE, {\n method: \"relay::resetAndReload\",\n sessionMetadataChange: \"__destroyed, 1\",\n sessionIdHash: this.getSessionIdHash()\n });\n this.connection.destroy();\n /**\n * Only clear storage if the session id we have in memory matches the one on disk\n * Otherwise, in the case where we have 2 tabs, another tab might have cleared\n * storage already. In that case if we clear storage again, the user will be in\n * a state where the first tab allows the user to connect but the session that\n * was used isn't persisted. This leaves the user in a state where they aren't\n * connected to the mobile app.\n */\n const storedSession = Session_1.Session.load(this.storage);\n if ((storedSession === null || storedSession === void 0 ? void 0 : storedSession.id) === this._session.id) {\n this.storage.clear();\n } else if (storedSession) {\n (_c = this.diagnostic) === null || _c === void 0 ? void 0 : _c.log(DiagnosticLogger_1.EVENTS.SKIPPED_CLEARING_SESSION, {\n sessionIdHash: this.getSessionIdHash(),\n storedSessionIdHash: Session_1.Session.hash(storedSession.id)\n });\n }\n if (this._reloadOnDisconnect) {\n this.ui.reloadUI();\n return;\n }\n if (this.accountsCallback) {\n this.accountsCallback([], true);\n }\n this.subscriptions = new rxjs_1.Subscription();\n const {\n session,\n ui,\n connection\n } = this.subscribe();\n this._session = session;\n this.connection = connection;\n this.ui = ui;\n if (isStandalone && this.ui.setStandalone) this.ui.setStandalone(true);\n this.attachUI();\n }, err => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.FAILURE, {\n method: \"relay::resetAndReload\",\n message: `failed to reset and reload with ${err}`,\n sessionIdHash: this.getSessionIdHash()\n });\n });\n }\n setAppInfo(appName, appLogoUrl) {\n this.appName = appName;\n this.appLogoUrl = appLogoUrl;\n }\n getStorageItem(key) {\n return this.storage.getItem(key);\n }\n get session() {\n return this._session;\n }\n setStorageItem(key, value) {\n this.storage.setItem(key, value);\n }\n signEthereumMessage(message, address, addPrefix, typedDataJson) {\n return this.sendRequest({\n method: Web3Method_1.Web3Method.signEthereumMessage,\n params: {\n message: (0, util_1.hexStringFromBuffer)(message, true),\n address,\n addPrefix,\n typedDataJson: typedDataJson || null\n }\n });\n }\n ethereumAddressFromSignedMessage(message, signature, addPrefix) {\n return this.sendRequest({\n method: Web3Method_1.Web3Method.ethereumAddressFromSignedMessage,\n params: {\n message: (0, util_1.hexStringFromBuffer)(message, true),\n signature: (0, util_1.hexStringFromBuffer)(signature, true),\n addPrefix\n }\n });\n }\n signEthereumTransaction(params) {\n return this.sendRequest({\n method: Web3Method_1.Web3Method.signEthereumTransaction,\n params: {\n fromAddress: params.fromAddress,\n toAddress: params.toAddress,\n weiValue: (0, util_1.bigIntStringFromBN)(params.weiValue),\n data: (0, util_1.hexStringFromBuffer)(params.data, true),\n nonce: params.nonce,\n gasPriceInWei: params.gasPriceInWei ? (0, util_1.bigIntStringFromBN)(params.gasPriceInWei) : null,\n maxFeePerGas: params.gasPriceInWei ? (0, util_1.bigIntStringFromBN)(params.gasPriceInWei) : null,\n maxPriorityFeePerGas: params.gasPriceInWei ? (0, util_1.bigIntStringFromBN)(params.gasPriceInWei) : null,\n gasLimit: params.gasLimit ? (0, util_1.bigIntStringFromBN)(params.gasLimit) : null,\n chainId: params.chainId,\n shouldSubmit: false\n }\n });\n }\n signAndSubmitEthereumTransaction(params) {\n return this.sendRequest({\n method: Web3Method_1.Web3Method.signEthereumTransaction,\n params: {\n fromAddress: params.fromAddress,\n toAddress: params.toAddress,\n weiValue: (0, util_1.bigIntStringFromBN)(params.weiValue),\n data: (0, util_1.hexStringFromBuffer)(params.data, true),\n nonce: params.nonce,\n gasPriceInWei: params.gasPriceInWei ? (0, util_1.bigIntStringFromBN)(params.gasPriceInWei) : null,\n maxFeePerGas: params.maxFeePerGas ? (0, util_1.bigIntStringFromBN)(params.maxFeePerGas) : null,\n maxPriorityFeePerGas: params.maxPriorityFeePerGas ? (0, util_1.bigIntStringFromBN)(params.maxPriorityFeePerGas) : null,\n gasLimit: params.gasLimit ? (0, util_1.bigIntStringFromBN)(params.gasLimit) : null,\n chainId: params.chainId,\n shouldSubmit: true\n }\n });\n }\n submitEthereumTransaction(signedTransaction, chainId) {\n return this.sendRequest({\n method: Web3Method_1.Web3Method.submitEthereumTransaction,\n params: {\n signedTransaction: (0, util_1.hexStringFromBuffer)(signedTransaction, true),\n chainId\n }\n });\n }\n scanQRCode(regExp) {\n return this.sendRequest({\n method: Web3Method_1.Web3Method.scanQRCode,\n params: {\n regExp\n }\n });\n }\n getQRCodeUrl() {\n return (0, util_1.createQrUrl)(this._session.id, this._session.secret, this.linkAPIUrl, false, this.options.version, this.dappDefaultChain);\n }\n genericRequest(data, action) {\n return this.sendRequest({\n method: Web3Method_1.Web3Method.generic,\n params: {\n action,\n data\n }\n });\n }\n sendGenericMessage(request) {\n return this.sendRequest(request);\n }\n sendRequest(request) {\n let hideSnackbarItem = null;\n const id = (0, util_1.randomBytesHex)(8);\n const cancel = error => {\n this.publishWeb3RequestCanceledEvent(id);\n this.handleErrorResponse(id, request.method, error);\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n };\n const promise = new Promise((resolve, reject) => {\n if (!this.ui.isStandalone()) {\n hideSnackbarItem = this.ui.showConnecting({\n isUnlinkedErrorState: this.isUnlinkedErrorState,\n onCancel: cancel,\n onResetConnection: this.resetAndReload // eslint-disable-line @typescript-eslint/unbound-method\n });\n }\n this.relayEventManager.callbacks.set(id, response => {\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n if (response.errorMessage) {\n return reject(new Error(response.errorMessage));\n }\n resolve(response);\n });\n if (this.ui.isStandalone()) {\n this.sendRequestStandalone(id, request);\n } else {\n this.publishWeb3RequestEvent(id, request);\n }\n });\n return {\n promise,\n cancel\n };\n }\n setConnectDisabled(disabled) {\n this.ui.setConnectDisabled(disabled);\n }\n setAccountsCallback(accountsCallback) {\n this.accountsCallback = accountsCallback;\n }\n setChainCallback(chainCallback) {\n this.chainCallback = chainCallback;\n }\n setDappDefaultChainCallback(chainId) {\n this.dappDefaultChainSubject.next(chainId);\n }\n publishWeb3RequestEvent(id, request) {\n var _a;\n const message = (0, Web3RequestMessage_1.Web3RequestMessage)({\n id,\n request\n });\n const storedSession = Session_1.Session.load(this.storage);\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.WEB3_REQUEST, {\n eventId: message.id,\n method: `relay::${message.request.method}`,\n sessionIdHash: this.getSessionIdHash(),\n storedSessionIdHash: storedSession ? Session_1.Session.hash(storedSession.id) : \"\",\n isSessionMismatched: ((storedSession === null || storedSession === void 0 ? void 0 : storedSession.id) !== this._session.id).toString()\n });\n this.subscriptions.add(this.publishEvent(\"Web3Request\", message, true).subscribe({\n next: _ => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.WEB3_REQUEST_PUBLISHED, {\n eventId: message.id,\n method: `relay::${message.request.method}`,\n sessionIdHash: this.getSessionIdHash(),\n storedSessionIdHash: storedSession ? Session_1.Session.hash(storedSession.id) : \"\",\n isSessionMismatched: ((storedSession === null || storedSession === void 0 ? void 0 : storedSession.id) !== this._session.id).toString()\n });\n },\n error: err => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id: message.id,\n response: {\n method: message.request.method,\n errorMessage: err.message\n }\n }));\n }\n }));\n }\n publishWeb3RequestCanceledEvent(id) {\n const message = (0, Web3RequestCanceledMessage_1.Web3RequestCanceledMessage)(id);\n this.subscriptions.add(this.publishEvent(\"Web3RequestCanceled\", message, false).subscribe());\n }\n publishEvent(event, message, callWebhook) {\n const secret = this.session.secret;\n return new rxjs_1.Observable(subscriber => {\n void aes256gcm.encrypt(JSON.stringify(Object.assign(Object.assign({}, message), {\n origin: location.origin\n })), secret).then(encrypted => {\n subscriber.next(encrypted);\n subscriber.complete();\n });\n }).pipe((0, operators_1.mergeMap)(encrypted => {\n return this.connection.publishEvent(event, encrypted, callWebhook);\n }));\n }\n handleIncomingEvent(event) {\n try {\n this.subscriptions.add((0, rxjs_1.from)(aes256gcm.decrypt(event.data, this.session.secret)).pipe((0, operators_1.map)(c => JSON.parse(c))).subscribe({\n next: json => {\n const message = (0, Web3ResponseMessage_1.isWeb3ResponseMessage)(json) ? json : null;\n if (!message) {\n return;\n }\n this.handleWeb3ResponseMessage(message);\n },\n error: () => {\n var _a;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.GENERAL_ERROR, {\n message: \"Had error decrypting\",\n value: \"incomingEvent\"\n });\n }\n }));\n } catch (_a) {\n return;\n }\n }\n handleWeb3ResponseMessage(message) {\n var _a;\n const {\n response\n } = message;\n (_a = this.diagnostic) === null || _a === void 0 ? void 0 : _a.log(DiagnosticLogger_1.EVENTS.WEB3_RESPONSE, {\n eventId: message.id,\n method: `relay::${response.method}`,\n sessionIdHash: this.getSessionIdHash()\n });\n if ((0, Web3Response_1.isRequestEthereumAccountsResponse)(response)) {\n WalletSDKRelay.accountRequestCallbackIds.forEach(id => this.invokeCallback(Object.assign(Object.assign({}, message), {\n id\n })));\n WalletSDKRelay.accountRequestCallbackIds.clear();\n return;\n }\n this.invokeCallback(message);\n }\n handleErrorResponse(id, method, error, errorCode) {\n var _a;\n const errorMessage = (_a = error === null || error === void 0 ? void 0 : error.message) !== null && _a !== void 0 ? _a : (0, errors_1.standardErrorMessage)(errorCode);\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: {\n method,\n errorMessage,\n errorCode\n }\n }));\n }\n invokeCallback(message) {\n const callback = this.relayEventManager.callbacks.get(message.id);\n if (callback) {\n callback(message.response);\n this.relayEventManager.callbacks.delete(message.id);\n }\n }\n requestEthereumAccounts() {\n const request = {\n method: Web3Method_1.Web3Method.requestEthereumAccounts,\n params: {\n appName: this.appName,\n appLogoUrl: this.appLogoUrl || null\n }\n };\n const hideSnackbarItem = null;\n const id = (0, util_1.randomBytesHex)(8);\n const cancel = error => {\n this.publishWeb3RequestCanceledEvent(id);\n this.handleErrorResponse(id, request.method, error);\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n };\n const promise = new Promise((resolve, reject) => {\n var _a;\n this.relayEventManager.callbacks.set(id, response => {\n this.ui.hideRequestEthereumAccounts();\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n if (response.errorMessage) {\n return reject(new Error(response.errorMessage));\n }\n resolve(response);\n });\n const userAgent = ((_a = window === null || window === void 0 ? void 0 : window.navigator) === null || _a === void 0 ? void 0 : _a.userAgent) || null;\n if (userAgent && /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(userAgent)) {\n let location;\n try {\n if ((0, util_1.isInIFrame)() && window.top) {\n location = window.top.location;\n } else {\n location = window.location;\n }\n } catch (e) {\n location = window.location;\n }\n location.href = `https://www.coinbase.com/connect-dapp?uri=${encodeURIComponent(location.href)}`;\n return;\n }\n if (this.ui.inlineAccountsResponse()) {\n const onAccounts = accounts => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.RequestEthereumAccountsResponse)(accounts)\n }));\n };\n this.ui.requestEthereumAccounts({\n onCancel: cancel,\n onAccounts\n });\n } else {\n // Error if user closes TryExtensionLinkDialog without connecting\n const err = errors_1.standardErrors.provider.userRejectedRequest(\"User denied account authorization\");\n this.ui.requestEthereumAccounts({\n onCancel: () => cancel(err)\n });\n }\n WalletSDKRelay.accountRequestCallbackIds.add(id);\n if (!this.ui.inlineAccountsResponse() && !this.ui.isStandalone()) {\n this.publishWeb3RequestEvent(id, request);\n }\n });\n return {\n promise,\n cancel\n };\n }\n selectProvider(providerOptions) {\n const request = {\n method: Web3Method_1.Web3Method.selectProvider,\n params: {\n providerOptions\n }\n };\n const id = (0, util_1.randomBytesHex)(8);\n const cancel = error => {\n this.publishWeb3RequestCanceledEvent(id);\n this.handleErrorResponse(id, request.method, error);\n };\n const promise = new Promise((resolve, reject) => {\n this.relayEventManager.callbacks.set(id, response => {\n if (response.errorMessage) {\n return reject(new Error(response.errorMessage));\n }\n resolve(response);\n });\n const _cancel = _error => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.SelectProviderResponse)(types_1.ProviderType.Unselected)\n }));\n };\n const approve = selectedProviderKey => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.SelectProviderResponse)(selectedProviderKey)\n }));\n };\n if (this.ui.selectProvider) this.ui.selectProvider({\n onApprove: approve,\n onCancel: _cancel,\n providerOptions\n });\n });\n return {\n cancel,\n promise\n };\n }\n watchAsset(type, address, symbol, decimals, image, chainId) {\n const request = {\n method: Web3Method_1.Web3Method.watchAsset,\n params: {\n type,\n options: {\n address,\n symbol,\n decimals,\n image\n },\n chainId\n }\n };\n let hideSnackbarItem = null;\n const id = (0, util_1.randomBytesHex)(8);\n const cancel = error => {\n this.publishWeb3RequestCanceledEvent(id);\n this.handleErrorResponse(id, request.method, error);\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n };\n if (!this.ui.inlineWatchAsset()) {\n hideSnackbarItem = this.ui.showConnecting({\n isUnlinkedErrorState: this.isUnlinkedErrorState,\n onCancel: cancel,\n onResetConnection: this.resetAndReload // eslint-disable-line @typescript-eslint/unbound-method\n });\n }\n const promise = new Promise((resolve, reject) => {\n this.relayEventManager.callbacks.set(id, response => {\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n if (response.errorMessage) {\n return reject(new Error(response.errorMessage));\n }\n resolve(response);\n });\n const _cancel = _error => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.WatchAssetReponse)(false)\n }));\n };\n const approve = () => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.WatchAssetReponse)(true)\n }));\n };\n if (this.ui.inlineWatchAsset()) {\n this.ui.watchAsset({\n onApprove: approve,\n onCancel: _cancel,\n type,\n address,\n symbol,\n decimals,\n image,\n chainId\n });\n }\n if (!this.ui.inlineWatchAsset() && !this.ui.isStandalone()) {\n this.publishWeb3RequestEvent(id, request);\n }\n });\n return {\n cancel,\n promise\n };\n }\n addEthereumChain(chainId, rpcUrls, iconUrls, blockExplorerUrls, chainName, nativeCurrency) {\n const request = {\n method: Web3Method_1.Web3Method.addEthereumChain,\n params: {\n chainId,\n rpcUrls,\n blockExplorerUrls,\n chainName,\n iconUrls,\n nativeCurrency\n }\n };\n let hideSnackbarItem = null;\n const id = (0, util_1.randomBytesHex)(8);\n const cancel = error => {\n this.publishWeb3RequestCanceledEvent(id);\n this.handleErrorResponse(id, request.method, error);\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n };\n if (!this.ui.inlineAddEthereumChain(chainId)) {\n hideSnackbarItem = this.ui.showConnecting({\n isUnlinkedErrorState: this.isUnlinkedErrorState,\n onCancel: cancel,\n onResetConnection: this.resetAndReload // eslint-disable-line @typescript-eslint/unbound-method\n });\n }\n const promise = new Promise((resolve, reject) => {\n this.relayEventManager.callbacks.set(id, response => {\n hideSnackbarItem === null || hideSnackbarItem === void 0 ? void 0 : hideSnackbarItem();\n if (response.errorMessage) {\n return reject(new Error(response.errorMessage));\n }\n resolve(response);\n });\n const _cancel = _error => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.AddEthereumChainResponse)({\n isApproved: false,\n rpcUrl: \"\"\n })\n }));\n };\n const approve = rpcUrl => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.AddEthereumChainResponse)({\n isApproved: true,\n rpcUrl\n })\n }));\n };\n if (this.ui.inlineAddEthereumChain(chainId)) {\n this.ui.addEthereumChain({\n onCancel: _cancel,\n onApprove: approve,\n chainId: request.params.chainId,\n rpcUrls: request.params.rpcUrls,\n blockExplorerUrls: request.params.blockExplorerUrls,\n chainName: request.params.chainName,\n iconUrls: request.params.iconUrls,\n nativeCurrency: request.params.nativeCurrency\n });\n }\n if (!this.ui.inlineAddEthereumChain(chainId) && !this.ui.isStandalone()) {\n this.publishWeb3RequestEvent(id, request);\n }\n });\n return {\n promise,\n cancel\n };\n }\n switchEthereumChain(chainId, address) {\n const request = {\n method: Web3Method_1.Web3Method.switchEthereumChain,\n params: Object.assign({\n chainId\n }, {\n address\n })\n };\n const id = (0, util_1.randomBytesHex)(8);\n const cancel = error => {\n this.publishWeb3RequestCanceledEvent(id);\n this.handleErrorResponse(id, request.method, error);\n };\n const promise = new Promise((resolve, reject) => {\n this.relayEventManager.callbacks.set(id, response => {\n if ((0, Web3Response_1.isErrorResponse)(response) && response.errorCode) {\n return reject(errors_1.standardErrors.provider.custom({\n code: response.errorCode,\n message: `Unrecognized chain ID. Try adding the chain using addEthereumChain first.`\n }));\n } else if (response.errorMessage) {\n return reject(new Error(response.errorMessage));\n }\n resolve(response);\n });\n const _cancel = error => {\n var _a;\n if (error) {\n // backward compatibility\n const errorCode = (_a = (0, errors_1.getErrorCode)(error)) !== null && _a !== void 0 ? _a : errors_1.standardErrorCodes.provider.unsupportedChain;\n this.handleErrorResponse(id, Web3Method_1.Web3Method.switchEthereumChain, error instanceof Error ? error : errors_1.standardErrors.provider.unsupportedChain(chainId), errorCode);\n } else {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.SwitchEthereumChainResponse)({\n isApproved: false,\n rpcUrl: \"\"\n })\n }));\n }\n };\n const approve = rpcUrl => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response: (0, Web3Response_1.SwitchEthereumChainResponse)({\n isApproved: true,\n rpcUrl\n })\n }));\n };\n this.ui.switchEthereumChain({\n onCancel: _cancel,\n onApprove: approve,\n chainId: request.params.chainId,\n address: request.params.address\n });\n if (!this.ui.inlineSwitchEthereumChain() && !this.ui.isStandalone()) {\n this.publishWeb3RequestEvent(id, request);\n }\n });\n return {\n promise,\n cancel\n };\n }\n inlineAddEthereumChain(chainId) {\n return this.ui.inlineAddEthereumChain(chainId);\n }\n getSessionIdHash() {\n return Session_1.Session.hash(this._session.id);\n }\n sendRequestStandalone(id, request) {\n const _cancel = error => {\n this.handleErrorResponse(id, request.method, error);\n };\n const onSuccess = response => {\n this.handleWeb3ResponseMessage((0, Web3ResponseMessage_1.Web3ResponseMessage)({\n id,\n response\n }));\n };\n switch (request.method) {\n case Web3Method_1.Web3Method.signEthereumMessage:\n this.ui.signEthereumMessage({\n request,\n onSuccess,\n onCancel: _cancel\n });\n break;\n case Web3Method_1.Web3Method.signEthereumTransaction:\n this.ui.signEthereumTransaction({\n request,\n onSuccess,\n onCancel: _cancel\n });\n break;\n case Web3Method_1.Web3Method.submitEthereumTransaction:\n this.ui.submitEthereumTransaction({\n request,\n onSuccess,\n onCancel: _cancel\n });\n break;\n case Web3Method_1.Web3Method.ethereumAddressFromSignedMessage:\n this.ui.ethereumAddressFromSignedMessage({\n request,\n onSuccess\n });\n break;\n default:\n _cancel();\n break;\n }\n }\n onSessionConfigChanged(_nextSessionConfig) {}\n}\nWalletSDKRelay.accountRequestCallbackIds = new Set();\n__decorate([bind_decorator_1.default], WalletSDKRelay.prototype, \"resetAndReload\", null);\n__decorate([bind_decorator_1.default], WalletSDKRelay.prototype, \"handleIncomingEvent\", null);\nexports.WalletSDKRelay = WalletSDKRelay;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.WalletSDKRelayEventManager = void 0;\nconst util_1 = require(\"../util\");\nclass WalletSDKRelayEventManager {\n constructor() {\n this._nextRequestId = 0;\n this.callbacks = new Map();\n }\n makeRequestId() {\n // max nextId == max int32 for compatibility with mobile\n this._nextRequestId = (this._nextRequestId + 1) % 0x7fffffff;\n const id = this._nextRequestId;\n const idStr = (0, util_1.prepend0x)(id.toString(16));\n // unlikely that this will ever be an issue, but just to be safe\n const callback = this.callbacks.get(idStr);\n if (callback) {\n this.callbacks.delete(idStr);\n }\n return id;\n }\n}\nexports.WalletSDKRelayEventManager = WalletSDKRelayEventManager;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.CoinbaseWalletSDK = void 0;\nconst wallet_logo_1 = require(\"./assets/wallet-logo\");\nconst constants_1 = require(\"./constants\");\nconst ScopedLocalStorage_1 = require(\"./lib/ScopedLocalStorage\");\nconst CoinbaseWalletProvider_1 = require(\"./provider/CoinbaseWalletProvider\");\nconst WalletSDKUI_1 = require(\"./provider/WalletSDKUI\");\nconst WalletSDKRelay_1 = require(\"./relay/WalletSDKRelay\");\nconst WalletSDKRelayEventManager_1 = require(\"./relay/WalletSDKRelayEventManager\");\nconst util_1 = require(\"./util\");\nconst version_1 = require(\"./version\");\nclass CoinbaseWalletSDK {\n /**\n * Constructor\n * @param options Coinbase Wallet SDK constructor options\n */\n constructor(options) {\n var _a, _b, _c;\n this._appName = \"\";\n this._appLogoUrl = null;\n this._relay = null;\n this._relayEventManager = null;\n const linkAPIUrl = options.linkAPIUrl || constants_1.LINK_API_URL;\n let uiConstructor;\n if (!options.uiConstructor) {\n uiConstructor = opts => new WalletSDKUI_1.WalletSDKUI(opts);\n } else {\n uiConstructor = options.uiConstructor;\n }\n if (typeof options.overrideIsMetaMask === \"undefined\") {\n this._overrideIsMetaMask = false;\n } else {\n this._overrideIsMetaMask = options.overrideIsMetaMask;\n }\n this._overrideIsCoinbaseWallet = (_a = options.overrideIsCoinbaseWallet) !== null && _a !== void 0 ? _a : true;\n this._overrideIsCoinbaseBrowser = (_b = options.overrideIsCoinbaseBrowser) !== null && _b !== void 0 ? _b : false;\n if (options.diagnosticLogger && options.eventListener) {\n throw new Error(\"Can't have both eventListener and diagnosticLogger options, use only diagnosticLogger\");\n }\n if (options.eventListener) {\n this._diagnosticLogger = {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n log: options.eventListener.onEvent\n };\n } else {\n this._diagnosticLogger = options.diagnosticLogger;\n }\n this._reloadOnDisconnect = (_c = options.reloadOnDisconnect) !== null && _c !== void 0 ? _c : true;\n const url = new URL(linkAPIUrl);\n const origin = `${url.protocol}//${url.host}`;\n this._storage = new ScopedLocalStorage_1.ScopedLocalStorage(`-walletlink:${origin}`); // needs migration to preserve local states\n this._storage.setItem(\"version\", CoinbaseWalletSDK.VERSION);\n if (this.walletExtension || this.coinbaseBrowser) {\n return;\n }\n this._relayEventManager = new WalletSDKRelayEventManager_1.WalletSDKRelayEventManager();\n this._relay = new WalletSDKRelay_1.WalletSDKRelay({\n linkAPIUrl,\n version: version_1.LIB_VERSION,\n darkMode: !!options.darkMode,\n uiConstructor,\n storage: this._storage,\n relayEventManager: this._relayEventManager,\n diagnosticLogger: this._diagnosticLogger,\n reloadOnDisconnect: this._reloadOnDisconnect\n });\n this.setAppInfo(options.appName, options.appLogoUrl);\n if (!!options.headlessMode) return;\n this._relay.attachUI();\n }\n /**\n * Create a Web3 Provider object\n * @param jsonRpcUrl Ethereum JSON RPC URL (Default: \"\")\n * @param chainId Ethereum Chain ID (Default: 1)\n * @returns A Web3 Provider\n */\n makeWeb3Provider(jsonRpcUrl = \"\", chainId = 1) {\n const extension = this.walletExtension;\n if (extension) {\n if (!this.isCipherProvider(extension)) {\n extension.setProviderInfo(jsonRpcUrl, chainId);\n }\n if (this._reloadOnDisconnect === false && typeof extension.disableReloadOnDisconnect === \"function\") extension.disableReloadOnDisconnect();\n return extension;\n }\n const dappBrowser = this.coinbaseBrowser;\n if (dappBrowser) {\n return dappBrowser;\n }\n const relay = this._relay;\n if (!relay || !this._relayEventManager || !this._storage) {\n throw new Error(\"Relay not initialized, should never happen\");\n }\n if (!jsonRpcUrl) relay.setConnectDisabled(true);\n return new CoinbaseWalletProvider_1.CoinbaseWalletProvider({\n relayProvider: () => Promise.resolve(relay),\n relayEventManager: this._relayEventManager,\n storage: this._storage,\n jsonRpcUrl,\n chainId,\n qrUrl: this.getQrUrl(),\n diagnosticLogger: this._diagnosticLogger,\n overrideIsMetaMask: this._overrideIsMetaMask,\n overrideIsCoinbaseWallet: this._overrideIsCoinbaseWallet,\n overrideIsCoinbaseBrowser: this._overrideIsCoinbaseBrowser\n });\n }\n /**\n * Set application information\n * @param appName Application name\n * @param appLogoUrl Application logo image URL\n */\n setAppInfo(appName, appLogoUrl) {\n var _a;\n this._appName = appName || \"DApp\";\n this._appLogoUrl = appLogoUrl || (0, util_1.getFavicon)();\n const extension = this.walletExtension;\n if (extension) {\n if (!this.isCipherProvider(extension)) {\n extension.setAppInfo(this._appName, this._appLogoUrl);\n }\n } else {\n (_a = this._relay) === null || _a === void 0 ? void 0 : _a.setAppInfo(this._appName, this._appLogoUrl);\n }\n }\n /**\n * Disconnect. After disconnecting, this will reload the web page to ensure\n * all potential stale state is cleared.\n */\n disconnect() {\n var _a;\n const extension = this.walletExtension;\n if (extension) {\n void extension.close();\n } else {\n (_a = this._relay) === null || _a === void 0 ? void 0 : _a.resetAndReload();\n }\n }\n /**\n * Return QR URL for mobile wallet connection, will return null if extension is installed\n */\n getQrUrl() {\n var _a, _b;\n return (_b = (_a = this._relay) === null || _a === void 0 ? void 0 : _a.getQRCodeUrl()) !== null && _b !== void 0 ? _b : null;\n }\n /**\n * Official Coinbase Wallet logo for developers to use on their frontend\n * @param type Type of wallet logo: \"standard\" | \"circle\" | \"text\" | \"textWithLogo\" | \"textLight\" | \"textWithLogoLight\"\n * @param width Width of the logo (Optional)\n * @returns SVG Data URI\n */\n getCoinbaseWalletLogo(type, width = 240) {\n return (0, wallet_logo_1.walletLogo)(type, width);\n }\n get walletExtension() {\n var _a;\n return (_a = window.coinbaseWalletExtension) !== null && _a !== void 0 ? _a : window.walletLinkExtension;\n }\n get coinbaseBrowser() {\n var _a, _b;\n try {\n // Coinbase DApp browser does not inject into iframes so grab provider from top frame if it exists\n const ethereum = (_a = window.ethereum) !== null && _a !== void 0 ? _a : (_b = window.top) === null || _b === void 0 ? void 0 : _b.ethereum;\n if (!ethereum) {\n return undefined;\n }\n if (\"isCoinbaseBrowser\" in ethereum && ethereum.isCoinbaseBrowser) {\n return ethereum;\n } else {\n return undefined;\n }\n } catch (e) {\n return undefined;\n }\n }\n isCipherProvider(provider) {\n // @ts-expect-error isCipher walletlink property\n return typeof provider.isCipher === \"boolean\" && provider.isCipher;\n }\n}\nexports.CoinbaseWalletSDK = CoinbaseWalletSDK;\nCoinbaseWalletSDK.VERSION = version_1.LIB_VERSION;","\"use strict\";\n\n// Copyright (c) 2018-2022 Coinbase, Inc. \n// Licensed under the Apache License, version 2.0\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.CoinbaseWalletProvider = exports.CoinbaseWalletSDK = void 0;\nconst CoinbaseWalletSDK_1 = require(\"./CoinbaseWalletSDK\");\nconst CoinbaseWalletProvider_1 = require(\"./provider/CoinbaseWalletProvider\");\nvar CoinbaseWalletSDK_2 = require(\"./CoinbaseWalletSDK\");\nObject.defineProperty(exports, \"CoinbaseWalletSDK\", {\n enumerable: true,\n get: function () {\n return CoinbaseWalletSDK_2.CoinbaseWalletSDK;\n }\n});\nvar CoinbaseWalletProvider_2 = require(\"./provider/CoinbaseWalletProvider\");\nObject.defineProperty(exports, \"CoinbaseWalletProvider\", {\n enumerable: true,\n get: function () {\n return CoinbaseWalletProvider_2.CoinbaseWalletProvider;\n }\n});\nexports.default = CoinbaseWalletSDK_1.CoinbaseWalletSDK;\nif (typeof window !== \"undefined\") {\n window.CoinbaseWalletSDK = CoinbaseWalletSDK_1.CoinbaseWalletSDK;\n window.CoinbaseWalletProvider = CoinbaseWalletProvider_1.CoinbaseWalletProvider;\n /**\n * @deprecated Use `window.CoinbaseWalletSDK`\n */\n window.WalletLink = CoinbaseWalletSDK_1.CoinbaseWalletSDK;\n /**\n * @deprecated Use `window.CoinbaseWalletProvider`\n */\n window.WalletLinkProvider = CoinbaseWalletProvider_1.CoinbaseWalletProvider;\n}","export function createErrorClass(createImpl) {\n const _super = instance => {\n Error.call(instance);\n instance.stack = new Error().stack;\n };\n const ctorFunc = createImpl(_super);\n ctorFunc.prototype = Object.create(Error.prototype);\n ctorFunc.prototype.constructor = ctorFunc;\n return ctorFunc;\n}\n","import { createErrorClass } from './createErrorClass';\nexport const EmptyError = createErrorClass(_super => function EmptyErrorImpl() {\n _super(this);\n this.name = 'EmptyError';\n this.message = 'no elements in sequence';\n});\n","export function isFunction(value) {\n return typeof value === 'function';\n}\n","import { createErrorClass } from './createErrorClass';\nexport const UnsubscriptionError = createErrorClass(_super => function UnsubscriptionErrorImpl(errors) {\n _super(this);\n this.message = errors ? `${errors.length} errors occurred during unsubscription:\n${errors.map((err, i) => `${i + 1}) ${err.toString()}`).join('\\n ')}` : '';\n this.name = 'UnsubscriptionError';\n this.errors = errors;\n});\n","export function arrRemove(arr, item) {\n if (arr) {\n const index = arr.indexOf(item);\n 0 <= index && arr.splice(index, 1);\n }\n}\n","import { isFunction } from './util/isFunction';\nimport { UnsubscriptionError } from './util/UnsubscriptionError';\nimport { arrRemove } from './util/arrRemove';\nexport class Subscription {\n constructor(initialTeardown) {\n this.initialTeardown = initialTeardown;\n this.closed = false;\n this._parentage = null;\n this._finalizers = null;\n }\n unsubscribe() {\n let errors;\n if (!this.closed) {\n this.closed = true;\n const {\n _parentage\n } = this;\n if (_parentage) {\n this._parentage = null;\n if (Array.isArray(_parentage)) {\n for (const parent of _parentage) {\n parent.remove(this);\n }\n } else {\n _parentage.remove(this);\n }\n }\n const {\n initialTeardown: initialFinalizer\n } = this;\n if (isFunction(initialFinalizer)) {\n try {\n initialFinalizer();\n } catch (e) {\n errors = e instanceof UnsubscriptionError ? e.errors : [e];\n }\n }\n const {\n _finalizers\n } = this;\n if (_finalizers) {\n this._finalizers = null;\n for (const finalizer of _finalizers) {\n try {\n execFinalizer(finalizer);\n } catch (err) {\n errors = errors !== null && errors !== void 0 ? errors : [];\n if (err instanceof UnsubscriptionError) {\n errors = [...errors, ...err.errors];\n } else {\n errors.push(err);\n }\n }\n }\n }\n if (errors) {\n throw new UnsubscriptionError(errors);\n }\n }\n }\n add(teardown) {\n var _a;\n if (teardown && teardown !== this) {\n if (this.closed) {\n execFinalizer(teardown);\n } else {\n if (teardown instanceof Subscription) {\n if (teardown.closed || teardown._hasParent(this)) {\n return;\n }\n teardown._addParent(this);\n }\n (this._finalizers = (_a = this._finalizers) !== null && _a !== void 0 ? _a : []).push(teardown);\n }\n }\n }\n _hasParent(parent) {\n const {\n _parentage\n } = this;\n return _parentage === parent || Array.isArray(_parentage) && _parentage.includes(parent);\n }\n _addParent(parent) {\n const {\n _parentage\n } = this;\n this._parentage = Array.isArray(_parentage) ? (_parentage.push(parent), _parentage) : _parentage ? [_parentage, parent] : parent;\n }\n _removeParent(parent) {\n const {\n _parentage\n } = this;\n if (_parentage === parent) {\n this._parentage = null;\n } else if (Array.isArray(_parentage)) {\n arrRemove(_parentage, parent);\n }\n }\n remove(teardown) {\n const {\n _finalizers\n } = this;\n _finalizers && arrRemove(_finalizers, teardown);\n if (teardown instanceof Subscription) {\n teardown._removeParent(this);\n }\n }\n}\nSubscription.EMPTY = (() => {\n const empty = new Subscription();\n empty.closed = true;\n return empty;\n})();\nexport const EMPTY_SUBSCRIPTION = Subscription.EMPTY;\nexport function isSubscription(value) {\n return value instanceof Subscription || value && 'closed' in value && isFunction(value.remove) && isFunction(value.add) && isFunction(value.unsubscribe);\n}\nfunction execFinalizer(finalizer) {\n if (isFunction(finalizer)) {\n finalizer();\n } else {\n finalizer.unsubscribe();\n }\n}\n","export const config = {\n onUnhandledError: null,\n onStoppedNotification: null,\n Promise: undefined,\n useDeprecatedSynchronousErrorHandling: false,\n useDeprecatedNextContext: false\n};\n","export const timeoutProvider = {\n setTimeout(handler, timeout, ...args) {\n const {\n delegate\n } = timeoutProvider;\n if (delegate === null || delegate === void 0 ? void 0 : delegate.setTimeout) {\n return delegate.setTimeout(handler, timeout, ...args);\n }\n return setTimeout(handler, timeout, ...args);\n },\n clearTimeout(handle) {\n const {\n delegate\n } = timeoutProvider;\n return ((delegate === null || delegate === void 0 ? void 0 : delegate.clearTimeout) || clearTimeout)(handle);\n },\n delegate: undefined\n};\n","import { config } from '../config';\nimport { timeoutProvider } from '../scheduler/timeoutProvider';\nexport function reportUnhandledError(err) {\n timeoutProvider.setTimeout(() => {\n const {\n onUnhandledError\n } = config;\n if (onUnhandledError) {\n onUnhandledError(err);\n } else {\n throw err;\n }\n });\n}\n","export function noop() {}\n","export const COMPLETE_NOTIFICATION = (() => createNotification('C', undefined, undefined))();\nexport function errorNotification(error) {\n return createNotification('E', undefined, error);\n}\nexport function nextNotification(value) {\n return createNotification('N', value, undefined);\n}\nexport function createNotification(kind, value, error) {\n return {\n kind,\n value,\n error\n };\n}\n","import { config } from '../config';\nlet context = null;\nexport function errorContext(cb) {\n if (config.useDeprecatedSynchronousErrorHandling) {\n const isRoot = !context;\n if (isRoot) {\n context = {\n errorThrown: false,\n error: null\n };\n }\n cb();\n if (isRoot) {\n const {\n errorThrown,\n error\n } = context;\n context = null;\n if (errorThrown) {\n throw error;\n }\n }\n } else {\n cb();\n }\n}\nexport function captureError(err) {\n if (config.useDeprecatedSynchronousErrorHandling && context) {\n context.errorThrown = true;\n context.error = err;\n }\n}\n","import { isFunction } from './util/isFunction';\nimport { isSubscription, Subscription } from './Subscription';\nimport { config } from './config';\nimport { reportUnhandledError } from './util/reportUnhandledError';\nimport { noop } from './util/noop';\nimport { nextNotification, errorNotification, COMPLETE_NOTIFICATION } from './NotificationFactories';\nimport { timeoutProvider } from './scheduler/timeoutProvider';\nimport { captureError } from './util/errorContext';\nexport class Subscriber extends Subscription {\n constructor(destination) {\n super();\n this.isStopped = false;\n if (destination) {\n this.destination = destination;\n if (isSubscription(destination)) {\n destination.add(this);\n }\n } else {\n this.destination = EMPTY_OBSERVER;\n }\n }\n static create(next, error, complete) {\n return new SafeSubscriber(next, error, complete);\n }\n next(value) {\n if (this.isStopped) {\n handleStoppedNotification(nextNotification(value), this);\n } else {\n this._next(value);\n }\n }\n error(err) {\n if (this.isStopped) {\n handleStoppedNotification(errorNotification(err), this);\n } else {\n this.isStopped = true;\n this._error(err);\n }\n }\n complete() {\n if (this.isStopped) {\n handleStoppedNotification(COMPLETE_NOTIFICATION, this);\n } else {\n this.isStopped = true;\n this._complete();\n }\n }\n unsubscribe() {\n if (!this.closed) {\n this.isStopped = true;\n super.unsubscribe();\n this.destination = null;\n }\n }\n _next(value) {\n this.destination.next(value);\n }\n _error(err) {\n try {\n this.destination.error(err);\n } finally {\n this.unsubscribe();\n }\n }\n _complete() {\n try {\n this.destination.complete();\n } finally {\n this.unsubscribe();\n }\n }\n}\nconst _bind = Function.prototype.bind;\nfunction bind(fn, thisArg) {\n return _bind.call(fn, thisArg);\n}\nclass ConsumerObserver {\n constructor(partialObserver) {\n this.partialObserver = partialObserver;\n }\n next(value) {\n const {\n partialObserver\n } = this;\n if (partialObserver.next) {\n try {\n partialObserver.next(value);\n } catch (error) {\n handleUnhandledError(error);\n }\n }\n }\n error(err) {\n const {\n partialObserver\n } = this;\n if (partialObserver.error) {\n try {\n partialObserver.error(err);\n } catch (error) {\n handleUnhandledError(error);\n }\n } else {\n handleUnhandledError(err);\n }\n }\n complete() {\n const {\n partialObserver\n } = this;\n if (partialObserver.complete) {\n try {\n partialObserver.complete();\n } catch (error) {\n handleUnhandledError(error);\n }\n }\n }\n}\nexport class SafeSubscriber extends Subscriber {\n constructor(observerOrNext, error, complete) {\n super();\n let partialObserver;\n if (isFunction(observerOrNext) || !observerOrNext) {\n partialObserver = {\n next: observerOrNext !== null && observerOrNext !== void 0 ? observerOrNext : undefined,\n error: error !== null && error !== void 0 ? error : undefined,\n complete: complete !== null && complete !== void 0 ? complete : undefined\n };\n } else {\n let context;\n if (this && config.useDeprecatedNextContext) {\n context = Object.create(observerOrNext);\n context.unsubscribe = () => this.unsubscribe();\n partialObserver = {\n next: observerOrNext.next && bind(observerOrNext.next, context),\n error: observerOrNext.error && bind(observerOrNext.error, context),\n complete: observerOrNext.complete && bind(observerOrNext.complete, context)\n };\n } else {\n partialObserver = observerOrNext;\n }\n }\n this.destination = new ConsumerObserver(partialObserver);\n }\n}\nfunction handleUnhandledError(error) {\n if (config.useDeprecatedSynchronousErrorHandling) {\n captureError(error);\n } else {\n reportUnhandledError(error);\n }\n}\nfunction defaultErrorHandler(err) {\n throw err;\n}\nfunction handleStoppedNotification(notification, subscriber) {\n const {\n onStoppedNotification\n } = config;\n onStoppedNotification && timeoutProvider.setTimeout(() => onStoppedNotification(notification, subscriber));\n}\nexport const EMPTY_OBSERVER = {\n closed: true,\n next: noop,\n error: defaultErrorHandler,\n complete: noop\n};\n","import { EmptyError } from './util/EmptyError';\nimport { SafeSubscriber } from './Subscriber';\nexport function firstValueFrom(source, config) {\n const hasConfig = typeof config === 'object';\n return new Promise((resolve, reject) => {\n const subscriber = new SafeSubscriber({\n next: value => {\n resolve(value);\n subscriber.unsubscribe();\n },\n error: reject,\n complete: () => {\n if (hasConfig) {\n resolve(config.defaultValue);\n } else {\n reject(new EmptyError());\n }\n }\n });\n source.subscribe(subscriber);\n });\n}\n","export const observable = (() => typeof Symbol === 'function' && Symbol.observable || '@@observable')();\n","export function identity(x) {\n return x;\n}\n","import { identity } from './identity';\nexport function pipe(...fns) {\n return pipeFromArray(fns);\n}\nexport function pipeFromArray(fns) {\n if (fns.length === 0) {\n return identity;\n }\n if (fns.length === 1) {\n return fns[0];\n }\n return function piped(input) {\n return fns.reduce((prev, fn) => fn(prev), input);\n };\n}\n","import { SafeSubscriber, Subscriber } from './Subscriber';\nimport { isSubscription } from './Subscription';\nimport { observable as Symbol_observable } from './symbol/observable';\nimport { pipeFromArray } from './util/pipe';\nimport { config } from './config';\nimport { isFunction } from './util/isFunction';\nimport { errorContext } from './util/errorContext';\nexport let Observable = /*#__PURE__*/(() => {\n class Observable {\n constructor(subscribe) {\n if (subscribe) {\n this._subscribe = subscribe;\n }\n }\n lift(operator) {\n const observable = new Observable();\n observable.source = this;\n observable.operator = operator;\n return observable;\n }\n subscribe(observerOrNext, error, complete) {\n const subscriber = isSubscriber(observerOrNext) ? observerOrNext : new SafeSubscriber(observerOrNext, error, complete);\n errorContext(() => {\n const {\n operator,\n source\n } = this;\n subscriber.add(operator ? operator.call(subscriber, source) : source ? this._subscribe(subscriber) : this._trySubscribe(subscriber));\n });\n return subscriber;\n }\n _trySubscribe(sink) {\n try {\n return this._subscribe(sink);\n } catch (err) {\n sink.error(err);\n }\n }\n forEach(next, promiseCtor) {\n promiseCtor = getPromiseCtor(promiseCtor);\n return new promiseCtor((resolve, reject) => {\n const subscriber = new SafeSubscriber({\n next: value => {\n try {\n next(value);\n } catch (err) {\n reject(err);\n subscriber.unsubscribe();\n }\n },\n error: reject,\n complete: resolve\n });\n this.subscribe(subscriber);\n });\n }\n _subscribe(subscriber) {\n var _a;\n return (_a = this.source) === null || _a === void 0 ? void 0 : _a.subscribe(subscriber);\n }\n [Symbol_observable]() {\n return this;\n }\n pipe(...operations) {\n return pipeFromArray(operations)(this);\n }\n toPromise(promiseCtor) {\n promiseCtor = getPromiseCtor(promiseCtor);\n return new promiseCtor((resolve, reject) => {\n let value;\n this.subscribe(x => value = x, err => reject(err), () => resolve(value));\n });\n }\n }\n Observable.create = subscribe => {\n return new Observable(subscribe);\n };\n return Observable;\n})();\nfunction getPromiseCtor(promiseCtor) {\n var _a;\n return (_a = promiseCtor !== null && promiseCtor !== void 0 ? promiseCtor : config.Promise) !== null && _a !== void 0 ? _a : Promise;\n}\nfunction isObserver(value) {\n return value && isFunction(value.next) && isFunction(value.error) && isFunction(value.complete);\n}\nfunction isSubscriber(value) {\n return value && value instanceof Subscriber || isObserver(value) && isSubscription(value);\n}\n","import { isFunction } from './isFunction';\nexport function hasLift(source) {\n return isFunction(source === null || source === void 0 ? void 0 : source.lift);\n}\nexport function operate(init) {\n return source => {\n if (hasLift(source)) {\n return source.lift(function (liftedSource) {\n try {\n return init(liftedSource, this);\n } catch (err) {\n this.error(err);\n }\n });\n }\n throw new TypeError('Unable to lift unknown Observable type');\n };\n}\n","import { Subscriber } from '../Subscriber';\nexport function createOperatorSubscriber(destination, onNext, onComplete, onError, onFinalize) {\n return new OperatorSubscriber(destination, onNext, onComplete, onError, onFinalize);\n}\nexport class OperatorSubscriber extends Subscriber {\n constructor(destination, onNext, onComplete, onError, onFinalize, shouldUnsubscribe) {\n super(destination);\n this.onFinalize = onFinalize;\n this.shouldUnsubscribe = shouldUnsubscribe;\n this._next = onNext ? function (value) {\n try {\n onNext(value);\n } catch (err) {\n destination.error(err);\n }\n } : super._next;\n this._error = onError ? function (err) {\n try {\n onError(err);\n } catch (err) {\n destination.error(err);\n } finally {\n this.unsubscribe();\n }\n } : super._error;\n this._complete = onComplete ? function () {\n try {\n onComplete();\n } catch (err) {\n destination.error(err);\n } finally {\n this.unsubscribe();\n }\n } : super._complete;\n }\n unsubscribe() {\n var _a;\n if (!this.shouldUnsubscribe || this.shouldUnsubscribe()) {\n const {\n closed\n } = this;\n super.unsubscribe();\n !closed && ((_a = this.onFinalize) === null || _a === void 0 ? void 0 : _a.call(this));\n }\n }\n}\n","import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function refCount() {\n return operate((source, subscriber) => {\n let connection = null;\n source._refCount++;\n const refCounter = createOperatorSubscriber(subscriber, undefined, undefined, undefined, () => {\n if (!source || source._refCount <= 0 || 0 < --source._refCount) {\n connection = null;\n return;\n }\n const sharedConnection = source._connection;\n const conn = connection;\n connection = null;\n if (sharedConnection && (!conn || sharedConnection === conn)) {\n sharedConnection.unsubscribe();\n }\n subscriber.unsubscribe();\n });\n source.subscribe(refCounter);\n if (!refCounter.closed) {\n connection = source.connect();\n }\n });\n}\n","import { Observable } from '../Observable';\nimport { Subscription } from '../Subscription';\nimport { refCount as higherOrderRefCount } from '../operators/refCount';\nimport { createOperatorSubscriber } from '../operators/OperatorSubscriber';\nimport { hasLift } from '../util/lift';\nexport class ConnectableObservable extends Observable {\n constructor(source, subjectFactory) {\n super();\n this.source = source;\n this.subjectFactory = subjectFactory;\n this._subject = null;\n this._refCount = 0;\n this._connection = null;\n if (hasLift(source)) {\n this.lift = source.lift;\n }\n }\n _subscribe(subscriber) {\n return this.getSubject().subscribe(subscriber);\n }\n getSubject() {\n const subject = this._subject;\n if (!subject || subject.isStopped) {\n this._subject = this.subjectFactory();\n }\n return this._subject;\n }\n _teardown() {\n this._refCount = 0;\n const {\n _connection\n } = this;\n this._subject = this._connection = null;\n _connection === null || _connection === void 0 ? void 0 : _connection.unsubscribe();\n }\n connect() {\n let connection = this._connection;\n if (!connection) {\n connection = this._connection = new Subscription();\n const subject = this.getSubject();\n connection.add(this.source.subscribe(createOperatorSubscriber(subject, undefined, () => {\n this._teardown();\n subject.complete();\n }, err => {\n this._teardown();\n subject.error(err);\n }, () => this._teardown())));\n if (connection.closed) {\n this._connection = null;\n connection = Subscription.EMPTY;\n }\n }\n return connection;\n }\n refCount() {\n return higherOrderRefCount()(this);\n }\n}\n","import { Subscription } from '../Subscription';\nexport const animationFrameProvider = {\n schedule(callback) {\n let request = requestAnimationFrame;\n let cancel = cancelAnimationFrame;\n const {\n delegate\n } = animationFrameProvider;\n if (delegate) {\n request = delegate.requestAnimationFrame;\n cancel = delegate.cancelAnimationFrame;\n }\n const handle = request(timestamp => {\n cancel = undefined;\n callback(timestamp);\n });\n return new Subscription(() => cancel === null || cancel === void 0 ? void 0 : cancel(handle));\n },\n requestAnimationFrame(...args) {\n const {\n delegate\n } = animationFrameProvider;\n return ((delegate === null || delegate === void 0 ? void 0 : delegate.requestAnimationFrame) || requestAnimationFrame)(...args);\n },\n cancelAnimationFrame(...args) {\n const {\n delegate\n } = animationFrameProvider;\n return ((delegate === null || delegate === void 0 ? void 0 : delegate.cancelAnimationFrame) || cancelAnimationFrame)(...args);\n },\n delegate: undefined\n};\n","import { createErrorClass } from './createErrorClass';\nexport const ObjectUnsubscribedError = createErrorClass(_super => function ObjectUnsubscribedErrorImpl() {\n _super(this);\n this.name = 'ObjectUnsubscribedError';\n this.message = 'object unsubscribed';\n});\n","import { Observable } from './Observable';\nimport { Subscription, EMPTY_SUBSCRIPTION } from './Subscription';\nimport { ObjectUnsubscribedError } from './util/ObjectUnsubscribedError';\nimport { arrRemove } from './util/arrRemove';\nimport { errorContext } from './util/errorContext';\nexport let Subject = /*#__PURE__*/(() => {\n class Subject extends Observable {\n constructor() {\n super();\n this.closed = false;\n this.currentObservers = null;\n this.observers = [];\n this.isStopped = false;\n this.hasError = false;\n this.thrownError = null;\n }\n lift(operator) {\n const subject = new AnonymousSubject(this, this);\n subject.operator = operator;\n return subject;\n }\n _throwIfClosed() {\n if (this.closed) {\n throw new ObjectUnsubscribedError();\n }\n }\n next(value) {\n errorContext(() => {\n this._throwIfClosed();\n if (!this.isStopped) {\n if (!this.currentObservers) {\n this.currentObservers = Array.from(this.observers);\n }\n for (const observer of this.currentObservers) {\n observer.next(value);\n }\n }\n });\n }\n error(err) {\n errorContext(() => {\n this._throwIfClosed();\n if (!this.isStopped) {\n this.hasError = this.isStopped = true;\n this.thrownError = err;\n const {\n observers\n } = this;\n while (observers.length) {\n observers.shift().error(err);\n }\n }\n });\n }\n complete() {\n errorContext(() => {\n this._throwIfClosed();\n if (!this.isStopped) {\n this.isStopped = true;\n const {\n observers\n } = this;\n while (observers.length) {\n observers.shift().complete();\n }\n }\n });\n }\n unsubscribe() {\n this.isStopped = this.closed = true;\n this.observers = this.currentObservers = null;\n }\n get observed() {\n var _a;\n return ((_a = this.observers) === null || _a === void 0 ? void 0 : _a.length) > 0;\n }\n _trySubscribe(subscriber) {\n this._throwIfClosed();\n return super._trySubscribe(subscriber);\n }\n _subscribe(subscriber) {\n this._throwIfClosed();\n this._checkFinalizedStatuses(subscriber);\n return this._innerSubscribe(subscriber);\n }\n _innerSubscribe(subscriber) {\n const {\n hasError,\n isStopped,\n observers\n } = this;\n if (hasError || isStopped) {\n return EMPTY_SUBSCRIPTION;\n }\n this.currentObservers = null;\n observers.push(subscriber);\n return new Subscription(() => {\n this.currentObservers = null;\n arrRemove(observers, subscriber);\n });\n }\n _checkFinalizedStatuses(subscriber) {\n const {\n hasError,\n thrownError,\n isStopped\n } = this;\n if (hasError) {\n subscriber.error(thrownError);\n } else if (isStopped) {\n subscriber.complete();\n }\n }\n asObservable() {\n const observable = new Observable();\n observable.source = this;\n return observable;\n }\n }\n Subject.create = (destination, source) => {\n return new AnonymousSubject(destination, source);\n };\n return Subject;\n})();\nexport class AnonymousSubject extends Subject {\n constructor(destination, source) {\n super();\n this.destination = destination;\n this.source = source;\n }\n next(value) {\n var _a, _b;\n (_b = (_a = this.destination) === null || _a === void 0 ? void 0 : _a.next) === null || _b === void 0 ? void 0 : _b.call(_a, value);\n }\n error(err) {\n var _a, _b;\n (_b = (_a = this.destination) === null || _a === void 0 ? void 0 : _a.error) === null || _b === void 0 ? void 0 : _b.call(_a, err);\n }\n complete() {\n var _a, _b;\n (_b = (_a = this.destination) === null || _a === void 0 ? void 0 : _a.complete) === null || _b === void 0 ? void 0 : _b.call(_a);\n }\n _subscribe(subscriber) {\n var _a, _b;\n return (_b = (_a = this.source) === null || _a === void 0 ? void 0 : _a.subscribe(subscriber)) !== null && _b !== void 0 ? _b : EMPTY_SUBSCRIPTION;\n }\n}\n","import { Subject } from './Subject';\nexport class BehaviorSubject extends Subject {\n constructor(_value) {\n super();\n this._value = _value;\n }\n get value() {\n return this.getValue();\n }\n _subscribe(subscriber) {\n const subscription = super._subscribe(subscriber);\n !subscription.closed && subscriber.next(this._value);\n return subscription;\n }\n getValue() {\n const {\n hasError,\n thrownError,\n _value\n } = this;\n if (hasError) {\n throw thrownError;\n }\n this._throwIfClosed();\n return _value;\n }\n next(value) {\n super.next(this._value = value);\n }\n}\n","export const dateTimestampProvider = {\n now() {\n return (dateTimestampProvider.delegate || Date).now();\n },\n delegate: undefined\n};\n","import { Subject } from './Subject';\nimport { dateTimestampProvider } from './scheduler/dateTimestampProvider';\nexport class ReplaySubject extends Subject {\n constructor(_bufferSize = Infinity, _windowTime = Infinity, _timestampProvider = dateTimestampProvider) {\n super();\n this._bufferSize = _bufferSize;\n this._windowTime = _windowTime;\n this._timestampProvider = _timestampProvider;\n this._buffer = [];\n this._infiniteTimeWindow = true;\n this._infiniteTimeWindow = _windowTime === Infinity;\n this._bufferSize = Math.max(1, _bufferSize);\n this._windowTime = Math.max(1, _windowTime);\n }\n next(value) {\n const {\n isStopped,\n _buffer,\n _infiniteTimeWindow,\n _timestampProvider,\n _windowTime\n } = this;\n if (!isStopped) {\n _buffer.push(value);\n !_infiniteTimeWindow && _buffer.push(_timestampProvider.now() + _windowTime);\n }\n this._trimBuffer();\n super.next(value);\n }\n _subscribe(subscriber) {\n this._throwIfClosed();\n this._trimBuffer();\n const subscription = this._innerSubscribe(subscriber);\n const {\n _infiniteTimeWindow,\n _buffer\n } = this;\n const copy = _buffer.slice();\n for (let i = 0; i < copy.length && !subscriber.closed; i += _infiniteTimeWindow ? 1 : 2) {\n subscriber.next(copy[i]);\n }\n this._checkFinalizedStatuses(subscriber);\n return subscription;\n }\n _trimBuffer() {\n const {\n _bufferSize,\n _timestampProvider,\n _buffer,\n _infiniteTimeWindow\n } = this;\n const adjustedBufferSize = (_infiniteTimeWindow ? 1 : 2) * _bufferSize;\n _bufferSize < Infinity && adjustedBufferSize < _buffer.length && _buffer.splice(0, _buffer.length - adjustedBufferSize);\n if (!_infiniteTimeWindow) {\n const now = _timestampProvider.now();\n let last = 0;\n for (let i = 1; i < _buffer.length && _buffer[i] <= now; i += 2) {\n last = i;\n }\n last && _buffer.splice(0, last + 1);\n }\n }\n}\n","import { Subscription } from '../Subscription';\nexport class Action extends Subscription {\n constructor(scheduler, work) {\n super();\n }\n schedule(state, delay = 0) {\n return this;\n }\n}\n","export const intervalProvider = {\n setInterval(handler, timeout, ...args) {\n const {\n delegate\n } = intervalProvider;\n if (delegate === null || delegate === void 0 ? void 0 : delegate.setInterval) {\n return delegate.setInterval(handler, timeout, ...args);\n }\n return setInterval(handler, timeout, ...args);\n },\n clearInterval(handle) {\n const {\n delegate\n } = intervalProvider;\n return ((delegate === null || delegate === void 0 ? void 0 : delegate.clearInterval) || clearInterval)(handle);\n },\n delegate: undefined\n};\n","import { Action } from './Action';\nimport { intervalProvider } from './intervalProvider';\nimport { arrRemove } from '../util/arrRemove';\nexport class AsyncAction extends Action {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n this.pending = false;\n }\n schedule(state, delay = 0) {\n var _a;\n if (this.closed) {\n return this;\n }\n this.state = state;\n const id = this.id;\n const scheduler = this.scheduler;\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, delay);\n }\n this.pending = true;\n this.delay = delay;\n this.id = (_a = this.id) !== null && _a !== void 0 ? _a : this.requestAsyncId(scheduler, this.id, delay);\n return this;\n }\n requestAsyncId(scheduler, _id, delay = 0) {\n return intervalProvider.setInterval(scheduler.flush.bind(scheduler, this), delay);\n }\n recycleAsyncId(_scheduler, id, delay = 0) {\n if (delay != null && this.delay === delay && this.pending === false) {\n return id;\n }\n if (id != null) {\n intervalProvider.clearInterval(id);\n }\n return undefined;\n }\n execute(state, delay) {\n if (this.closed) {\n return new Error('executing a cancelled action');\n }\n this.pending = false;\n const error = this._execute(state, delay);\n if (error) {\n return error;\n } else if (this.pending === false && this.id != null) {\n this.id = this.recycleAsyncId(this.scheduler, this.id, null);\n }\n }\n _execute(state, _delay) {\n let errored = false;\n let errorValue;\n try {\n this.work(state);\n } catch (e) {\n errored = true;\n errorValue = e ? e : new Error('Scheduled action threw falsy error');\n }\n if (errored) {\n this.unsubscribe();\n return errorValue;\n }\n }\n unsubscribe() {\n if (!this.closed) {\n const {\n id,\n scheduler\n } = this;\n const {\n actions\n } = scheduler;\n this.work = this.state = this.scheduler = null;\n this.pending = false;\n arrRemove(actions, this);\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, null);\n }\n this.delay = null;\n super.unsubscribe();\n }\n }\n}\n","let nextHandle = 1;\nlet resolved;\nconst activeHandles = {};\nfunction findAndClearHandle(handle) {\n if (handle in activeHandles) {\n delete activeHandles[handle];\n return true;\n }\n return false;\n}\nexport const Immediate = {\n setImmediate(cb) {\n const handle = nextHandle++;\n activeHandles[handle] = true;\n if (!resolved) {\n resolved = Promise.resolve();\n }\n resolved.then(() => findAndClearHandle(handle) && cb());\n return handle;\n },\n clearImmediate(handle) {\n findAndClearHandle(handle);\n }\n};\nexport const TestTools = {\n pending() {\n return Object.keys(activeHandles).length;\n }\n};\n","import { Immediate } from '../util/Immediate';\nconst {\n setImmediate,\n clearImmediate\n} = Immediate;\nexport const immediateProvider = {\n setImmediate(...args) {\n const {\n delegate\n } = immediateProvider;\n return ((delegate === null || delegate === void 0 ? void 0 : delegate.setImmediate) || setImmediate)(...args);\n },\n clearImmediate(handle) {\n const {\n delegate\n } = immediateProvider;\n return ((delegate === null || delegate === void 0 ? void 0 : delegate.clearImmediate) || clearImmediate)(handle);\n },\n delegate: undefined\n};\n","import { AsyncAction } from './AsyncAction';\nimport { immediateProvider } from './immediateProvider';\nexport class AsapAction extends AsyncAction {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n }\n requestAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && delay > 0) {\n return super.requestAsyncId(scheduler, id, delay);\n }\n scheduler.actions.push(this);\n return scheduler._scheduled || (scheduler._scheduled = immediateProvider.setImmediate(scheduler.flush.bind(scheduler, undefined)));\n }\n recycleAsyncId(scheduler, id, delay = 0) {\n var _a;\n if (delay != null ? delay > 0 : this.delay > 0) {\n return super.recycleAsyncId(scheduler, id, delay);\n }\n const {\n actions\n } = scheduler;\n if (id != null && ((_a = actions[actions.length - 1]) === null || _a === void 0 ? void 0 : _a.id) !== id) {\n immediateProvider.clearImmediate(id);\n if (scheduler._scheduled === id) {\n scheduler._scheduled = undefined;\n }\n }\n return undefined;\n }\n}\n","import { dateTimestampProvider } from './scheduler/dateTimestampProvider';\nexport class Scheduler {\n constructor(schedulerActionCtor, now = Scheduler.now) {\n this.schedulerActionCtor = schedulerActionCtor;\n this.now = now;\n }\n schedule(work, delay = 0, state) {\n return new this.schedulerActionCtor(this, work).schedule(state, delay);\n }\n}\nScheduler.now = dateTimestampProvider.now;\n","import { Scheduler } from '../Scheduler';\nexport class AsyncScheduler extends Scheduler {\n constructor(SchedulerAction, now = Scheduler.now) {\n super(SchedulerAction, now);\n this.actions = [];\n this._active = false;\n }\n flush(action) {\n const {\n actions\n } = this;\n if (this._active) {\n actions.push(action);\n return;\n }\n let error;\n this._active = true;\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while (action = actions.shift());\n this._active = false;\n if (error) {\n while (action = actions.shift()) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n","import { AsyncScheduler } from './AsyncScheduler';\nexport class AsapScheduler extends AsyncScheduler {\n flush(action) {\n this._active = true;\n const flushId = this._scheduled;\n this._scheduled = undefined;\n const {\n actions\n } = this;\n let error;\n action = action || actions.shift();\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while ((action = actions[0]) && action.id === flushId && actions.shift());\n this._active = false;\n if (error) {\n while ((action = actions[0]) && action.id === flushId && actions.shift()) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n","import { AsapAction } from './AsapAction';\nimport { AsapScheduler } from './AsapScheduler';\nexport const asapScheduler = new AsapScheduler(AsapAction);\nexport const asap = asapScheduler;\n","import { AsyncAction } from './AsyncAction';\nimport { AsyncScheduler } from './AsyncScheduler';\nexport const asyncScheduler = new AsyncScheduler(AsyncAction);\nexport const async = asyncScheduler;\n","import { AsyncAction } from './AsyncAction';\nimport { animationFrameProvider } from './animationFrameProvider';\nexport class AnimationFrameAction extends AsyncAction {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n }\n requestAsyncId(scheduler, id, delay = 0) {\n if (delay !== null && delay > 0) {\n return super.requestAsyncId(scheduler, id, delay);\n }\n scheduler.actions.push(this);\n return scheduler._scheduled || (scheduler._scheduled = animationFrameProvider.requestAnimationFrame(() => scheduler.flush(undefined)));\n }\n recycleAsyncId(scheduler, id, delay = 0) {\n var _a;\n if (delay != null ? delay > 0 : this.delay > 0) {\n return super.recycleAsyncId(scheduler, id, delay);\n }\n const {\n actions\n } = scheduler;\n if (id != null && ((_a = actions[actions.length - 1]) === null || _a === void 0 ? void 0 : _a.id) !== id) {\n animationFrameProvider.cancelAnimationFrame(id);\n scheduler._scheduled = undefined;\n }\n return undefined;\n }\n}\n","import { AsyncScheduler } from './AsyncScheduler';\nexport class AnimationFrameScheduler extends AsyncScheduler {\n flush(action) {\n this._active = true;\n const flushId = this._scheduled;\n this._scheduled = undefined;\n const {\n actions\n } = this;\n let error;\n action = action || actions.shift();\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while ((action = actions[0]) && action.id === flushId && actions.shift());\n this._active = false;\n if (error) {\n while ((action = actions[0]) && action.id === flushId && actions.shift()) {\n action.unsubscribe();\n }\n throw error;\n }\n }\n}\n","import { AnimationFrameAction } from './AnimationFrameAction';\nimport { AnimationFrameScheduler } from './AnimationFrameScheduler';\nexport const animationFrameScheduler = new AnimationFrameScheduler(AnimationFrameAction);\nexport const animationFrame = animationFrameScheduler;\n","import { Observable } from '../Observable';\nexport const EMPTY = new Observable(subscriber => subscriber.complete());\nexport function empty(scheduler) {\n return scheduler ? emptyScheduled(scheduler) : EMPTY;\n}\nfunction emptyScheduled(scheduler) {\n return new Observable(subscriber => scheduler.schedule(() => subscriber.complete()));\n}\n","import { isFunction } from './isFunction';\nexport function isScheduler(value) {\n return value && isFunction(value.schedule);\n}\n","import { isFunction } from './isFunction';\nimport { isScheduler } from './isScheduler';\nfunction last(arr) {\n return arr[arr.length - 1];\n}\nexport function popResultSelector(args) {\n return isFunction(last(args)) ? args.pop() : undefined;\n}\nexport function popScheduler(args) {\n return isScheduler(last(args)) ? args.pop() : undefined;\n}\nexport function popNumber(args, defaultValue) {\n return typeof last(args) === 'number' ? args.pop() : defaultValue;\n}\n","import { __asyncValues, __awaiter } from \"tslib\";\nimport { isArrayLike } from '../util/isArrayLike';\nimport { isPromise } from '../util/isPromise';\nimport { Observable } from '../Observable';\nimport { isInteropObservable } from '../util/isInteropObservable';\nimport { isAsyncIterable } from '../util/isAsyncIterable';\nimport { createInvalidObservableTypeError } from '../util/throwUnobservableError';\nimport { isIterable } from '../util/isIterable';\nimport { isReadableStreamLike, readableStreamLikeToAsyncGenerator } from '../util/isReadableStreamLike';\nimport { isFunction } from '../util/isFunction';\nimport { reportUnhandledError } from '../util/reportUnhandledError';\nimport { observable as Symbol_observable } from '../symbol/observable';\nexport function innerFrom(input) {\n if (input instanceof Observable) {\n return input;\n }\n if (input != null) {\n if (isInteropObservable(input)) {\n return fromInteropObservable(input);\n }\n if (isArrayLike(input)) {\n return fromArrayLike(input);\n }\n if (isPromise(input)) {\n return fromPromise(input);\n }\n if (isAsyncIterable(input)) {\n return fromAsyncIterable(input);\n }\n if (isIterable(input)) {\n return fromIterable(input);\n }\n if (isReadableStreamLike(input)) {\n return fromReadableStreamLike(input);\n }\n }\n throw createInvalidObservableTypeError(input);\n}\nexport function fromInteropObservable(obj) {\n return new Observable(subscriber => {\n const obs = obj[Symbol_observable]();\n if (isFunction(obs.subscribe)) {\n return obs.subscribe(subscriber);\n }\n throw new TypeError('Provided object does not correctly implement Symbol.observable');\n });\n}\nexport function fromArrayLike(array) {\n return new Observable(subscriber => {\n for (let i = 0; i < array.length && !subscriber.closed; i++) {\n subscriber.next(array[i]);\n }\n subscriber.complete();\n });\n}\nexport function fromPromise(promise) {\n return new Observable(subscriber => {\n promise.then(value => {\n if (!subscriber.closed) {\n subscriber.next(value);\n subscriber.complete();\n }\n }, err => subscriber.error(err)).then(null, reportUnhandledError);\n });\n}\nexport function fromIterable(iterable) {\n return new Observable(subscriber => {\n for (const value of iterable) {\n subscriber.next(value);\n if (subscriber.closed) {\n return;\n }\n }\n subscriber.complete();\n });\n}\nexport function fromAsyncIterable(asyncIterable) {\n return new Observable(subscriber => {\n process(asyncIterable, subscriber).catch(err => subscriber.error(err));\n });\n}\nexport function fromReadableStreamLike(readableStream) {\n return fromAsyncIterable(readableStreamLikeToAsyncGenerator(readableStream));\n}\nfunction process(asyncIterable, subscriber) {\n var asyncIterable_1, asyncIterable_1_1;\n var e_1, _a;\n return __awaiter(this, void 0, void 0, function* () {\n try {\n for (asyncIterable_1 = __asyncValues(asyncIterable); asyncIterable_1_1 = yield asyncIterable_1.next(), !asyncIterable_1_1.done;) {\n const value = asyncIterable_1_1.value;\n subscriber.next(value);\n if (subscriber.closed) {\n return;\n }\n }\n } catch (e_1_1) {\n e_1 = {\n error: e_1_1\n };\n } finally {\n try {\n if (asyncIterable_1_1 && !asyncIterable_1_1.done && (_a = asyncIterable_1.return)) yield _a.call(asyncIterable_1);\n } finally {\n if (e_1) throw e_1.error;\n }\n }\n subscriber.complete();\n });\n}\n","export const isArrayLike = x => x && typeof x.length === 'number' && typeof x !== 'function';\n","import { isFunction } from \"./isFunction\";\nexport function isPromise(value) {\n return isFunction(value === null || value === void 0 ? void 0 : value.then);\n}\n","import { observable as Symbol_observable } from '../symbol/observable';\nimport { isFunction } from './isFunction';\nexport function isInteropObservable(input) {\n return isFunction(input[Symbol_observable]);\n}\n","import { isFunction } from './isFunction';\nexport function isAsyncIterable(obj) {\n return Symbol.asyncIterator && isFunction(obj === null || obj === void 0 ? void 0 : obj[Symbol.asyncIterator]);\n}\n","export function createInvalidObservableTypeError(input) {\n return new TypeError(`You provided ${input !== null && typeof input === 'object' ? 'an invalid object' : `'${input}'`} where a stream was expected. You can provide an Observable, Promise, ReadableStream, Array, AsyncIterable, or Iterable.`);\n}\n","export function getSymbolIterator() {\n if (typeof Symbol !== 'function' || !Symbol.iterator) {\n return '@@iterator';\n }\n return Symbol.iterator;\n}\nexport const iterator = getSymbolIterator();\n","import { iterator as Symbol_iterator } from '../symbol/iterator';\nimport { isFunction } from './isFunction';\nexport function isIterable(input) {\n return isFunction(input === null || input === void 0 ? void 0 : input[Symbol_iterator]);\n}\n","import { __asyncGenerator, __await } from \"tslib\";\nimport { isFunction } from './isFunction';\nexport function readableStreamLikeToAsyncGenerator(readableStream) {\n return __asyncGenerator(this, arguments, function* readableStreamLikeToAsyncGenerator_1() {\n const reader = readableStream.getReader();\n try {\n while (true) {\n const {\n value,\n done\n } = yield __await(reader.read());\n if (done) {\n return yield __await(void 0);\n }\n yield yield __await(value);\n }\n } finally {\n reader.releaseLock();\n }\n });\n}\nexport function isReadableStreamLike(obj) {\n return isFunction(obj === null || obj === void 0 ? void 0 : obj.getReader);\n}\n","export function executeSchedule(parentSubscription, scheduler, work, delay = 0, repeat = false) {\n const scheduleSubscription = scheduler.schedule(function () {\n work();\n if (repeat) {\n parentSubscription.add(this.schedule(null, delay));\n } else {\n this.unsubscribe();\n }\n }, delay);\n parentSubscription.add(scheduleSubscription);\n if (!repeat) {\n return scheduleSubscription;\n }\n}\n","import { executeSchedule } from '../util/executeSchedule';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function observeOn(scheduler, delay = 0) {\n return operate((source, subscriber) => {\n source.subscribe(createOperatorSubscriber(subscriber, value => executeSchedule(subscriber, scheduler, () => subscriber.next(value), delay), () => executeSchedule(subscriber, scheduler, () => subscriber.complete(), delay), err => executeSchedule(subscriber, scheduler, () => subscriber.error(err), delay)));\n });\n}\n","import { operate } from '../util/lift';\nexport function subscribeOn(scheduler, delay = 0) {\n return operate((source, subscriber) => {\n subscriber.add(scheduler.schedule(() => source.subscribe(subscriber), delay));\n });\n}\n","import { innerFrom } from '../observable/innerFrom';\nimport { observeOn } from '../operators/observeOn';\nimport { subscribeOn } from '../operators/subscribeOn';\nexport function scheduleObservable(input, scheduler) {\n return innerFrom(input).pipe(subscribeOn(scheduler), observeOn(scheduler));\n}\n","import { innerFrom } from '../observable/innerFrom';\nimport { observeOn } from '../operators/observeOn';\nimport { subscribeOn } from '../operators/subscribeOn';\nexport function schedulePromise(input, scheduler) {\n return innerFrom(input).pipe(subscribeOn(scheduler), observeOn(scheduler));\n}\n","import { Observable } from '../Observable';\nexport function scheduleArray(input, scheduler) {\n return new Observable(subscriber => {\n let i = 0;\n return scheduler.schedule(function () {\n if (i === input.length) {\n subscriber.complete();\n } else {\n subscriber.next(input[i++]);\n if (!subscriber.closed) {\n this.schedule();\n }\n }\n });\n });\n}\n","import { Observable } from '../Observable';\nimport { iterator as Symbol_iterator } from '../symbol/iterator';\nimport { isFunction } from '../util/isFunction';\nimport { executeSchedule } from '../util/executeSchedule';\nexport function scheduleIterable(input, scheduler) {\n return new Observable(subscriber => {\n let iterator;\n executeSchedule(subscriber, scheduler, () => {\n iterator = input[Symbol_iterator]();\n executeSchedule(subscriber, scheduler, () => {\n let value;\n let done;\n try {\n ({\n value,\n done\n } = iterator.next());\n } catch (err) {\n subscriber.error(err);\n return;\n }\n if (done) {\n subscriber.complete();\n } else {\n subscriber.next(value);\n }\n }, 0, true);\n });\n return () => isFunction(iterator === null || iterator === void 0 ? void 0 : iterator.return) && iterator.return();\n });\n}\n","import { Observable } from '../Observable';\nimport { executeSchedule } from '../util/executeSchedule';\nexport function scheduleAsyncIterable(input, scheduler) {\n if (!input) {\n throw new Error('Iterable cannot be null');\n }\n return new Observable(subscriber => {\n executeSchedule(subscriber, scheduler, () => {\n const iterator = input[Symbol.asyncIterator]();\n executeSchedule(subscriber, scheduler, () => {\n iterator.next().then(result => {\n if (result.done) {\n subscriber.complete();\n } else {\n subscriber.next(result.value);\n }\n });\n }, 0, true);\n });\n });\n}\n","import { scheduleAsyncIterable } from './scheduleAsyncIterable';\nimport { readableStreamLikeToAsyncGenerator } from '../util/isReadableStreamLike';\nexport function scheduleReadableStreamLike(input, scheduler) {\n return scheduleAsyncIterable(readableStreamLikeToAsyncGenerator(input), scheduler);\n}\n","import { scheduleObservable } from './scheduleObservable';\nimport { schedulePromise } from './schedulePromise';\nimport { scheduleArray } from './scheduleArray';\nimport { scheduleIterable } from './scheduleIterable';\nimport { scheduleAsyncIterable } from './scheduleAsyncIterable';\nimport { isInteropObservable } from '../util/isInteropObservable';\nimport { isPromise } from '../util/isPromise';\nimport { isArrayLike } from '../util/isArrayLike';\nimport { isIterable } from '../util/isIterable';\nimport { isAsyncIterable } from '../util/isAsyncIterable';\nimport { createInvalidObservableTypeError } from '../util/throwUnobservableError';\nimport { isReadableStreamLike } from '../util/isReadableStreamLike';\nimport { scheduleReadableStreamLike } from './scheduleReadableStreamLike';\nexport function scheduled(input, scheduler) {\n if (input != null) {\n if (isInteropObservable(input)) {\n return scheduleObservable(input, scheduler);\n }\n if (isArrayLike(input)) {\n return scheduleArray(input, scheduler);\n }\n if (isPromise(input)) {\n return schedulePromise(input, scheduler);\n }\n if (isAsyncIterable(input)) {\n return scheduleAsyncIterable(input, scheduler);\n }\n if (isIterable(input)) {\n return scheduleIterable(input, scheduler);\n }\n if (isReadableStreamLike(input)) {\n return scheduleReadableStreamLike(input, scheduler);\n }\n }\n throw createInvalidObservableTypeError(input);\n}\n","import { scheduled } from '../scheduled/scheduled';\nimport { innerFrom } from './innerFrom';\nexport function from(input, scheduler) {\n return scheduler ? scheduled(input, scheduler) : innerFrom(input);\n}\n","import { popScheduler } from '../util/args';\nimport { from } from './from';\nexport function of(...args) {\n const scheduler = popScheduler(args);\n return from(args, scheduler);\n}\n","import { Observable } from '../Observable';\nimport { isFunction } from '../util/isFunction';\nexport function throwError(errorOrErrorFactory, scheduler) {\n const errorFactory = isFunction(errorOrErrorFactory) ? errorOrErrorFactory : () => errorOrErrorFactory;\n const init = subscriber => subscriber.error(errorFactory());\n return new Observable(scheduler ? subscriber => scheduler.schedule(init, 0, subscriber) : init);\n}\n","import { Observable } from '../Observable';\nimport { isFunction } from './isFunction';\nexport function isObservable(obj) {\n return !!obj && (obj instanceof Observable || isFunction(obj.lift) && isFunction(obj.subscribe));\n}\n","export function isValidDate(value) {\n return value instanceof Date && !isNaN(value);\n}\n","import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function map(project, thisArg) {\n return operate((source, subscriber) => {\n let index = 0;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n subscriber.next(project.call(thisArg, value, index++));\n }));\n });\n}\n","import { map } from \"../operators/map\";\nconst {\n isArray\n} = Array;\nfunction callOrApply(fn, args) {\n return isArray(args) ? fn(...args) : fn(args);\n}\nexport function mapOneOrManyArgs(fn) {\n return map(args => callOrApply(fn, args));\n}\n","const {\n isArray\n} = Array;\nconst {\n getPrototypeOf,\n prototype: objectProto,\n keys: getKeys\n} = Object;\nexport function argsArgArrayOrObject(args) {\n if (args.length === 1) {\n const first = args[0];\n if (isArray(first)) {\n return {\n args: first,\n keys: null\n };\n }\n if (isPOJO(first)) {\n const keys = getKeys(first);\n return {\n args: keys.map(key => first[key]),\n keys\n };\n }\n }\n return {\n args: args,\n keys: null\n };\n}\nfunction isPOJO(obj) {\n return obj && typeof obj === 'object' && getPrototypeOf(obj) === objectProto;\n}\n","export function createObject(keys, values) {\n return keys.reduce((result, key, i) => (result[key] = values[i], result), {});\n}\n","import { Observable } from '../Observable';\nimport { argsArgArrayOrObject } from '../util/argsArgArrayOrObject';\nimport { from } from './from';\nimport { identity } from '../util/identity';\nimport { mapOneOrManyArgs } from '../util/mapOneOrManyArgs';\nimport { popResultSelector, popScheduler } from '../util/args';\nimport { createObject } from '../util/createObject';\nimport { createOperatorSubscriber } from '../operators/OperatorSubscriber';\nimport { executeSchedule } from '../util/executeSchedule';\nexport function combineLatest(...args) {\n const scheduler = popScheduler(args);\n const resultSelector = popResultSelector(args);\n const {\n args: observables,\n keys\n } = argsArgArrayOrObject(args);\n if (observables.length === 0) {\n return from([], scheduler);\n }\n const result = new Observable(combineLatestInit(observables, scheduler, keys ? values => createObject(keys, values) : identity));\n return resultSelector ? result.pipe(mapOneOrManyArgs(resultSelector)) : result;\n}\nexport function combineLatestInit(observables, scheduler, valueTransform = identity) {\n return subscriber => {\n maybeSchedule(scheduler, () => {\n const {\n length\n } = observables;\n const values = new Array(length);\n let active = length;\n let remainingFirstValues = length;\n for (let i = 0; i < length; i++) {\n maybeSchedule(scheduler, () => {\n const source = from(observables[i], scheduler);\n let hasFirstValue = false;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n values[i] = value;\n if (!hasFirstValue) {\n hasFirstValue = true;\n remainingFirstValues--;\n }\n if (!remainingFirstValues) {\n subscriber.next(valueTransform(values.slice()));\n }\n }, () => {\n if (! --active) {\n subscriber.complete();\n }\n }));\n }, subscriber);\n }\n }, subscriber);\n };\n}\nfunction maybeSchedule(scheduler, execute, subscription) {\n if (scheduler) {\n executeSchedule(subscription, scheduler, execute);\n } else {\n execute();\n }\n}\n","import { innerFrom } from '../observable/innerFrom';\nimport { executeSchedule } from '../util/executeSchedule';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function mergeInternals(source, subscriber, project, concurrent, onBeforeNext, expand, innerSubScheduler, additionalFinalizer) {\n const buffer = [];\n let active = 0;\n let index = 0;\n let isComplete = false;\n const checkComplete = () => {\n if (isComplete && !buffer.length && !active) {\n subscriber.complete();\n }\n };\n const outerNext = value => active < concurrent ? doInnerSub(value) : buffer.push(value);\n const doInnerSub = value => {\n expand && subscriber.next(value);\n active++;\n let innerComplete = false;\n innerFrom(project(value, index++)).subscribe(createOperatorSubscriber(subscriber, innerValue => {\n onBeforeNext === null || onBeforeNext === void 0 ? void 0 : onBeforeNext(innerValue);\n if (expand) {\n outerNext(innerValue);\n } else {\n subscriber.next(innerValue);\n }\n }, () => {\n innerComplete = true;\n }, undefined, () => {\n if (innerComplete) {\n try {\n active--;\n while (buffer.length && active < concurrent) {\n const bufferedValue = buffer.shift();\n if (innerSubScheduler) {\n executeSchedule(subscriber, innerSubScheduler, () => doInnerSub(bufferedValue));\n } else {\n doInnerSub(bufferedValue);\n }\n }\n checkComplete();\n } catch (err) {\n subscriber.error(err);\n }\n }\n }));\n };\n source.subscribe(createOperatorSubscriber(subscriber, outerNext, () => {\n isComplete = true;\n checkComplete();\n }));\n return () => {\n additionalFinalizer === null || additionalFinalizer === void 0 ? void 0 : additionalFinalizer();\n };\n}\n","import { map } from './map';\nimport { innerFrom } from '../observable/innerFrom';\nimport { operate } from '../util/lift';\nimport { mergeInternals } from './mergeInternals';\nimport { isFunction } from '../util/isFunction';\nexport function mergeMap(project, resultSelector, concurrent = Infinity) {\n if (isFunction(resultSelector)) {\n return mergeMap((a, i) => map((b, ii) => resultSelector(a, b, i, ii))(innerFrom(project(a, i))), concurrent);\n } else if (typeof resultSelector === 'number') {\n concurrent = resultSelector;\n }\n return operate((source, subscriber) => mergeInternals(source, subscriber, project, concurrent));\n}\n","import { mergeMap } from './mergeMap';\nimport { identity } from '../util/identity';\nexport function mergeAll(concurrent = Infinity) {\n return mergeMap(identity, concurrent);\n}\n","import { mergeAll } from './mergeAll';\nexport function concatAll() {\n return mergeAll(1);\n}\n","import { concatAll } from '../operators/concatAll';\nimport { popScheduler } from '../util/args';\nimport { from } from './from';\nexport function concat(...args) {\n return concatAll()(from(args, popScheduler(args)));\n}\n","import { Observable } from '../Observable';\nimport { innerFrom } from './innerFrom';\nexport function defer(observableFactory) {\n return new Observable(subscriber => {\n innerFrom(observableFactory()).subscribe(subscriber);\n });\n}\n","import { Observable } from '../Observable';\nimport { argsArgArrayOrObject } from '../util/argsArgArrayOrObject';\nimport { innerFrom } from './innerFrom';\nimport { popResultSelector } from '../util/args';\nimport { createOperatorSubscriber } from '../operators/OperatorSubscriber';\nimport { mapOneOrManyArgs } from '../util/mapOneOrManyArgs';\nimport { createObject } from '../util/createObject';\nexport function forkJoin(...args) {\n const resultSelector = popResultSelector(args);\n const {\n args: sources,\n keys\n } = argsArgArrayOrObject(args);\n const result = new Observable(subscriber => {\n const {\n length\n } = sources;\n if (!length) {\n subscriber.complete();\n return;\n }\n const values = new Array(length);\n let remainingCompletions = length;\n let remainingEmissions = length;\n for (let sourceIndex = 0; sourceIndex < length; sourceIndex++) {\n let hasValue = false;\n innerFrom(sources[sourceIndex]).subscribe(createOperatorSubscriber(subscriber, value => {\n if (!hasValue) {\n hasValue = true;\n remainingEmissions--;\n }\n values[sourceIndex] = value;\n }, () => remainingCompletions--, undefined, () => {\n if (!remainingCompletions || !hasValue) {\n if (!remainingEmissions) {\n subscriber.next(keys ? createObject(keys, values) : values);\n }\n subscriber.complete();\n }\n }));\n }\n });\n return resultSelector ? result.pipe(mapOneOrManyArgs(resultSelector)) : result;\n}\n","import { innerFrom } from '../observable/innerFrom';\nimport { Observable } from '../Observable';\nimport { mergeMap } from '../operators/mergeMap';\nimport { isArrayLike } from '../util/isArrayLike';\nimport { isFunction } from '../util/isFunction';\nimport { mapOneOrManyArgs } from '../util/mapOneOrManyArgs';\nconst nodeEventEmitterMethods = ['addListener', 'removeListener'];\nconst eventTargetMethods = ['addEventListener', 'removeEventListener'];\nconst jqueryMethods = ['on', 'off'];\nexport function fromEvent(target, eventName, options, resultSelector) {\n if (isFunction(options)) {\n resultSelector = options;\n options = undefined;\n }\n if (resultSelector) {\n return fromEvent(target, eventName, options).pipe(mapOneOrManyArgs(resultSelector));\n }\n const [add, remove] = isEventTarget(target) ? eventTargetMethods.map(methodName => handler => target[methodName](eventName, handler, options)) : isNodeStyleEventEmitter(target) ? nodeEventEmitterMethods.map(toCommonHandlerRegistry(target, eventName)) : isJQueryStyleEventEmitter(target) ? jqueryMethods.map(toCommonHandlerRegistry(target, eventName)) : [];\n if (!add) {\n if (isArrayLike(target)) {\n return mergeMap(subTarget => fromEvent(subTarget, eventName, options))(innerFrom(target));\n }\n }\n if (!add) {\n throw new TypeError('Invalid event target');\n }\n return new Observable(subscriber => {\n const handler = (...args) => subscriber.next(1 < args.length ? args : args[0]);\n add(handler);\n return () => remove(handler);\n });\n}\nfunction toCommonHandlerRegistry(target, eventName) {\n return methodName => handler => target[methodName](eventName, handler);\n}\nfunction isNodeStyleEventEmitter(target) {\n return isFunction(target.addListener) && isFunction(target.removeListener);\n}\nfunction isJQueryStyleEventEmitter(target) {\n return isFunction(target.on) && isFunction(target.off);\n}\nfunction isEventTarget(target) {\n return isFunction(target.addEventListener) && isFunction(target.removeEventListener);\n}\n","import { Observable } from '../Observable';\nimport { async as asyncScheduler } from '../scheduler/async';\nimport { isScheduler } from '../util/isScheduler';\nimport { isValidDate } from '../util/isDate';\nexport function timer(dueTime = 0, intervalOrScheduler, scheduler = asyncScheduler) {\n let intervalDuration = -1;\n if (intervalOrScheduler != null) {\n if (isScheduler(intervalOrScheduler)) {\n scheduler = intervalOrScheduler;\n } else {\n intervalDuration = intervalOrScheduler;\n }\n }\n return new Observable(subscriber => {\n let due = isValidDate(dueTime) ? +dueTime - scheduler.now() : dueTime;\n if (due < 0) {\n due = 0;\n }\n let n = 0;\n return scheduler.schedule(function () {\n if (!subscriber.closed) {\n subscriber.next(n++);\n if (0 <= intervalDuration) {\n this.schedule(undefined, intervalDuration);\n } else {\n subscriber.complete();\n }\n }\n }, due);\n });\n}\n","import { mergeAll } from '../operators/mergeAll';\nimport { innerFrom } from './innerFrom';\nimport { EMPTY } from './empty';\nimport { popNumber, popScheduler } from '../util/args';\nimport { from } from './from';\nexport function merge(...args) {\n const scheduler = popScheduler(args);\n const concurrent = popNumber(args, Infinity);\n const sources = args;\n return !sources.length ? EMPTY : sources.length === 1 ? innerFrom(sources[0]) : mergeAll(concurrent)(from(sources, scheduler));\n}\n","import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function filter(predicate, thisArg) {\n return operate((source, subscriber) => {\n let index = 0;\n source.subscribe(createOperatorSubscriber(subscriber, value => predicate.call(thisArg, value, index++) && subscriber.next(value)));\n });\n}\n","import { operate } from '../util/lift';\nimport { innerFrom } from '../observable/innerFrom';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function audit(durationSelector) {\n return operate((source, subscriber) => {\n let hasValue = false;\n let lastValue = null;\n let durationSubscriber = null;\n let isComplete = false;\n const endDuration = () => {\n durationSubscriber === null || durationSubscriber === void 0 ? void 0 : durationSubscriber.unsubscribe();\n durationSubscriber = null;\n if (hasValue) {\n hasValue = false;\n const value = lastValue;\n lastValue = null;\n subscriber.next(value);\n }\n isComplete && subscriber.complete();\n };\n const cleanupDuration = () => {\n durationSubscriber = null;\n isComplete && subscriber.complete();\n };\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n hasValue = true;\n lastValue = value;\n if (!durationSubscriber) {\n innerFrom(durationSelector(value)).subscribe(durationSubscriber = createOperatorSubscriber(subscriber, endDuration, cleanupDuration));\n }\n }, () => {\n isComplete = true;\n (!hasValue || !durationSubscriber || durationSubscriber.closed) && subscriber.complete();\n }));\n });\n}\n","import { asyncScheduler } from '../scheduler/async';\nimport { audit } from './audit';\nimport { timer } from '../observable/timer';\nexport function auditTime(duration, scheduler = asyncScheduler) {\n return audit(() => timer(duration, scheduler));\n}\n","import { innerFrom } from '../observable/innerFrom';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nimport { operate } from '../util/lift';\nexport function catchError(selector) {\n return operate((source, subscriber) => {\n let innerSub = null;\n let syncUnsub = false;\n let handledResult;\n innerSub = source.subscribe(createOperatorSubscriber(subscriber, undefined, undefined, err => {\n handledResult = innerFrom(selector(err, catchError(selector)(source)));\n if (innerSub) {\n innerSub.unsubscribe();\n innerSub = null;\n handledResult.subscribe(subscriber);\n } else {\n syncUnsub = true;\n }\n }));\n if (syncUnsub) {\n innerSub.unsubscribe();\n innerSub = null;\n handledResult.subscribe(subscriber);\n }\n });\n}\n","import { createOperatorSubscriber } from './OperatorSubscriber';\nexport function scanInternals(accumulator, seed, hasSeed, emitOnNext, emitBeforeComplete) {\n return (source, subscriber) => {\n let hasState = hasSeed;\n let state = seed;\n let index = 0;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n const i = index++;\n state = hasState ? accumulator(state, value, i) : (hasState = true, value);\n emitOnNext && subscriber.next(state);\n }, emitBeforeComplete && (() => {\n hasState && subscriber.next(state);\n subscriber.complete();\n })));\n };\n}\n","import { mergeMap } from './mergeMap';\nimport { isFunction } from '../util/isFunction';\nexport function concatMap(project, resultSelector) {\n return isFunction(resultSelector) ? mergeMap(project, resultSelector, 1) : mergeMap(project, 1);\n}\n","import { asyncScheduler } from '../scheduler/async';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function debounceTime(dueTime, scheduler = asyncScheduler) {\n return operate((source, subscriber) => {\n let activeTask = null;\n let lastValue = null;\n let lastTime = null;\n const emit = () => {\n if (activeTask) {\n activeTask.unsubscribe();\n activeTask = null;\n const value = lastValue;\n lastValue = null;\n subscriber.next(value);\n }\n };\n function emitWhenIdle() {\n const targetTime = lastTime + dueTime;\n const now = scheduler.now();\n if (now < targetTime) {\n activeTask = this.schedule(undefined, targetTime - now);\n subscriber.add(activeTask);\n return;\n }\n emit();\n }\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n lastValue = value;\n lastTime = scheduler.now();\n if (!activeTask) {\n activeTask = scheduler.schedule(emitWhenIdle, dueTime);\n subscriber.add(activeTask);\n }\n }, () => {\n emit();\n subscriber.complete();\n }, undefined, () => {\n lastValue = activeTask = null;\n }));\n });\n}\n","import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function defaultIfEmpty(defaultValue) {\n return operate((source, subscriber) => {\n let hasValue = false;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n hasValue = true;\n subscriber.next(value);\n }, () => {\n if (!hasValue) {\n subscriber.next(defaultValue);\n }\n subscriber.complete();\n }));\n });\n}\n","import { EMPTY } from '../observable/empty';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function take(count) {\n return count <= 0 ? () => EMPTY : operate((source, subscriber) => {\n let seen = 0;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n if (++seen <= count) {\n subscriber.next(value);\n if (count <= seen) {\n subscriber.complete();\n }\n }\n }));\n });\n}\n","import { map } from './map';\nexport function mapTo(value) {\n return map(() => value);\n}\n","import { EmptyError } from '../util/EmptyError';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function throwIfEmpty(errorFactory = defaultErrorFactory) {\n return operate((source, subscriber) => {\n let hasValue = false;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n hasValue = true;\n subscriber.next(value);\n }, () => hasValue ? subscriber.complete() : subscriber.error(errorFactory())));\n });\n}\nfunction defaultErrorFactory() {\n return new EmptyError();\n}\n","import { operate } from '../util/lift';\nexport function finalize(callback) {\n return operate((source, subscriber) => {\n try {\n source.subscribe(subscriber);\n } finally {\n subscriber.add(callback);\n }\n });\n}\n","import { EmptyError } from '../util/EmptyError';\nimport { filter } from './filter';\nimport { take } from './take';\nimport { defaultIfEmpty } from './defaultIfEmpty';\nimport { throwIfEmpty } from './throwIfEmpty';\nimport { identity } from '../util/identity';\nexport function first(predicate, defaultValue) {\n const hasDefaultValue = arguments.length >= 2;\n return source => source.pipe(predicate ? filter((v, i) => predicate(v, i, source)) : identity, take(1), hasDefaultValue ? defaultIfEmpty(defaultValue) : throwIfEmpty(() => new EmptyError()));\n}\n","import { EMPTY } from '../observable/empty';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function takeLast(count) {\n return count <= 0 ? () => EMPTY : operate((source, subscriber) => {\n let buffer = [];\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n buffer.push(value);\n count < buffer.length && buffer.shift();\n }, () => {\n for (const value of buffer) {\n subscriber.next(value);\n }\n subscriber.complete();\n }, undefined, () => {\n buffer = null;\n }));\n });\n}\n","import { EmptyError } from '../util/EmptyError';\nimport { filter } from './filter';\nimport { takeLast } from './takeLast';\nimport { throwIfEmpty } from './throwIfEmpty';\nimport { defaultIfEmpty } from './defaultIfEmpty';\nimport { identity } from '../util/identity';\nexport function last(predicate, defaultValue) {\n const hasDefaultValue = arguments.length >= 2;\n return source => source.pipe(predicate ? filter((v, i) => predicate(v, i, source)) : identity, takeLast(1), hasDefaultValue ? defaultIfEmpty(defaultValue) : throwIfEmpty(() => new EmptyError()));\n}\n","import { operate } from '../util/lift';\nimport { scanInternals } from './scanInternals';\nexport function scan(accumulator, seed) {\n return operate(scanInternals(accumulator, seed, arguments.length >= 2, true));\n}\n","import { concat } from '../observable/concat';\nimport { popScheduler } from '../util/args';\nimport { operate } from '../util/lift';\nexport function startWith(...values) {\n const scheduler = popScheduler(values);\n return operate((source, subscriber) => {\n (scheduler ? concat(values, source, scheduler) : concat(values, source)).subscribe(subscriber);\n });\n}\n","import { innerFrom } from '../observable/innerFrom';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function switchMap(project, resultSelector) {\n return operate((source, subscriber) => {\n let innerSubscriber = null;\n let index = 0;\n let isComplete = false;\n const checkComplete = () => isComplete && !innerSubscriber && subscriber.complete();\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n innerSubscriber === null || innerSubscriber === void 0 ? void 0 : innerSubscriber.unsubscribe();\n let innerIndex = 0;\n const outerIndex = index++;\n innerFrom(project(value, outerIndex)).subscribe(innerSubscriber = createOperatorSubscriber(subscriber, innerValue => subscriber.next(resultSelector ? resultSelector(value, innerValue, outerIndex, innerIndex++) : innerValue), () => {\n innerSubscriber = null;\n checkComplete();\n }));\n }, () => {\n isComplete = true;\n checkComplete();\n }));\n });\n}\n","import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nimport { innerFrom } from '../observable/innerFrom';\nimport { noop } from '../util/noop';\nexport function takeUntil(notifier) {\n return operate((source, subscriber) => {\n innerFrom(notifier).subscribe(createOperatorSubscriber(subscriber, () => subscriber.complete(), noop));\n !subscriber.closed && source.subscribe(subscriber);\n });\n}\n","import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function takeWhile(predicate, inclusive = false) {\n return operate((source, subscriber) => {\n let index = 0;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n const result = predicate(value, index++);\n (result || inclusive) && subscriber.next(value);\n !result && subscriber.complete();\n }));\n });\n}\n","import { isFunction } from '../util/isFunction';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nimport { identity } from '../util/identity';\nexport function tap(observerOrNext, error, complete) {\n const tapObserver = isFunction(observerOrNext) || error || complete ? {\n next: observerOrNext,\n error,\n complete\n } : observerOrNext;\n return tapObserver ? operate((source, subscriber) => {\n var _a;\n (_a = tapObserver.subscribe) === null || _a === void 0 ? void 0 : _a.call(tapObserver);\n let isUnsub = true;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n var _a;\n (_a = tapObserver.next) === null || _a === void 0 ? void 0 : _a.call(tapObserver, value);\n subscriber.next(value);\n }, () => {\n var _a;\n isUnsub = false;\n (_a = tapObserver.complete) === null || _a === void 0 ? void 0 : _a.call(tapObserver);\n subscriber.complete();\n }, err => {\n var _a;\n isUnsub = false;\n (_a = tapObserver.error) === null || _a === void 0 ? void 0 : _a.call(tapObserver, err);\n subscriber.error(err);\n }, () => {\n var _a, _b;\n if (isUnsub) {\n (_a = tapObserver.unsubscribe) === null || _a === void 0 ? void 0 : _a.call(tapObserver);\n }\n (_b = tapObserver.finalize) === null || _b === void 0 ? void 0 : _b.call(tapObserver);\n }));\n }) : identity;\n}\n","/**\n * @license Angular v18.2.12\n * (c) 2010-2024 Google LLC. https://angular.io/\n * License: MIT\n */\n\n/**\n * The default equality function used for `signal` and `computed`, which uses referential equality.\n */\nfunction defaultEquals(a, b) {\n return Object.is(a, b);\n}\n\n/**\n * The currently active consumer `ReactiveNode`, if running code in a reactive context.\n *\n * Change this via `setActiveConsumer`.\n */\nlet activeConsumer = null;\nlet inNotificationPhase = false;\n/**\n * Global epoch counter. Incremented whenever a source signal is set.\n */\nlet epoch = 1;\n/**\n * Symbol used to tell `Signal`s apart from other functions.\n *\n * This can be used to auto-unwrap signals in various cases, or to auto-wrap non-signal values.\n */\nconst SIGNAL = /* @__PURE__ */Symbol('SIGNAL');\nfunction setActiveConsumer(consumer) {\n const prev = activeConsumer;\n activeConsumer = consumer;\n return prev;\n}\nfunction getActiveConsumer() {\n return activeConsumer;\n}\nfunction isInNotificationPhase() {\n return inNotificationPhase;\n}\nfunction isReactive(value) {\n return value[SIGNAL] !== undefined;\n}\nconst REACTIVE_NODE = {\n version: 0,\n lastCleanEpoch: 0,\n dirty: false,\n producerNode: undefined,\n producerLastReadVersion: undefined,\n producerIndexOfThis: undefined,\n nextProducerIndex: 0,\n liveConsumerNode: undefined,\n liveConsumerIndexOfThis: undefined,\n consumerAllowSignalWrites: false,\n consumerIsAlwaysLive: false,\n producerMustRecompute: () => false,\n producerRecomputeValue: () => {},\n consumerMarkedDirty: () => {},\n consumerOnSignalRead: () => {}\n};\n/**\n * Called by implementations when a producer's signal is read.\n */\nfunction producerAccessed(node) {\n if (inNotificationPhase) {\n throw new Error(typeof ngDevMode !== 'undefined' && ngDevMode ? `Assertion error: signal read during notification phase` : '');\n }\n if (activeConsumer === null) {\n // Accessed outside of a reactive context, so nothing to record.\n return;\n }\n activeConsumer.consumerOnSignalRead(node);\n // This producer is the `idx`th dependency of `activeConsumer`.\n const idx = activeConsumer.nextProducerIndex++;\n assertConsumerNode(activeConsumer);\n if (idx < activeConsumer.producerNode.length && activeConsumer.producerNode[idx] !== node) {\n // There's been a change in producers since the last execution of `activeConsumer`.\n // `activeConsumer.producerNode[idx]` holds a stale dependency which will be be removed and\n // replaced with `this`.\n //\n // If `activeConsumer` isn't live, then this is a no-op, since we can replace the producer in\n // `activeConsumer.producerNode` directly. However, if `activeConsumer` is live, then we need\n // to remove it from the stale producer's `liveConsumer`s.\n if (consumerIsLive(activeConsumer)) {\n const staleProducer = activeConsumer.producerNode[idx];\n producerRemoveLiveConsumerAtIndex(staleProducer, activeConsumer.producerIndexOfThis[idx]);\n // At this point, the only record of `staleProducer` is the reference at\n // `activeConsumer.producerNode[idx]` which will be overwritten below.\n }\n }\n if (activeConsumer.producerNode[idx] !== node) {\n // We're a new dependency of the consumer (at `idx`).\n activeConsumer.producerNode[idx] = node;\n // If the active consumer is live, then add it as a live consumer. If not, then use 0 as a\n // placeholder value.\n activeConsumer.producerIndexOfThis[idx] = consumerIsLive(activeConsumer) ? producerAddLiveConsumer(node, activeConsumer, idx) : 0;\n }\n activeConsumer.producerLastReadVersion[idx] = node.version;\n}\n/**\n * Increment the global epoch counter.\n *\n * Called by source producers (that is, not computeds) whenever their values change.\n */\nfunction producerIncrementEpoch() {\n epoch++;\n}\n/**\n * Ensure this producer's `version` is up-to-date.\n */\nfunction producerUpdateValueVersion(node) {\n if (consumerIsLive(node) && !node.dirty) {\n // A live consumer will be marked dirty by producers, so a clean state means that its version\n // is guaranteed to be up-to-date.\n return;\n }\n if (!node.dirty && node.lastCleanEpoch === epoch) {\n // Even non-live consumers can skip polling if they previously found themselves to be clean at\n // the current epoch, since their dependencies could not possibly have changed (such a change\n // would've increased the epoch).\n return;\n }\n if (!node.producerMustRecompute(node) && !consumerPollProducersForChange(node)) {\n // None of our producers report a change since the last time they were read, so no\n // recomputation of our value is necessary, and we can consider ourselves clean.\n node.dirty = false;\n node.lastCleanEpoch = epoch;\n return;\n }\n node.producerRecomputeValue(node);\n // After recomputing the value, we're no longer dirty.\n node.dirty = false;\n node.lastCleanEpoch = epoch;\n}\n/**\n * Propagate a dirty notification to live consumers of this producer.\n */\nfunction producerNotifyConsumers(node) {\n if (node.liveConsumerNode === undefined) {\n return;\n }\n // Prevent signal reads when we're updating the graph\n const prev = inNotificationPhase;\n inNotificationPhase = true;\n try {\n for (const consumer of node.liveConsumerNode) {\n if (!consumer.dirty) {\n consumerMarkDirty(consumer);\n }\n }\n } finally {\n inNotificationPhase = prev;\n }\n}\n/**\n * Whether this `ReactiveNode` in its producer capacity is currently allowed to initiate updates,\n * based on the current consumer context.\n */\nfunction producerUpdatesAllowed() {\n return activeConsumer?.consumerAllowSignalWrites !== false;\n}\nfunction consumerMarkDirty(node) {\n node.dirty = true;\n producerNotifyConsumers(node);\n node.consumerMarkedDirty?.(node);\n}\n/**\n * Prepare this consumer to run a computation in its reactive context.\n *\n * Must be called by subclasses which represent reactive computations, before those computations\n * begin.\n */\nfunction consumerBeforeComputation(node) {\n node && (node.nextProducerIndex = 0);\n return setActiveConsumer(node);\n}\n/**\n * Finalize this consumer's state after a reactive computation has run.\n *\n * Must be called by subclasses which represent reactive computations, after those computations\n * have finished.\n */\nfunction consumerAfterComputation(node, prevConsumer) {\n setActiveConsumer(prevConsumer);\n if (!node || node.producerNode === undefined || node.producerIndexOfThis === undefined || node.producerLastReadVersion === undefined) {\n return;\n }\n if (consumerIsLive(node)) {\n // For live consumers, we need to remove the producer -> consumer edge for any stale producers\n // which weren't dependencies after the recomputation.\n for (let i = node.nextProducerIndex; i < node.producerNode.length; i++) {\n producerRemoveLiveConsumerAtIndex(node.producerNode[i], node.producerIndexOfThis[i]);\n }\n }\n // Truncate the producer tracking arrays.\n // Perf note: this is essentially truncating the length to `node.nextProducerIndex`, but\n // benchmarking has shown that individual pop operations are faster.\n while (node.producerNode.length > node.nextProducerIndex) {\n node.producerNode.pop();\n node.producerLastReadVersion.pop();\n node.producerIndexOfThis.pop();\n }\n}\n/**\n * Determine whether this consumer has any dependencies which have changed since the last time\n * they were read.\n */\nfunction consumerPollProducersForChange(node) {\n assertConsumerNode(node);\n // Poll producers for change.\n for (let i = 0; i < node.producerNode.length; i++) {\n const producer = node.producerNode[i];\n const seenVersion = node.producerLastReadVersion[i];\n // First check the versions. A mismatch means that the producer's value is known to have\n // changed since the last time we read it.\n if (seenVersion !== producer.version) {\n return true;\n }\n // The producer's version is the same as the last time we read it, but it might itself be\n // stale. Force the producer to recompute its version (calculating a new value if necessary).\n producerUpdateValueVersion(producer);\n // Now when we do this check, `producer.version` is guaranteed to be up to date, so if the\n // versions still match then it has not changed since the last time we read it.\n if (seenVersion !== producer.version) {\n return true;\n }\n }\n return false;\n}\n/**\n * Disconnect this consumer from the graph.\n */\nfunction consumerDestroy(node) {\n assertConsumerNode(node);\n if (consumerIsLive(node)) {\n // Drop all connections from the graph to this node.\n for (let i = 0; i < node.producerNode.length; i++) {\n producerRemoveLiveConsumerAtIndex(node.producerNode[i], node.producerIndexOfThis[i]);\n }\n }\n // Truncate all the arrays to drop all connection from this node to the graph.\n node.producerNode.length = node.producerLastReadVersion.length = node.producerIndexOfThis.length = 0;\n if (node.liveConsumerNode) {\n node.liveConsumerNode.length = node.liveConsumerIndexOfThis.length = 0;\n }\n}\n/**\n * Add `consumer` as a live consumer of this node.\n *\n * Note that this operation is potentially transitive. If this node becomes live, then it becomes\n * a live consumer of all of its current producers.\n */\nfunction producerAddLiveConsumer(node, consumer, indexOfThis) {\n assertProducerNode(node);\n if (node.liveConsumerNode.length === 0 && isConsumerNode(node)) {\n // When going from 0 to 1 live consumers, we become a live consumer to our producers.\n for (let i = 0; i < node.producerNode.length; i++) {\n node.producerIndexOfThis[i] = producerAddLiveConsumer(node.producerNode[i], node, i);\n }\n }\n node.liveConsumerIndexOfThis.push(indexOfThis);\n return node.liveConsumerNode.push(consumer) - 1;\n}\n/**\n * Remove the live consumer at `idx`.\n */\nfunction producerRemoveLiveConsumerAtIndex(node, idx) {\n assertProducerNode(node);\n if (typeof ngDevMode !== 'undefined' && ngDevMode && idx >= node.liveConsumerNode.length) {\n throw new Error(`Assertion error: active consumer index ${idx} is out of bounds of ${node.liveConsumerNode.length} consumers)`);\n }\n if (node.liveConsumerNode.length === 1 && isConsumerNode(node)) {\n // When removing the last live consumer, we will no longer be live. We need to remove\n // ourselves from our producers' tracking (which may cause consumer-producers to lose\n // liveness as well).\n for (let i = 0; i < node.producerNode.length; i++) {\n producerRemoveLiveConsumerAtIndex(node.producerNode[i], node.producerIndexOfThis[i]);\n }\n }\n // Move the last value of `liveConsumers` into `idx`. Note that if there's only a single\n // live consumer, this is a no-op.\n const lastIdx = node.liveConsumerNode.length - 1;\n node.liveConsumerNode[idx] = node.liveConsumerNode[lastIdx];\n node.liveConsumerIndexOfThis[idx] = node.liveConsumerIndexOfThis[lastIdx];\n // Truncate the array.\n node.liveConsumerNode.length--;\n node.liveConsumerIndexOfThis.length--;\n // If the index is still valid, then we need to fix the index pointer from the producer to this\n // consumer, and update it from `lastIdx` to `idx` (accounting for the move above).\n if (idx < node.liveConsumerNode.length) {\n const idxProducer = node.liveConsumerIndexOfThis[idx];\n const consumer = node.liveConsumerNode[idx];\n assertConsumerNode(consumer);\n consumer.producerIndexOfThis[idxProducer] = idx;\n }\n}\nfunction consumerIsLive(node) {\n return node.consumerIsAlwaysLive || (node?.liveConsumerNode?.length ?? 0) > 0;\n}\nfunction assertConsumerNode(node) {\n node.producerNode ??= [];\n node.producerIndexOfThis ??= [];\n node.producerLastReadVersion ??= [];\n}\nfunction assertProducerNode(node) {\n node.liveConsumerNode ??= [];\n node.liveConsumerIndexOfThis ??= [];\n}\nfunction isConsumerNode(node) {\n return node.producerNode !== undefined;\n}\n\n/**\n * Create a computed signal which derives a reactive value from an expression.\n */\nfunction createComputed(computation) {\n const node = Object.create(COMPUTED_NODE);\n node.computation = computation;\n const computed = () => {\n // Check if the value needs updating before returning it.\n producerUpdateValueVersion(node);\n // Record that someone looked at this signal.\n producerAccessed(node);\n if (node.value === ERRORED) {\n throw node.error;\n }\n return node.value;\n };\n computed[SIGNAL] = node;\n return computed;\n}\n/**\n * A dedicated symbol used before a computed value has been calculated for the first time.\n * Explicitly typed as `any` so we can use it as signal's value.\n */\nconst UNSET = /* @__PURE__ */Symbol('UNSET');\n/**\n * A dedicated symbol used in place of a computed signal value to indicate that a given computation\n * is in progress. Used to detect cycles in computation chains.\n * Explicitly typed as `any` so we can use it as signal's value.\n */\nconst COMPUTING = /* @__PURE__ */Symbol('COMPUTING');\n/**\n * A dedicated symbol used in place of a computed signal value to indicate that a given computation\n * failed. The thrown error is cached until the computation gets dirty again.\n * Explicitly typed as `any` so we can use it as signal's value.\n */\nconst ERRORED = /* @__PURE__ */Symbol('ERRORED');\n// Note: Using an IIFE here to ensure that the spread assignment is not considered\n// a side-effect, ending up preserving `COMPUTED_NODE` and `REACTIVE_NODE`.\n// TODO: remove when https://github.com/evanw/esbuild/issues/3392 is resolved.\nconst COMPUTED_NODE = /* @__PURE__ */(() => {\n return {\n ...REACTIVE_NODE,\n value: UNSET,\n dirty: true,\n error: null,\n equal: defaultEquals,\n producerMustRecompute(node) {\n // Force a recomputation if there's no current value, or if the current value is in the\n // process of being calculated (which should throw an error).\n return node.value === UNSET || node.value === COMPUTING;\n },\n producerRecomputeValue(node) {\n if (node.value === COMPUTING) {\n // Our computation somehow led to a cyclic read of itself.\n throw new Error('Detected cycle in computations.');\n }\n const oldValue = node.value;\n node.value = COMPUTING;\n const prevConsumer = consumerBeforeComputation(node);\n let newValue;\n try {\n newValue = node.computation();\n } catch (err) {\n newValue = ERRORED;\n node.error = err;\n } finally {\n consumerAfterComputation(node, prevConsumer);\n }\n if (oldValue !== UNSET && oldValue !== ERRORED && newValue !== ERRORED && node.equal(oldValue, newValue)) {\n // No change to `valueVersion` - old and new values are\n // semantically equivalent.\n node.value = oldValue;\n return;\n }\n node.value = newValue;\n node.version++;\n }\n };\n})();\nfunction defaultThrowError() {\n throw new Error();\n}\nlet throwInvalidWriteToSignalErrorFn = defaultThrowError;\nfunction throwInvalidWriteToSignalError() {\n throwInvalidWriteToSignalErrorFn();\n}\nfunction setThrowInvalidWriteToSignalError(fn) {\n throwInvalidWriteToSignalErrorFn = fn;\n}\n\n/**\n * If set, called after `WritableSignal`s are updated.\n *\n * This hook can be used to achieve various effects, such as running effects synchronously as part\n * of setting a signal.\n */\nlet postSignalSetFn = null;\n/**\n * Create a `Signal` that can be set or updated directly.\n */\nfunction createSignal(initialValue) {\n const node = Object.create(SIGNAL_NODE);\n node.value = initialValue;\n const getter = () => {\n producerAccessed(node);\n return node.value;\n };\n getter[SIGNAL] = node;\n return getter;\n}\nfunction setPostSignalSetFn(fn) {\n const prev = postSignalSetFn;\n postSignalSetFn = fn;\n return prev;\n}\nfunction signalGetFn() {\n producerAccessed(this);\n return this.value;\n}\nfunction signalSetFn(node, newValue) {\n if (!producerUpdatesAllowed()) {\n throwInvalidWriteToSignalError();\n }\n if (!node.equal(node.value, newValue)) {\n node.value = newValue;\n signalValueChanged(node);\n }\n}\nfunction signalUpdateFn(node, updater) {\n if (!producerUpdatesAllowed()) {\n throwInvalidWriteToSignalError();\n }\n signalSetFn(node, updater(node.value));\n}\nfunction runPostSignalSetFn() {\n postSignalSetFn?.();\n}\n// Note: Using an IIFE here to ensure that the spread assignment is not considered\n// a side-effect, ending up preserving `COMPUTED_NODE` and `REACTIVE_NODE`.\n// TODO: remove when https://github.com/evanw/esbuild/issues/3392 is resolved.\nconst SIGNAL_NODE = /* @__PURE__ */(() => {\n return {\n ...REACTIVE_NODE,\n equal: defaultEquals,\n value: undefined\n };\n})();\nfunction signalValueChanged(node) {\n node.version++;\n producerIncrementEpoch();\n producerNotifyConsumers(node);\n postSignalSetFn?.();\n}\nfunction createWatch(fn, schedule, allowSignalWrites) {\n const node = Object.create(WATCH_NODE);\n if (allowSignalWrites) {\n node.consumerAllowSignalWrites = true;\n }\n node.fn = fn;\n node.schedule = schedule;\n const registerOnCleanup = cleanupFn => {\n node.cleanupFn = cleanupFn;\n };\n function isWatchNodeDestroyed(node) {\n return node.fn === null && node.schedule === null;\n }\n function destroyWatchNode(node) {\n if (!isWatchNodeDestroyed(node)) {\n consumerDestroy(node); // disconnect watcher from the reactive graph\n node.cleanupFn();\n // nullify references to the integration functions to mark node as destroyed\n node.fn = null;\n node.schedule = null;\n node.cleanupFn = NOOP_CLEANUP_FN;\n }\n }\n const run = () => {\n if (node.fn === null) {\n // trying to run a destroyed watch is noop\n return;\n }\n if (isInNotificationPhase()) {\n throw new Error(`Schedulers cannot synchronously execute watches while scheduling.`);\n }\n node.dirty = false;\n if (node.hasRun && !consumerPollProducersForChange(node)) {\n return;\n }\n node.hasRun = true;\n const prevConsumer = consumerBeforeComputation(node);\n try {\n node.cleanupFn();\n node.cleanupFn = NOOP_CLEANUP_FN;\n node.fn(registerOnCleanup);\n } finally {\n consumerAfterComputation(node, prevConsumer);\n }\n };\n node.ref = {\n notify: () => consumerMarkDirty(node),\n run,\n cleanup: () => node.cleanupFn(),\n destroy: () => destroyWatchNode(node),\n [SIGNAL]: node\n };\n return node.ref;\n}\nconst NOOP_CLEANUP_FN = () => {};\n// Note: Using an IIFE here to ensure that the spread assignment is not considered\n// a side-effect, ending up preserving `COMPUTED_NODE` and `REACTIVE_NODE`.\n// TODO: remove when https://github.com/evanw/esbuild/issues/3392 is resolved.\nconst WATCH_NODE = /* @__PURE__ */(() => {\n return {\n ...REACTIVE_NODE,\n consumerIsAlwaysLive: true,\n consumerAllowSignalWrites: false,\n consumerMarkedDirty: node => {\n if (node.schedule !== null) {\n node.schedule(node.ref);\n }\n },\n hasRun: false,\n cleanupFn: NOOP_CLEANUP_FN\n };\n})();\nfunction setAlternateWeakRefImpl(impl) {\n // TODO: remove this function\n}\nexport { REACTIVE_NODE, SIGNAL, SIGNAL_NODE, consumerAfterComputation, consumerBeforeComputation, consumerDestroy, consumerMarkDirty, consumerPollProducersForChange, createComputed, createSignal, createWatch, defaultEquals, getActiveConsumer, isInNotificationPhase, isReactive, producerAccessed, producerIncrementEpoch, producerNotifyConsumers, producerUpdateValueVersion, producerUpdatesAllowed, runPostSignalSetFn, setActiveConsumer, setAlternateWeakRefImpl, setPostSignalSetFn, setThrowInvalidWriteToSignalError, signalSetFn, signalUpdateFn };\n","/**\n * @license Angular v18.2.12\n * (c) 2010-2024 Google LLC. https://angular.io/\n * License: MIT\n */\n\nimport { SIGNAL_NODE as SIGNAL_NODE$1, signalSetFn as signalSetFn$1, producerAccessed as producerAccessed$1, SIGNAL as SIGNAL$1, getActiveConsumer as getActiveConsumer$1, setActiveConsumer as setActiveConsumer$1, consumerDestroy as consumerDestroy$1, REACTIVE_NODE as REACTIVE_NODE$1, consumerBeforeComputation as consumerBeforeComputation$1, consumerAfterComputation as consumerAfterComputation$1, consumerPollProducersForChange as consumerPollProducersForChange$1, createSignal as createSignal$1, signalUpdateFn as signalUpdateFn$1, createComputed as createComputed$1, setThrowInvalidWriteToSignalError as setThrowInvalidWriteToSignalError$1, createWatch as createWatch$1 } from '@angular/core/primitives/signals';\nexport { SIGNAL as ɵSIGNAL } from '@angular/core/primitives/signals';\nimport { BehaviorSubject, Subject, Subscription } from 'rxjs';\nimport { map, first } from 'rxjs/operators';\nimport { Attribute as Attribute$1, EventContract, EventContractContainer, getAppScopedQueuedEventInfos, clearAppScopedEarlyEventContract, EventDispatcher, registerDispatcher, isEarlyEventType, isCaptureEventType } from '@angular/core/primitives/event-dispatch';\n\n/**\n * Base URL for the error details page.\n *\n * Keep this constant in sync across:\n * - packages/compiler-cli/src/ngtsc/diagnostics/src/error_details_base_url.ts\n * - packages/core/src/error_details_base_url.ts\n */\nconst ERROR_DETAILS_PAGE_BASE_URL = 'https://angular.dev/errors';\n/**\n * URL for the XSS security documentation.\n */\nconst XSS_SECURITY_URL = 'https://g.co/ng/security#xss';\n\n/**\n * Class that represents a runtime error.\n * Formats and outputs the error message in a consistent way.\n *\n * Example:\n * ```\n * throw new RuntimeError(\n * RuntimeErrorCode.INJECTOR_ALREADY_DESTROYED,\n * ngDevMode && 'Injector has already been destroyed.');\n * ```\n *\n * Note: the `message` argument contains a descriptive error message as a string in development\n * mode (when the `ngDevMode` is defined). In production mode (after tree-shaking pass), the\n * `message` argument becomes `false`, thus we account for it in the typings and the runtime\n * logic.\n */\nclass RuntimeError extends Error {\n constructor(code, message) {\n super(formatRuntimeError(code, message));\n this.code = code;\n }\n}\n/**\n * Called to format a runtime error.\n * See additional info on the `message` argument type in the `RuntimeError` class description.\n */\nfunction formatRuntimeError(code, message) {\n // Error code might be a negative number, which is a special marker that instructs the logic to\n // generate a link to the error details page on angular.io.\n // We also prepend `0` to non-compile-time errors.\n const fullCode = `NG0${Math.abs(code)}`;\n let errorMessage = `${fullCode}${message ? ': ' + message : ''}`;\n if (ngDevMode && code < 0) {\n const addPeriodSeparator = !errorMessage.match(/[.,;!?\\n]$/);\n const separator = addPeriodSeparator ? '.' : '';\n errorMessage = `${errorMessage}${separator} Find more at ${ERROR_DETAILS_PAGE_BASE_URL}/${fullCode}`;\n }\n return errorMessage;\n}\nconst REQUIRED_UNSET_VALUE = /* @__PURE__ */Symbol('InputSignalNode#UNSET');\n// Note: Using an IIFE here to ensure that the spread assignment is not considered\n// a side-effect, ending up preserving `COMPUTED_NODE` and `REACTIVE_NODE`.\n// TODO: remove when https://github.com/evanw/esbuild/issues/3392 is resolved.\nconst INPUT_SIGNAL_NODE = /* @__PURE__ */(() => {\n return {\n ...SIGNAL_NODE$1,\n transformFn: undefined,\n applyValueToInputSignal(node, value) {\n signalSetFn$1(node, value);\n }\n };\n})();\nconst ɵINPUT_SIGNAL_BRAND_READ_TYPE = /* @__PURE__ */Symbol();\nconst ɵINPUT_SIGNAL_BRAND_WRITE_TYPE = /* @__PURE__ */Symbol();\n/**\n * Creates an input signal.\n *\n * @param initialValue The initial value.\n * Can be set to {@link REQUIRED_UNSET_VALUE} for required inputs.\n * @param options Additional options for the input. e.g. a transform, or an alias.\n */\nfunction createInputSignal(initialValue, options) {\n const node = Object.create(INPUT_SIGNAL_NODE);\n node.value = initialValue;\n // Perf note: Always set `transformFn` here to ensure that `node` always\n // has the same v8 class shape, allowing monomorphic reads on input signals.\n node.transformFn = options?.transform;\n function inputValueFn() {\n // Record that someone looked at this signal.\n producerAccessed$1(node);\n if (node.value === REQUIRED_UNSET_VALUE) {\n throw new RuntimeError(-950 /* RuntimeErrorCode.REQUIRED_INPUT_NO_VALUE */, ngDevMode && 'Input is required but no value is available yet.');\n }\n return node.value;\n }\n inputValueFn[SIGNAL$1] = node;\n if (ngDevMode) {\n inputValueFn.toString = () => `[Input Signal: ${inputValueFn()}]`;\n }\n return inputValueFn;\n}\n\n/**\n * Convince closure compiler that the wrapped function has no side-effects.\n *\n * Closure compiler always assumes that `toString` has no side-effects. We use this quirk to\n * allow us to execute a function but have closure compiler mark the call as no-side-effects.\n * It is important that the return value for the `noSideEffects` function be assigned\n * to something which is retained otherwise the call to `noSideEffects` will be removed by closure\n * compiler.\n */\nfunction noSideEffects(fn) {\n return {\n toString: fn\n }.toString();\n}\nconst ANNOTATIONS = '__annotations__';\nconst PARAMETERS = '__parameters__';\nconst PROP_METADATA = '__prop__metadata__';\n/**\n * @suppress {globalThis}\n */\nfunction makeDecorator(name, props, parentClass, additionalProcessing, typeFn) {\n return noSideEffects(() => {\n const metaCtor = makeMetadataCtor(props);\n function DecoratorFactory(...args) {\n if (this instanceof DecoratorFactory) {\n metaCtor.call(this, ...args);\n return this;\n }\n const annotationInstance = new DecoratorFactory(...args);\n return function TypeDecorator(cls) {\n if (typeFn) typeFn(cls, ...args);\n // Use of Object.defineProperty is important since it creates non-enumerable property which\n // prevents the property is copied during subclassing.\n const annotations = cls.hasOwnProperty(ANNOTATIONS) ? cls[ANNOTATIONS] : Object.defineProperty(cls, ANNOTATIONS, {\n value: []\n })[ANNOTATIONS];\n annotations.push(annotationInstance);\n if (additionalProcessing) additionalProcessing(cls);\n return cls;\n };\n }\n if (parentClass) {\n DecoratorFactory.prototype = Object.create(parentClass.prototype);\n }\n DecoratorFactory.prototype.ngMetadataName = name;\n DecoratorFactory.annotationCls = DecoratorFactory;\n return DecoratorFactory;\n });\n}\nfunction makeMetadataCtor(props) {\n return function ctor(...args) {\n if (props) {\n const values = props(...args);\n for (const propName in values) {\n this[propName] = values[propName];\n }\n }\n };\n}\nfunction makeParamDecorator(name, props, parentClass) {\n return noSideEffects(() => {\n const metaCtor = makeMetadataCtor(props);\n function ParamDecoratorFactory(...args) {\n if (this instanceof ParamDecoratorFactory) {\n metaCtor.apply(this, args);\n return this;\n }\n const annotationInstance = new ParamDecoratorFactory(...args);\n ParamDecorator.annotation = annotationInstance;\n return ParamDecorator;\n function ParamDecorator(cls, unusedKey, index) {\n // Use of Object.defineProperty is important since it creates non-enumerable property which\n // prevents the property is copied during subclassing.\n const parameters = cls.hasOwnProperty(PARAMETERS) ? cls[PARAMETERS] : Object.defineProperty(cls, PARAMETERS, {\n value: []\n })[PARAMETERS];\n // there might be gaps if some in between parameters do not have annotations.\n // we pad with nulls.\n while (parameters.length <= index) {\n parameters.push(null);\n }\n (parameters[index] = parameters[index] || []).push(annotationInstance);\n return cls;\n }\n }\n if (parentClass) {\n ParamDecoratorFactory.prototype = Object.create(parentClass.prototype);\n }\n ParamDecoratorFactory.prototype.ngMetadataName = name;\n ParamDecoratorFactory.annotationCls = ParamDecoratorFactory;\n return ParamDecoratorFactory;\n });\n}\nfunction makePropDecorator(name, props, parentClass, additionalProcessing) {\n return noSideEffects(() => {\n const metaCtor = makeMetadataCtor(props);\n function PropDecoratorFactory(...args) {\n if (this instanceof PropDecoratorFactory) {\n metaCtor.apply(this, args);\n return this;\n }\n const decoratorInstance = new PropDecoratorFactory(...args);\n function PropDecorator(target, name) {\n // target is undefined with standard decorators. This case is not supported and will throw\n // if this decorator is used in JIT mode with standard decorators.\n if (target === undefined) {\n throw new Error('Standard Angular field decorators are not supported in JIT mode.');\n }\n const constructor = target.constructor;\n // Use of Object.defineProperty is important because it creates a non-enumerable property\n // which prevents the property from being copied during subclassing.\n const meta = constructor.hasOwnProperty(PROP_METADATA) ? constructor[PROP_METADATA] : Object.defineProperty(constructor, PROP_METADATA, {\n value: {}\n })[PROP_METADATA];\n meta[name] = meta.hasOwnProperty(name) && meta[name] || [];\n meta[name].unshift(decoratorInstance);\n if (additionalProcessing) additionalProcessing(target, name, ...args);\n }\n return PropDecorator;\n }\n if (parentClass) {\n PropDecoratorFactory.prototype = Object.create(parentClass.prototype);\n }\n PropDecoratorFactory.prototype.ngMetadataName = name;\n PropDecoratorFactory.annotationCls = PropDecoratorFactory;\n return PropDecoratorFactory;\n });\n}\nconst _global = globalThis;\nfunction ngDevModeResetPerfCounters() {\n const locationString = typeof location !== 'undefined' ? location.toString() : '';\n const newCounters = {\n namedConstructors: locationString.indexOf('ngDevMode=namedConstructors') != -1,\n firstCreatePass: 0,\n tNode: 0,\n tView: 0,\n rendererCreateTextNode: 0,\n rendererSetText: 0,\n rendererCreateElement: 0,\n rendererAddEventListener: 0,\n rendererSetAttribute: 0,\n rendererRemoveAttribute: 0,\n rendererSetProperty: 0,\n rendererSetClassName: 0,\n rendererAddClass: 0,\n rendererRemoveClass: 0,\n rendererSetStyle: 0,\n rendererRemoveStyle: 0,\n rendererDestroy: 0,\n rendererDestroyNode: 0,\n rendererMoveNode: 0,\n rendererRemoveNode: 0,\n rendererAppendChild: 0,\n rendererInsertBefore: 0,\n rendererCreateComment: 0,\n hydratedNodes: 0,\n hydratedComponents: 0,\n dehydratedViewsRemoved: 0,\n dehydratedViewsCleanupRuns: 0,\n componentsSkippedHydration: 0\n };\n // Make sure to refer to ngDevMode as ['ngDevMode'] for closure.\n const allowNgDevModeTrue = locationString.indexOf('ngDevMode=false') === -1;\n if (!allowNgDevModeTrue) {\n _global['ngDevMode'] = false;\n } else {\n if (typeof _global['ngDevMode'] !== 'object') {\n _global['ngDevMode'] = {};\n }\n Object.assign(_global['ngDevMode'], newCounters);\n }\n return newCounters;\n}\n/**\n * This function checks to see if the `ngDevMode` has been set. If yes,\n * then we honor it, otherwise we default to dev mode with additional checks.\n *\n * The idea is that unless we are doing production build where we explicitly\n * set `ngDevMode == false` we should be helping the developer by providing\n * as much early warning and errors as possible.\n *\n * `ɵɵdefineComponent` is guaranteed to have been called before any component template functions\n * (and thus Ivy instructions), so a single initialization there is sufficient to ensure ngDevMode\n * is defined for the entire instruction set.\n *\n * When checking `ngDevMode` on toplevel, always init it before referencing it\n * (e.g. `((typeof ngDevMode === 'undefined' || ngDevMode) && initNgDevMode())`), otherwise you can\n * get a `ReferenceError` like in https://github.com/angular/angular/issues/31595.\n *\n * Details on possible values for `ngDevMode` can be found on its docstring.\n *\n * NOTE:\n * - changes to the `ngDevMode` name must be synced with `compiler-cli/src/tooling.ts`.\n */\nfunction initNgDevMode() {\n // The below checks are to ensure that calling `initNgDevMode` multiple times does not\n // reset the counters.\n // If the `ngDevMode` is not an object, then it means we have not created the perf counters\n // yet.\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n if (typeof ngDevMode !== 'object' || Object.keys(ngDevMode).length === 0) {\n ngDevModeResetPerfCounters();\n }\n return typeof ngDevMode !== 'undefined' && !!ngDevMode;\n }\n return false;\n}\nfunction getClosureSafeProperty(objWithPropertyToExtract) {\n for (let key in objWithPropertyToExtract) {\n if (objWithPropertyToExtract[key] === getClosureSafeProperty) {\n return key;\n }\n }\n throw Error('Could not find renamed property on target object.');\n}\n/**\n * Sets properties on a target object from a source object, but only if\n * the property doesn't already exist on the target object.\n * @param target The target to set properties on\n * @param source The source of the property keys and values to set\n */\nfunction fillProperties(target, source) {\n for (const key in source) {\n if (source.hasOwnProperty(key) && !target.hasOwnProperty(key)) {\n target[key] = source[key];\n }\n }\n}\nfunction stringify(token) {\n if (typeof token === 'string') {\n return token;\n }\n if (Array.isArray(token)) {\n return '[' + token.map(stringify).join(', ') + ']';\n }\n if (token == null) {\n return '' + token;\n }\n if (token.overriddenName) {\n return `${token.overriddenName}`;\n }\n if (token.name) {\n return `${token.name}`;\n }\n const res = token.toString();\n if (res == null) {\n return '' + res;\n }\n const newLineIndex = res.indexOf('\\n');\n return newLineIndex === -1 ? res : res.substring(0, newLineIndex);\n}\n/**\n * Concatenates two strings with separator, allocating new strings only when necessary.\n *\n * @param before before string.\n * @param separator separator string.\n * @param after after string.\n * @returns concatenated string.\n */\nfunction concatStringsWithSpace(before, after) {\n return before == null || before === '' ? after === null ? '' : after : after == null || after === '' ? before : before + ' ' + after;\n}\n/**\n * Ellipses the string in the middle when longer than the max length\n *\n * @param string\n * @param maxLength of the output string\n * @returns ellipsed string with ... in the middle\n */\nfunction truncateMiddle(str, maxLength = 100) {\n if (!str || maxLength < 1 || str.length <= maxLength) return str;\n if (maxLength == 1) return str.substring(0, 1) + '...';\n const halfLimit = Math.round(maxLength / 2);\n return str.substring(0, halfLimit) + '...' + str.substring(str.length - halfLimit);\n}\nconst __forward_ref__ = /*#__PURE__*/getClosureSafeProperty({\n __forward_ref__: getClosureSafeProperty\n});\n/**\n * Allows to refer to references which are not yet defined.\n *\n * For instance, `forwardRef` is used when the `token` which we need to refer to for the purposes of\n * DI is declared, but not yet defined. It is also used when the `token` which we use when creating\n * a query is not yet defined.\n *\n * `forwardRef` is also used to break circularities in standalone components imports.\n *\n * @usageNotes\n * ### Circular dependency example\n * {@example core/di/ts/forward_ref/forward_ref_spec.ts region='forward_ref'}\n *\n * ### Circular standalone reference import example\n * ```ts\n * @Component({\n * standalone: true,\n * imports: [ChildComponent],\n * selector: 'app-parent',\n * template: ``,\n * })\n * export class ParentComponent {\n * @Input() hideParent: boolean;\n * }\n *\n *\n * @Component({\n * standalone: true,\n * imports: [CommonModule, forwardRef(() => ParentComponent)],\n * selector: 'app-child',\n * template: ``,\n * })\n * export class ChildComponent {\n * @Input() hideParent: boolean;\n * }\n * ```\n *\n * @publicApi\n */\nfunction forwardRef(forwardRefFn) {\n forwardRefFn.__forward_ref__ = forwardRef;\n forwardRefFn.toString = function () {\n return stringify(this());\n };\n return forwardRefFn;\n}\n/**\n * Lazily retrieves the reference value from a forwardRef.\n *\n * Acts as the identity function when given a non-forward-ref value.\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/di/ts/forward_ref/forward_ref_spec.ts region='resolve_forward_ref'}\n *\n * @see {@link forwardRef}\n * @publicApi\n */\nfunction resolveForwardRef(type) {\n return isForwardRef(type) ? type() : type;\n}\n/** Checks whether a function is wrapped by a `forwardRef`. */\nfunction isForwardRef(fn) {\n return typeof fn === 'function' && fn.hasOwnProperty(__forward_ref__) && fn.__forward_ref__ === forwardRef;\n}\n\n// The functions in this file verify that the assumptions we are making\nfunction assertNumber(actual, msg) {\n if (!(typeof actual === 'number')) {\n throwError(msg, typeof actual, 'number', '===');\n }\n}\nfunction assertNumberInRange(actual, minInclusive, maxInclusive) {\n assertNumber(actual, 'Expected a number');\n assertLessThanOrEqual(actual, maxInclusive, 'Expected number to be less than or equal to');\n assertGreaterThanOrEqual(actual, minInclusive, 'Expected number to be greater than or equal to');\n}\nfunction assertString(actual, msg) {\n if (!(typeof actual === 'string')) {\n throwError(msg, actual === null ? 'null' : typeof actual, 'string', '===');\n }\n}\nfunction assertFunction(actual, msg) {\n if (!(typeof actual === 'function')) {\n throwError(msg, actual === null ? 'null' : typeof actual, 'function', '===');\n }\n}\nfunction assertEqual(actual, expected, msg) {\n if (!(actual == expected)) {\n throwError(msg, actual, expected, '==');\n }\n}\nfunction assertNotEqual(actual, expected, msg) {\n if (!(actual != expected)) {\n throwError(msg, actual, expected, '!=');\n }\n}\nfunction assertSame(actual, expected, msg) {\n if (!(actual === expected)) {\n throwError(msg, actual, expected, '===');\n }\n}\nfunction assertNotSame(actual, expected, msg) {\n if (!(actual !== expected)) {\n throwError(msg, actual, expected, '!==');\n }\n}\nfunction assertLessThan(actual, expected, msg) {\n if (!(actual < expected)) {\n throwError(msg, actual, expected, '<');\n }\n}\nfunction assertLessThanOrEqual(actual, expected, msg) {\n if (!(actual <= expected)) {\n throwError(msg, actual, expected, '<=');\n }\n}\nfunction assertGreaterThan(actual, expected, msg) {\n if (!(actual > expected)) {\n throwError(msg, actual, expected, '>');\n }\n}\nfunction assertGreaterThanOrEqual(actual, expected, msg) {\n if (!(actual >= expected)) {\n throwError(msg, actual, expected, '>=');\n }\n}\nfunction assertNotDefined(actual, msg) {\n if (actual != null) {\n throwError(msg, actual, null, '==');\n }\n}\nfunction assertDefined(actual, msg) {\n if (actual == null) {\n throwError(msg, actual, null, '!=');\n }\n}\nfunction throwError(msg, actual, expected, comparison) {\n throw new Error(`ASSERTION ERROR: ${msg}` + (comparison == null ? '' : ` [Expected=> ${expected} ${comparison} ${actual} <=Actual]`));\n}\nfunction assertDomNode(node) {\n if (!(node instanceof Node)) {\n throwError(`The provided value must be an instance of a DOM Node but got ${stringify(node)}`);\n }\n}\nfunction assertElement(node) {\n if (!(node instanceof Element)) {\n throwError(`The provided value must be an element but got ${stringify(node)}`);\n }\n}\nfunction assertIndexInRange(arr, index) {\n assertDefined(arr, 'Array must be defined.');\n const maxLen = arr.length;\n if (index < 0 || index >= maxLen) {\n throwError(`Index expected to be less than ${maxLen} but got ${index}`);\n }\n}\nfunction assertOneOf(value, ...validValues) {\n if (validValues.indexOf(value) !== -1) return true;\n throwError(`Expected value to be one of ${JSON.stringify(validValues)} but was ${JSON.stringify(value)}.`);\n}\nfunction assertNotReactive(fn) {\n if (getActiveConsumer$1() !== null) {\n throwError(`${fn}() should never be called in a reactive context.`);\n }\n}\n\n/**\n * Construct an injectable definition which defines how a token will be constructed by the DI\n * system, and in which injectors (if any) it will be available.\n *\n * This should be assigned to a static `ɵprov` field on a type, which will then be an\n * `InjectableType`.\n *\n * Options:\n * * `providedIn` determines which injectors will include the injectable, by either associating it\n * with an `@NgModule` or other `InjectorType`, or by specifying that this injectable should be\n * provided in the `'root'` injector, which will be the application-level injector in most apps.\n * * `factory` gives the zero argument function which will create an instance of the injectable.\n * The factory can call [`inject`](api/core/inject) to access the `Injector` and request injection\n * of dependencies.\n *\n * @codeGenApi\n * @publicApi This instruction has been emitted by ViewEngine for some time and is deployed to npm.\n */\nfunction ɵɵdefineInjectable(opts) {\n return {\n token: opts.token,\n providedIn: opts.providedIn || null,\n factory: opts.factory,\n value: undefined\n };\n}\n/**\n * @deprecated in v8, delete after v10. This API should be used only by generated code, and that\n * code should now use ɵɵdefineInjectable instead.\n * @publicApi\n */\nconst defineInjectable = ɵɵdefineInjectable;\n/**\n * Construct an `InjectorDef` which configures an injector.\n *\n * This should be assigned to a static injector def (`ɵinj`) field on a type, which will then be an\n * `InjectorType`.\n *\n * Options:\n *\n * * `providers`: an optional array of providers to add to the injector. Each provider must\n * either have a factory or point to a type which has a `ɵprov` static property (the\n * type must be an `InjectableType`).\n * * `imports`: an optional array of imports of other `InjectorType`s or `InjectorTypeWithModule`s\n * whose providers will also be added to the injector. Locally provided types will override\n * providers from imports.\n *\n * @codeGenApi\n */\nfunction ɵɵdefineInjector(options) {\n return {\n providers: options.providers || [],\n imports: options.imports || []\n };\n}\n/**\n * Read the injectable def (`ɵprov`) for `type` in a way which is immune to accidentally reading\n * inherited value.\n *\n * @param type A type which may have its own (non-inherited) `ɵprov`.\n */\nfunction getInjectableDef(type) {\n return getOwnDefinition(type, NG_PROV_DEF) || getOwnDefinition(type, NG_INJECTABLE_DEF);\n}\nfunction isInjectable(type) {\n return getInjectableDef(type) !== null;\n}\n/**\n * Return definition only if it is defined directly on `type` and is not inherited from a base\n * class of `type`.\n */\nfunction getOwnDefinition(type, field) {\n return type.hasOwnProperty(field) ? type[field] : null;\n}\n/**\n * Read the injectable def (`ɵprov`) for `type` or read the `ɵprov` from one of its ancestors.\n *\n * @param type A type which may have `ɵprov`, via inheritance.\n *\n * @deprecated Will be removed in a future version of Angular, where an error will occur in the\n * scenario if we find the `ɵprov` on an ancestor only.\n */\nfunction getInheritedInjectableDef(type) {\n const def = type && (type[NG_PROV_DEF] || type[NG_INJECTABLE_DEF]);\n if (def) {\n ngDevMode && console.warn(`DEPRECATED: DI is instantiating a token \"${type.name}\" that inherits its @Injectable decorator but does not provide one itself.\\n` + `This will become an error in a future version of Angular. Please add @Injectable() to the \"${type.name}\" class.`);\n return def;\n } else {\n return null;\n }\n}\n/**\n * Read the injector def type in a way which is immune to accidentally reading inherited value.\n *\n * @param type type which may have an injector def (`ɵinj`)\n */\nfunction getInjectorDef(type) {\n return type && (type.hasOwnProperty(NG_INJ_DEF) || type.hasOwnProperty(NG_INJECTOR_DEF)) ? type[NG_INJ_DEF] : null;\n}\nconst NG_PROV_DEF = /*#__PURE__*/getClosureSafeProperty({\n ɵprov: getClosureSafeProperty\n});\nconst NG_INJ_DEF = /*#__PURE__*/getClosureSafeProperty({\n ɵinj: getClosureSafeProperty\n});\n// We need to keep these around so we can read off old defs if new defs are unavailable\nconst NG_INJECTABLE_DEF = /*#__PURE__*/getClosureSafeProperty({\n ngInjectableDef: getClosureSafeProperty\n});\nconst NG_INJECTOR_DEF = /*#__PURE__*/getClosureSafeProperty({\n ngInjectorDef: getClosureSafeProperty\n});\n\n/**\n * Creates a token that can be used in a DI Provider.\n *\n * Use an `InjectionToken` whenever the type you are injecting is not reified (does not have a\n * runtime representation) such as when injecting an interface, callable type, array or\n * parameterized type.\n *\n * `InjectionToken` is parameterized on `T` which is the type of object which will be returned by\n * the `Injector`. This provides an additional level of type safety.\n *\n *
\n *\n * **Important Note**: Ensure that you use the same instance of the `InjectionToken` in both the\n * provider and the injection call. Creating a new instance of `InjectionToken` in different places,\n * even with the same description, will be treated as different tokens by Angular's DI system,\n * leading to a `NullInjectorError`.\n *\n *
\n *\n * \n *\n * When creating an `InjectionToken`, you can optionally specify a factory function which returns\n * (possibly by creating) a default value of the parameterized type `T`. This sets up the\n * `InjectionToken` using this factory as a provider as if it was defined explicitly in the\n * application's root injector. If the factory function, which takes zero arguments, needs to inject\n * dependencies, it can do so using the [`inject`](api/core/inject) function.\n * As you can see in the Tree-shakable InjectionToken example below.\n *\n * Additionally, if a `factory` is specified you can also specify the `providedIn` option, which\n * overrides the above behavior and marks the token as belonging to a particular `@NgModule` (note:\n * this option is now deprecated). As mentioned above, `'root'` is the default value for\n * `providedIn`.\n *\n * The `providedIn: NgModule` and `providedIn: 'any'` options are deprecated.\n *\n * @usageNotes\n * ### Basic Examples\n *\n * ### Plain InjectionToken\n *\n * {@example core/di/ts/injector_spec.ts region='InjectionToken'}\n *\n * ### Tree-shakable InjectionToken\n *\n * {@example core/di/ts/injector_spec.ts region='ShakableInjectionToken'}\n *\n * @publicApi\n */\nclass InjectionToken {\n /**\n * @param _desc Description for the token,\n * used only for debugging purposes,\n * it should but does not need to be unique\n * @param options Options for the token's usage, as described above\n */\n constructor(_desc, options) {\n this._desc = _desc;\n /** @internal */\n this.ngMetadataName = 'InjectionToken';\n this.ɵprov = undefined;\n if (typeof options == 'number') {\n (typeof ngDevMode === 'undefined' || ngDevMode) && assertLessThan(options, 0, 'Only negative numbers are supported here');\n // This is a special hack to assign __NG_ELEMENT_ID__ to this instance.\n // See `InjectorMarkers`\n this.__NG_ELEMENT_ID__ = options;\n } else if (options !== undefined) {\n this.ɵprov = ɵɵdefineInjectable({\n token: this,\n providedIn: options.providedIn || 'root',\n factory: options.factory\n });\n }\n }\n /**\n * @internal\n */\n get multi() {\n return this;\n }\n toString() {\n return `InjectionToken ${this._desc}`;\n }\n}\nlet _injectorProfilerContext;\nfunction getInjectorProfilerContext() {\n !ngDevMode && throwError('getInjectorProfilerContext should never be called in production mode');\n return _injectorProfilerContext;\n}\nfunction setInjectorProfilerContext(context) {\n !ngDevMode && throwError('setInjectorProfilerContext should never be called in production mode');\n const previous = _injectorProfilerContext;\n _injectorProfilerContext = context;\n return previous;\n}\nlet injectorProfilerCallback = null;\n/**\n * Sets the callback function which will be invoked during certain DI events within the\n * runtime (for example: injecting services, creating injectable instances, configuring providers)\n *\n * Warning: this function is *INTERNAL* and should not be relied upon in application's code.\n * The contract of the function might be changed in any release and/or the function can be removed\n * completely.\n *\n * @param profiler function provided by the caller or null value to disable profiling.\n */\nconst setInjectorProfiler = injectorProfiler => {\n !ngDevMode && throwError('setInjectorProfiler should never be called in production mode');\n injectorProfilerCallback = injectorProfiler;\n};\n/**\n * Injector profiler function which emits on DI events executed by the runtime.\n *\n * @param event InjectorProfilerEvent corresponding to the DI event being emitted\n */\nfunction injectorProfiler(event) {\n !ngDevMode && throwError('Injector profiler should never be called in production mode');\n if (injectorProfilerCallback != null /* both `null` and `undefined` */) {\n injectorProfilerCallback(event);\n }\n}\n/**\n * Emits an InjectorProfilerEventType.ProviderConfigured to the injector profiler. The data in the\n * emitted event includes the raw provider, as well as the token that provider is providing.\n *\n * @param eventProvider A provider object\n */\nfunction emitProviderConfiguredEvent(eventProvider, isViewProvider = false) {\n !ngDevMode && throwError('Injector profiler should never be called in production mode');\n let token;\n // if the provider is a TypeProvider (typeof provider is function) then the token is the\n // provider itself\n if (typeof eventProvider === 'function') {\n token = eventProvider;\n }\n // if the provider is an injection token, then the token is the injection token.\n else if (eventProvider instanceof InjectionToken) {\n token = eventProvider;\n }\n // in all other cases we can access the token via the `provide` property of the provider\n else {\n token = resolveForwardRef(eventProvider.provide);\n }\n let provider = eventProvider;\n // Injection tokens may define their own default provider which gets attached to the token itself\n // as `ɵprov`. In this case, we want to emit the provider that is attached to the token, not the\n // token itself.\n if (eventProvider instanceof InjectionToken) {\n provider = eventProvider.ɵprov || eventProvider;\n }\n injectorProfiler({\n type: 2 /* InjectorProfilerEventType.ProviderConfigured */,\n context: getInjectorProfilerContext(),\n providerRecord: {\n token,\n provider,\n isViewProvider\n }\n });\n}\n/**\n * Emits an event to the injector profiler with the instance that was created. Note that\n * the injector associated with this emission can be accessed by using getDebugInjectContext()\n *\n * @param instance an object created by an injector\n */\nfunction emitInstanceCreatedByInjectorEvent(instance) {\n !ngDevMode && throwError('Injector profiler should never be called in production mode');\n injectorProfiler({\n type: 1 /* InjectorProfilerEventType.InstanceCreatedByInjector */,\n context: getInjectorProfilerContext(),\n instance: {\n value: instance\n }\n });\n}\n/**\n * @param token DI token associated with injected service\n * @param value the instance of the injected service (i.e the result of `inject(token)`)\n * @param flags the flags that the token was injected with\n */\nfunction emitInjectEvent(token, value, flags) {\n !ngDevMode && throwError('Injector profiler should never be called in production mode');\n injectorProfiler({\n type: 0 /* InjectorProfilerEventType.Inject */,\n context: getInjectorProfilerContext(),\n service: {\n token,\n value,\n flags\n }\n });\n}\nfunction runInInjectorProfilerContext(injector, token, callback) {\n !ngDevMode && throwError('runInInjectorProfilerContext should never be called in production mode');\n const prevInjectContext = setInjectorProfilerContext({\n injector,\n token\n });\n try {\n callback();\n } finally {\n setInjectorProfilerContext(prevInjectContext);\n }\n}\nfunction isEnvironmentProviders(value) {\n return value && !!value.ɵproviders;\n}\nconst NG_COMP_DEF = /*#__PURE__*/getClosureSafeProperty({\n ɵcmp: getClosureSafeProperty\n});\nconst NG_DIR_DEF = /*#__PURE__*/getClosureSafeProperty({\n ɵdir: getClosureSafeProperty\n});\nconst NG_PIPE_DEF = /*#__PURE__*/getClosureSafeProperty({\n ɵpipe: getClosureSafeProperty\n});\nconst NG_MOD_DEF = /*#__PURE__*/getClosureSafeProperty({\n ɵmod: getClosureSafeProperty\n});\nconst NG_FACTORY_DEF = /*#__PURE__*/getClosureSafeProperty({\n ɵfac: getClosureSafeProperty\n});\n/**\n * If a directive is diPublic, bloomAdd sets a property on the type with this constant as\n * the key and the directive's unique ID as the value. This allows us to map directives to their\n * bloom filter bit for DI.\n */\n// TODO(misko): This is wrong. The NG_ELEMENT_ID should never be minified.\nconst NG_ELEMENT_ID = /*#__PURE__*/getClosureSafeProperty({\n __NG_ELEMENT_ID__: getClosureSafeProperty\n});\n/**\n * The `NG_ENV_ID` field on a DI token indicates special processing in the `EnvironmentInjector`:\n * getting such tokens from the `EnvironmentInjector` will bypass the standard DI resolution\n * strategy and instead will return implementation produced by the `NG_ENV_ID` factory function.\n *\n * This particular retrieval of DI tokens is mostly done to eliminate circular dependencies and\n * improve tree-shaking.\n */\nconst NG_ENV_ID = /*#__PURE__*/getClosureSafeProperty({\n __NG_ENV_ID__: getClosureSafeProperty\n});\n\n/**\n * Used for stringify render output in Ivy.\n * Important! This function is very performance-sensitive and we should\n * be extra careful not to introduce megamorphic reads in it.\n * Check `core/test/render3/perf/render_stringify` for benchmarks and alternate implementations.\n */\nfunction renderStringify(value) {\n if (typeof value === 'string') return value;\n if (value == null) return '';\n // Use `String` so that it invokes the `toString` method of the value. Note that this\n // appears to be faster than calling `value.toString` (see `render_stringify` benchmark).\n return String(value);\n}\n/**\n * Used to stringify a value so that it can be displayed in an error message.\n *\n * Important! This function contains a megamorphic read and should only be\n * used for error messages.\n */\nfunction stringifyForError(value) {\n if (typeof value === 'function') return value.name || value.toString();\n if (typeof value === 'object' && value != null && typeof value.type === 'function') {\n return value.type.name || value.type.toString();\n }\n return renderStringify(value);\n}\n/**\n * Used to stringify a `Type` and including the file path and line number in which it is defined, if\n * possible, for better debugging experience.\n *\n * Important! This function contains a megamorphic read and should only be used for error messages.\n */\nfunction debugStringifyTypeForError(type) {\n // TODO(pmvald): Do some refactoring so that we can use getComponentDef here without creating\n // circular deps.\n let componentDef = type[NG_COMP_DEF] || null;\n if (componentDef !== null && componentDef.debugInfo) {\n return stringifyTypeFromDebugInfo(componentDef.debugInfo);\n }\n return stringifyForError(type);\n}\n// TODO(pmvald): Do some refactoring so that we can use the type ClassDebugInfo for the param\n// debugInfo here without creating circular deps.\nfunction stringifyTypeFromDebugInfo(debugInfo) {\n if (!debugInfo.filePath || !debugInfo.lineNumber) {\n return debugInfo.className;\n } else {\n return `${debugInfo.className} (at ${debugInfo.filePath}:${debugInfo.lineNumber})`;\n }\n}\n\n/** Called when directives inject each other (creating a circular dependency) */\nfunction throwCyclicDependencyError(token, path) {\n const depPath = path ? `. Dependency path: ${path.join(' > ')} > ${token}` : '';\n throw new RuntimeError(-200 /* RuntimeErrorCode.CYCLIC_DI_DEPENDENCY */, ngDevMode ? `Circular dependency in DI detected for ${token}${depPath}` : token);\n}\nfunction throwMixedMultiProviderError() {\n throw new Error(`Cannot mix multi providers and regular providers`);\n}\nfunction throwInvalidProviderError(ngModuleType, providers, provider) {\n if (ngModuleType && providers) {\n const providerDetail = providers.map(v => v == provider ? '?' + provider + '?' : '...');\n throw new Error(`Invalid provider for the NgModule '${stringify(ngModuleType)}' - only instances of Provider and Type are allowed, got: [${providerDetail.join(', ')}]`);\n } else if (isEnvironmentProviders(provider)) {\n if (provider.ɵfromNgModule) {\n throw new RuntimeError(207 /* RuntimeErrorCode.PROVIDER_IN_WRONG_CONTEXT */, `Invalid providers from 'importProvidersFrom' present in a non-environment injector. 'importProvidersFrom' can't be used for component providers.`);\n } else {\n throw new RuntimeError(207 /* RuntimeErrorCode.PROVIDER_IN_WRONG_CONTEXT */, `Invalid providers present in a non-environment injector. 'EnvironmentProviders' can't be used for component providers.`);\n }\n } else {\n throw new Error('Invalid provider');\n }\n}\n/** Throws an error when a token is not found in DI. */\nfunction throwProviderNotFoundError(token, injectorName) {\n const errorMessage = ngDevMode && `No provider for ${stringifyForError(token)} found${injectorName ? ` in ${injectorName}` : ''}`;\n throw new RuntimeError(-201 /* RuntimeErrorCode.PROVIDER_NOT_FOUND */, errorMessage);\n}\n\n/**\n * Injection flags for DI.\n *\n * @publicApi\n * @deprecated use an options object for [`inject`](api/core/inject) instead.\n */\nvar InjectFlags = /*#__PURE__*/function (InjectFlags) {\n // TODO(alxhub): make this 'const' (and remove `InternalInjectFlags` enum) when ngc no longer\n // writes exports of it into ngfactory files.\n /** Check self and check parent injector if needed */\n InjectFlags[InjectFlags[\"Default\"] = 0] = \"Default\";\n /**\n * Specifies that an injector should retrieve a dependency from any injector until reaching the\n * host element of the current component. (Only used with Element Injector)\n */\n InjectFlags[InjectFlags[\"Host\"] = 1] = \"Host\";\n /** Don't ascend to ancestors of the node requesting injection. */\n InjectFlags[InjectFlags[\"Self\"] = 2] = \"Self\";\n /** Skip the node that is requesting injection. */\n InjectFlags[InjectFlags[\"SkipSelf\"] = 4] = \"SkipSelf\";\n /** Inject `defaultValue` instead if token not found. */\n InjectFlags[InjectFlags[\"Optional\"] = 8] = \"Optional\";\n return InjectFlags;\n}(InjectFlags || {});\n/**\n * Current implementation of inject.\n *\n * By default, it is `injectInjectorOnly`, which makes it `Injector`-only aware. It can be changed\n * to `directiveInject`, which brings in the `NodeInjector` system of ivy. It is designed this\n * way for two reasons:\n * 1. `Injector` should not depend on ivy logic.\n * 2. To maintain tree shake-ability we don't want to bring in unnecessary code.\n */\nlet _injectImplementation;\nfunction getInjectImplementation() {\n return _injectImplementation;\n}\n/**\n * Sets the current inject implementation.\n */\nfunction setInjectImplementation(impl) {\n const previous = _injectImplementation;\n _injectImplementation = impl;\n return previous;\n}\n/**\n * Injects `root` tokens in limp mode.\n *\n * If no injector exists, we can still inject tree-shakable providers which have `providedIn` set to\n * `\"root\"`. This is known as the limp mode injection. In such case the value is stored in the\n * injectable definition.\n */\nfunction injectRootLimpMode(token, notFoundValue, flags) {\n const injectableDef = getInjectableDef(token);\n if (injectableDef && injectableDef.providedIn == 'root') {\n return injectableDef.value === undefined ? injectableDef.value = injectableDef.factory() : injectableDef.value;\n }\n if (flags & InjectFlags.Optional) return null;\n if (notFoundValue !== undefined) return notFoundValue;\n throwProviderNotFoundError(token, 'Injector');\n}\n/**\n * Assert that `_injectImplementation` is not `fn`.\n *\n * This is useful, to prevent infinite recursion.\n *\n * @param fn Function which it should not equal to\n */\nfunction assertInjectImplementationNotEqual(fn) {\n ngDevMode && assertNotEqual(_injectImplementation, fn, 'Calling ɵɵinject would cause infinite recursion');\n}\nconst _THROW_IF_NOT_FOUND = {};\nconst THROW_IF_NOT_FOUND = _THROW_IF_NOT_FOUND;\n/*\n * Name of a property (that we patch onto DI decorator), which is used as an annotation of which\n * InjectFlag this decorator represents. This allows to avoid direct references to the DI decorators\n * in the code, thus making them tree-shakable.\n */\nconst DI_DECORATOR_FLAG = '__NG_DI_FLAG__';\nconst NG_TEMP_TOKEN_PATH = 'ngTempTokenPath';\nconst NG_TOKEN_PATH = 'ngTokenPath';\nconst NEW_LINE = /\\n/gm;\nconst NO_NEW_LINE = 'ɵ';\nconst SOURCE = '__source';\n/**\n * Current injector value used by `inject`.\n * - `undefined`: it is an error to call `inject`\n * - `null`: `inject` can be called but there is no injector (limp-mode).\n * - Injector instance: Use the injector for resolution.\n */\nlet _currentInjector = undefined;\nfunction getCurrentInjector() {\n return _currentInjector;\n}\nfunction setCurrentInjector(injector) {\n const former = _currentInjector;\n _currentInjector = injector;\n return former;\n}\nfunction injectInjectorOnly(token, flags = InjectFlags.Default) {\n if (_currentInjector === undefined) {\n throw new RuntimeError(-203 /* RuntimeErrorCode.MISSING_INJECTION_CONTEXT */, ngDevMode && `inject() must be called from an injection context such as a constructor, a factory function, a field initializer, or a function used with \\`runInInjectionContext\\`.`);\n } else if (_currentInjector === null) {\n return injectRootLimpMode(token, undefined, flags);\n } else {\n const value = _currentInjector.get(token, flags & InjectFlags.Optional ? null : undefined, flags);\n ngDevMode && emitInjectEvent(token, value, flags);\n return value;\n }\n}\nfunction ɵɵinject(token, flags = InjectFlags.Default) {\n return (getInjectImplementation() || injectInjectorOnly)(resolveForwardRef(token), flags);\n}\n/**\n * Throws an error indicating that a factory function could not be generated by the compiler for a\n * particular class.\n *\n * The name of the class is not mentioned here, but will be in the generated factory function name\n * and thus in the stack trace.\n *\n * @codeGenApi\n */\nfunction ɵɵinvalidFactoryDep(index) {\n throw new RuntimeError(202 /* RuntimeErrorCode.INVALID_FACTORY_DEPENDENCY */, ngDevMode && `This constructor is not compatible with Angular Dependency Injection because its dependency at index ${index} of the parameter list is invalid.\nThis can happen if the dependency type is a primitive like a string or if an ancestor of this class is missing an Angular decorator.\n\nPlease check that 1) the type for the parameter at index ${index} is correct and 2) the correct Angular decorators are defined for this class and its ancestors.`);\n}\n/**\n * Injects a token from the currently active injector.\n * `inject` is only supported in an [injection context](guide/di/dependency-injection-context). It\n * can be used during:\n * - Construction (via the `constructor`) of a class being instantiated by the DI system, such\n * as an `@Injectable` or `@Component`.\n * - In the initializer for fields of such classes.\n * - In the factory function specified for `useFactory` of a `Provider` or an `@Injectable`.\n * - In the `factory` function specified for an `InjectionToken`.\n * - In a stackframe of a function call in a DI context\n *\n * @param token A token that represents a dependency that should be injected.\n * @param flags Optional flags that control how injection is executed.\n * The flags correspond to injection strategies that can be specified with\n * parameter decorators `@Host`, `@Self`, `@SkipSelf`, and `@Optional`.\n * @returns the injected value if operation is successful, `null` otherwise.\n * @throws if called outside of a supported context.\n *\n * @usageNotes\n * In practice the `inject()` calls are allowed in a constructor, a constructor parameter and a\n * field initializer:\n *\n * ```typescript\n * @Injectable({providedIn: 'root'})\n * export class Car {\n * radio: Radio|undefined;\n * // OK: field initializer\n * spareTyre = inject(Tyre);\n *\n * constructor() {\n * // OK: constructor body\n * this.radio = inject(Radio);\n * }\n * }\n * ```\n *\n * It is also legal to call `inject` from a provider's factory:\n *\n * ```typescript\n * providers: [\n * {provide: Car, useFactory: () => {\n * // OK: a class factory\n * const engine = inject(Engine);\n * return new Car(engine);\n * }}\n * ]\n * ```\n *\n * Calls to the `inject()` function outside of the class creation context will result in error. Most\n * notably, calls to `inject()` are disallowed after a class instance was created, in methods\n * (including lifecycle hooks):\n *\n * ```typescript\n * @Component({ ... })\n * export class CarComponent {\n * ngOnInit() {\n * // ERROR: too late, the component instance was already created\n * const engine = inject(Engine);\n * engine.start();\n * }\n * }\n * ```\n *\n * @publicApi\n */\nfunction inject(token, flags = InjectFlags.Default) {\n // The `as any` here _shouldn't_ be necessary, but without it JSCompiler\n // throws a disambiguation error due to the multiple signatures.\n return ɵɵinject(token, convertToBitFlags(flags));\n}\n// Converts object-based DI flags (`InjectOptions`) to bit flags (`InjectFlags`).\nfunction convertToBitFlags(flags) {\n if (typeof flags === 'undefined' || typeof flags === 'number') {\n return flags;\n }\n // While TypeScript doesn't accept it without a cast, bitwise OR with false-y values in\n // JavaScript is a no-op. We can use that for a very codesize-efficient conversion from\n // `InjectOptions` to `InjectFlags`.\n return 0 /* InternalInjectFlags.Default */ | (\n // comment to force a line break in the formatter\n flags.optional && 8 /* InternalInjectFlags.Optional */) | (flags.host && 1 /* InternalInjectFlags.Host */) | (flags.self && 2 /* InternalInjectFlags.Self */) | (flags.skipSelf && 4 /* InternalInjectFlags.SkipSelf */);\n}\nfunction injectArgs(types) {\n const args = [];\n for (let i = 0; i < types.length; i++) {\n const arg = resolveForwardRef(types[i]);\n if (Array.isArray(arg)) {\n if (arg.length === 0) {\n throw new RuntimeError(900 /* RuntimeErrorCode.INVALID_DIFFER_INPUT */, ngDevMode && 'Arguments array must have arguments.');\n }\n let type = undefined;\n let flags = InjectFlags.Default;\n for (let j = 0; j < arg.length; j++) {\n const meta = arg[j];\n const flag = getInjectFlag(meta);\n if (typeof flag === 'number') {\n // Special case when we handle @Inject decorator.\n if (flag === -1 /* DecoratorFlags.Inject */) {\n type = meta.token;\n } else {\n flags |= flag;\n }\n } else {\n type = meta;\n }\n }\n args.push(ɵɵinject(type, flags));\n } else {\n args.push(ɵɵinject(arg));\n }\n }\n return args;\n}\n/**\n * Attaches a given InjectFlag to a given decorator using monkey-patching.\n * Since DI decorators can be used in providers `deps` array (when provider is configured using\n * `useFactory`) without initialization (e.g. `Host`) and as an instance (e.g. `new Host()`), we\n * attach the flag to make it available both as a static property and as a field on decorator\n * instance.\n *\n * @param decorator Provided DI decorator.\n * @param flag InjectFlag that should be applied.\n */\nfunction attachInjectFlag(decorator, flag) {\n decorator[DI_DECORATOR_FLAG] = flag;\n decorator.prototype[DI_DECORATOR_FLAG] = flag;\n return decorator;\n}\n/**\n * Reads monkey-patched property that contains InjectFlag attached to a decorator.\n *\n * @param token Token that may contain monkey-patched DI flags property.\n */\nfunction getInjectFlag(token) {\n return token[DI_DECORATOR_FLAG];\n}\nfunction catchInjectorError(e, token, injectorErrorName, source) {\n const tokenPath = e[NG_TEMP_TOKEN_PATH];\n if (token[SOURCE]) {\n tokenPath.unshift(token[SOURCE]);\n }\n e.message = formatError('\\n' + e.message, tokenPath, injectorErrorName, source);\n e[NG_TOKEN_PATH] = tokenPath;\n e[NG_TEMP_TOKEN_PATH] = null;\n throw e;\n}\nfunction formatError(text, obj, injectorErrorName, source = null) {\n text = text && text.charAt(0) === '\\n' && text.charAt(1) == NO_NEW_LINE ? text.slice(2) : text;\n let context = stringify(obj);\n if (Array.isArray(obj)) {\n context = obj.map(stringify).join(' -> ');\n } else if (typeof obj === 'object') {\n let parts = [];\n for (let key in obj) {\n if (obj.hasOwnProperty(key)) {\n let value = obj[key];\n parts.push(key + ':' + (typeof value === 'string' ? JSON.stringify(value) : stringify(value)));\n }\n }\n context = `{${parts.join(', ')}}`;\n }\n return `${injectorErrorName}${source ? '(' + source + ')' : ''}[${context}]: ${text.replace(NEW_LINE, '\\n ')}`;\n}\n\n/**\n * Inject decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nconst Inject = /*#__PURE__*/attachInjectFlag(\n/*#__PURE__*/\n// Disable tslint because `DecoratorFlags` is a const enum which gets inlined.\nmakeParamDecorator('Inject', token => ({\n token\n})), -1 /* DecoratorFlags.Inject */);\n/**\n * Optional decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nconst Optional =\n/*#__PURE__*/\n// Disable tslint because `InternalInjectFlags` is a const enum which gets inlined.\n// tslint:disable-next-line: no-toplevel-property-access\nattachInjectFlag( /*#__PURE__*/makeParamDecorator('Optional'), 8 /* InternalInjectFlags.Optional */);\n/**\n * Self decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nconst Self =\n/*#__PURE__*/\n// Disable tslint because `InternalInjectFlags` is a const enum which gets inlined.\n// tslint:disable-next-line: no-toplevel-property-access\nattachInjectFlag( /*#__PURE__*/makeParamDecorator('Self'), 2 /* InternalInjectFlags.Self */);\n/**\n * `SkipSelf` decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nconst SkipSelf =\n/*#__PURE__*/\n// Disable tslint because `InternalInjectFlags` is a const enum which gets inlined.\n// tslint:disable-next-line: no-toplevel-property-access\nattachInjectFlag( /*#__PURE__*/makeParamDecorator('SkipSelf'), 4 /* InternalInjectFlags.SkipSelf */);\n/**\n * Host decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nconst Host =\n/*#__PURE__*/\n// Disable tslint because `InternalInjectFlags` is a const enum which gets inlined.\n// tslint:disable-next-line: no-toplevel-property-access\nattachInjectFlag( /*#__PURE__*/makeParamDecorator('Host'), 1 /* InternalInjectFlags.Host */);\nfunction getFactoryDef(type, throwNotFound) {\n const hasFactoryDef = type.hasOwnProperty(NG_FACTORY_DEF);\n if (!hasFactoryDef && throwNotFound === true && ngDevMode) {\n throw new Error(`Type ${stringify(type)} does not have 'ɵfac' property.`);\n }\n return hasFactoryDef ? type[NG_FACTORY_DEF] : null;\n}\n\n/**\n * Determines if the contents of two arrays is identical\n *\n * @param a first array\n * @param b second array\n * @param identityAccessor Optional function for extracting stable object identity from a value in\n * the array.\n */\nfunction arrayEquals(a, b, identityAccessor) {\n if (a.length !== b.length) return false;\n for (let i = 0; i < a.length; i++) {\n let valueA = a[i];\n let valueB = b[i];\n if (identityAccessor) {\n valueA = identityAccessor(valueA);\n valueB = identityAccessor(valueB);\n }\n if (valueB !== valueA) {\n return false;\n }\n }\n return true;\n}\n/**\n * Flattens an array.\n */\nfunction flatten(list) {\n return list.flat(Number.POSITIVE_INFINITY);\n}\nfunction deepForEach(input, fn) {\n input.forEach(value => Array.isArray(value) ? deepForEach(value, fn) : fn(value));\n}\nfunction addToArray(arr, index, value) {\n // perf: array.push is faster than array.splice!\n if (index >= arr.length) {\n arr.push(value);\n } else {\n arr.splice(index, 0, value);\n }\n}\nfunction removeFromArray(arr, index) {\n // perf: array.pop is faster than array.splice!\n if (index >= arr.length - 1) {\n return arr.pop();\n } else {\n return arr.splice(index, 1)[0];\n }\n}\nfunction newArray(size, value) {\n const list = [];\n for (let i = 0; i < size; i++) {\n list.push(value);\n }\n return list;\n}\n/**\n * Remove item from array (Same as `Array.splice()` but faster.)\n *\n * `Array.splice()` is not as fast because it has to allocate an array for the elements which were\n * removed. This causes memory pressure and slows down code when most of the time we don't\n * care about the deleted items array.\n *\n * https://jsperf.com/fast-array-splice (About 20x faster)\n *\n * @param array Array to splice\n * @param index Index of element in array to remove.\n * @param count Number of items to remove.\n */\nfunction arraySplice(array, index, count) {\n const length = array.length - count;\n while (index < length) {\n array[index] = array[index + count];\n index++;\n }\n while (count--) {\n array.pop(); // shrink the array\n }\n}\n/**\n * Same as `Array.splice(index, 0, value)` but faster.\n *\n * `Array.splice()` is not fast because it has to allocate an array for the elements which were\n * removed. This causes memory pressure and slows down code when most of the time we don't\n * care about the deleted items array.\n *\n * @param array Array to splice.\n * @param index Index in array where the `value` should be added.\n * @param value Value to add to array.\n */\nfunction arrayInsert(array, index, value) {\n ngDevMode && assertLessThanOrEqual(index, array.length, \"Can't insert past array end.\");\n let end = array.length;\n while (end > index) {\n const previousEnd = end - 1;\n array[end] = array[previousEnd];\n end = previousEnd;\n }\n array[index] = value;\n}\n/**\n * Same as `Array.splice2(index, 0, value1, value2)` but faster.\n *\n * `Array.splice()` is not fast because it has to allocate an array for the elements which were\n * removed. This causes memory pressure and slows down code when most of the time we don't\n * care about the deleted items array.\n *\n * @param array Array to splice.\n * @param index Index in array where the `value` should be added.\n * @param value1 Value to add to array.\n * @param value2 Value to add to array.\n */\nfunction arrayInsert2(array, index, value1, value2) {\n ngDevMode && assertLessThanOrEqual(index, array.length, \"Can't insert past array end.\");\n let end = array.length;\n if (end == index) {\n // inserting at the end.\n array.push(value1, value2);\n } else if (end === 1) {\n // corner case when we have less items in array than we have items to insert.\n array.push(value2, array[0]);\n array[0] = value1;\n } else {\n end--;\n array.push(array[end - 1], array[end]);\n while (end > index) {\n const previousEnd = end - 2;\n array[end] = array[previousEnd];\n end--;\n }\n array[index] = value1;\n array[index + 1] = value2;\n }\n}\n/**\n * Get an index of an `value` in a sorted `array`.\n *\n * NOTE:\n * - This uses binary search algorithm for fast removals.\n *\n * @param array A sorted array to binary search.\n * @param value The value to look for.\n * @returns index of the value.\n * - positive index if value found.\n * - negative index if value not found. (`~index` to get the value where it should have been\n * located)\n */\nfunction arrayIndexOfSorted(array, value) {\n return _arrayIndexOfSorted(array, value, 0);\n}\n/**\n * Set a `value` for a `key`.\n *\n * @param keyValueArray to modify.\n * @param key The key to locate or create.\n * @param value The value to set for a `key`.\n * @returns index (always even) of where the value vas set.\n */\nfunction keyValueArraySet(keyValueArray, key, value) {\n let index = keyValueArrayIndexOf(keyValueArray, key);\n if (index >= 0) {\n // if we found it set it.\n keyValueArray[index | 1] = value;\n } else {\n index = ~index;\n arrayInsert2(keyValueArray, index, key, value);\n }\n return index;\n}\n/**\n * Retrieve a `value` for a `key` (on `undefined` if not found.)\n *\n * @param keyValueArray to search.\n * @param key The key to locate.\n * @return The `value` stored at the `key` location or `undefined if not found.\n */\nfunction keyValueArrayGet(keyValueArray, key) {\n const index = keyValueArrayIndexOf(keyValueArray, key);\n if (index >= 0) {\n // if we found it retrieve it.\n return keyValueArray[index | 1];\n }\n return undefined;\n}\n/**\n * Retrieve a `key` index value in the array or `-1` if not found.\n *\n * @param keyValueArray to search.\n * @param key The key to locate.\n * @returns index of where the key is (or should have been.)\n * - positive (even) index if key found.\n * - negative index if key not found. (`~index` (even) to get the index where it should have\n * been inserted.)\n */\nfunction keyValueArrayIndexOf(keyValueArray, key) {\n return _arrayIndexOfSorted(keyValueArray, key, 1);\n}\n/**\n * Delete a `key` (and `value`) from the `KeyValueArray`.\n *\n * @param keyValueArray to modify.\n * @param key The key to locate or delete (if exist).\n * @returns index of where the key was (or should have been.)\n * - positive (even) index if key found and deleted.\n * - negative index if key not found. (`~index` (even) to get the index where it should have\n * been.)\n */\nfunction keyValueArrayDelete(keyValueArray, key) {\n const index = keyValueArrayIndexOf(keyValueArray, key);\n if (index >= 0) {\n // if we found it remove it.\n arraySplice(keyValueArray, index, 2);\n }\n return index;\n}\n/**\n * INTERNAL: Get an index of an `value` in a sorted `array` by grouping search by `shift`.\n *\n * NOTE:\n * - This uses binary search algorithm for fast removals.\n *\n * @param array A sorted array to binary search.\n * @param value The value to look for.\n * @param shift grouping shift.\n * - `0` means look at every location\n * - `1` means only look at every other (even) location (the odd locations are to be ignored as\n * they are values.)\n * @returns index of the value.\n * - positive index if value found.\n * - negative index if value not found. (`~index` to get the value where it should have been\n * inserted)\n */\nfunction _arrayIndexOfSorted(array, value, shift) {\n ngDevMode && assertEqual(Array.isArray(array), true, 'Expecting an array');\n let start = 0;\n let end = array.length >> shift;\n while (end !== start) {\n const middle = start + (end - start >> 1); // find the middle.\n const current = array[middle << shift];\n if (value === current) {\n return middle << shift;\n } else if (current > value) {\n end = middle;\n } else {\n start = middle + 1; // We already searched middle so make it non-inclusive by adding 1\n }\n }\n return ~(end << shift);\n}\n\n/**\n * This file contains reuseable \"empty\" symbols that can be used as default return values\n * in different parts of the rendering code. Because the same symbols are returned, this\n * allows for identity checks against these values to be consistently used by the framework\n * code.\n */\nconst EMPTY_OBJ = {};\nconst EMPTY_ARRAY = [];\n// freezing the values prevents any code from accidentally inserting new values in\nif ((typeof ngDevMode === 'undefined' || ngDevMode) && /*#__PURE__*/initNgDevMode()) {\n // These property accesses can be ignored because ngDevMode will be set to false\n // when optimizing code and the whole if statement will be dropped.\n // tslint:disable-next-line:no-toplevel-property-access\n /*#__PURE__*/Object.freeze(EMPTY_OBJ);\n // tslint:disable-next-line:no-toplevel-property-access\n /*#__PURE__*/Object.freeze(EMPTY_ARRAY);\n}\n\n/**\n * A multi-provider token for initialization functions that will run upon construction of an\n * environment injector.\n *\n * Note: As opposed to the `APP_INITIALIZER` token, the `ENVIRONMENT_INITIALIZER` functions are not awaited,\n * hence they should not be `async`.\n *\n * @publicApi\n */\nconst ENVIRONMENT_INITIALIZER = /*#__PURE__*/new InjectionToken(ngDevMode ? 'ENVIRONMENT_INITIALIZER' : '');\n\n/**\n * An InjectionToken that gets the current `Injector` for `createInjector()`-style injectors.\n *\n * Requesting this token instead of `Injector` allows `StaticInjector` to be tree-shaken from a\n * project.\n *\n * @publicApi\n */\nconst INJECTOR$1 = /*#__PURE__*/new InjectionToken(ngDevMode ? 'INJECTOR' : '',\n// Disable tslint because this is const enum which gets inlined not top level prop access.\n// tslint:disable-next-line: no-toplevel-property-access\n-1 /* InjectorMarkers.Injector */);\nconst INJECTOR_DEF_TYPES = /*#__PURE__*/new InjectionToken(ngDevMode ? 'INJECTOR_DEF_TYPES' : '');\nclass NullInjector {\n get(token, notFoundValue = THROW_IF_NOT_FOUND) {\n if (notFoundValue === THROW_IF_NOT_FOUND) {\n const error = new Error(`NullInjectorError: No provider for ${stringify(token)}!`);\n error.name = 'NullInjectorError';\n throw error;\n }\n return notFoundValue;\n }\n}\n\n/**\n * The strategy that the default change detector uses to detect changes.\n * When set, takes effect the next time change detection is triggered.\n *\n * @see [Change detection usage](/api/core/ChangeDetectorRef?tab=usage-notes)\n * @see [Skipping component subtrees](/best-practices/skipping-subtrees)\n *\n * @publicApi\n */\nvar ChangeDetectionStrategy = /*#__PURE__*/function (ChangeDetectionStrategy) {\n /**\n * Use the `CheckOnce` strategy, meaning that automatic change detection is deactivated\n * until reactivated by setting the strategy to `Default` (`CheckAlways`).\n * Change detection can still be explicitly invoked.\n * This strategy applies to all child directives and cannot be overridden.\n */\n ChangeDetectionStrategy[ChangeDetectionStrategy[\"OnPush\"] = 0] = \"OnPush\";\n /**\n * Use the default `CheckAlways` strategy, in which change detection is automatic until\n * explicitly deactivated.\n */\n ChangeDetectionStrategy[ChangeDetectionStrategy[\"Default\"] = 1] = \"Default\";\n return ChangeDetectionStrategy;\n}(ChangeDetectionStrategy || {});\n/**\n * Defines the CSS styles encapsulation policies for the {@link Component} decorator's\n * `encapsulation` option.\n *\n * See {@link Component#encapsulation encapsulation}.\n *\n * @usageNotes\n * ### Example\n *\n * {@example core/ts/metadata/encapsulation.ts region='longform'}\n *\n * @publicApi\n */\nvar ViewEncapsulation$1 = /*#__PURE__*/function (ViewEncapsulation) {\n // TODO: consider making `ViewEncapsulation` a `const enum` instead. See\n // https://github.com/angular/angular/issues/44119 for additional information.\n /**\n * Emulates a native Shadow DOM encapsulation behavior by adding a specific attribute to the\n * component's host element and applying the same attribute to all the CSS selectors provided\n * via {@link Component#styles styles} or {@link Component#styleUrls styleUrls}.\n *\n * This is the default option.\n */\n ViewEncapsulation[ViewEncapsulation[\"Emulated\"] = 0] = \"Emulated\";\n // Historically the 1 value was for `Native` encapsulation which has been removed as of v11.\n /**\n * Doesn't provide any sort of CSS style encapsulation, meaning that all the styles provided\n * via {@link Component#styles styles} or {@link Component#styleUrls styleUrls} are applicable\n * to any HTML element of the application regardless of their host Component.\n */\n ViewEncapsulation[ViewEncapsulation[\"None\"] = 2] = \"None\";\n /**\n * Uses the browser's native Shadow DOM API to encapsulate CSS styles, meaning that it creates\n * a ShadowRoot for the component's host element which is then used to encapsulate\n * all the Component's styling.\n */\n ViewEncapsulation[ViewEncapsulation[\"ShadowDom\"] = 3] = \"ShadowDom\";\n return ViewEncapsulation;\n}(ViewEncapsulation$1 || {});\n/** Flags describing an input for a directive. */\nvar InputFlags = /*#__PURE__*/function (InputFlags) {\n InputFlags[InputFlags[\"None\"] = 0] = \"None\";\n InputFlags[InputFlags[\"SignalBased\"] = 1] = \"SignalBased\";\n InputFlags[InputFlags[\"HasDecoratorInputTransform\"] = 2] = \"HasDecoratorInputTransform\";\n return InputFlags;\n}(InputFlags || {});\n/**\n * Returns an index of `classToSearch` in `className` taking token boundaries into account.\n *\n * `classIndexOf('AB A', 'A', 0)` will be 3 (not 0 since `AB!==A`)\n *\n * @param className A string containing classes (whitespace separated)\n * @param classToSearch A class name to locate\n * @param startingIndex Starting location of search\n * @returns an index of the located class (or -1 if not found)\n */\nfunction classIndexOf(className, classToSearch, startingIndex) {\n ngDevMode && assertNotEqual(classToSearch, '', 'can not look for \"\" string.');\n let end = className.length;\n while (true) {\n const foundIndex = className.indexOf(classToSearch, startingIndex);\n if (foundIndex === -1) return foundIndex;\n if (foundIndex === 0 || className.charCodeAt(foundIndex - 1) <= 32 /* CharCode.SPACE */) {\n // Ensure that it has leading whitespace\n const length = classToSearch.length;\n if (foundIndex + length === end || className.charCodeAt(foundIndex + length) <= 32 /* CharCode.SPACE */) {\n // Ensure that it has trailing whitespace\n return foundIndex;\n }\n }\n // False positive, keep searching from where we left off.\n startingIndex = foundIndex + 1;\n }\n}\n\n/**\n * Assigns all attribute values to the provided element via the inferred renderer.\n *\n * This function accepts two forms of attribute entries:\n *\n * default: (key, value):\n * attrs = [key1, value1, key2, value2]\n *\n * namespaced: (NAMESPACE_MARKER, uri, name, value)\n * attrs = [NAMESPACE_MARKER, uri, name, value, NAMESPACE_MARKER, uri, name, value]\n *\n * The `attrs` array can contain a mix of both the default and namespaced entries.\n * The \"default\" values are set without a marker, but if the function comes across\n * a marker value then it will attempt to set a namespaced value. If the marker is\n * not of a namespaced value then the function will quit and return the index value\n * where it stopped during the iteration of the attrs array.\n *\n * See [AttributeMarker] to understand what the namespace marker value is.\n *\n * Note that this instruction does not support assigning style and class values to\n * an element. See `elementStart` and `elementHostAttrs` to learn how styling values\n * are applied to an element.\n * @param renderer The renderer to be used\n * @param native The element that the attributes will be assigned to\n * @param attrs The attribute array of values that will be assigned to the element\n * @returns the index value that was last accessed in the attributes array\n */\nfunction setUpAttributes(renderer, native, attrs) {\n let i = 0;\n while (i < attrs.length) {\n const value = attrs[i];\n if (typeof value === 'number') {\n // only namespaces are supported. Other value types (such as style/class\n // entries) are not supported in this function.\n if (value !== 0 /* AttributeMarker.NamespaceURI */) {\n break;\n }\n // we just landed on the marker value ... therefore\n // we should skip to the next entry\n i++;\n const namespaceURI = attrs[i++];\n const attrName = attrs[i++];\n const attrVal = attrs[i++];\n ngDevMode && ngDevMode.rendererSetAttribute++;\n renderer.setAttribute(native, attrName, attrVal, namespaceURI);\n } else {\n // attrName is string;\n const attrName = value;\n const attrVal = attrs[++i];\n // Standard attributes\n ngDevMode && ngDevMode.rendererSetAttribute++;\n if (isAnimationProp(attrName)) {\n renderer.setProperty(native, attrName, attrVal);\n } else {\n renderer.setAttribute(native, attrName, attrVal);\n }\n i++;\n }\n }\n // another piece of code may iterate over the same attributes array. Therefore\n // it may be helpful to return the exact spot where the attributes array exited\n // whether by running into an unsupported marker or if all the static values were\n // iterated over.\n return i;\n}\n/**\n * Test whether the given value is a marker that indicates that the following\n * attribute values in a `TAttributes` array are only the names of attributes,\n * and not name-value pairs.\n * @param marker The attribute marker to test.\n * @returns true if the marker is a \"name-only\" marker (e.g. `Bindings`, `Template` or `I18n`).\n */\nfunction isNameOnlyAttributeMarker(marker) {\n return marker === 3 /* AttributeMarker.Bindings */ || marker === 4 /* AttributeMarker.Template */ || marker === 6 /* AttributeMarker.I18n */;\n}\nfunction isAnimationProp(name) {\n // Perf note: accessing charCodeAt to check for the first character of a string is faster as\n // compared to accessing a character at index 0 (ex. name[0]). The main reason for this is that\n // charCodeAt doesn't allocate memory to return a substring.\n return name.charCodeAt(0) === 64 /* CharCode.AT_SIGN */;\n}\n/**\n * Merges `src` `TAttributes` into `dst` `TAttributes` removing any duplicates in the process.\n *\n * This merge function keeps the order of attrs same.\n *\n * @param dst Location of where the merged `TAttributes` should end up.\n * @param src `TAttributes` which should be appended to `dst`\n */\nfunction mergeHostAttrs(dst, src) {\n if (src === null || src.length === 0) {\n // do nothing\n } else if (dst === null || dst.length === 0) {\n // We have source, but dst is empty, just make a copy.\n dst = src.slice();\n } else {\n let srcMarker = -1 /* AttributeMarker.ImplicitAttributes */;\n for (let i = 0; i < src.length; i++) {\n const item = src[i];\n if (typeof item === 'number') {\n srcMarker = item;\n } else {\n if (srcMarker === 0 /* AttributeMarker.NamespaceURI */) {\n // Case where we need to consume `key1`, `key2`, `value` items.\n } else if (srcMarker === -1 /* AttributeMarker.ImplicitAttributes */ || srcMarker === 2 /* AttributeMarker.Styles */) {\n // Case where we have to consume `key1` and `value` only.\n mergeHostAttribute(dst, srcMarker, item, null, src[++i]);\n } else {\n // Case where we have to consume `key1` only.\n mergeHostAttribute(dst, srcMarker, item, null, null);\n }\n }\n }\n }\n return dst;\n}\n/**\n * Append `key`/`value` to existing `TAttributes` taking region marker and duplicates into account.\n *\n * @param dst `TAttributes` to append to.\n * @param marker Region where the `key`/`value` should be added.\n * @param key1 Key to add to `TAttributes`\n * @param key2 Key to add to `TAttributes` (in case of `AttributeMarker.NamespaceURI`)\n * @param value Value to add or to overwrite to `TAttributes` Only used if `marker` is not Class.\n */\nfunction mergeHostAttribute(dst, marker, key1, key2, value) {\n let i = 0;\n // Assume that new markers will be inserted at the end.\n let markerInsertPosition = dst.length;\n // scan until correct type.\n if (marker === -1 /* AttributeMarker.ImplicitAttributes */) {\n markerInsertPosition = -1;\n } else {\n while (i < dst.length) {\n const dstValue = dst[i++];\n if (typeof dstValue === 'number') {\n if (dstValue === marker) {\n markerInsertPosition = -1;\n break;\n } else if (dstValue > marker) {\n // We need to save this as we want the markers to be inserted in specific order.\n markerInsertPosition = i - 1;\n break;\n }\n }\n }\n }\n // search until you find place of insertion\n while (i < dst.length) {\n const item = dst[i];\n if (typeof item === 'number') {\n // since `i` started as the index after the marker, we did not find it if we are at the next\n // marker\n break;\n } else if (item === key1) {\n // We already have same token\n if (key2 === null) {\n if (value !== null) {\n dst[i + 1] = value;\n }\n return;\n } else if (key2 === dst[i + 1]) {\n dst[i + 2] = value;\n return;\n }\n }\n // Increment counter.\n i++;\n if (key2 !== null) i++;\n if (value !== null) i++;\n }\n // insert at location.\n if (markerInsertPosition !== -1) {\n dst.splice(markerInsertPosition, 0, marker);\n i = markerInsertPosition + 1;\n }\n dst.splice(i++, 0, key1);\n if (key2 !== null) {\n dst.splice(i++, 0, key2);\n }\n if (value !== null) {\n dst.splice(i++, 0, value);\n }\n}\nconst NG_TEMPLATE_SELECTOR = 'ng-template';\n/**\n * Search the `TAttributes` to see if it contains `cssClassToMatch` (case insensitive)\n *\n * @param tNode static data of the node to match\n * @param attrs `TAttributes` to search through.\n * @param cssClassToMatch class to match (lowercase)\n * @param isProjectionMode Whether or not class matching should look into the attribute `class` in\n * addition to the `AttributeMarker.Classes`.\n */\nfunction isCssClassMatching(tNode, attrs, cssClassToMatch, isProjectionMode) {\n ngDevMode && assertEqual(cssClassToMatch, cssClassToMatch.toLowerCase(), 'Class name expected to be lowercase.');\n let i = 0;\n if (isProjectionMode) {\n for (; i < attrs.length && typeof attrs[i] === 'string'; i += 2) {\n // Search for an implicit `class` attribute and check if its value matches `cssClassToMatch`.\n if (attrs[i] === 'class' && classIndexOf(attrs[i + 1].toLowerCase(), cssClassToMatch, 0) !== -1) {\n return true;\n }\n }\n } else if (isInlineTemplate(tNode)) {\n // Matching directives (i.e. when not matching for projection mode) should not consider the\n // class bindings that are present on inline templates, as those class bindings only target\n // the root node of the template, not the template itself.\n return false;\n }\n // Resume the search for classes after the `Classes` marker.\n i = attrs.indexOf(1 /* AttributeMarker.Classes */, i);\n if (i > -1) {\n // We found the classes section. Start searching for the class.\n let item;\n while (++i < attrs.length && typeof (item = attrs[i]) === 'string') {\n if (item.toLowerCase() === cssClassToMatch) {\n return true;\n }\n }\n }\n return false;\n}\n/**\n * Checks whether the `tNode` represents an inline template (e.g. `*ngFor`).\n *\n * @param tNode current TNode\n */\nfunction isInlineTemplate(tNode) {\n return tNode.type === 4 /* TNodeType.Container */ && tNode.value !== NG_TEMPLATE_SELECTOR;\n}\n/**\n * Function that checks whether a given tNode matches tag-based selector and has a valid type.\n *\n * Matching can be performed in 2 modes: projection mode (when we project nodes) and regular\n * directive matching mode:\n * - in the \"directive matching\" mode we do _not_ take TContainer's tagName into account if it is\n * different from NG_TEMPLATE_SELECTOR (value different from NG_TEMPLATE_SELECTOR indicates that a\n * tag name was extracted from * syntax so we would match the same directive twice);\n * - in the \"projection\" mode, we use a tag name potentially extracted from the * syntax processing\n * (applicable to TNodeType.Container only).\n */\nfunction hasTagAndTypeMatch(tNode, currentSelector, isProjectionMode) {\n const tagNameToCompare = tNode.type === 4 /* TNodeType.Container */ && !isProjectionMode ? NG_TEMPLATE_SELECTOR : tNode.value;\n return currentSelector === tagNameToCompare;\n}\n/**\n * A utility function to match an Ivy node static data against a simple CSS selector\n *\n * @param tNode static data of the node to match\n * @param selector The selector to try matching against the node.\n * @param isProjectionMode if `true` we are matching for content projection, otherwise we are doing\n * directive matching.\n * @returns true if node matches the selector.\n */\nfunction isNodeMatchingSelector(tNode, selector, isProjectionMode) {\n ngDevMode && assertDefined(selector[0], 'Selector should have a tag name');\n let mode = 4 /* SelectorFlags.ELEMENT */;\n const nodeAttrs = tNode.attrs;\n // Find the index of first attribute that has no value, only a name.\n const nameOnlyMarkerIdx = nodeAttrs !== null ? getNameOnlyMarkerIndex(nodeAttrs) : 0;\n // When processing \":not\" selectors, we skip to the next \":not\" if the\n // current one doesn't match\n let skipToNextSelector = false;\n for (let i = 0; i < selector.length; i++) {\n const current = selector[i];\n if (typeof current === 'number') {\n // If we finish processing a :not selector and it hasn't failed, return false\n if (!skipToNextSelector && !isPositive(mode) && !isPositive(current)) {\n return false;\n }\n // If we are skipping to the next :not() and this mode flag is positive,\n // it's a part of the current :not() selector, and we should keep skipping\n if (skipToNextSelector && isPositive(current)) continue;\n skipToNextSelector = false;\n mode = current | mode & 1 /* SelectorFlags.NOT */;\n continue;\n }\n if (skipToNextSelector) continue;\n if (mode & 4 /* SelectorFlags.ELEMENT */) {\n mode = 2 /* SelectorFlags.ATTRIBUTE */ | mode & 1 /* SelectorFlags.NOT */;\n if (current !== '' && !hasTagAndTypeMatch(tNode, current, isProjectionMode) || current === '' && selector.length === 1) {\n if (isPositive(mode)) return false;\n skipToNextSelector = true;\n }\n } else if (mode & 8 /* SelectorFlags.CLASS */) {\n if (nodeAttrs === null || !isCssClassMatching(tNode, nodeAttrs, current, isProjectionMode)) {\n if (isPositive(mode)) return false;\n skipToNextSelector = true;\n }\n } else {\n const selectorAttrValue = selector[++i];\n const attrIndexInNode = findAttrIndexInNode(current, nodeAttrs, isInlineTemplate(tNode), isProjectionMode);\n if (attrIndexInNode === -1) {\n if (isPositive(mode)) return false;\n skipToNextSelector = true;\n continue;\n }\n if (selectorAttrValue !== '') {\n let nodeAttrValue;\n if (attrIndexInNode > nameOnlyMarkerIdx) {\n nodeAttrValue = '';\n } else {\n ngDevMode && assertNotEqual(nodeAttrs[attrIndexInNode], 0 /* AttributeMarker.NamespaceURI */, 'We do not match directives on namespaced attributes');\n // we lowercase the attribute value to be able to match\n // selectors without case-sensitivity\n // (selectors are already in lowercase when generated)\n nodeAttrValue = nodeAttrs[attrIndexInNode + 1].toLowerCase();\n }\n if (mode & 2 /* SelectorFlags.ATTRIBUTE */ && selectorAttrValue !== nodeAttrValue) {\n if (isPositive(mode)) return false;\n skipToNextSelector = true;\n }\n }\n }\n }\n return isPositive(mode) || skipToNextSelector;\n}\nfunction isPositive(mode) {\n return (mode & 1 /* SelectorFlags.NOT */) === 0;\n}\n/**\n * Examines the attribute's definition array for a node to find the index of the\n * attribute that matches the given `name`.\n *\n * NOTE: This will not match namespaced attributes.\n *\n * Attribute matching depends upon `isInlineTemplate` and `isProjectionMode`.\n * The following table summarizes which types of attributes we attempt to match:\n *\n * ===========================================================================================================\n * Modes | Normal Attributes | Bindings Attributes | Template Attributes | I18n\n * Attributes\n * ===========================================================================================================\n * Inline + Projection | YES | YES | NO | YES\n * -----------------------------------------------------------------------------------------------------------\n * Inline + Directive | NO | NO | YES | NO\n * -----------------------------------------------------------------------------------------------------------\n * Non-inline + Projection | YES | YES | NO | YES\n * -----------------------------------------------------------------------------------------------------------\n * Non-inline + Directive | YES | YES | NO | YES\n * ===========================================================================================================\n *\n * @param name the name of the attribute to find\n * @param attrs the attribute array to examine\n * @param isInlineTemplate true if the node being matched is an inline template (e.g. `*ngFor`)\n * rather than a manually expanded template node (e.g ``).\n * @param isProjectionMode true if we are matching against content projection otherwise we are\n * matching against directives.\n */\nfunction findAttrIndexInNode(name, attrs, isInlineTemplate, isProjectionMode) {\n if (attrs === null) return -1;\n let i = 0;\n if (isProjectionMode || !isInlineTemplate) {\n let bindingsMode = false;\n while (i < attrs.length) {\n const maybeAttrName = attrs[i];\n if (maybeAttrName === name) {\n return i;\n } else if (maybeAttrName === 3 /* AttributeMarker.Bindings */ || maybeAttrName === 6 /* AttributeMarker.I18n */) {\n bindingsMode = true;\n } else if (maybeAttrName === 1 /* AttributeMarker.Classes */ || maybeAttrName === 2 /* AttributeMarker.Styles */) {\n let value = attrs[++i];\n // We should skip classes here because we have a separate mechanism for\n // matching classes in projection mode.\n while (typeof value === 'string') {\n value = attrs[++i];\n }\n continue;\n } else if (maybeAttrName === 4 /* AttributeMarker.Template */) {\n // We do not care about Template attributes in this scenario.\n break;\n } else if (maybeAttrName === 0 /* AttributeMarker.NamespaceURI */) {\n // Skip the whole namespaced attribute and value. This is by design.\n i += 4;\n continue;\n }\n // In binding mode there are only names, rather than name-value pairs.\n i += bindingsMode ? 1 : 2;\n }\n // We did not match the attribute\n return -1;\n } else {\n return matchTemplateAttribute(attrs, name);\n }\n}\nfunction isNodeMatchingSelectorList(tNode, selector, isProjectionMode = false) {\n for (let i = 0; i < selector.length; i++) {\n if (isNodeMatchingSelector(tNode, selector[i], isProjectionMode)) {\n return true;\n }\n }\n return false;\n}\nfunction getProjectAsAttrValue(tNode) {\n const nodeAttrs = tNode.attrs;\n if (nodeAttrs != null) {\n const ngProjectAsAttrIdx = nodeAttrs.indexOf(5 /* AttributeMarker.ProjectAs */);\n // only check for ngProjectAs in attribute names, don't accidentally match attribute's value\n // (attribute names are stored at even indexes)\n if ((ngProjectAsAttrIdx & 1) === 0) {\n return nodeAttrs[ngProjectAsAttrIdx + 1];\n }\n }\n return null;\n}\nfunction getNameOnlyMarkerIndex(nodeAttrs) {\n for (let i = 0; i < nodeAttrs.length; i++) {\n const nodeAttr = nodeAttrs[i];\n if (isNameOnlyAttributeMarker(nodeAttr)) {\n return i;\n }\n }\n return nodeAttrs.length;\n}\nfunction matchTemplateAttribute(attrs, name) {\n let i = attrs.indexOf(4 /* AttributeMarker.Template */);\n if (i > -1) {\n i++;\n while (i < attrs.length) {\n const attr = attrs[i];\n // Return in case we checked all template attrs and are switching to the next section in the\n // attrs array (that starts with a number that represents an attribute marker).\n if (typeof attr === 'number') return -1;\n if (attr === name) return i;\n i++;\n }\n }\n return -1;\n}\n/**\n * Checks whether a selector is inside a CssSelectorList\n * @param selector Selector to be checked.\n * @param list List in which to look for the selector.\n */\nfunction isSelectorInSelectorList(selector, list) {\n selectorListLoop: for (let i = 0; i < list.length; i++) {\n const currentSelectorInList = list[i];\n if (selector.length !== currentSelectorInList.length) {\n continue;\n }\n for (let j = 0; j < selector.length; j++) {\n if (selector[j] !== currentSelectorInList[j]) {\n continue selectorListLoop;\n }\n }\n return true;\n }\n return false;\n}\nfunction maybeWrapInNotSelector(isNegativeMode, chunk) {\n return isNegativeMode ? ':not(' + chunk.trim() + ')' : chunk;\n}\nfunction stringifyCSSSelector(selector) {\n let result = selector[0];\n let i = 1;\n let mode = 2 /* SelectorFlags.ATTRIBUTE */;\n let currentChunk = '';\n let isNegativeMode = false;\n while (i < selector.length) {\n let valueOrMarker = selector[i];\n if (typeof valueOrMarker === 'string') {\n if (mode & 2 /* SelectorFlags.ATTRIBUTE */) {\n const attrValue = selector[++i];\n currentChunk += '[' + valueOrMarker + (attrValue.length > 0 ? '=\"' + attrValue + '\"' : '') + ']';\n } else if (mode & 8 /* SelectorFlags.CLASS */) {\n currentChunk += '.' + valueOrMarker;\n } else if (mode & 4 /* SelectorFlags.ELEMENT */) {\n currentChunk += ' ' + valueOrMarker;\n }\n } else {\n //\n // Append current chunk to the final result in case we come across SelectorFlag, which\n // indicates that the previous section of a selector is over. We need to accumulate content\n // between flags to make sure we wrap the chunk later in :not() selector if needed, e.g.\n // ```\n // ['', Flags.CLASS, '.classA', Flags.CLASS | Flags.NOT, '.classB', '.classC']\n // ```\n // should be transformed to `.classA :not(.classB .classC)`.\n //\n // Note: for negative selector part, we accumulate content between flags until we find the\n // next negative flag. This is needed to support a case where `:not()` rule contains more than\n // one chunk, e.g. the following selector:\n // ```\n // ['', Flags.ELEMENT | Flags.NOT, 'p', Flags.CLASS, 'foo', Flags.CLASS | Flags.NOT, 'bar']\n // ```\n // should be stringified to `:not(p.foo) :not(.bar)`\n //\n if (currentChunk !== '' && !isPositive(valueOrMarker)) {\n result += maybeWrapInNotSelector(isNegativeMode, currentChunk);\n currentChunk = '';\n }\n mode = valueOrMarker;\n // According to CssSelector spec, once we come across `SelectorFlags.NOT` flag, the negative\n // mode is maintained for remaining chunks of a selector.\n isNegativeMode = isNegativeMode || !isPositive(mode);\n }\n i++;\n }\n if (currentChunk !== '') {\n result += maybeWrapInNotSelector(isNegativeMode, currentChunk);\n }\n return result;\n}\n/**\n * Generates string representation of CSS selector in parsed form.\n *\n * ComponentDef and DirectiveDef are generated with the selector in parsed form to avoid doing\n * additional parsing at runtime (for example, for directive matching). However in some cases (for\n * example, while bootstrapping a component), a string version of the selector is required to query\n * for the host element on the page. This function takes the parsed form of a selector and returns\n * its string representation.\n *\n * @param selectorList selector in parsed form\n * @returns string representation of a given selector\n */\nfunction stringifyCSSSelectorList(selectorList) {\n return selectorList.map(stringifyCSSSelector).join(',');\n}\n/**\n * Extracts attributes and classes information from a given CSS selector.\n *\n * This function is used while creating a component dynamically. In this case, the host element\n * (that is created dynamically) should contain attributes and classes specified in component's CSS\n * selector.\n *\n * @param selector CSS selector in parsed form (in a form of array)\n * @returns object with `attrs` and `classes` fields that contain extracted information\n */\nfunction extractAttrsAndClassesFromSelector(selector) {\n const attrs = [];\n const classes = [];\n let i = 1;\n let mode = 2 /* SelectorFlags.ATTRIBUTE */;\n while (i < selector.length) {\n let valueOrMarker = selector[i];\n if (typeof valueOrMarker === 'string') {\n if (mode === 2 /* SelectorFlags.ATTRIBUTE */) {\n if (valueOrMarker !== '') {\n attrs.push(valueOrMarker, selector[++i]);\n }\n } else if (mode === 8 /* SelectorFlags.CLASS */) {\n classes.push(valueOrMarker);\n }\n } else {\n // According to CssSelector spec, once we come across `SelectorFlags.NOT` flag, the negative\n // mode is maintained for remaining chunks of a selector. Since attributes and classes are\n // extracted only for \"positive\" part of the selector, we can stop here.\n if (!isPositive(mode)) break;\n mode = valueOrMarker;\n }\n i++;\n }\n return {\n attrs,\n classes\n };\n}\n\n/**\n * Create a component definition object.\n *\n *\n * # Example\n * ```\n * class MyComponent {\n * // Generated by Angular Template Compiler\n * // [Symbol] syntax will not be supported by TypeScript until v2.7\n * static ɵcmp = defineComponent({\n * ...\n * });\n * }\n * ```\n * @codeGenApi\n */\nfunction ɵɵdefineComponent(componentDefinition) {\n return noSideEffects(() => {\n // Initialize ngDevMode. This must be the first statement in ɵɵdefineComponent.\n // See the `initNgDevMode` docstring for more information.\n (typeof ngDevMode === 'undefined' || ngDevMode) && initNgDevMode();\n const baseDef = getNgDirectiveDef(componentDefinition);\n const def = {\n ...baseDef,\n decls: componentDefinition.decls,\n vars: componentDefinition.vars,\n template: componentDefinition.template,\n consts: componentDefinition.consts || null,\n ngContentSelectors: componentDefinition.ngContentSelectors,\n onPush: componentDefinition.changeDetection === ChangeDetectionStrategy.OnPush,\n directiveDefs: null,\n // assigned in noSideEffects\n pipeDefs: null,\n // assigned in noSideEffects\n dependencies: baseDef.standalone && componentDefinition.dependencies || null,\n getStandaloneInjector: null,\n signals: componentDefinition.signals ?? false,\n data: componentDefinition.data || {},\n encapsulation: componentDefinition.encapsulation || ViewEncapsulation$1.Emulated,\n styles: componentDefinition.styles || EMPTY_ARRAY,\n _: null,\n schemas: componentDefinition.schemas || null,\n tView: null,\n id: ''\n };\n initFeatures(def);\n const dependencies = componentDefinition.dependencies;\n def.directiveDefs = extractDefListOrFactory(dependencies, /* pipeDef */false);\n def.pipeDefs = extractDefListOrFactory(dependencies, /* pipeDef */true);\n def.id = getComponentId(def);\n return def;\n });\n}\nfunction extractDirectiveDef(type) {\n return getComponentDef(type) || getDirectiveDef(type);\n}\nfunction nonNull(value) {\n return value !== null;\n}\n/**\n * @codeGenApi\n */\nfunction ɵɵdefineNgModule(def) {\n return noSideEffects(() => {\n const res = {\n type: def.type,\n bootstrap: def.bootstrap || EMPTY_ARRAY,\n declarations: def.declarations || EMPTY_ARRAY,\n imports: def.imports || EMPTY_ARRAY,\n exports: def.exports || EMPTY_ARRAY,\n transitiveCompileScopes: null,\n schemas: def.schemas || null,\n id: def.id || null\n };\n return res;\n });\n}\nfunction parseAndConvertBindingsForDefinition(obj, declaredInputs) {\n if (obj == null) return EMPTY_OBJ;\n const newLookup = {};\n for (const minifiedKey in obj) {\n if (obj.hasOwnProperty(minifiedKey)) {\n const value = obj[minifiedKey];\n let publicName;\n let declaredName;\n let inputFlags = InputFlags.None;\n if (Array.isArray(value)) {\n inputFlags = value[0];\n publicName = value[1];\n declaredName = value[2] ?? publicName; // declared name might not be set to save bytes.\n } else {\n publicName = value;\n declaredName = value;\n }\n // For inputs, capture the declared name, or if some flags are set.\n if (declaredInputs) {\n // Perf note: An array is only allocated for the input if there are flags.\n newLookup[publicName] = inputFlags !== InputFlags.None ? [minifiedKey, inputFlags] : minifiedKey;\n declaredInputs[publicName] = declaredName;\n } else {\n newLookup[publicName] = minifiedKey;\n }\n }\n }\n return newLookup;\n}\n/**\n * Create a directive definition object.\n *\n * # Example\n * ```ts\n * class MyDirective {\n * // Generated by Angular Template Compiler\n * // [Symbol] syntax will not be supported by TypeScript until v2.7\n * static ɵdir = ɵɵdefineDirective({\n * ...\n * });\n * }\n * ```\n *\n * @codeGenApi\n */\nfunction ɵɵdefineDirective(directiveDefinition) {\n return noSideEffects(() => {\n const def = getNgDirectiveDef(directiveDefinition);\n initFeatures(def);\n return def;\n });\n}\n/**\n * Create a pipe definition object.\n *\n * # Example\n * ```\n * class MyPipe implements PipeTransform {\n * // Generated by Angular Template Compiler\n * static ɵpipe = definePipe({\n * ...\n * });\n * }\n * ```\n * @param pipeDef Pipe definition generated by the compiler\n *\n * @codeGenApi\n */\nfunction ɵɵdefinePipe(pipeDef) {\n return {\n type: pipeDef.type,\n name: pipeDef.name,\n factory: null,\n pure: pipeDef.pure !== false,\n standalone: pipeDef.standalone === true,\n onDestroy: pipeDef.type.prototype.ngOnDestroy || null\n };\n}\n/**\n * The following getter methods retrieve the definition from the type. Currently the retrieval\n * honors inheritance, but in the future we may change the rule to require that definitions are\n * explicit. This would require some sort of migration strategy.\n */\nfunction getComponentDef(type) {\n return type[NG_COMP_DEF] || null;\n}\nfunction getDirectiveDef(type) {\n return type[NG_DIR_DEF] || null;\n}\nfunction getPipeDef$1(type) {\n return type[NG_PIPE_DEF] || null;\n}\n/**\n * Checks whether a given Component, Directive or Pipe is marked as standalone.\n * This will return false if passed anything other than a Component, Directive, or Pipe class\n * See [this guide](guide/components/importing) for additional information:\n *\n * @param type A reference to a Component, Directive or Pipe.\n * @publicApi\n */\nfunction isStandalone(type) {\n const def = getComponentDef(type) || getDirectiveDef(type) || getPipeDef$1(type);\n return def !== null ? def.standalone : false;\n}\nfunction getNgModuleDef(type, throwNotFound) {\n const ngModuleDef = type[NG_MOD_DEF] || null;\n if (!ngModuleDef && throwNotFound === true) {\n throw new Error(`Type ${stringify(type)} does not have 'ɵmod' property.`);\n }\n return ngModuleDef;\n}\nfunction getNgDirectiveDef(directiveDefinition) {\n const declaredInputs = {};\n return {\n type: directiveDefinition.type,\n providersResolver: null,\n factory: null,\n hostBindings: directiveDefinition.hostBindings || null,\n hostVars: directiveDefinition.hostVars || 0,\n hostAttrs: directiveDefinition.hostAttrs || null,\n contentQueries: directiveDefinition.contentQueries || null,\n declaredInputs: declaredInputs,\n inputTransforms: null,\n inputConfig: directiveDefinition.inputs || EMPTY_OBJ,\n exportAs: directiveDefinition.exportAs || null,\n standalone: directiveDefinition.standalone === true,\n signals: directiveDefinition.signals === true,\n selectors: directiveDefinition.selectors || EMPTY_ARRAY,\n viewQuery: directiveDefinition.viewQuery || null,\n features: directiveDefinition.features || null,\n setInput: null,\n findHostDirectiveDefs: null,\n hostDirectives: null,\n inputs: parseAndConvertBindingsForDefinition(directiveDefinition.inputs, declaredInputs),\n outputs: parseAndConvertBindingsForDefinition(directiveDefinition.outputs),\n debugInfo: null\n };\n}\nfunction initFeatures(definition) {\n definition.features?.forEach(fn => fn(definition));\n}\nfunction extractDefListOrFactory(dependencies, pipeDef) {\n if (!dependencies) {\n return null;\n }\n const defExtractor = pipeDef ? getPipeDef$1 : extractDirectiveDef;\n return () => (typeof dependencies === 'function' ? dependencies() : dependencies).map(dep => defExtractor(dep)).filter(nonNull);\n}\n/**\n * A map that contains the generated component IDs and type.\n */\nconst GENERATED_COMP_IDS = /*#__PURE__*/new Map();\n/**\n * A method can returns a component ID from the component definition using a variant of DJB2 hash\n * algorithm.\n */\nfunction getComponentId(componentDef) {\n let hash = 0;\n // We cannot rely solely on the component selector as the same selector can be used in different\n // modules.\n //\n // `componentDef.style` is not used, due to it causing inconsistencies. Ex: when server\n // component styles has no sourcemaps and browsers do.\n //\n // Example:\n // https://github.com/angular/components/blob/d9f82c8f95309e77a6d82fd574c65871e91354c2/src/material/core/option/option.ts#L248\n // https://github.com/angular/components/blob/285f46dc2b4c5b127d356cb7c4714b221f03ce50/src/material/legacy-core/option/option.ts#L32\n const hashSelectors = [componentDef.selectors, componentDef.ngContentSelectors, componentDef.hostVars, componentDef.hostAttrs, componentDef.consts, componentDef.vars, componentDef.decls, componentDef.encapsulation, componentDef.standalone, componentDef.signals, componentDef.exportAs, JSON.stringify(componentDef.inputs), JSON.stringify(componentDef.outputs),\n // We cannot use 'componentDef.type.name' as the name of the symbol will change and will not\n // match in the server and browser bundles.\n Object.getOwnPropertyNames(componentDef.type.prototype), !!componentDef.contentQueries, !!componentDef.viewQuery].join('|');\n for (const char of hashSelectors) {\n hash = Math.imul(31, hash) + char.charCodeAt(0) << 0;\n }\n // Force positive number hash.\n // 2147483647 = equivalent of Integer.MAX_VALUE.\n hash += 2147483647 + 1;\n const compId = 'c' + hash;\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n if (GENERATED_COMP_IDS.has(compId)) {\n const previousCompDefType = GENERATED_COMP_IDS.get(compId);\n if (previousCompDefType !== componentDef.type) {\n console.warn(formatRuntimeError(-912 /* RuntimeErrorCode.COMPONENT_ID_COLLISION */, `Component ID generation collision detected. Components '${previousCompDefType.name}' and '${componentDef.type.name}' with selector '${stringifyCSSSelectorList(componentDef.selectors)}' generated the same component ID. To fix this, you can change the selector of one of those components or add an extra host attribute to force a different ID.`));\n }\n } else {\n GENERATED_COMP_IDS.set(compId, componentDef.type);\n }\n }\n return compId;\n}\n\n/**\n * Wrap an array of `Provider`s into `EnvironmentProviders`, preventing them from being accidentally\n * referenced in `@Component` in a component injector.\n */\nfunction makeEnvironmentProviders(providers) {\n return {\n ɵproviders: providers\n };\n}\n/**\n * Collects providers from all NgModules and standalone components, including transitively imported\n * ones.\n *\n * Providers extracted via `importProvidersFrom` are only usable in an application injector or\n * another environment injector (such as a route injector). They should not be used in component\n * providers.\n *\n * More information about standalone components can be found in [this\n * guide](guide/components/importing).\n *\n * @usageNotes\n * The results of the `importProvidersFrom` call can be used in the `bootstrapApplication` call:\n *\n * ```typescript\n * await bootstrapApplication(RootComponent, {\n * providers: [\n * importProvidersFrom(NgModuleOne, NgModuleTwo)\n * ]\n * });\n * ```\n *\n * You can also use the `importProvidersFrom` results in the `providers` field of a route, when a\n * standalone component is used:\n *\n * ```typescript\n * export const ROUTES: Route[] = [\n * {\n * path: 'foo',\n * providers: [\n * importProvidersFrom(NgModuleOne, NgModuleTwo)\n * ],\n * component: YourStandaloneComponent\n * }\n * ];\n * ```\n *\n * @returns Collected providers from the specified list of types.\n * @publicApi\n */\nfunction importProvidersFrom(...sources) {\n return {\n ɵproviders: internalImportProvidersFrom(true, sources),\n ɵfromNgModule: true\n };\n}\nfunction internalImportProvidersFrom(checkForStandaloneCmp, ...sources) {\n const providersOut = [];\n const dedup = new Set(); // already seen types\n let injectorTypesWithProviders;\n const collectProviders = provider => {\n providersOut.push(provider);\n };\n deepForEach(sources, source => {\n if ((typeof ngDevMode === 'undefined' || ngDevMode) && checkForStandaloneCmp) {\n const cmpDef = getComponentDef(source);\n if (cmpDef?.standalone) {\n throw new RuntimeError(800 /* RuntimeErrorCode.IMPORT_PROVIDERS_FROM_STANDALONE */, `Importing providers supports NgModule or ModuleWithProviders but got a standalone component \"${stringifyForError(source)}\"`);\n }\n }\n // Narrow `source` to access the internal type analogue for `ModuleWithProviders`.\n const internalSource = source;\n if (walkProviderTree(internalSource, collectProviders, [], dedup)) {\n injectorTypesWithProviders ||= [];\n injectorTypesWithProviders.push(internalSource);\n }\n });\n // Collect all providers from `ModuleWithProviders` types.\n if (injectorTypesWithProviders !== undefined) {\n processInjectorTypesWithProviders(injectorTypesWithProviders, collectProviders);\n }\n return providersOut;\n}\n/**\n * Collects all providers from the list of `ModuleWithProviders` and appends them to the provided\n * array.\n */\nfunction processInjectorTypesWithProviders(typesWithProviders, visitor) {\n for (let i = 0; i < typesWithProviders.length; i++) {\n const {\n ngModule,\n providers\n } = typesWithProviders[i];\n deepForEachProvider(providers, provider => {\n ngDevMode && validateProvider(provider, providers || EMPTY_ARRAY, ngModule);\n visitor(provider, ngModule);\n });\n }\n}\n/**\n * The logic visits an `InjectorType`, an `InjectorTypeWithProviders`, or a standalone\n * `ComponentType`, and all of its transitive providers and collects providers.\n *\n * If an `InjectorTypeWithProviders` that declares providers besides the type is specified,\n * the function will return \"true\" to indicate that the providers of the type definition need\n * to be processed. This allows us to process providers of injector types after all imports of\n * an injector definition are processed. (following View Engine semantics: see FW-1349)\n */\nfunction walkProviderTree(container, visitor, parents, dedup) {\n container = resolveForwardRef(container);\n if (!container) return false;\n // The actual type which had the definition. Usually `container`, but may be an unwrapped type\n // from `InjectorTypeWithProviders`.\n let defType = null;\n let injDef = getInjectorDef(container);\n const cmpDef = !injDef && getComponentDef(container);\n if (!injDef && !cmpDef) {\n // `container` is not an injector type or a component type. It might be:\n // * An `InjectorTypeWithProviders` that wraps an injector type.\n // * A standalone directive or pipe that got pulled in from a standalone component's\n // dependencies.\n // Try to unwrap it as an `InjectorTypeWithProviders` first.\n const ngModule = container.ngModule;\n injDef = getInjectorDef(ngModule);\n if (injDef) {\n defType = ngModule;\n } else {\n // Not a component or injector type, so ignore it.\n return false;\n }\n } else if (cmpDef && !cmpDef.standalone) {\n return false;\n } else {\n defType = container;\n }\n // Check for circular dependencies.\n if (ngDevMode && parents.indexOf(defType) !== -1) {\n const defName = stringify(defType);\n const path = parents.map(stringify);\n throwCyclicDependencyError(defName, path);\n }\n // Check for multiple imports of the same module\n const isDuplicate = dedup.has(defType);\n if (cmpDef) {\n if (isDuplicate) {\n // This component definition has already been processed.\n return false;\n }\n dedup.add(defType);\n if (cmpDef.dependencies) {\n const deps = typeof cmpDef.dependencies === 'function' ? cmpDef.dependencies() : cmpDef.dependencies;\n for (const dep of deps) {\n walkProviderTree(dep, visitor, parents, dedup);\n }\n }\n } else if (injDef) {\n // First, include providers from any imports.\n if (injDef.imports != null && !isDuplicate) {\n // Before processing defType's imports, add it to the set of parents. This way, if it ends\n // up deeply importing itself, this can be detected.\n ngDevMode && parents.push(defType);\n // Add it to the set of dedups. This way we can detect multiple imports of the same module\n dedup.add(defType);\n let importTypesWithProviders;\n try {\n deepForEach(injDef.imports, imported => {\n if (walkProviderTree(imported, visitor, parents, dedup)) {\n importTypesWithProviders ||= [];\n // If the processed import is an injector type with providers, we store it in the\n // list of import types with providers, so that we can process those afterwards.\n importTypesWithProviders.push(imported);\n }\n });\n } finally {\n // Remove it from the parents set when finished.\n ngDevMode && parents.pop();\n }\n // Imports which are declared with providers (TypeWithProviders) need to be processed\n // after all imported modules are processed. This is similar to how View Engine\n // processes/merges module imports in the metadata resolver. See: FW-1349.\n if (importTypesWithProviders !== undefined) {\n processInjectorTypesWithProviders(importTypesWithProviders, visitor);\n }\n }\n if (!isDuplicate) {\n // Track the InjectorType and add a provider for it.\n // It's important that this is done after the def's imports.\n const factory = getFactoryDef(defType) || (() => new defType());\n // Append extra providers to make more info available for consumers (to retrieve an injector\n // type), as well as internally (to calculate an injection scope correctly and eagerly\n // instantiate a `defType` when an injector is created).\n // Provider to create `defType` using its factory.\n visitor({\n provide: defType,\n useFactory: factory,\n deps: EMPTY_ARRAY\n }, defType);\n // Make this `defType` available to an internal logic that calculates injector scope.\n visitor({\n provide: INJECTOR_DEF_TYPES,\n useValue: defType,\n multi: true\n }, defType);\n // Provider to eagerly instantiate `defType` via `INJECTOR_INITIALIZER`.\n visitor({\n provide: ENVIRONMENT_INITIALIZER,\n useValue: () => ɵɵinject(defType),\n multi: true\n }, defType);\n }\n // Next, include providers listed on the definition itself.\n const defProviders = injDef.providers;\n if (defProviders != null && !isDuplicate) {\n const injectorType = container;\n deepForEachProvider(defProviders, provider => {\n ngDevMode && validateProvider(provider, defProviders, injectorType);\n visitor(provider, injectorType);\n });\n }\n } else {\n // Should not happen, but just in case.\n return false;\n }\n return defType !== container && container.providers !== undefined;\n}\nfunction validateProvider(provider, providers, containerType) {\n if (isTypeProvider(provider) || isValueProvider(provider) || isFactoryProvider(provider) || isExistingProvider(provider)) {\n return;\n }\n // Here we expect the provider to be a `useClass` provider (by elimination).\n const classRef = resolveForwardRef(provider && (provider.useClass || provider.provide));\n if (!classRef) {\n throwInvalidProviderError(containerType, providers, provider);\n }\n}\nfunction deepForEachProvider(providers, fn) {\n for (let provider of providers) {\n if (isEnvironmentProviders(provider)) {\n provider = provider.ɵproviders;\n }\n if (Array.isArray(provider)) {\n deepForEachProvider(provider, fn);\n } else {\n fn(provider);\n }\n }\n}\nconst USE_VALUE$1 = /*#__PURE__*/getClosureSafeProperty({\n provide: String,\n useValue: getClosureSafeProperty\n});\nfunction isValueProvider(value) {\n return value !== null && typeof value == 'object' && USE_VALUE$1 in value;\n}\nfunction isExistingProvider(value) {\n return !!(value && value.useExisting);\n}\nfunction isFactoryProvider(value) {\n return !!(value && value.useFactory);\n}\nfunction isTypeProvider(value) {\n return typeof value === 'function';\n}\nfunction isClassProvider(value) {\n return !!value.useClass;\n}\n\n/**\n * An internal token whose presence in an injector indicates that the injector should treat itself\n * as a root scoped injector when processing requests for unknown tokens which may indicate\n * they are provided in the root scope.\n */\nconst INJECTOR_SCOPE = /*#__PURE__*/new InjectionToken(ngDevMode ? 'Set Injector scope.' : '');\n\n/**\n * Marker which indicates that a value has not yet been created from the factory function.\n */\nconst NOT_YET = {};\n/**\n * Marker which indicates that the factory function for a token is in the process of being called.\n *\n * If the injector is asked to inject a token with its value set to CIRCULAR, that indicates\n * injection of a dependency has recursively attempted to inject the original token, and there is\n * a circular dependency among the providers.\n */\nconst CIRCULAR = {};\n/**\n * A lazily initialized NullInjector.\n */\nlet NULL_INJECTOR = undefined;\nfunction getNullInjector() {\n if (NULL_INJECTOR === undefined) {\n NULL_INJECTOR = new NullInjector();\n }\n return NULL_INJECTOR;\n}\n/**\n * An `Injector` that's part of the environment injector hierarchy, which exists outside of the\n * component tree.\n */\nclass EnvironmentInjector {}\nclass R3Injector extends EnvironmentInjector {\n /**\n * Flag indicating that this injector was previously destroyed.\n */\n get destroyed() {\n return this._destroyed;\n }\n constructor(providers, parent, source, scopes) {\n super();\n this.parent = parent;\n this.source = source;\n this.scopes = scopes;\n /**\n * Map of tokens to records which contain the instances of those tokens.\n * - `null` value implies that we don't have the record. Used by tree-shakable injectors\n * to prevent further searches.\n */\n this.records = new Map();\n /**\n * Set of values instantiated by this injector which contain `ngOnDestroy` lifecycle hooks.\n */\n this._ngOnDestroyHooks = new Set();\n this._onDestroyHooks = [];\n this._destroyed = false;\n // Start off by creating Records for every provider.\n forEachSingleProvider(providers, provider => this.processProvider(provider));\n // Make sure the INJECTOR token provides this injector.\n this.records.set(INJECTOR$1, makeRecord(undefined, this));\n // And `EnvironmentInjector` if the current injector is supposed to be env-scoped.\n if (scopes.has('environment')) {\n this.records.set(EnvironmentInjector, makeRecord(undefined, this));\n }\n // Detect whether this injector has the APP_ROOT_SCOPE token and thus should provide\n // any injectable scoped to APP_ROOT_SCOPE.\n const record = this.records.get(INJECTOR_SCOPE);\n if (record != null && typeof record.value === 'string') {\n this.scopes.add(record.value);\n }\n this.injectorDefTypes = new Set(this.get(INJECTOR_DEF_TYPES, EMPTY_ARRAY, InjectFlags.Self));\n }\n /**\n * Destroy the injector and release references to every instance or provider associated with it.\n *\n * Also calls the `OnDestroy` lifecycle hooks of every instance that was created for which a\n * hook was found.\n */\n destroy() {\n this.assertNotDestroyed();\n // Set destroyed = true first, in case lifecycle hooks re-enter destroy().\n this._destroyed = true;\n const prevConsumer = setActiveConsumer$1(null);\n try {\n // Call all the lifecycle hooks.\n for (const service of this._ngOnDestroyHooks) {\n service.ngOnDestroy();\n }\n const onDestroyHooks = this._onDestroyHooks;\n // Reset the _onDestroyHooks array before iterating over it to prevent hooks that unregister\n // themselves from mutating the array during iteration.\n this._onDestroyHooks = [];\n for (const hook of onDestroyHooks) {\n hook();\n }\n } finally {\n // Release all references.\n this.records.clear();\n this._ngOnDestroyHooks.clear();\n this.injectorDefTypes.clear();\n setActiveConsumer$1(prevConsumer);\n }\n }\n onDestroy(callback) {\n this.assertNotDestroyed();\n this._onDestroyHooks.push(callback);\n return () => this.removeOnDestroy(callback);\n }\n runInContext(fn) {\n this.assertNotDestroyed();\n const previousInjector = setCurrentInjector(this);\n const previousInjectImplementation = setInjectImplementation(undefined);\n let prevInjectContext;\n if (ngDevMode) {\n prevInjectContext = setInjectorProfilerContext({\n injector: this,\n token: null\n });\n }\n try {\n return fn();\n } finally {\n setCurrentInjector(previousInjector);\n setInjectImplementation(previousInjectImplementation);\n ngDevMode && setInjectorProfilerContext(prevInjectContext);\n }\n }\n get(token, notFoundValue = THROW_IF_NOT_FOUND, flags = InjectFlags.Default) {\n this.assertNotDestroyed();\n if (token.hasOwnProperty(NG_ENV_ID)) {\n return token[NG_ENV_ID](this);\n }\n flags = convertToBitFlags(flags);\n // Set the injection context.\n let prevInjectContext;\n if (ngDevMode) {\n prevInjectContext = setInjectorProfilerContext({\n injector: this,\n token: token\n });\n }\n const previousInjector = setCurrentInjector(this);\n const previousInjectImplementation = setInjectImplementation(undefined);\n try {\n // Check for the SkipSelf flag.\n if (!(flags & InjectFlags.SkipSelf)) {\n // SkipSelf isn't set, check if the record belongs to this injector.\n let record = this.records.get(token);\n if (record === undefined) {\n // No record, but maybe the token is scoped to this injector. Look for an injectable\n // def with a scope matching this injector.\n const def = couldBeInjectableType(token) && getInjectableDef(token);\n if (def && this.injectableDefInScope(def)) {\n // Found an injectable def and it's scoped to this injector. Pretend as if it was here\n // all along.\n if (ngDevMode) {\n runInInjectorProfilerContext(this, token, () => {\n emitProviderConfiguredEvent(token);\n });\n }\n record = makeRecord(injectableDefOrInjectorDefFactory(token), NOT_YET);\n } else {\n record = null;\n }\n this.records.set(token, record);\n }\n // If a record was found, get the instance for it and return it.\n if (record != null /* NOT null || undefined */) {\n return this.hydrate(token, record);\n }\n }\n // Select the next injector based on the Self flag - if self is set, the next injector is\n // the NullInjector, otherwise it's the parent.\n const nextInjector = !(flags & InjectFlags.Self) ? this.parent : getNullInjector();\n // Set the notFoundValue based on the Optional flag - if optional is set and notFoundValue\n // is undefined, the value is null, otherwise it's the notFoundValue.\n notFoundValue = flags & InjectFlags.Optional && notFoundValue === THROW_IF_NOT_FOUND ? null : notFoundValue;\n return nextInjector.get(token, notFoundValue);\n } catch (e) {\n if (e.name === 'NullInjectorError') {\n const path = e[NG_TEMP_TOKEN_PATH] = e[NG_TEMP_TOKEN_PATH] || [];\n path.unshift(stringify(token));\n if (previousInjector) {\n // We still have a parent injector, keep throwing\n throw e;\n } else {\n // Format & throw the final error message when we don't have any previous injector\n return catchInjectorError(e, token, 'R3InjectorError', this.source);\n }\n } else {\n throw e;\n }\n } finally {\n // Lastly, restore the previous injection context.\n setInjectImplementation(previousInjectImplementation);\n setCurrentInjector(previousInjector);\n ngDevMode && setInjectorProfilerContext(prevInjectContext);\n }\n }\n /** @internal */\n resolveInjectorInitializers() {\n const prevConsumer = setActiveConsumer$1(null);\n const previousInjector = setCurrentInjector(this);\n const previousInjectImplementation = setInjectImplementation(undefined);\n let prevInjectContext;\n if (ngDevMode) {\n prevInjectContext = setInjectorProfilerContext({\n injector: this,\n token: null\n });\n }\n try {\n const initializers = this.get(ENVIRONMENT_INITIALIZER, EMPTY_ARRAY, InjectFlags.Self);\n if (ngDevMode && !Array.isArray(initializers)) {\n throw new RuntimeError(-209 /* RuntimeErrorCode.INVALID_MULTI_PROVIDER */, 'Unexpected type of the `ENVIRONMENT_INITIALIZER` token value ' + `(expected an array, but got ${typeof initializers}). ` + 'Please check that the `ENVIRONMENT_INITIALIZER` token is configured as a ' + '`multi: true` provider.');\n }\n for (const initializer of initializers) {\n initializer();\n }\n } finally {\n setCurrentInjector(previousInjector);\n setInjectImplementation(previousInjectImplementation);\n ngDevMode && setInjectorProfilerContext(prevInjectContext);\n setActiveConsumer$1(prevConsumer);\n }\n }\n toString() {\n const tokens = [];\n const records = this.records;\n for (const token of records.keys()) {\n tokens.push(stringify(token));\n }\n return `R3Injector[${tokens.join(', ')}]`;\n }\n assertNotDestroyed() {\n if (this._destroyed) {\n throw new RuntimeError(205 /* RuntimeErrorCode.INJECTOR_ALREADY_DESTROYED */, ngDevMode && 'Injector has already been destroyed.');\n }\n }\n /**\n * Process a `SingleProvider` and add it.\n */\n processProvider(provider) {\n // Determine the token from the provider. Either it's its own token, or has a {provide: ...}\n // property.\n provider = resolveForwardRef(provider);\n let token = isTypeProvider(provider) ? provider : resolveForwardRef(provider && provider.provide);\n // Construct a `Record` for the provider.\n const record = providerToRecord(provider);\n if (ngDevMode) {\n runInInjectorProfilerContext(this, token, () => {\n // Emit InjectorProfilerEventType.Create if provider is a value provider because\n // these are the only providers that do not go through the value hydration logic\n // where this event would normally be emitted from.\n if (isValueProvider(provider)) {\n emitInstanceCreatedByInjectorEvent(provider.useValue);\n }\n emitProviderConfiguredEvent(provider);\n });\n }\n if (!isTypeProvider(provider) && provider.multi === true) {\n // If the provider indicates that it's a multi-provider, process it specially.\n // First check whether it's been defined already.\n let multiRecord = this.records.get(token);\n if (multiRecord) {\n // It has. Throw a nice error if\n if (ngDevMode && multiRecord.multi === undefined) {\n throwMixedMultiProviderError();\n }\n } else {\n multiRecord = makeRecord(undefined, NOT_YET, true);\n multiRecord.factory = () => injectArgs(multiRecord.multi);\n this.records.set(token, multiRecord);\n }\n token = provider;\n multiRecord.multi.push(provider);\n } else {\n if (ngDevMode) {\n const existing = this.records.get(token);\n if (existing && existing.multi !== undefined) {\n throwMixedMultiProviderError();\n }\n }\n }\n this.records.set(token, record);\n }\n hydrate(token, record) {\n const prevConsumer = setActiveConsumer$1(null);\n try {\n if (ngDevMode && record.value === CIRCULAR) {\n throwCyclicDependencyError(stringify(token));\n } else if (record.value === NOT_YET) {\n record.value = CIRCULAR;\n if (ngDevMode) {\n runInInjectorProfilerContext(this, token, () => {\n record.value = record.factory();\n emitInstanceCreatedByInjectorEvent(record.value);\n });\n } else {\n record.value = record.factory();\n }\n }\n if (typeof record.value === 'object' && record.value && hasOnDestroy(record.value)) {\n this._ngOnDestroyHooks.add(record.value);\n }\n return record.value;\n } finally {\n setActiveConsumer$1(prevConsumer);\n }\n }\n injectableDefInScope(def) {\n if (!def.providedIn) {\n return false;\n }\n const providedIn = resolveForwardRef(def.providedIn);\n if (typeof providedIn === 'string') {\n return providedIn === 'any' || this.scopes.has(providedIn);\n } else {\n return this.injectorDefTypes.has(providedIn);\n }\n }\n removeOnDestroy(callback) {\n const destroyCBIdx = this._onDestroyHooks.indexOf(callback);\n if (destroyCBIdx !== -1) {\n this._onDestroyHooks.splice(destroyCBIdx, 1);\n }\n }\n}\nfunction injectableDefOrInjectorDefFactory(token) {\n // Most tokens will have an injectable def directly on them, which specifies a factory directly.\n const injectableDef = getInjectableDef(token);\n const factory = injectableDef !== null ? injectableDef.factory : getFactoryDef(token);\n if (factory !== null) {\n return factory;\n }\n // InjectionTokens should have an injectable def (ɵprov) and thus should be handled above.\n // If it's missing that, it's an error.\n if (token instanceof InjectionToken) {\n throw new RuntimeError(204 /* RuntimeErrorCode.INVALID_INJECTION_TOKEN */, ngDevMode && `Token ${stringify(token)} is missing a ɵprov definition.`);\n }\n // Undecorated types can sometimes be created if they have no constructor arguments.\n if (token instanceof Function) {\n return getUndecoratedInjectableFactory(token);\n }\n // There was no way to resolve a factory for this token.\n throw new RuntimeError(204 /* RuntimeErrorCode.INVALID_INJECTION_TOKEN */, ngDevMode && 'unreachable');\n}\nfunction getUndecoratedInjectableFactory(token) {\n // If the token has parameters then it has dependencies that we cannot resolve implicitly.\n const paramLength = token.length;\n if (paramLength > 0) {\n throw new RuntimeError(204 /* RuntimeErrorCode.INVALID_INJECTION_TOKEN */, ngDevMode && `Can't resolve all parameters for ${stringify(token)}: (${newArray(paramLength, '?').join(', ')}).`);\n }\n // The constructor function appears to have no parameters.\n // This might be because it inherits from a super-class. In which case, use an injectable\n // def from an ancestor if there is one.\n // Otherwise this really is a simple class with no dependencies, so return a factory that\n // just instantiates the zero-arg constructor.\n const inheritedInjectableDef = getInheritedInjectableDef(token);\n if (inheritedInjectableDef !== null) {\n return () => inheritedInjectableDef.factory(token);\n } else {\n return () => new token();\n }\n}\nfunction providerToRecord(provider) {\n if (isValueProvider(provider)) {\n return makeRecord(undefined, provider.useValue);\n } else {\n const factory = providerToFactory(provider);\n return makeRecord(factory, NOT_YET);\n }\n}\n/**\n * Converts a `SingleProvider` into a factory function.\n *\n * @param provider provider to convert to factory\n */\nfunction providerToFactory(provider, ngModuleType, providers) {\n let factory = undefined;\n if (ngDevMode && isEnvironmentProviders(provider)) {\n throwInvalidProviderError(undefined, providers, provider);\n }\n if (isTypeProvider(provider)) {\n const unwrappedProvider = resolveForwardRef(provider);\n return getFactoryDef(unwrappedProvider) || injectableDefOrInjectorDefFactory(unwrappedProvider);\n } else {\n if (isValueProvider(provider)) {\n factory = () => resolveForwardRef(provider.useValue);\n } else if (isFactoryProvider(provider)) {\n factory = () => provider.useFactory(...injectArgs(provider.deps || []));\n } else if (isExistingProvider(provider)) {\n factory = () => ɵɵinject(resolveForwardRef(provider.useExisting));\n } else {\n const classRef = resolveForwardRef(provider && (provider.useClass || provider.provide));\n if (ngDevMode && !classRef) {\n throwInvalidProviderError(ngModuleType, providers, provider);\n }\n if (hasDeps(provider)) {\n factory = () => new classRef(...injectArgs(provider.deps));\n } else {\n return getFactoryDef(classRef) || injectableDefOrInjectorDefFactory(classRef);\n }\n }\n }\n return factory;\n}\nfunction makeRecord(factory, value, multi = false) {\n return {\n factory: factory,\n value: value,\n multi: multi ? [] : undefined\n };\n}\nfunction hasDeps(value) {\n return !!value.deps;\n}\nfunction hasOnDestroy(value) {\n return value !== null && typeof value === 'object' && typeof value.ngOnDestroy === 'function';\n}\nfunction couldBeInjectableType(value) {\n return typeof value === 'function' || typeof value === 'object' && value instanceof InjectionToken;\n}\nfunction forEachSingleProvider(providers, fn) {\n for (const provider of providers) {\n if (Array.isArray(provider)) {\n forEachSingleProvider(provider, fn);\n } else if (provider && isEnvironmentProviders(provider)) {\n forEachSingleProvider(provider.ɵproviders, fn);\n } else {\n fn(provider);\n }\n }\n}\n\n/**\n * Runs the given function in the [context](guide/di/dependency-injection-context) of the given\n * `Injector`.\n *\n * Within the function's stack frame, [`inject`](api/core/inject) can be used to inject dependencies\n * from the given `Injector`. Note that `inject` is only usable synchronously, and cannot be used in\n * any asynchronous callbacks or after any `await` points.\n *\n * @param injector the injector which will satisfy calls to [`inject`](api/core/inject) while `fn`\n * is executing\n * @param fn the closure to be run in the context of `injector`\n * @returns the return value of the function, if any\n * @publicApi\n */\nfunction runInInjectionContext(injector, fn) {\n if (injector instanceof R3Injector) {\n injector.assertNotDestroyed();\n }\n let prevInjectorProfilerContext;\n if (ngDevMode) {\n prevInjectorProfilerContext = setInjectorProfilerContext({\n injector,\n token: null\n });\n }\n const prevInjector = setCurrentInjector(injector);\n const previousInjectImplementation = setInjectImplementation(undefined);\n try {\n return fn();\n } finally {\n setCurrentInjector(prevInjector);\n ngDevMode && setInjectorProfilerContext(prevInjectorProfilerContext);\n setInjectImplementation(previousInjectImplementation);\n }\n}\n/**\n * Whether the current stack frame is inside an injection context.\n */\nfunction isInInjectionContext() {\n return getInjectImplementation() !== undefined || getCurrentInjector() != null;\n}\n/**\n * Asserts that the current stack frame is within an [injection\n * context](guide/di/dependency-injection-context) and has access to `inject`.\n *\n * @param debugFn a reference to the function making the assertion (used for the error message).\n *\n * @publicApi\n */\nfunction assertInInjectionContext(debugFn) {\n // Taking a `Function` instead of a string name here prevents the unminified name of the function\n // from being retained in the bundle regardless of minification.\n if (!isInInjectionContext()) {\n throw new RuntimeError(-203 /* RuntimeErrorCode.MISSING_INJECTION_CONTEXT */, ngDevMode && debugFn.name + '() can only be used within an injection context such as a constructor, a factory function, a field initializer, or a function used with `runInInjectionContext`');\n }\n}\nvar FactoryTarget = /*#__PURE__*/function (FactoryTarget) {\n FactoryTarget[FactoryTarget[\"Directive\"] = 0] = \"Directive\";\n FactoryTarget[FactoryTarget[\"Component\"] = 1] = \"Component\";\n FactoryTarget[FactoryTarget[\"Injectable\"] = 2] = \"Injectable\";\n FactoryTarget[FactoryTarget[\"Pipe\"] = 3] = \"Pipe\";\n FactoryTarget[FactoryTarget[\"NgModule\"] = 4] = \"NgModule\";\n return FactoryTarget;\n}(FactoryTarget || {});\nvar R3TemplateDependencyKind = /*#__PURE__*/function (R3TemplateDependencyKind) {\n R3TemplateDependencyKind[R3TemplateDependencyKind[\"Directive\"] = 0] = \"Directive\";\n R3TemplateDependencyKind[R3TemplateDependencyKind[\"Pipe\"] = 1] = \"Pipe\";\n R3TemplateDependencyKind[R3TemplateDependencyKind[\"NgModule\"] = 2] = \"NgModule\";\n return R3TemplateDependencyKind;\n}(R3TemplateDependencyKind || {});\nvar ViewEncapsulation = /*#__PURE__*/function (ViewEncapsulation) {\n ViewEncapsulation[ViewEncapsulation[\"Emulated\"] = 0] = \"Emulated\";\n // Historically the 1 value was for `Native` encapsulation which has been removed as of v11.\n ViewEncapsulation[ViewEncapsulation[\"None\"] = 2] = \"None\";\n ViewEncapsulation[ViewEncapsulation[\"ShadowDom\"] = 3] = \"ShadowDom\";\n return ViewEncapsulation;\n}(ViewEncapsulation || {});\nfunction getCompilerFacade(request) {\n const globalNg = _global['ng'];\n if (globalNg && globalNg.ɵcompilerFacade) {\n return globalNg.ɵcompilerFacade;\n }\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n // Log the type as an error so that a developer can easily navigate to the type from the\n // console.\n console.error(`JIT compilation failed for ${request.kind}`, request.type);\n let message = `The ${request.kind} '${request.type.name}' needs to be compiled using the JIT compiler, but '@angular/compiler' is not available.\\n\\n`;\n if (request.usage === 1 /* JitCompilerUsage.PartialDeclaration */) {\n message += `The ${request.kind} is part of a library that has been partially compiled.\\n`;\n message += `However, the Angular Linker has not processed the library such that JIT compilation is used as fallback.\\n`;\n message += '\\n';\n message += `Ideally, the library is processed using the Angular Linker to become fully AOT compiled.\\n`;\n } else {\n message += `JIT compilation is discouraged for production use-cases! Consider using AOT mode instead.\\n`;\n }\n message += `Alternatively, the JIT compiler should be loaded by bootstrapping using '@angular/platform-browser-dynamic' or '@angular/platform-server',\\n`;\n message += `or manually provide the compiler with 'import \"@angular/compiler\";' before bootstrapping.`;\n throw new Error(message);\n } else {\n throw new Error('JIT compiler unavailable');\n }\n}\n\n/**\n * A mapping of the @angular/core API surface used in generated expressions to the actual symbols.\n *\n * This should be kept up to date with the public exports of @angular/core.\n */\nconst angularCoreDiEnv = {\n 'ɵɵdefineInjectable': ɵɵdefineInjectable,\n 'ɵɵdefineInjector': ɵɵdefineInjector,\n 'ɵɵinject': ɵɵinject,\n 'ɵɵinvalidFactoryDep': ɵɵinvalidFactoryDep,\n 'resolveForwardRef': resolveForwardRef\n};\n\n/**\n * @description\n *\n * Represents a type that a Component or other object is instances of.\n *\n * An example of a `Type` is `MyCustomComponent` class, which in JavaScript is represented by\n * the `MyCustomComponent` constructor function.\n *\n * @publicApi\n */\nconst Type = Function;\nfunction isType(v) {\n return typeof v === 'function';\n}\n\n/*\n * #########################\n * Attention: These Regular expressions have to hold even if the code is minified!\n * ##########################\n */\n/**\n * Regular expression that detects pass-through constructors for ES5 output. This Regex\n * intends to capture the common delegation pattern emitted by TypeScript and Babel. Also\n * it intends to capture the pattern where existing constructors have been downleveled from\n * ES2015 to ES5 using TypeScript w/ downlevel iteration. e.g.\n *\n * ```\n * function MyClass() {\n * var _this = _super.apply(this, arguments) || this;\n * ```\n *\n * downleveled to ES5 with `downlevelIteration` for TypeScript < 4.2:\n * ```\n * function MyClass() {\n * var _this = _super.apply(this, __spread(arguments)) || this;\n * ```\n *\n * or downleveled to ES5 with `downlevelIteration` for TypeScript >= 4.2:\n * ```\n * function MyClass() {\n * var _this = _super.apply(this, __spreadArray([], __read(arguments), false)) || this;\n * ```\n *\n * More details can be found in: https://github.com/angular/angular/issues/38453.\n */\nconst ES5_DELEGATE_CTOR = /^function\\s+\\S+\\(\\)\\s*{[\\s\\S]+\\.apply\\(this,\\s*(arguments|(?:[^()]+\\(\\[\\],)?[^()]+\\(arguments\\).*)\\)/;\n/** Regular expression that detects ES2015 classes which extend from other classes. */\nconst ES2015_INHERITED_CLASS = /^class\\s+[A-Za-z\\d$_]*\\s*extends\\s+[^{]+{/;\n/**\n * Regular expression that detects ES2015 classes which extend from other classes and\n * have an explicit constructor defined.\n */\nconst ES2015_INHERITED_CLASS_WITH_CTOR = /^class\\s+[A-Za-z\\d$_]*\\s*extends\\s+[^{]+{[\\s\\S]*constructor\\s*\\(/;\n/**\n * Regular expression that detects ES2015 classes which extend from other classes\n * and inherit a constructor.\n */\nconst ES2015_INHERITED_CLASS_WITH_DELEGATE_CTOR = /^class\\s+[A-Za-z\\d$_]*\\s*extends\\s+[^{]+{[\\s\\S]*constructor\\s*\\(\\)\\s*{[^}]*super\\(\\.\\.\\.arguments\\)/;\n/**\n * Determine whether a stringified type is a class which delegates its constructor\n * to its parent.\n *\n * This is not trivial since compiled code can actually contain a constructor function\n * even if the original source code did not. For instance, when the child class contains\n * an initialized instance property.\n */\nfunction isDelegateCtor(typeStr) {\n return ES5_DELEGATE_CTOR.test(typeStr) || ES2015_INHERITED_CLASS_WITH_DELEGATE_CTOR.test(typeStr) || ES2015_INHERITED_CLASS.test(typeStr) && !ES2015_INHERITED_CLASS_WITH_CTOR.test(typeStr);\n}\nclass ReflectionCapabilities {\n constructor(reflect) {\n this._reflect = reflect || _global['Reflect'];\n }\n factory(t) {\n return (...args) => new t(...args);\n }\n /** @internal */\n _zipTypesAndAnnotations(paramTypes, paramAnnotations) {\n let result;\n if (typeof paramTypes === 'undefined') {\n result = newArray(paramAnnotations.length);\n } else {\n result = newArray(paramTypes.length);\n }\n for (let i = 0; i < result.length; i++) {\n // TS outputs Object for parameters without types, while Traceur omits\n // the annotations. For now we preserve the Traceur behavior to aid\n // migration, but this can be revisited.\n if (typeof paramTypes === 'undefined') {\n result[i] = [];\n } else if (paramTypes[i] && paramTypes[i] != Object) {\n result[i] = [paramTypes[i]];\n } else {\n result[i] = [];\n }\n if (paramAnnotations && paramAnnotations[i] != null) {\n result[i] = result[i].concat(paramAnnotations[i]);\n }\n }\n return result;\n }\n _ownParameters(type, parentCtor) {\n const typeStr = type.toString();\n // If we have no decorators, we only have function.length as metadata.\n // In that case, to detect whether a child class declared an own constructor or not,\n // we need to look inside of that constructor to check whether it is\n // just calling the parent.\n // This also helps to work around for https://github.com/Microsoft/TypeScript/issues/12439\n // that sets 'design:paramtypes' to []\n // if a class inherits from another class but has no ctor declared itself.\n if (isDelegateCtor(typeStr)) {\n return null;\n }\n // Prefer the direct API.\n if (type.parameters && type.parameters !== parentCtor.parameters) {\n return type.parameters;\n }\n // API of tsickle for lowering decorators to properties on the class.\n const tsickleCtorParams = type.ctorParameters;\n if (tsickleCtorParams && tsickleCtorParams !== parentCtor.ctorParameters) {\n // Newer tsickle uses a function closure\n // Retain the non-function case for compatibility with older tsickle\n const ctorParameters = typeof tsickleCtorParams === 'function' ? tsickleCtorParams() : tsickleCtorParams;\n const paramTypes = ctorParameters.map(ctorParam => ctorParam && ctorParam.type);\n const paramAnnotations = ctorParameters.map(ctorParam => ctorParam && convertTsickleDecoratorIntoMetadata(ctorParam.decorators));\n return this._zipTypesAndAnnotations(paramTypes, paramAnnotations);\n }\n // API for metadata created by invoking the decorators.\n const paramAnnotations = type.hasOwnProperty(PARAMETERS) && type[PARAMETERS];\n const paramTypes = this._reflect && this._reflect.getOwnMetadata && this._reflect.getOwnMetadata('design:paramtypes', type);\n if (paramTypes || paramAnnotations) {\n return this._zipTypesAndAnnotations(paramTypes, paramAnnotations);\n }\n // If a class has no decorators, at least create metadata\n // based on function.length.\n // Note: We know that this is a real constructor as we checked\n // the content of the constructor above.\n return newArray(type.length);\n }\n parameters(type) {\n // Note: only report metadata if we have at least one class decorator\n // to stay in sync with the static reflector.\n if (!isType(type)) {\n return [];\n }\n const parentCtor = getParentCtor(type);\n let parameters = this._ownParameters(type, parentCtor);\n if (!parameters && parentCtor !== Object) {\n parameters = this.parameters(parentCtor);\n }\n return parameters || [];\n }\n _ownAnnotations(typeOrFunc, parentCtor) {\n // Prefer the direct API.\n if (typeOrFunc.annotations && typeOrFunc.annotations !== parentCtor.annotations) {\n let annotations = typeOrFunc.annotations;\n if (typeof annotations === 'function' && annotations.annotations) {\n annotations = annotations.annotations;\n }\n return annotations;\n }\n // API of tsickle for lowering decorators to properties on the class.\n if (typeOrFunc.decorators && typeOrFunc.decorators !== parentCtor.decorators) {\n return convertTsickleDecoratorIntoMetadata(typeOrFunc.decorators);\n }\n // API for metadata created by invoking the decorators.\n if (typeOrFunc.hasOwnProperty(ANNOTATIONS)) {\n return typeOrFunc[ANNOTATIONS];\n }\n return null;\n }\n annotations(typeOrFunc) {\n if (!isType(typeOrFunc)) {\n return [];\n }\n const parentCtor = getParentCtor(typeOrFunc);\n const ownAnnotations = this._ownAnnotations(typeOrFunc, parentCtor) || [];\n const parentAnnotations = parentCtor !== Object ? this.annotations(parentCtor) : [];\n return parentAnnotations.concat(ownAnnotations);\n }\n _ownPropMetadata(typeOrFunc, parentCtor) {\n // Prefer the direct API.\n if (typeOrFunc.propMetadata && typeOrFunc.propMetadata !== parentCtor.propMetadata) {\n let propMetadata = typeOrFunc.propMetadata;\n if (typeof propMetadata === 'function' && propMetadata.propMetadata) {\n propMetadata = propMetadata.propMetadata;\n }\n return propMetadata;\n }\n // API of tsickle for lowering decorators to properties on the class.\n if (typeOrFunc.propDecorators && typeOrFunc.propDecorators !== parentCtor.propDecorators) {\n const propDecorators = typeOrFunc.propDecorators;\n const propMetadata = {};\n Object.keys(propDecorators).forEach(prop => {\n propMetadata[prop] = convertTsickleDecoratorIntoMetadata(propDecorators[prop]);\n });\n return propMetadata;\n }\n // API for metadata created by invoking the decorators.\n if (typeOrFunc.hasOwnProperty(PROP_METADATA)) {\n return typeOrFunc[PROP_METADATA];\n }\n return null;\n }\n propMetadata(typeOrFunc) {\n if (!isType(typeOrFunc)) {\n return {};\n }\n const parentCtor = getParentCtor(typeOrFunc);\n const propMetadata = {};\n if (parentCtor !== Object) {\n const parentPropMetadata = this.propMetadata(parentCtor);\n Object.keys(parentPropMetadata).forEach(propName => {\n propMetadata[propName] = parentPropMetadata[propName];\n });\n }\n const ownPropMetadata = this._ownPropMetadata(typeOrFunc, parentCtor);\n if (ownPropMetadata) {\n Object.keys(ownPropMetadata).forEach(propName => {\n const decorators = [];\n if (propMetadata.hasOwnProperty(propName)) {\n decorators.push(...propMetadata[propName]);\n }\n decorators.push(...ownPropMetadata[propName]);\n propMetadata[propName] = decorators;\n });\n }\n return propMetadata;\n }\n ownPropMetadata(typeOrFunc) {\n if (!isType(typeOrFunc)) {\n return {};\n }\n return this._ownPropMetadata(typeOrFunc, getParentCtor(typeOrFunc)) || {};\n }\n hasLifecycleHook(type, lcProperty) {\n return type instanceof Type && lcProperty in type.prototype;\n }\n}\nfunction convertTsickleDecoratorIntoMetadata(decoratorInvocations) {\n if (!decoratorInvocations) {\n return [];\n }\n return decoratorInvocations.map(decoratorInvocation => {\n const decoratorType = decoratorInvocation.type;\n const annotationCls = decoratorType.annotationCls;\n const annotationArgs = decoratorInvocation.args ? decoratorInvocation.args : [];\n return new annotationCls(...annotationArgs);\n });\n}\nfunction getParentCtor(ctor) {\n const parentProto = ctor.prototype ? Object.getPrototypeOf(ctor.prototype) : null;\n const parentCtor = parentProto ? parentProto.constructor : null;\n // Note: We always use `Object` as the null value\n // to simplify checking later on.\n return parentCtor || Object;\n}\n\n// Below are constants for LView indices to help us look up LView members\n// without having to remember the specific indices.\n// Uglify will inline these when minifying so there shouldn't be a cost.\nconst HOST = 0;\nconst TVIEW = 1;\n// Shared with LContainer\nconst FLAGS = 2;\nconst PARENT = 3;\nconst NEXT = 4;\nconst T_HOST = 5;\n// End shared with LContainer\nconst HYDRATION = 6;\nconst CLEANUP = 7;\nconst CONTEXT = 8;\nconst INJECTOR = 9;\nconst ENVIRONMENT = 10;\nconst RENDERER = 11;\nconst CHILD_HEAD = 12;\nconst CHILD_TAIL = 13;\n// FIXME(misko): Investigate if the three declarations aren't all same thing.\nconst DECLARATION_VIEW = 14;\nconst DECLARATION_COMPONENT_VIEW = 15;\nconst DECLARATION_LCONTAINER = 16;\nconst PREORDER_HOOK_FLAGS = 17;\nconst QUERIES = 18;\nconst ID = 19;\nconst EMBEDDED_VIEW_INJECTOR = 20;\nconst ON_DESTROY_HOOKS = 21;\nconst EFFECTS_TO_SCHEDULE = 22;\nconst REACTIVE_TEMPLATE_CONSUMER = 23;\n/**\n * Size of LView's header. Necessary to adjust for it when setting slots.\n *\n * IMPORTANT: `HEADER_OFFSET` should only be referred to the in the `ɵɵ*` instructions to translate\n * instruction index into `LView` index. All other indexes should be in the `LView` index space and\n * there should be no need to refer to `HEADER_OFFSET` anywhere else.\n */\nconst HEADER_OFFSET = 25;\n\n/**\n * Special location which allows easy identification of type. If we have an array which was\n * retrieved from the `LView` and that array has `true` at `TYPE` location, we know it is\n * `LContainer`.\n */\nconst TYPE = 1;\n/**\n * Below are constants for LContainer indices to help us look up LContainer members\n * without having to remember the specific indices.\n * Uglify will inline these when minifying so there shouldn't be a cost.\n */\n// FLAGS, PARENT, NEXT, and T_HOST are indices 2, 3, 4, and 5\n// As we already have these constants in LView, we don't need to re-create them.\nconst DEHYDRATED_VIEWS = 6;\nconst NATIVE = 7;\nconst VIEW_REFS = 8;\nconst MOVED_VIEWS = 9;\n/**\n * Size of LContainer's header. Represents the index after which all views in the\n * container will be inserted. We need to keep a record of current views so we know\n * which views are already in the DOM (and don't need to be re-added) and so we can\n * remove views from the DOM when they are no longer required.\n */\nconst CONTAINER_HEADER_OFFSET = 10;\n/** Flags associated with an LContainer (saved in LContainer[FLAGS]) */\nvar LContainerFlags = /*#__PURE__*/function (LContainerFlags) {\n LContainerFlags[LContainerFlags[\"None\"] = 0] = \"None\";\n /**\n * Flag to signify that this `LContainer` may have transplanted views which need to be change\n * detected. (see: `LView[DECLARATION_COMPONENT_VIEW])`.\n *\n * This flag, once set, is never unset for the `LContainer`.\n */\n LContainerFlags[LContainerFlags[\"HasTransplantedViews\"] = 2] = \"HasTransplantedViews\";\n return LContainerFlags;\n}(LContainerFlags || {});\n/**\n * True if `value` is `LView`.\n * @param value wrapped value of `RNode`, `LView`, `LContainer`\n */\nfunction isLView(value) {\n return Array.isArray(value) && typeof value[TYPE] === 'object';\n}\n/**\n * True if `value` is `LContainer`.\n * @param value wrapped value of `RNode`, `LView`, `LContainer`\n */\nfunction isLContainer(value) {\n return Array.isArray(value) && value[TYPE] === true;\n}\nfunction isContentQueryHost(tNode) {\n return (tNode.flags & 4 /* TNodeFlags.hasContentQuery */) !== 0;\n}\nfunction isComponentHost(tNode) {\n return tNode.componentOffset > -1;\n}\nfunction isDirectiveHost(tNode) {\n return (tNode.flags & 1 /* TNodeFlags.isDirectiveHost */) === 1 /* TNodeFlags.isDirectiveHost */;\n}\nfunction isComponentDef(def) {\n return !!def.template;\n}\nfunction isRootView(target) {\n return (target[FLAGS] & 512 /* LViewFlags.IsRoot */) !== 0;\n}\nfunction isProjectionTNode(tNode) {\n return (tNode.type & 16 /* TNodeType.Projection */) === 16 /* TNodeType.Projection */;\n}\nfunction hasI18n(lView) {\n return (lView[FLAGS] & 32 /* LViewFlags.HasI18n */) === 32 /* LViewFlags.HasI18n */;\n}\nfunction isDestroyed(lView) {\n return (lView[FLAGS] & 256 /* LViewFlags.Destroyed */) === 256 /* LViewFlags.Destroyed */;\n}\n\n// [Assert functions do not constraint type when they are guarded by a truthy\n// expression.](https://github.com/microsoft/TypeScript/issues/37295)\nfunction assertTNodeForLView(tNode, lView) {\n assertTNodeForTView(tNode, lView[TVIEW]);\n}\nfunction assertTNodeForTView(tNode, tView) {\n assertTNode(tNode);\n const tData = tView.data;\n for (let i = HEADER_OFFSET; i < tData.length; i++) {\n if (tData[i] === tNode) {\n return;\n }\n }\n throwError('This TNode does not belong to this TView.');\n}\nfunction assertTNode(tNode) {\n assertDefined(tNode, 'TNode must be defined');\n if (!(tNode && typeof tNode === 'object' && tNode.hasOwnProperty('directiveStylingLast'))) {\n throwError('Not of type TNode, got: ' + tNode);\n }\n}\nfunction assertTIcu(tIcu) {\n assertDefined(tIcu, 'Expected TIcu to be defined');\n if (!(typeof tIcu.currentCaseLViewIndex === 'number')) {\n throwError('Object is not of TIcu type.');\n }\n}\nfunction assertComponentType(actual, msg = \"Type passed in is not ComponentType, it does not have 'ɵcmp' property.\") {\n if (!getComponentDef(actual)) {\n throwError(msg);\n }\n}\nfunction assertNgModuleType(actual, msg = \"Type passed in is not NgModuleType, it does not have 'ɵmod' property.\") {\n if (!getNgModuleDef(actual)) {\n throwError(msg);\n }\n}\nfunction assertCurrentTNodeIsParent(isParent) {\n assertEqual(isParent, true, 'currentTNode should be a parent');\n}\nfunction assertHasParent(tNode) {\n assertDefined(tNode, 'currentTNode should exist!');\n assertDefined(tNode.parent, 'currentTNode should have a parent');\n}\nfunction assertLContainer(value) {\n assertDefined(value, 'LContainer must be defined');\n assertEqual(isLContainer(value), true, 'Expecting LContainer');\n}\nfunction assertLViewOrUndefined(value) {\n value && assertEqual(isLView(value), true, 'Expecting LView or undefined or null');\n}\nfunction assertLView(value) {\n assertDefined(value, 'LView must be defined');\n assertEqual(isLView(value), true, 'Expecting LView');\n}\nfunction assertFirstCreatePass(tView, errMessage) {\n assertEqual(tView.firstCreatePass, true, errMessage || 'Should only be called in first create pass.');\n}\nfunction assertFirstUpdatePass(tView, errMessage) {\n assertEqual(tView.firstUpdatePass, true, errMessage || 'Should only be called in first update pass.');\n}\n/**\n * This is a basic sanity check that an object is probably a directive def. DirectiveDef is\n * an interface, so we can't do a direct instanceof check.\n */\nfunction assertDirectiveDef(obj) {\n if (obj.type === undefined || obj.selectors == undefined || obj.inputs === undefined) {\n throwError(`Expected a DirectiveDef/ComponentDef and this object does not seem to have the expected shape.`);\n }\n}\nfunction assertIndexInDeclRange(tView, index) {\n assertBetween(HEADER_OFFSET, tView.bindingStartIndex, index);\n}\nfunction assertIndexInExpandoRange(lView, index) {\n const tView = lView[1];\n assertBetween(tView.expandoStartIndex, lView.length, index);\n}\nfunction assertBetween(lower, upper, index) {\n if (!(lower <= index && index < upper)) {\n throwError(`Index out of range (expecting ${lower} <= ${index} < ${upper})`);\n }\n}\nfunction assertProjectionSlots(lView, errMessage) {\n assertDefined(lView[DECLARATION_COMPONENT_VIEW], 'Component views should exist.');\n assertDefined(lView[DECLARATION_COMPONENT_VIEW][T_HOST].projection, errMessage || 'Components with projection nodes () must have projection slots defined.');\n}\nfunction assertParentView(lView, errMessage) {\n assertDefined(lView, errMessage || \"Component views should always have a parent view (component's host view)\");\n}\nfunction assertNoDuplicateDirectives(directives) {\n // The array needs at least two elements in order to have duplicates.\n if (directives.length < 2) {\n return;\n }\n const seenDirectives = new Set();\n for (const current of directives) {\n if (seenDirectives.has(current)) {\n throw new RuntimeError(309 /* RuntimeErrorCode.DUPLICATE_DIRECTIVE */, `Directive ${current.type.name} matches multiple times on the same element. ` + `Directives can only match an element once.`);\n }\n seenDirectives.add(current);\n }\n}\n/**\n * This is a basic sanity check that the `injectorIndex` seems to point to what looks like a\n * NodeInjector data structure.\n *\n * @param lView `LView` which should be checked.\n * @param injectorIndex index into the `LView` where the `NodeInjector` is expected.\n */\nfunction assertNodeInjector(lView, injectorIndex) {\n assertIndexInExpandoRange(lView, injectorIndex);\n assertIndexInExpandoRange(lView, injectorIndex + 8 /* NodeInjectorOffset.PARENT */);\n assertNumber(lView[injectorIndex + 0], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 1], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 2], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 3], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 4], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 5], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 6], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 7], 'injectorIndex should point to a bloom filter');\n assertNumber(lView[injectorIndex + 8 /* NodeInjectorOffset.PARENT */], 'injectorIndex should point to parent injector');\n}\n\n/**\n * Represents a basic change from a previous to a new value for a single\n * property on a directive instance. Passed as a value in a\n * {@link SimpleChanges} object to the `ngOnChanges` hook.\n *\n * @see {@link OnChanges}\n *\n * @publicApi\n */\nclass SimpleChange {\n constructor(previousValue, currentValue, firstChange) {\n this.previousValue = previousValue;\n this.currentValue = currentValue;\n this.firstChange = firstChange;\n }\n /**\n * Check whether the new value is the first value assigned.\n */\n isFirstChange() {\n return this.firstChange;\n }\n}\nfunction applyValueToInputField(instance, inputSignalNode, privateName, value) {\n if (inputSignalNode !== null) {\n inputSignalNode.applyValueToInputSignal(inputSignalNode, value);\n } else {\n instance[privateName] = value;\n }\n}\n\n/**\n * The NgOnChangesFeature decorates a component with support for the ngOnChanges\n * lifecycle hook, so it should be included in any component that implements\n * that hook.\n *\n * If the component or directive uses inheritance, the NgOnChangesFeature MUST\n * be included as a feature AFTER {@link InheritDefinitionFeature}, otherwise\n * inherited properties will not be propagated to the ngOnChanges lifecycle\n * hook.\n *\n * Example usage:\n *\n * ```\n * static ɵcmp = defineComponent({\n * ...\n * inputs: {name: 'publicName'},\n * features: [NgOnChangesFeature]\n * });\n * ```\n *\n * @codeGenApi\n */\nfunction ɵɵNgOnChangesFeature() {\n return NgOnChangesFeatureImpl;\n}\nfunction NgOnChangesFeatureImpl(definition) {\n if (definition.type.prototype.ngOnChanges) {\n definition.setInput = ngOnChangesSetInput;\n }\n return rememberChangeHistoryAndInvokeOnChangesHook;\n}\n// This option ensures that the ngOnChanges lifecycle hook will be inherited\n// from superclasses (in InheritDefinitionFeature).\n/** @nocollapse */\n// tslint:disable-next-line:no-toplevel-property-access\nɵɵNgOnChangesFeature.ngInherit = true;\n/**\n * This is a synthetic lifecycle hook which gets inserted into `TView.preOrderHooks` to simulate\n * `ngOnChanges`.\n *\n * The hook reads the `NgSimpleChangesStore` data from the component instance and if changes are\n * found it invokes `ngOnChanges` on the component instance.\n *\n * @param this Component instance. Because this function gets inserted into `TView.preOrderHooks`,\n * it is guaranteed to be called with component instance.\n */\nfunction rememberChangeHistoryAndInvokeOnChangesHook() {\n const simpleChangesStore = getSimpleChangesStore(this);\n const current = simpleChangesStore?.current;\n if (current) {\n const previous = simpleChangesStore.previous;\n if (previous === EMPTY_OBJ) {\n simpleChangesStore.previous = current;\n } else {\n // New changes are copied to the previous store, so that we don't lose history for inputs\n // which were not changed this time\n for (let key in current) {\n previous[key] = current[key];\n }\n }\n simpleChangesStore.current = null;\n this.ngOnChanges(current);\n }\n}\nfunction ngOnChangesSetInput(instance, inputSignalNode, value, publicName, privateName) {\n const declaredName = this.declaredInputs[publicName];\n ngDevMode && assertString(declaredName, 'Name of input in ngOnChanges has to be a string');\n const simpleChangesStore = getSimpleChangesStore(instance) || setSimpleChangesStore(instance, {\n previous: EMPTY_OBJ,\n current: null\n });\n const current = simpleChangesStore.current || (simpleChangesStore.current = {});\n const previous = simpleChangesStore.previous;\n const previousChange = previous[declaredName];\n current[declaredName] = new SimpleChange(previousChange && previousChange.currentValue, value, previous === EMPTY_OBJ);\n applyValueToInputField(instance, inputSignalNode, privateName, value);\n}\nconst SIMPLE_CHANGES_STORE = '__ngSimpleChanges__';\nfunction getSimpleChangesStore(instance) {\n return instance[SIMPLE_CHANGES_STORE] || null;\n}\nfunction setSimpleChangesStore(instance, store) {\n return instance[SIMPLE_CHANGES_STORE] = store;\n}\nlet profilerCallback = null;\n/**\n * Sets the callback function which will be invoked before and after performing certain actions at\n * runtime (for example, before and after running change detection).\n *\n * Warning: this function is *INTERNAL* and should not be relied upon in application's code.\n * The contract of the function might be changed in any release and/or the function can be removed\n * completely.\n *\n * @param profiler function provided by the caller or null value to disable profiling.\n */\nconst setProfiler = profiler => {\n profilerCallback = profiler;\n};\n/**\n * Profiler function which wraps user code executed by the runtime.\n *\n * @param event ProfilerEvent corresponding to the execution context\n * @param instance component instance\n * @param hookOrListener lifecycle hook function or output listener. The value depends on the\n * execution context\n * @returns\n */\nconst profiler = function (event, instance, hookOrListener) {\n if (profilerCallback != null /* both `null` and `undefined` */) {\n profilerCallback(event, instance, hookOrListener);\n }\n};\nconst SVG_NAMESPACE = 'svg';\nconst MATH_ML_NAMESPACE = 'math';\n\n/**\n * For efficiency reasons we often put several different data types (`RNode`, `LView`, `LContainer`)\n * in same location in `LView`. This is because we don't want to pre-allocate space for it\n * because the storage is sparse. This file contains utilities for dealing with such data types.\n *\n * How do we know what is stored at a given location in `LView`.\n * - `Array.isArray(value) === false` => `RNode` (The normal storage value)\n * - `Array.isArray(value) === true` => then the `value[0]` represents the wrapped value.\n * - `typeof value[TYPE] === 'object'` => `LView`\n * - This happens when we have a component at a given location\n * - `typeof value[TYPE] === true` => `LContainer`\n * - This happens when we have `LContainer` binding at a given location.\n *\n *\n * NOTE: it is assumed that `Array.isArray` and `typeof` operations are very efficient.\n */\n/**\n * Returns `RNode`.\n * @param value wrapped value of `RNode`, `LView`, `LContainer`\n */\nfunction unwrapRNode(value) {\n while (Array.isArray(value)) {\n value = value[HOST];\n }\n return value;\n}\n/**\n * Returns `LView` or `null` if not found.\n * @param value wrapped value of `RNode`, `LView`, `LContainer`\n */\nfunction unwrapLView(value) {\n while (Array.isArray(value)) {\n // This check is same as `isLView()` but we don't call at as we don't want to call\n // `Array.isArray()` twice and give JITer more work for inlining.\n if (typeof value[TYPE] === 'object') return value;\n value = value[HOST];\n }\n return null;\n}\n/**\n * Retrieves an element value from the provided `viewData`, by unwrapping\n * from any containers, component views, or style contexts.\n */\nfunction getNativeByIndex(index, lView) {\n ngDevMode && assertIndexInRange(lView, index);\n ngDevMode && assertGreaterThanOrEqual(index, HEADER_OFFSET, 'Expected to be past HEADER_OFFSET');\n return unwrapRNode(lView[index]);\n}\n/**\n * Retrieve an `RNode` for a given `TNode` and `LView`.\n *\n * This function guarantees in dev mode to retrieve a non-null `RNode`.\n *\n * @param tNode\n * @param lView\n */\nfunction getNativeByTNode(tNode, lView) {\n ngDevMode && assertTNodeForLView(tNode, lView);\n ngDevMode && assertIndexInRange(lView, tNode.index);\n const node = unwrapRNode(lView[tNode.index]);\n return node;\n}\n/**\n * Retrieve an `RNode` or `null` for a given `TNode` and `LView`.\n *\n * Some `TNode`s don't have associated `RNode`s. For example `Projection`\n *\n * @param tNode\n * @param lView\n */\nfunction getNativeByTNodeOrNull(tNode, lView) {\n const index = tNode === null ? -1 : tNode.index;\n if (index !== -1) {\n ngDevMode && assertTNodeForLView(tNode, lView);\n const node = unwrapRNode(lView[index]);\n return node;\n }\n return null;\n}\n// fixme(misko): The return Type should be `TNode|null`\nfunction getTNode(tView, index) {\n ngDevMode && assertGreaterThan(index, -1, 'wrong index for TNode');\n ngDevMode && assertLessThan(index, tView.data.length, 'wrong index for TNode');\n const tNode = tView.data[index];\n ngDevMode && tNode !== null && assertTNode(tNode);\n return tNode;\n}\n/** Retrieves a value from any `LView` or `TData`. */\nfunction load(view, index) {\n ngDevMode && assertIndexInRange(view, index);\n return view[index];\n}\nfunction getComponentLViewByIndex(nodeIndex, hostView) {\n // Could be an LView or an LContainer. If LContainer, unwrap to find LView.\n ngDevMode && assertIndexInRange(hostView, nodeIndex);\n const slotValue = hostView[nodeIndex];\n const lView = isLView(slotValue) ? slotValue : slotValue[HOST];\n return lView;\n}\n/** Checks whether a given view is in creation mode */\nfunction isCreationMode(view) {\n return (view[FLAGS] & 4 /* LViewFlags.CreationMode */) === 4 /* LViewFlags.CreationMode */;\n}\n/**\n * Returns a boolean for whether the view is attached to the change detection tree.\n *\n * Note: This determines whether a view should be checked, not whether it's inserted\n * into a container. For that, you'll want `viewAttachedToContainer` below.\n */\nfunction viewAttachedToChangeDetector(view) {\n return (view[FLAGS] & 128 /* LViewFlags.Attached */) === 128 /* LViewFlags.Attached */;\n}\n/** Returns a boolean for whether the view is attached to a container. */\nfunction viewAttachedToContainer(view) {\n return isLContainer(view[PARENT]);\n}\nfunction getConstant(consts, index) {\n if (index === null || index === undefined) return null;\n ngDevMode && assertIndexInRange(consts, index);\n return consts[index];\n}\n/**\n * Resets the pre-order hook flags of the view.\n * @param lView the LView on which the flags are reset\n */\nfunction resetPreOrderHookFlags(lView) {\n lView[PREORDER_HOOK_FLAGS] = 0;\n}\n/**\n * Adds the `RefreshView` flag from the lView and updates HAS_CHILD_VIEWS_TO_REFRESH flag of\n * parents.\n */\nfunction markViewForRefresh(lView) {\n if (lView[FLAGS] & 1024 /* LViewFlags.RefreshView */) {\n return;\n }\n lView[FLAGS] |= 1024 /* LViewFlags.RefreshView */;\n if (viewAttachedToChangeDetector(lView)) {\n markAncestorsForTraversal(lView);\n }\n}\n/**\n * Walks up the LView hierarchy.\n * @param nestingLevel Number of times to walk up in hierarchy.\n * @param currentView View from which to start the lookup.\n */\nfunction walkUpViews(nestingLevel, currentView) {\n while (nestingLevel > 0) {\n ngDevMode && assertDefined(currentView[DECLARATION_VIEW], 'Declaration view should be defined if nesting level is greater than 0.');\n currentView = currentView[DECLARATION_VIEW];\n nestingLevel--;\n }\n return currentView;\n}\nfunction requiresRefreshOrTraversal(lView) {\n return !!(lView[FLAGS] & (1024 /* LViewFlags.RefreshView */ | 8192 /* LViewFlags.HasChildViewsToRefresh */) || lView[REACTIVE_TEMPLATE_CONSUMER]?.dirty);\n}\n/**\n * Updates the `HasChildViewsToRefresh` flag on the parents of the `LView` as well as the\n * parents above.\n */\nfunction updateAncestorTraversalFlagsOnAttach(lView) {\n lView[ENVIRONMENT].changeDetectionScheduler?.notify(8 /* NotificationSource.ViewAttached */);\n if (lView[FLAGS] & 64 /* LViewFlags.Dirty */) {\n lView[FLAGS] |= 1024 /* LViewFlags.RefreshView */;\n }\n if (requiresRefreshOrTraversal(lView)) {\n markAncestorsForTraversal(lView);\n }\n}\n/**\n * Ensures views above the given `lView` are traversed during change detection even when they are\n * not dirty.\n *\n * This is done by setting the `HAS_CHILD_VIEWS_TO_REFRESH` flag up to the root, stopping when the\n * flag is already `true` or the `lView` is detached.\n */\nfunction markAncestorsForTraversal(lView) {\n lView[ENVIRONMENT].changeDetectionScheduler?.notify(0 /* NotificationSource.MarkAncestorsForTraversal */);\n let parent = getLViewParent(lView);\n while (parent !== null) {\n // We stop adding markers to the ancestors once we reach one that already has the marker. This\n // is to avoid needlessly traversing all the way to the root when the marker already exists.\n if (parent[FLAGS] & 8192 /* LViewFlags.HasChildViewsToRefresh */) {\n break;\n }\n parent[FLAGS] |= 8192 /* LViewFlags.HasChildViewsToRefresh */;\n if (!viewAttachedToChangeDetector(parent)) {\n break;\n }\n parent = getLViewParent(parent);\n }\n}\n/**\n * Stores a LView-specific destroy callback.\n */\nfunction storeLViewOnDestroy(lView, onDestroyCallback) {\n if ((lView[FLAGS] & 256 /* LViewFlags.Destroyed */) === 256 /* LViewFlags.Destroyed */) {\n throw new RuntimeError(911 /* RuntimeErrorCode.VIEW_ALREADY_DESTROYED */, ngDevMode && 'View has already been destroyed.');\n }\n if (lView[ON_DESTROY_HOOKS] === null) {\n lView[ON_DESTROY_HOOKS] = [];\n }\n lView[ON_DESTROY_HOOKS].push(onDestroyCallback);\n}\n/**\n * Removes previously registered LView-specific destroy callback.\n */\nfunction removeLViewOnDestroy(lView, onDestroyCallback) {\n if (lView[ON_DESTROY_HOOKS] === null) return;\n const destroyCBIdx = lView[ON_DESTROY_HOOKS].indexOf(onDestroyCallback);\n if (destroyCBIdx !== -1) {\n lView[ON_DESTROY_HOOKS].splice(destroyCBIdx, 1);\n }\n}\n/**\n * Gets the parent LView of the passed LView, if the PARENT is an LContainer, will get the parent of\n * that LContainer, which is an LView\n * @param lView the lView whose parent to get\n */\nfunction getLViewParent(lView) {\n ngDevMode && assertLView(lView);\n const parent = lView[PARENT];\n return isLContainer(parent) ? parent[PARENT] : parent;\n}\nconst instructionState = {\n lFrame: /*#__PURE__*/createLFrame(null),\n bindingsEnabled: true,\n skipHydrationRootTNode: null\n};\nvar CheckNoChangesMode = /*#__PURE__*/function (CheckNoChangesMode) {\n CheckNoChangesMode[CheckNoChangesMode[\"Off\"] = 0] = \"Off\";\n CheckNoChangesMode[CheckNoChangesMode[\"Exhaustive\"] = 1] = \"Exhaustive\";\n CheckNoChangesMode[CheckNoChangesMode[\"OnlyDirtyViews\"] = 2] = \"OnlyDirtyViews\";\n return CheckNoChangesMode;\n}(CheckNoChangesMode || {});\n/**\n * In this mode, any changes in bindings will throw an ExpressionChangedAfterChecked error.\n *\n * Necessary to support ChangeDetectorRef.checkNoChanges().\n *\n * The `checkNoChanges` function is invoked only in ngDevMode=true and verifies that no unintended\n * changes exist in the change detector or its children.\n */\nlet _checkNoChangesMode = 0; /* CheckNoChangesMode.Off */\n/**\n * Flag used to indicate that we are in the middle running change detection on a view\n *\n * @see detectChangesInViewWhileDirty\n */\nlet _isRefreshingViews = false;\n/**\n * Returns true if the instruction state stack is empty.\n *\n * Intended to be called from tests only (tree shaken otherwise).\n */\nfunction specOnlyIsInstructionStateEmpty() {\n return instructionState.lFrame.parent === null;\n}\nfunction getElementDepthCount() {\n return instructionState.lFrame.elementDepthCount;\n}\nfunction increaseElementDepthCount() {\n instructionState.lFrame.elementDepthCount++;\n}\nfunction decreaseElementDepthCount() {\n instructionState.lFrame.elementDepthCount--;\n}\nfunction getBindingsEnabled() {\n return instructionState.bindingsEnabled;\n}\n/**\n * Returns true if currently inside a skip hydration block.\n * @returns boolean\n */\nfunction isInSkipHydrationBlock$1() {\n return instructionState.skipHydrationRootTNode !== null;\n}\n/**\n * Returns true if this is the root TNode of the skip hydration block.\n * @param tNode the current TNode\n * @returns boolean\n */\nfunction isSkipHydrationRootTNode(tNode) {\n return instructionState.skipHydrationRootTNode === tNode;\n}\n/**\n * Enables directive matching on elements.\n *\n * * Example:\n * ```\n * \n * Should match component / directive.\n * \n *
\n * \n * \n * Should not match component / directive because we are in ngNonBindable.\n * \n * \n *
\n * ```\n *\n * @codeGenApi\n */\nfunction ɵɵenableBindings() {\n instructionState.bindingsEnabled = true;\n}\n/**\n * Sets a flag to specify that the TNode is in a skip hydration block.\n * @param tNode the current TNode\n */\nfunction enterSkipHydrationBlock(tNode) {\n instructionState.skipHydrationRootTNode = tNode;\n}\n/**\n * Disables directive matching on element.\n *\n * * Example:\n * ```\n * \n * Should match component / directive.\n * \n *
\n * \n * \n * Should not match component / directive because we are in ngNonBindable.\n * \n * \n *
\n * ```\n *\n * @codeGenApi\n */\nfunction ɵɵdisableBindings() {\n instructionState.bindingsEnabled = false;\n}\n/**\n * Clears the root skip hydration node when leaving a skip hydration block.\n */\nfunction leaveSkipHydrationBlock() {\n instructionState.skipHydrationRootTNode = null;\n}\n/**\n * Return the current `LView`.\n */\nfunction getLView() {\n return instructionState.lFrame.lView;\n}\n/**\n * Return the current `TView`.\n */\nfunction getTView() {\n return instructionState.lFrame.tView;\n}\n/**\n * Restores `contextViewData` to the given OpaqueViewState instance.\n *\n * Used in conjunction with the getCurrentView() instruction to save a snapshot\n * of the current view and restore it when listeners are invoked. This allows\n * walking the declaration view tree in listeners to get vars from parent views.\n *\n * @param viewToRestore The OpaqueViewState instance to restore.\n * @returns Context of the restored OpaqueViewState instance.\n *\n * @codeGenApi\n */\nfunction ɵɵrestoreView(viewToRestore) {\n instructionState.lFrame.contextLView = viewToRestore;\n return viewToRestore[CONTEXT];\n}\n/**\n * Clears the view set in `ɵɵrestoreView` from memory. Returns the passed in\n * value so that it can be used as a return value of an instruction.\n *\n * @codeGenApi\n */\nfunction ɵɵresetView(value) {\n instructionState.lFrame.contextLView = null;\n return value;\n}\nfunction getCurrentTNode() {\n let currentTNode = getCurrentTNodePlaceholderOk();\n while (currentTNode !== null && currentTNode.type === 64 /* TNodeType.Placeholder */) {\n currentTNode = currentTNode.parent;\n }\n return currentTNode;\n}\nfunction getCurrentTNodePlaceholderOk() {\n return instructionState.lFrame.currentTNode;\n}\nfunction getCurrentParentTNode() {\n const lFrame = instructionState.lFrame;\n const currentTNode = lFrame.currentTNode;\n return lFrame.isParent ? currentTNode : currentTNode.parent;\n}\nfunction setCurrentTNode(tNode, isParent) {\n ngDevMode && tNode && assertTNodeForTView(tNode, instructionState.lFrame.tView);\n const lFrame = instructionState.lFrame;\n lFrame.currentTNode = tNode;\n lFrame.isParent = isParent;\n}\nfunction isCurrentTNodeParent() {\n return instructionState.lFrame.isParent;\n}\nfunction setCurrentTNodeAsNotParent() {\n instructionState.lFrame.isParent = false;\n}\nfunction getContextLView() {\n const contextLView = instructionState.lFrame.contextLView;\n ngDevMode && assertDefined(contextLView, 'contextLView must be defined.');\n return contextLView;\n}\nfunction isInCheckNoChangesMode() {\n !ngDevMode && throwError('Must never be called in production mode');\n return _checkNoChangesMode !== CheckNoChangesMode.Off;\n}\nfunction isExhaustiveCheckNoChanges() {\n !ngDevMode && throwError('Must never be called in production mode');\n return _checkNoChangesMode === CheckNoChangesMode.Exhaustive;\n}\nfunction setIsInCheckNoChangesMode(mode) {\n !ngDevMode && throwError('Must never be called in production mode');\n _checkNoChangesMode = mode;\n}\nfunction isRefreshingViews() {\n return _isRefreshingViews;\n}\nfunction setIsRefreshingViews(mode) {\n _isRefreshingViews = mode;\n}\n// top level variables should not be exported for performance reasons (PERF_NOTES.md)\nfunction getBindingRoot() {\n const lFrame = instructionState.lFrame;\n let index = lFrame.bindingRootIndex;\n if (index === -1) {\n index = lFrame.bindingRootIndex = lFrame.tView.bindingStartIndex;\n }\n return index;\n}\nfunction getBindingIndex() {\n return instructionState.lFrame.bindingIndex;\n}\nfunction setBindingIndex(value) {\n return instructionState.lFrame.bindingIndex = value;\n}\nfunction nextBindingIndex() {\n return instructionState.lFrame.bindingIndex++;\n}\nfunction incrementBindingIndex(count) {\n const lFrame = instructionState.lFrame;\n const index = lFrame.bindingIndex;\n lFrame.bindingIndex = lFrame.bindingIndex + count;\n return index;\n}\nfunction isInI18nBlock() {\n return instructionState.lFrame.inI18n;\n}\nfunction setInI18nBlock(isInI18nBlock) {\n instructionState.lFrame.inI18n = isInI18nBlock;\n}\n/**\n * Set a new binding root index so that host template functions can execute.\n *\n * Bindings inside the host template are 0 index. But because we don't know ahead of time\n * how many host bindings we have we can't pre-compute them. For this reason they are all\n * 0 index and we just shift the root so that they match next available location in the LView.\n *\n * @param bindingRootIndex Root index for `hostBindings`\n * @param currentDirectiveIndex `TData[currentDirectiveIndex]` will point to the current directive\n * whose `hostBindings` are being processed.\n */\nfunction setBindingRootForHostBindings(bindingRootIndex, currentDirectiveIndex) {\n const lFrame = instructionState.lFrame;\n lFrame.bindingIndex = lFrame.bindingRootIndex = bindingRootIndex;\n setCurrentDirectiveIndex(currentDirectiveIndex);\n}\n/**\n * When host binding is executing this points to the directive index.\n * `TView.data[getCurrentDirectiveIndex()]` is `DirectiveDef`\n * `LView[getCurrentDirectiveIndex()]` is directive instance.\n */\nfunction getCurrentDirectiveIndex() {\n return instructionState.lFrame.currentDirectiveIndex;\n}\n/**\n * Sets an index of a directive whose `hostBindings` are being processed.\n *\n * @param currentDirectiveIndex `TData` index where current directive instance can be found.\n */\nfunction setCurrentDirectiveIndex(currentDirectiveIndex) {\n instructionState.lFrame.currentDirectiveIndex = currentDirectiveIndex;\n}\n/**\n * Retrieve the current `DirectiveDef` which is active when `hostBindings` instruction is being\n * executed.\n *\n * @param tData Current `TData` where the `DirectiveDef` will be looked up at.\n */\nfunction getCurrentDirectiveDef(tData) {\n const currentDirectiveIndex = instructionState.lFrame.currentDirectiveIndex;\n return currentDirectiveIndex === -1 ? null : tData[currentDirectiveIndex];\n}\nfunction getCurrentQueryIndex() {\n return instructionState.lFrame.currentQueryIndex;\n}\nfunction setCurrentQueryIndex(value) {\n instructionState.lFrame.currentQueryIndex = value;\n}\n/**\n * Returns a `TNode` of the location where the current `LView` is declared at.\n *\n * @param lView an `LView` that we want to find parent `TNode` for.\n */\nfunction getDeclarationTNode(lView) {\n const tView = lView[TVIEW];\n // Return the declaration parent for embedded views\n if (tView.type === 2 /* TViewType.Embedded */) {\n ngDevMode && assertDefined(tView.declTNode, 'Embedded TNodes should have declaration parents.');\n return tView.declTNode;\n }\n // Components don't have `TView.declTNode` because each instance of component could be\n // inserted in different location, hence `TView.declTNode` is meaningless.\n // Falling back to `T_HOST` in case we cross component boundary.\n if (tView.type === 1 /* TViewType.Component */) {\n return lView[T_HOST];\n }\n // Remaining TNode type is `TViewType.Root` which doesn't have a parent TNode.\n return null;\n}\n/**\n * This is a light weight version of the `enterView` which is needed by the DI system.\n *\n * @param lView `LView` location of the DI context.\n * @param tNode `TNode` for DI context\n * @param flags DI context flags. if `SkipSelf` flag is set than we walk up the declaration\n * tree from `tNode` until we find parent declared `TElementNode`.\n * @returns `true` if we have successfully entered DI associated with `tNode` (or with declared\n * `TNode` if `flags` has `SkipSelf`). Failing to enter DI implies that no associated\n * `NodeInjector` can be found and we should instead use `ModuleInjector`.\n * - If `true` than this call must be fallowed by `leaveDI`\n * - If `false` than this call failed and we should NOT call `leaveDI`\n */\nfunction enterDI(lView, tNode, flags) {\n ngDevMode && assertLViewOrUndefined(lView);\n if (flags & InjectFlags.SkipSelf) {\n ngDevMode && assertTNodeForTView(tNode, lView[TVIEW]);\n let parentTNode = tNode;\n let parentLView = lView;\n while (true) {\n ngDevMode && assertDefined(parentTNode, 'Parent TNode should be defined');\n parentTNode = parentTNode.parent;\n if (parentTNode === null && !(flags & InjectFlags.Host)) {\n parentTNode = getDeclarationTNode(parentLView);\n if (parentTNode === null) break;\n // In this case, a parent exists and is definitely an element. So it will definitely\n // have an existing lView as the declaration view, which is why we can assume it's defined.\n ngDevMode && assertDefined(parentLView, 'Parent LView should be defined');\n parentLView = parentLView[DECLARATION_VIEW];\n // In Ivy there are Comment nodes that correspond to ngIf and NgFor embedded directives\n // We want to skip those and look only at Elements and ElementContainers to ensure\n // we're looking at true parent nodes, and not content or other types.\n if (parentTNode.type & (2 /* TNodeType.Element */ | 8 /* TNodeType.ElementContainer */)) {\n break;\n }\n } else {\n break;\n }\n }\n if (parentTNode === null) {\n // If we failed to find a parent TNode this means that we should use module injector.\n return false;\n } else {\n tNode = parentTNode;\n lView = parentLView;\n }\n }\n ngDevMode && assertTNodeForLView(tNode, lView);\n const lFrame = instructionState.lFrame = allocLFrame();\n lFrame.currentTNode = tNode;\n lFrame.lView = lView;\n return true;\n}\n/**\n * Swap the current lView with a new lView.\n *\n * For performance reasons we store the lView in the top level of the module.\n * This way we minimize the number of properties to read. Whenever a new view\n * is entered we have to store the lView for later, and when the view is\n * exited the state has to be restored\n *\n * @param newView New lView to become active\n * @returns the previously active lView;\n */\nfunction enterView(newView) {\n ngDevMode && assertNotEqual(newView[0], newView[1], '????');\n ngDevMode && assertLViewOrUndefined(newView);\n const newLFrame = allocLFrame();\n if (ngDevMode) {\n assertEqual(newLFrame.isParent, true, 'Expected clean LFrame');\n assertEqual(newLFrame.lView, null, 'Expected clean LFrame');\n assertEqual(newLFrame.tView, null, 'Expected clean LFrame');\n assertEqual(newLFrame.selectedIndex, -1, 'Expected clean LFrame');\n assertEqual(newLFrame.elementDepthCount, 0, 'Expected clean LFrame');\n assertEqual(newLFrame.currentDirectiveIndex, -1, 'Expected clean LFrame');\n assertEqual(newLFrame.currentNamespace, null, 'Expected clean LFrame');\n assertEqual(newLFrame.bindingRootIndex, -1, 'Expected clean LFrame');\n assertEqual(newLFrame.currentQueryIndex, 0, 'Expected clean LFrame');\n }\n const tView = newView[TVIEW];\n instructionState.lFrame = newLFrame;\n ngDevMode && tView.firstChild && assertTNodeForTView(tView.firstChild, tView);\n newLFrame.currentTNode = tView.firstChild;\n newLFrame.lView = newView;\n newLFrame.tView = tView;\n newLFrame.contextLView = newView;\n newLFrame.bindingIndex = tView.bindingStartIndex;\n newLFrame.inI18n = false;\n}\n/**\n * Allocates next free LFrame. This function tries to reuse the `LFrame`s to lower memory pressure.\n */\nfunction allocLFrame() {\n const currentLFrame = instructionState.lFrame;\n const childLFrame = currentLFrame === null ? null : currentLFrame.child;\n const newLFrame = childLFrame === null ? createLFrame(currentLFrame) : childLFrame;\n return newLFrame;\n}\nfunction createLFrame(parent) {\n const lFrame = {\n currentTNode: null,\n isParent: true,\n lView: null,\n tView: null,\n selectedIndex: -1,\n contextLView: null,\n elementDepthCount: 0,\n currentNamespace: null,\n currentDirectiveIndex: -1,\n bindingRootIndex: -1,\n bindingIndex: -1,\n currentQueryIndex: 0,\n parent: parent,\n child: null,\n inI18n: false\n };\n parent !== null && (parent.child = lFrame); // link the new LFrame for reuse.\n return lFrame;\n}\n/**\n * A lightweight version of leave which is used with DI.\n *\n * This function only resets `currentTNode` and `LView` as those are the only properties\n * used with DI (`enterDI()`).\n *\n * NOTE: This function is reexported as `leaveDI`. However `leaveDI` has return type of `void` where\n * as `leaveViewLight` has `LFrame`. This is so that `leaveViewLight` can be used in `leaveView`.\n */\nfunction leaveViewLight() {\n const oldLFrame = instructionState.lFrame;\n instructionState.lFrame = oldLFrame.parent;\n oldLFrame.currentTNode = null;\n oldLFrame.lView = null;\n return oldLFrame;\n}\n/**\n * This is a lightweight version of the `leaveView` which is needed by the DI system.\n *\n * NOTE: this function is an alias so that we can change the type of the function to have `void`\n * return type.\n */\nconst leaveDI = leaveViewLight;\n/**\n * Leave the current `LView`\n *\n * This pops the `LFrame` with the associated `LView` from the stack.\n *\n * IMPORTANT: We must zero out the `LFrame` values here otherwise they will be retained. This is\n * because for performance reasons we don't release `LFrame` but rather keep it for next use.\n */\nfunction leaveView() {\n const oldLFrame = leaveViewLight();\n oldLFrame.isParent = true;\n oldLFrame.tView = null;\n oldLFrame.selectedIndex = -1;\n oldLFrame.contextLView = null;\n oldLFrame.elementDepthCount = 0;\n oldLFrame.currentDirectiveIndex = -1;\n oldLFrame.currentNamespace = null;\n oldLFrame.bindingRootIndex = -1;\n oldLFrame.bindingIndex = -1;\n oldLFrame.currentQueryIndex = 0;\n}\nfunction nextContextImpl(level) {\n const contextLView = instructionState.lFrame.contextLView = walkUpViews(level, instructionState.lFrame.contextLView);\n return contextLView[CONTEXT];\n}\n/**\n * Gets the currently selected element index.\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n */\nfunction getSelectedIndex() {\n return instructionState.lFrame.selectedIndex;\n}\n/**\n * Sets the most recent index passed to {@link select}\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n *\n * (Note that if an \"exit function\" was set earlier (via `setElementExitFn()`) then that will be\n * run if and when the provided `index` value is different from the current selected index value.)\n */\nfunction setSelectedIndex(index) {\n ngDevMode && index !== -1 && assertGreaterThanOrEqual(index, HEADER_OFFSET, 'Index must be past HEADER_OFFSET (or -1).');\n ngDevMode && assertLessThan(index, instructionState.lFrame.lView.length, \"Can't set index passed end of LView\");\n instructionState.lFrame.selectedIndex = index;\n}\n/**\n * Gets the `tNode` that represents currently selected element.\n */\nfunction getSelectedTNode() {\n const lFrame = instructionState.lFrame;\n return getTNode(lFrame.tView, lFrame.selectedIndex);\n}\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.\n *\n * @codeGenApi\n */\nfunction ɵɵnamespaceSVG() {\n instructionState.lFrame.currentNamespace = SVG_NAMESPACE;\n}\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.\n *\n * @codeGenApi\n */\nfunction ɵɵnamespaceMathML() {\n instructionState.lFrame.currentNamespace = MATH_ML_NAMESPACE;\n}\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n *\n * @codeGenApi\n */\nfunction ɵɵnamespaceHTML() {\n namespaceHTMLInternal();\n}\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n */\nfunction namespaceHTMLInternal() {\n instructionState.lFrame.currentNamespace = null;\n}\nfunction getNamespace$1() {\n return instructionState.lFrame.currentNamespace;\n}\nlet _wasLastNodeCreated = true;\n/**\n * Retrieves a global flag that indicates whether the most recent DOM node\n * was created or hydrated.\n */\nfunction wasLastNodeCreated() {\n return _wasLastNodeCreated;\n}\n/**\n * Sets a global flag to indicate whether the most recent DOM node\n * was created or hydrated.\n */\nfunction lastNodeWasCreated(flag) {\n _wasLastNodeCreated = flag;\n}\n\n/**\n * Adds all directive lifecycle hooks from the given `DirectiveDef` to the given `TView`.\n *\n * Must be run *only* on the first template pass.\n *\n * Sets up the pre-order hooks on the provided `tView`,\n * see {@link HookData} for details about the data structure.\n *\n * @param directiveIndex The index of the directive in LView\n * @param directiveDef The definition containing the hooks to setup in tView\n * @param tView The current TView\n */\nfunction registerPreOrderHooks(directiveIndex, directiveDef, tView) {\n ngDevMode && assertFirstCreatePass(tView);\n const {\n ngOnChanges,\n ngOnInit,\n ngDoCheck\n } = directiveDef.type.prototype;\n if (ngOnChanges) {\n const wrappedOnChanges = NgOnChangesFeatureImpl(directiveDef);\n (tView.preOrderHooks ??= []).push(directiveIndex, wrappedOnChanges);\n (tView.preOrderCheckHooks ??= []).push(directiveIndex, wrappedOnChanges);\n }\n if (ngOnInit) {\n (tView.preOrderHooks ??= []).push(0 - directiveIndex, ngOnInit);\n }\n if (ngDoCheck) {\n (tView.preOrderHooks ??= []).push(directiveIndex, ngDoCheck);\n (tView.preOrderCheckHooks ??= []).push(directiveIndex, ngDoCheck);\n }\n}\n/**\n *\n * Loops through the directives on the provided `tNode` and queues hooks to be\n * run that are not initialization hooks.\n *\n * Should be executed during `elementEnd()` and similar to\n * preserve hook execution order. Content, view, and destroy hooks for projected\n * components and directives must be called *before* their hosts.\n *\n * Sets up the content, view, and destroy hooks on the provided `tView`,\n * see {@link HookData} for details about the data structure.\n *\n * NOTE: This does not set up `onChanges`, `onInit` or `doCheck`, those are set up\n * separately at `elementStart`.\n *\n * @param tView The current TView\n * @param tNode The TNode whose directives are to be searched for hooks to queue\n */\nfunction registerPostOrderHooks(tView, tNode) {\n ngDevMode && assertFirstCreatePass(tView);\n // It's necessary to loop through the directives at elementEnd() (rather than processing in\n // directiveCreate) so we can preserve the current hook order. Content, view, and destroy\n // hooks for projected components and directives must be called *before* their hosts.\n for (let i = tNode.directiveStart, end = tNode.directiveEnd; i < end; i++) {\n const directiveDef = tView.data[i];\n ngDevMode && assertDefined(directiveDef, 'Expecting DirectiveDef');\n const lifecycleHooks = directiveDef.type.prototype;\n const {\n ngAfterContentInit,\n ngAfterContentChecked,\n ngAfterViewInit,\n ngAfterViewChecked,\n ngOnDestroy\n } = lifecycleHooks;\n if (ngAfterContentInit) {\n (tView.contentHooks ??= []).push(-i, ngAfterContentInit);\n }\n if (ngAfterContentChecked) {\n (tView.contentHooks ??= []).push(i, ngAfterContentChecked);\n (tView.contentCheckHooks ??= []).push(i, ngAfterContentChecked);\n }\n if (ngAfterViewInit) {\n (tView.viewHooks ??= []).push(-i, ngAfterViewInit);\n }\n if (ngAfterViewChecked) {\n (tView.viewHooks ??= []).push(i, ngAfterViewChecked);\n (tView.viewCheckHooks ??= []).push(i, ngAfterViewChecked);\n }\n if (ngOnDestroy != null) {\n (tView.destroyHooks ??= []).push(i, ngOnDestroy);\n }\n }\n}\n/**\n * Executing hooks requires complex logic as we need to deal with 2 constraints.\n *\n * 1. Init hooks (ngOnInit, ngAfterContentInit, ngAfterViewInit) must all be executed once and only\n * once, across many change detection cycles. This must be true even if some hooks throw, or if\n * some recursively trigger a change detection cycle.\n * To solve that, it is required to track the state of the execution of these init hooks.\n * This is done by storing and maintaining flags in the view: the {@link InitPhaseState},\n * and the index within that phase. They can be seen as a cursor in the following structure:\n * [[onInit1, onInit2], [afterContentInit1], [afterViewInit1, afterViewInit2, afterViewInit3]]\n * They are stored as flags in LView[FLAGS].\n *\n * 2. Pre-order hooks can be executed in batches, because of the select instruction.\n * To be able to pause and resume their execution, we also need some state about the hook's array\n * that is being processed:\n * - the index of the next hook to be executed\n * - the number of init hooks already found in the processed part of the array\n * They are stored as flags in LView[PREORDER_HOOK_FLAGS].\n */\n/**\n * Executes pre-order check hooks ( OnChanges, DoChanges) given a view where all the init hooks were\n * executed once. This is a light version of executeInitAndCheckPreOrderHooks where we can skip read\n * / write of the init-hooks related flags.\n * @param lView The LView where hooks are defined\n * @param hooks Hooks to be run\n * @param nodeIndex 3 cases depending on the value:\n * - undefined: all hooks from the array should be executed (post-order case)\n * - null: execute hooks only from the saved index until the end of the array (pre-order case, when\n * flushing the remaining hooks)\n * - number: execute hooks only from the saved index until that node index exclusive (pre-order\n * case, when executing select(number))\n */\nfunction executeCheckHooks(lView, hooks, nodeIndex) {\n callHooks(lView, hooks, 3 /* InitPhaseState.InitPhaseCompleted */, nodeIndex);\n}\n/**\n * Executes post-order init and check hooks (one of AfterContentInit, AfterContentChecked,\n * AfterViewInit, AfterViewChecked) given a view where there are pending init hooks to be executed.\n * @param lView The LView where hooks are defined\n * @param hooks Hooks to be run\n * @param initPhase A phase for which hooks should be run\n * @param nodeIndex 3 cases depending on the value:\n * - undefined: all hooks from the array should be executed (post-order case)\n * - null: execute hooks only from the saved index until the end of the array (pre-order case, when\n * flushing the remaining hooks)\n * - number: execute hooks only from the saved index until that node index exclusive (pre-order\n * case, when executing select(number))\n */\nfunction executeInitAndCheckHooks(lView, hooks, initPhase, nodeIndex) {\n ngDevMode && assertNotEqual(initPhase, 3 /* InitPhaseState.InitPhaseCompleted */, 'Init pre-order hooks should not be called more than once');\n if ((lView[FLAGS] & 3 /* LViewFlags.InitPhaseStateMask */) === initPhase) {\n callHooks(lView, hooks, initPhase, nodeIndex);\n }\n}\nfunction incrementInitPhaseFlags(lView, initPhase) {\n ngDevMode && assertNotEqual(initPhase, 3 /* InitPhaseState.InitPhaseCompleted */, 'Init hooks phase should not be incremented after all init hooks have been run.');\n let flags = lView[FLAGS];\n if ((flags & 3 /* LViewFlags.InitPhaseStateMask */) === initPhase) {\n flags &= 16383 /* LViewFlags.IndexWithinInitPhaseReset */;\n flags += 1 /* LViewFlags.InitPhaseStateIncrementer */;\n lView[FLAGS] = flags;\n }\n}\n/**\n * Calls lifecycle hooks with their contexts, skipping init hooks if it's not\n * the first LView pass\n *\n * @param currentView The current view\n * @param arr The array in which the hooks are found\n * @param initPhaseState the current state of the init phase\n * @param currentNodeIndex 3 cases depending on the value:\n * - undefined: all hooks from the array should be executed (post-order case)\n * - null: execute hooks only from the saved index until the end of the array (pre-order case, when\n * flushing the remaining hooks)\n * - number: execute hooks only from the saved index until that node index exclusive (pre-order\n * case, when executing select(number))\n */\nfunction callHooks(currentView, arr, initPhase, currentNodeIndex) {\n ngDevMode && assertEqual(isInCheckNoChangesMode(), false, 'Hooks should never be run when in check no changes mode.');\n const startIndex = currentNodeIndex !== undefined ? currentView[PREORDER_HOOK_FLAGS] & 65535 /* PreOrderHookFlags.IndexOfTheNextPreOrderHookMaskMask */ : 0;\n const nodeIndexLimit = currentNodeIndex != null ? currentNodeIndex : -1;\n const max = arr.length - 1; // Stop the loop at length - 1, because we look for the hook at i + 1\n let lastNodeIndexFound = 0;\n for (let i = startIndex; i < max; i++) {\n const hook = arr[i + 1];\n if (typeof hook === 'number') {\n lastNodeIndexFound = arr[i];\n if (currentNodeIndex != null && lastNodeIndexFound >= currentNodeIndex) {\n break;\n }\n } else {\n const isInitHook = arr[i] < 0;\n if (isInitHook) {\n currentView[PREORDER_HOOK_FLAGS] += 65536 /* PreOrderHookFlags.NumberOfInitHooksCalledIncrementer */;\n }\n if (lastNodeIndexFound < nodeIndexLimit || nodeIndexLimit == -1) {\n callHook(currentView, initPhase, arr, i);\n currentView[PREORDER_HOOK_FLAGS] = (currentView[PREORDER_HOOK_FLAGS] & 4294901760 /* PreOrderHookFlags.NumberOfInitHooksCalledMask */) + i + 2;\n }\n i++;\n }\n }\n}\n/**\n * Executes a single lifecycle hook, making sure that:\n * - it is called in the non-reactive context;\n * - profiling data are registered.\n */\nfunction callHookInternal(directive, hook) {\n profiler(4 /* ProfilerEvent.LifecycleHookStart */, directive, hook);\n const prevConsumer = setActiveConsumer$1(null);\n try {\n hook.call(directive);\n } finally {\n setActiveConsumer$1(prevConsumer);\n profiler(5 /* ProfilerEvent.LifecycleHookEnd */, directive, hook);\n }\n}\n/**\n * Execute one hook against the current `LView`.\n *\n * @param currentView The current view\n * @param initPhaseState the current state of the init phase\n * @param arr The array in which the hooks are found\n * @param i The current index within the hook data array\n */\nfunction callHook(currentView, initPhase, arr, i) {\n const isInitHook = arr[i] < 0;\n const hook = arr[i + 1];\n const directiveIndex = isInitHook ? -arr[i] : arr[i];\n const directive = currentView[directiveIndex];\n if (isInitHook) {\n const indexWithintInitPhase = currentView[FLAGS] >> 14 /* LViewFlags.IndexWithinInitPhaseShift */;\n // The init phase state must be always checked here as it may have been recursively updated.\n if (indexWithintInitPhase < currentView[PREORDER_HOOK_FLAGS] >> 16 /* PreOrderHookFlags.NumberOfInitHooksCalledShift */ && (currentView[FLAGS] & 3 /* LViewFlags.InitPhaseStateMask */) === initPhase) {\n currentView[FLAGS] += 16384 /* LViewFlags.IndexWithinInitPhaseIncrementer */;\n callHookInternal(directive, hook);\n }\n } else {\n callHookInternal(directive, hook);\n }\n}\nconst NO_PARENT_INJECTOR = -1;\n/**\n * Each injector is saved in 9 contiguous slots in `LView` and 9 contiguous slots in\n * `TView.data`. This allows us to store information about the current node's tokens (which\n * can be shared in `TView`) as well as the tokens of its ancestor nodes (which cannot be\n * shared, so they live in `LView`).\n *\n * Each of these slots (aside from the last slot) contains a bloom filter. This bloom filter\n * determines whether a directive is available on the associated node or not. This prevents us\n * from searching the directives array at this level unless it's probable the directive is in it.\n *\n * See: https://en.wikipedia.org/wiki/Bloom_filter for more about bloom filters.\n *\n * Because all injectors have been flattened into `LView` and `TViewData`, they cannot typed\n * using interfaces as they were previously. The start index of each `LInjector` and `TInjector`\n * will differ based on where it is flattened into the main array, so it's not possible to know\n * the indices ahead of time and save their types here. The interfaces are still included here\n * for documentation purposes.\n *\n * export interface LInjector extends Array {\n *\n * // Cumulative bloom for directive IDs 0-31 (IDs are % BLOOM_SIZE)\n * [0]: number;\n *\n * // Cumulative bloom for directive IDs 32-63\n * [1]: number;\n *\n * // Cumulative bloom for directive IDs 64-95\n * [2]: number;\n *\n * // Cumulative bloom for directive IDs 96-127\n * [3]: number;\n *\n * // Cumulative bloom for directive IDs 128-159\n * [4]: number;\n *\n * // Cumulative bloom for directive IDs 160 - 191\n * [5]: number;\n *\n * // Cumulative bloom for directive IDs 192 - 223\n * [6]: number;\n *\n * // Cumulative bloom for directive IDs 224 - 255\n * [7]: number;\n *\n * // We need to store a reference to the injector's parent so DI can keep looking up\n * // the injector tree until it finds the dependency it's looking for.\n * [PARENT_INJECTOR]: number;\n * }\n *\n * export interface TInjector extends Array {\n *\n * // Shared node bloom for directive IDs 0-31 (IDs are % BLOOM_SIZE)\n * [0]: number;\n *\n * // Shared node bloom for directive IDs 32-63\n * [1]: number;\n *\n * // Shared node bloom for directive IDs 64-95\n * [2]: number;\n *\n * // Shared node bloom for directive IDs 96-127\n * [3]: number;\n *\n * // Shared node bloom for directive IDs 128-159\n * [4]: number;\n *\n * // Shared node bloom for directive IDs 160 - 191\n * [5]: number;\n *\n * // Shared node bloom for directive IDs 192 - 223\n * [6]: number;\n *\n * // Shared node bloom for directive IDs 224 - 255\n * [7]: number;\n *\n * // Necessary to find directive indices for a particular node.\n * [TNODE]: TElementNode|TElementContainerNode|TContainerNode;\n * }\n */\n/**\n * Factory for creating instances of injectors in the NodeInjector.\n *\n * This factory is complicated by the fact that it can resolve `multi` factories as well.\n *\n * NOTE: Some of the fields are optional which means that this class has two hidden classes.\n * - One without `multi` support (most common)\n * - One with `multi` values, (rare).\n *\n * Since VMs can cache up to 4 inline hidden classes this is OK.\n *\n * - Single factory: Only `resolving` and `factory` is defined.\n * - `providers` factory: `componentProviders` is a number and `index = -1`.\n * - `viewProviders` factory: `componentProviders` is a number and `index` points to `providers`.\n */\nclass NodeInjectorFactory {\n constructor(\n /**\n * Factory to invoke in order to create a new instance.\n */\n factory,\n /**\n * Set to `true` if the token is declared in `viewProviders` (or if it is component).\n */\n isViewProvider, injectImplementation) {\n this.factory = factory;\n /**\n * Marker set to true during factory invocation to see if we get into recursive loop.\n * Recursive loop causes an error to be displayed.\n */\n this.resolving = false;\n ngDevMode && assertDefined(factory, 'Factory not specified');\n ngDevMode && assertEqual(typeof factory, 'function', 'Expected factory function.');\n this.canSeeViewProviders = isViewProvider;\n this.injectImpl = injectImplementation;\n }\n}\nfunction isFactory(obj) {\n return obj instanceof NodeInjectorFactory;\n}\n\n/**\n * Converts `TNodeType` into human readable text.\n * Make sure this matches with `TNodeType`\n */\nfunction toTNodeTypeAsString(tNodeType) {\n let text = '';\n tNodeType & 1 /* TNodeType.Text */ && (text += '|Text');\n tNodeType & 2 /* TNodeType.Element */ && (text += '|Element');\n tNodeType & 4 /* TNodeType.Container */ && (text += '|Container');\n tNodeType & 8 /* TNodeType.ElementContainer */ && (text += '|ElementContainer');\n tNodeType & 16 /* TNodeType.Projection */ && (text += '|Projection');\n tNodeType & 32 /* TNodeType.Icu */ && (text += '|IcuContainer');\n tNodeType & 64 /* TNodeType.Placeholder */ && (text += '|Placeholder');\n tNodeType & 128 /* TNodeType.LetDeclaration */ && (text += '|LetDeclaration');\n return text.length > 0 ? text.substring(1) : text;\n}\n/**\n * Helper function to detect if a given value matches a `TNode` shape.\n *\n * The logic uses the `insertBeforeIndex` and its possible values as\n * a way to differentiate a TNode shape from other types of objects\n * within the `TView.data`. This is not a perfect check, but it can\n * be a reasonable differentiator, since we control the shapes of objects\n * within `TView.data`.\n */\nfunction isTNodeShape(value) {\n return value != null && typeof value === 'object' && (value.insertBeforeIndex === null || typeof value.insertBeforeIndex === 'number' || Array.isArray(value.insertBeforeIndex));\n}\nfunction isLetDeclaration(tNode) {\n return !!(tNode.type & 128 /* TNodeType.LetDeclaration */);\n}\n/**\n * Returns `true` if the `TNode` has a directive which has `@Input()` for `class` binding.\n *\n * ```\n *
\n * ```\n * and\n * ```\n * @Directive({\n * })\n * class MyDirective {\n * @Input()\n * class: string;\n * }\n * ```\n *\n * In the above case it is necessary to write the reconciled styling information into the\n * directive's input.\n *\n * @param tNode\n */\nfunction hasClassInput(tNode) {\n return (tNode.flags & 8 /* TNodeFlags.hasClassInput */) !== 0;\n}\n/**\n * Returns `true` if the `TNode` has a directive which has `@Input()` for `style` binding.\n *\n * ```\n *
\n * ```\n * and\n * ```\n * @Directive({\n * })\n * class MyDirective {\n * @Input()\n * class: string;\n * }\n * ```\n *\n * In the above case it is necessary to write the reconciled styling information into the\n * directive's input.\n *\n * @param tNode\n */\nfunction hasStyleInput(tNode) {\n return (tNode.flags & 16 /* TNodeFlags.hasStyleInput */) !== 0;\n}\nfunction assertTNodeType(tNode, expectedTypes, message) {\n assertDefined(tNode, 'should be called with a TNode');\n if ((tNode.type & expectedTypes) === 0) {\n throwError(message || `Expected [${toTNodeTypeAsString(expectedTypes)}] but got ${toTNodeTypeAsString(tNode.type)}.`);\n }\n}\nfunction assertPureTNodeType(type) {\n if (!(type === 2 /* TNodeType.Element */ || type === 1 /* TNodeType.Text */ || type === 4 /* TNodeType.Container */ || type === 8 /* TNodeType.ElementContainer */ || type === 32 /* TNodeType.Icu */ || type === 16 /* TNodeType.Projection */ || type === 64 /* TNodeType.Placeholder */ || type === 128 /* TNodeType.LetDeclaration */)) {\n throwError(`Expected TNodeType to have only a single type selected, but got ${toTNodeTypeAsString(type)}.`);\n }\n}\n\n// This default value is when checking the hierarchy for a token.\n//\n// It means both:\n// - the token is not provided by the current injector,\n// - only the element injectors should be checked (ie do not check module injectors\n//\n// mod1\n// /\n// el1 mod2\n// \\ /\n// el2\n//\n// When requesting el2.injector.get(token), we should check in the following order and return the\n// first found value:\n// - el2.injector.get(token, default)\n// - el1.injector.get(token, NOT_FOUND_CHECK_ONLY_ELEMENT_INJECTOR) -> do not check the module\n// - mod2.injector.get(token, default)\nconst NOT_FOUND_CHECK_ONLY_ELEMENT_INJECTOR = {};\n\n/**\n * Injector that looks up a value using a specific injector, before falling back to the module\n * injector. Used primarily when creating components or embedded views dynamically.\n */\nclass ChainedInjector {\n constructor(injector, parentInjector) {\n this.injector = injector;\n this.parentInjector = parentInjector;\n }\n get(token, notFoundValue, flags) {\n flags = convertToBitFlags(flags);\n const value = this.injector.get(token, NOT_FOUND_CHECK_ONLY_ELEMENT_INJECTOR, flags);\n if (value !== NOT_FOUND_CHECK_ONLY_ELEMENT_INJECTOR || notFoundValue === NOT_FOUND_CHECK_ONLY_ELEMENT_INJECTOR) {\n // Return the value from the root element injector when\n // - it provides it\n // (value !== NOT_FOUND_CHECK_ONLY_ELEMENT_INJECTOR)\n // - the module injector should not be checked\n // (notFoundValue === NOT_FOUND_CHECK_ONLY_ELEMENT_INJECTOR)\n return value;\n }\n return this.parentInjector.get(token, notFoundValue, flags);\n }\n}\n\n/// Parent Injector Utils ///////////////////////////////////////////////////////////////\nfunction hasParentInjector(parentLocation) {\n return parentLocation !== NO_PARENT_INJECTOR;\n}\nfunction getParentInjectorIndex(parentLocation) {\n if (ngDevMode) {\n assertNumber(parentLocation, 'Number expected');\n assertNotEqual(parentLocation, -1, 'Not a valid state.');\n const parentInjectorIndex = parentLocation & 32767 /* RelativeInjectorLocationFlags.InjectorIndexMask */;\n assertGreaterThan(parentInjectorIndex, HEADER_OFFSET, 'Parent injector must be pointing past HEADER_OFFSET.');\n }\n return parentLocation & 32767 /* RelativeInjectorLocationFlags.InjectorIndexMask */;\n}\nfunction getParentInjectorViewOffset(parentLocation) {\n return parentLocation >> 16 /* RelativeInjectorLocationFlags.ViewOffsetShift */;\n}\n/**\n * Unwraps a parent injector location number to find the view offset from the current injector,\n * then walks up the declaration view tree until the view is found that contains the parent\n * injector.\n *\n * @param location The location of the parent injector, which contains the view offset\n * @param startView The LView instance from which to start walking up the view tree\n * @returns The LView instance that contains the parent injector\n */\nfunction getParentInjectorView(location, startView) {\n let viewOffset = getParentInjectorViewOffset(location);\n let parentView = startView;\n // For most cases, the parent injector can be found on the host node (e.g. for component\n // or container), but we must keep the loop here to support the rarer case of deeply nested\n // tags or inline views, where the parent injector might live many views\n // above the child injector.\n while (viewOffset > 0) {\n parentView = parentView[DECLARATION_VIEW];\n viewOffset--;\n }\n return parentView;\n}\n/**\n * Detects whether an injector is an instance of a `ChainedInjector`,\n * created based on the `OutletInjector`.\n */\nfunction isRouterOutletInjector(currentInjector) {\n return currentInjector instanceof ChainedInjector && typeof currentInjector.injector.__ngOutletInjector === 'function';\n}\n\n/**\n * Defines if the call to `inject` should include `viewProviders` in its resolution.\n *\n * This is set to true when we try to instantiate a component. This value is reset in\n * `getNodeInjectable` to a value which matches the declaration location of the token about to be\n * instantiated. This is done so that if we are injecting a token which was declared outside of\n * `viewProviders` we don't accidentally pull `viewProviders` in.\n *\n * Example:\n *\n * ```\n * @Injectable()\n * class MyService {\n * constructor(public value: String) {}\n * }\n *\n * @Component({\n * providers: [\n * MyService,\n * {provide: String, value: 'providers' }\n * ]\n * viewProviders: [\n * {provide: String, value: 'viewProviders'}\n * ]\n * })\n * class MyComponent {\n * constructor(myService: MyService, value: String) {\n * // We expect that Component can see into `viewProviders`.\n * expect(value).toEqual('viewProviders');\n * // `MyService` was not declared in `viewProviders` hence it can't see it.\n * expect(myService.value).toEqual('providers');\n * }\n * }\n *\n * ```\n */\nlet includeViewProviders = true;\nfunction setIncludeViewProviders(v) {\n const oldValue = includeViewProviders;\n includeViewProviders = v;\n return oldValue;\n}\n/**\n * The number of slots in each bloom filter (used by DI). The larger this number, the fewer\n * directives that will share slots, and thus, the fewer false positives when checking for\n * the existence of a directive.\n */\nconst BLOOM_SIZE = 256;\nconst BLOOM_MASK = BLOOM_SIZE - 1;\n/**\n * The number of bits that is represented by a single bloom bucket. JS bit operations are 32 bits,\n * so each bucket represents 32 distinct tokens which accounts for log2(32) = 5 bits of a bloom hash\n * number.\n */\nconst BLOOM_BUCKET_BITS = 5;\n/** Counter used to generate unique IDs for directives. */\nlet nextNgElementId = 0;\n/** Value used when something wasn't found by an injector. */\nconst NOT_FOUND = {};\n/**\n * Registers this directive as present in its node's injector by flipping the directive's\n * corresponding bit in the injector's bloom filter.\n *\n * @param injectorIndex The index of the node injector where this token should be registered\n * @param tView The TView for the injector's bloom filters\n * @param type The directive token to register\n */\nfunction bloomAdd(injectorIndex, tView, type) {\n ngDevMode && assertEqual(tView.firstCreatePass, true, 'expected firstCreatePass to be true');\n let id;\n if (typeof type === 'string') {\n id = type.charCodeAt(0) || 0;\n } else if (type.hasOwnProperty(NG_ELEMENT_ID)) {\n id = type[NG_ELEMENT_ID];\n }\n // Set a unique ID on the directive type, so if something tries to inject the directive,\n // we can easily retrieve the ID and hash it into the bloom bit that should be checked.\n if (id == null) {\n id = type[NG_ELEMENT_ID] = nextNgElementId++;\n }\n // We only have BLOOM_SIZE (256) slots in our bloom filter (8 buckets * 32 bits each),\n // so all unique IDs must be modulo-ed into a number from 0 - 255 to fit into the filter.\n const bloomHash = id & BLOOM_MASK;\n // Create a mask that targets the specific bit associated with the directive.\n // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n // to bit positions 0 - 31 in a 32 bit integer.\n const mask = 1 << bloomHash;\n // Each bloom bucket in `tData` represents `BLOOM_BUCKET_BITS` number of bits of `bloomHash`.\n // Any bits in `bloomHash` beyond `BLOOM_BUCKET_BITS` indicate the bucket offset that the mask\n // should be written to.\n tView.data[injectorIndex + (bloomHash >> BLOOM_BUCKET_BITS)] |= mask;\n}\n/**\n * Creates (or gets an existing) injector for a given element or container.\n *\n * @param tNode for which an injector should be retrieved / created.\n * @param lView View where the node is stored\n * @returns Node injector\n */\nfunction getOrCreateNodeInjectorForNode(tNode, lView) {\n const existingInjectorIndex = getInjectorIndex(tNode, lView);\n if (existingInjectorIndex !== -1) {\n return existingInjectorIndex;\n }\n const tView = lView[TVIEW];\n if (tView.firstCreatePass) {\n tNode.injectorIndex = lView.length;\n insertBloom(tView.data, tNode); // foundation for node bloom\n insertBloom(lView, null); // foundation for cumulative bloom\n insertBloom(tView.blueprint, null);\n }\n const parentLoc = getParentInjectorLocation(tNode, lView);\n const injectorIndex = tNode.injectorIndex;\n // If a parent injector can't be found, its location is set to -1.\n // In that case, we don't need to set up a cumulative bloom\n if (hasParentInjector(parentLoc)) {\n const parentIndex = getParentInjectorIndex(parentLoc);\n const parentLView = getParentInjectorView(parentLoc, lView);\n const parentData = parentLView[TVIEW].data;\n // Creates a cumulative bloom filter that merges the parent's bloom filter\n // and its own cumulative bloom (which contains tokens for all ancestors)\n for (let i = 0; i < 8 /* NodeInjectorOffset.BLOOM_SIZE */; i++) {\n lView[injectorIndex + i] = parentLView[parentIndex + i] | parentData[parentIndex + i];\n }\n }\n lView[injectorIndex + 8 /* NodeInjectorOffset.PARENT */] = parentLoc;\n return injectorIndex;\n}\nfunction insertBloom(arr, footer) {\n arr.push(0, 0, 0, 0, 0, 0, 0, 0, footer);\n}\nfunction getInjectorIndex(tNode, lView) {\n if (tNode.injectorIndex === -1 ||\n // If the injector index is the same as its parent's injector index, then the index has been\n // copied down from the parent node. No injector has been created yet on this node.\n tNode.parent && tNode.parent.injectorIndex === tNode.injectorIndex ||\n // After the first template pass, the injector index might exist but the parent values\n // might not have been calculated yet for this instance\n lView[tNode.injectorIndex + 8 /* NodeInjectorOffset.PARENT */] === null) {\n return -1;\n } else {\n ngDevMode && assertIndexInRange(lView, tNode.injectorIndex);\n return tNode.injectorIndex;\n }\n}\n/**\n * Finds the index of the parent injector, with a view offset if applicable. Used to set the\n * parent injector initially.\n *\n * @returns Returns a number that is the combination of the number of LViews that we have to go up\n * to find the LView containing the parent inject AND the index of the injector within that LView.\n */\nfunction getParentInjectorLocation(tNode, lView) {\n if (tNode.parent && tNode.parent.injectorIndex !== -1) {\n // If we have a parent `TNode` and there is an injector associated with it we are done, because\n // the parent injector is within the current `LView`.\n return tNode.parent.injectorIndex; // ViewOffset is 0\n }\n // When parent injector location is computed it may be outside of the current view. (ie it could\n // be pointing to a declared parent location). This variable stores number of declaration parents\n // we need to walk up in order to find the parent injector location.\n let declarationViewOffset = 0;\n let parentTNode = null;\n let lViewCursor = lView;\n // The parent injector is not in the current `LView`. We will have to walk the declared parent\n // `LView` hierarchy and look for it. If we walk of the top, that means that there is no parent\n // `NodeInjector`.\n while (lViewCursor !== null) {\n parentTNode = getTNodeFromLView(lViewCursor);\n if (parentTNode === null) {\n // If we have no parent, than we are done.\n return NO_PARENT_INJECTOR;\n }\n ngDevMode && parentTNode && assertTNodeForLView(parentTNode, lViewCursor[DECLARATION_VIEW]);\n // Every iteration of the loop requires that we go to the declared parent.\n declarationViewOffset++;\n lViewCursor = lViewCursor[DECLARATION_VIEW];\n if (parentTNode.injectorIndex !== -1) {\n // We found a NodeInjector which points to something.\n return parentTNode.injectorIndex | declarationViewOffset << 16 /* RelativeInjectorLocationFlags.ViewOffsetShift */;\n }\n }\n return NO_PARENT_INJECTOR;\n}\n/**\n * Makes a type or an injection token public to the DI system by adding it to an\n * injector's bloom filter.\n *\n * @param di The node injector in which a directive will be added\n * @param token The type or the injection token to be made public\n */\nfunction diPublicInInjector(injectorIndex, tView, token) {\n bloomAdd(injectorIndex, tView, token);\n}\n/**\n * Inject static attribute value into directive constructor.\n *\n * This method is used with `factory` functions which are generated as part of\n * `defineDirective` or `defineComponent`. The method retrieves the static value\n * of an attribute. (Dynamic attributes are not supported since they are not resolved\n * at the time of injection and can change over time.)\n *\n * # Example\n * Given:\n * ```\n * @Component(...)\n * class MyComponent {\n * constructor(@Attribute('title') title: string) { ... }\n * }\n * ```\n * When instantiated with\n * ```\n * \n * ```\n *\n * Then factory method generated is:\n * ```\n * MyComponent.ɵcmp = defineComponent({\n * factory: () => new MyComponent(injectAttribute('title'))\n * ...\n * })\n * ```\n *\n * @publicApi\n */\nfunction injectAttributeImpl(tNode, attrNameToInject) {\n ngDevMode && assertTNodeType(tNode, 12 /* TNodeType.AnyContainer */ | 3 /* TNodeType.AnyRNode */);\n ngDevMode && assertDefined(tNode, 'expecting tNode');\n if (attrNameToInject === 'class') {\n return tNode.classes;\n }\n if (attrNameToInject === 'style') {\n return tNode.styles;\n }\n const attrs = tNode.attrs;\n if (attrs) {\n const attrsLength = attrs.length;\n let i = 0;\n while (i < attrsLength) {\n const value = attrs[i];\n // If we hit a `Bindings` or `Template` marker then we are done.\n if (isNameOnlyAttributeMarker(value)) break;\n // Skip namespaced attributes\n if (value === 0 /* AttributeMarker.NamespaceURI */) {\n // we skip the next two values\n // as namespaced attributes looks like\n // [..., AttributeMarker.NamespaceURI, 'http://someuri.com/test', 'test:exist',\n // 'existValue', ...]\n i = i + 2;\n } else if (typeof value === 'number') {\n // Skip to the first value of the marked attribute.\n i++;\n while (i < attrsLength && typeof attrs[i] === 'string') {\n i++;\n }\n } else if (value === attrNameToInject) {\n return attrs[i + 1];\n } else {\n i = i + 2;\n }\n }\n }\n return null;\n}\nfunction notFoundValueOrThrow(notFoundValue, token, flags) {\n if (flags & InjectFlags.Optional || notFoundValue !== undefined) {\n return notFoundValue;\n } else {\n throwProviderNotFoundError(token, 'NodeInjector');\n }\n}\n/**\n * Returns the value associated to the given token from the ModuleInjector or throws exception\n *\n * @param lView The `LView` that contains the `tNode`\n * @param token The token to look for\n * @param flags Injection flags\n * @param notFoundValue The value to return when the injection flags is `InjectFlags.Optional`\n * @returns the value from the injector or throws an exception\n */\nfunction lookupTokenUsingModuleInjector(lView, token, flags, notFoundValue) {\n if (flags & InjectFlags.Optional && notFoundValue === undefined) {\n // This must be set or the NullInjector will throw for optional deps\n notFoundValue = null;\n }\n if ((flags & (InjectFlags.Self | InjectFlags.Host)) === 0) {\n const moduleInjector = lView[INJECTOR];\n // switch to `injectInjectorOnly` implementation for module injector, since module injector\n // should not have access to Component/Directive DI scope (that may happen through\n // `directiveInject` implementation)\n const previousInjectImplementation = setInjectImplementation(undefined);\n try {\n if (moduleInjector) {\n return moduleInjector.get(token, notFoundValue, flags & InjectFlags.Optional);\n } else {\n return injectRootLimpMode(token, notFoundValue, flags & InjectFlags.Optional);\n }\n } finally {\n setInjectImplementation(previousInjectImplementation);\n }\n }\n return notFoundValueOrThrow(notFoundValue, token, flags);\n}\n/**\n * Returns the value associated to the given token from the NodeInjectors => ModuleInjector.\n *\n * Look for the injector providing the token by walking up the node injector tree and then\n * the module injector tree.\n *\n * This function patches `token` with `__NG_ELEMENT_ID__` which contains the id for the bloom\n * filter. `-1` is reserved for injecting `Injector` (implemented by `NodeInjector`)\n *\n * @param tNode The Node where the search for the injector should start\n * @param lView The `LView` that contains the `tNode`\n * @param token The token to look for\n * @param flags Injection flags\n * @param notFoundValue The value to return when the injection flags is `InjectFlags.Optional`\n * @returns the value from the injector, `null` when not found, or `notFoundValue` if provided\n */\nfunction getOrCreateInjectable(tNode, lView, token, flags = InjectFlags.Default, notFoundValue) {\n if (tNode !== null) {\n // If the view or any of its ancestors have an embedded\n // view injector, we have to look it up there first.\n if (lView[FLAGS] & 2048 /* LViewFlags.HasEmbeddedViewInjector */ &&\n // The token must be present on the current node injector when the `Self`\n // flag is set, so the lookup on embedded view injector(s) can be skipped.\n !(flags & InjectFlags.Self)) {\n const embeddedInjectorValue = lookupTokenUsingEmbeddedInjector(tNode, lView, token, flags, NOT_FOUND);\n if (embeddedInjectorValue !== NOT_FOUND) {\n return embeddedInjectorValue;\n }\n }\n // Otherwise try the node injector.\n const value = lookupTokenUsingNodeInjector(tNode, lView, token, flags, NOT_FOUND);\n if (value !== NOT_FOUND) {\n return value;\n }\n }\n // Finally, fall back to the module injector.\n return lookupTokenUsingModuleInjector(lView, token, flags, notFoundValue);\n}\n/**\n * Returns the value associated to the given token from the node injector.\n *\n * @param tNode The Node where the search for the injector should start\n * @param lView The `LView` that contains the `tNode`\n * @param token The token to look for\n * @param flags Injection flags\n * @param notFoundValue The value to return when the injection flags is `InjectFlags.Optional`\n * @returns the value from the injector, `null` when not found, or `notFoundValue` if provided\n */\nfunction lookupTokenUsingNodeInjector(tNode, lView, token, flags, notFoundValue) {\n const bloomHash = bloomHashBitOrFactory(token);\n // If the ID stored here is a function, this is a special object like ElementRef or TemplateRef\n // so just call the factory function to create it.\n if (typeof bloomHash === 'function') {\n if (!enterDI(lView, tNode, flags)) {\n // Failed to enter DI, try module injector instead. If a token is injected with the @Host\n // flag, the module injector is not searched for that token in Ivy.\n return flags & InjectFlags.Host ? notFoundValueOrThrow(notFoundValue, token, flags) : lookupTokenUsingModuleInjector(lView, token, flags, notFoundValue);\n }\n try {\n let value;\n if (ngDevMode) {\n runInInjectorProfilerContext(new NodeInjector(getCurrentTNode(), getLView()), token, () => {\n value = bloomHash(flags);\n if (value != null) {\n emitInstanceCreatedByInjectorEvent(value);\n }\n });\n } else {\n value = bloomHash(flags);\n }\n if (value == null && !(flags & InjectFlags.Optional)) {\n throwProviderNotFoundError(token);\n } else {\n return value;\n }\n } finally {\n leaveDI();\n }\n } else if (typeof bloomHash === 'number') {\n // A reference to the previous injector TView that was found while climbing the element\n // injector tree. This is used to know if viewProviders can be accessed on the current\n // injector.\n let previousTView = null;\n let injectorIndex = getInjectorIndex(tNode, lView);\n let parentLocation = NO_PARENT_INJECTOR;\n let hostTElementNode = flags & InjectFlags.Host ? lView[DECLARATION_COMPONENT_VIEW][T_HOST] : null;\n // If we should skip this injector, or if there is no injector on this node, start by\n // searching the parent injector.\n if (injectorIndex === -1 || flags & InjectFlags.SkipSelf) {\n parentLocation = injectorIndex === -1 ? getParentInjectorLocation(tNode, lView) : lView[injectorIndex + 8 /* NodeInjectorOffset.PARENT */];\n if (parentLocation === NO_PARENT_INJECTOR || !shouldSearchParent(flags, false)) {\n injectorIndex = -1;\n } else {\n previousTView = lView[TVIEW];\n injectorIndex = getParentInjectorIndex(parentLocation);\n lView = getParentInjectorView(parentLocation, lView);\n }\n }\n // Traverse up the injector tree until we find a potential match or until we know there\n // *isn't* a match.\n while (injectorIndex !== -1) {\n ngDevMode && assertNodeInjector(lView, injectorIndex);\n // Check the current injector. If it matches, see if it contains token.\n const tView = lView[TVIEW];\n ngDevMode && assertTNodeForLView(tView.data[injectorIndex + 8 /* NodeInjectorOffset.TNODE */], lView);\n if (bloomHasToken(bloomHash, injectorIndex, tView.data)) {\n // At this point, we have an injector which *may* contain the token, so we step through\n // the providers and directives associated with the injector's corresponding node to get\n // the instance.\n const instance = searchTokensOnInjector(injectorIndex, lView, token, previousTView, flags, hostTElementNode);\n if (instance !== NOT_FOUND) {\n return instance;\n }\n }\n parentLocation = lView[injectorIndex + 8 /* NodeInjectorOffset.PARENT */];\n if (parentLocation !== NO_PARENT_INJECTOR && shouldSearchParent(flags, lView[TVIEW].data[injectorIndex + 8 /* NodeInjectorOffset.TNODE */] === hostTElementNode) && bloomHasToken(bloomHash, injectorIndex, lView)) {\n // The def wasn't found anywhere on this node, so it was a false positive.\n // Traverse up the tree and continue searching.\n previousTView = tView;\n injectorIndex = getParentInjectorIndex(parentLocation);\n lView = getParentInjectorView(parentLocation, lView);\n } else {\n // If we should not search parent OR If the ancestor bloom filter value does not have the\n // bit corresponding to the directive we can give up on traversing up to find the specific\n // injector.\n injectorIndex = -1;\n }\n }\n }\n return notFoundValue;\n}\nfunction searchTokensOnInjector(injectorIndex, lView, token, previousTView, flags, hostTElementNode) {\n const currentTView = lView[TVIEW];\n const tNode = currentTView.data[injectorIndex + 8 /* NodeInjectorOffset.TNODE */];\n // First, we need to determine if view providers can be accessed by the starting element.\n // There are two possibilities\n const canAccessViewProviders = previousTView == null ?\n // 1) This is the first invocation `previousTView == null` which means that we are at the\n // `TNode` of where injector is starting to look. In such a case the only time we are allowed\n // to look into the ViewProviders is if:\n // - we are on a component\n // - AND the injector set `includeViewProviders` to true (implying that the token can see\n // ViewProviders because it is the Component or a Service which itself was declared in\n // ViewProviders)\n isComponentHost(tNode) && includeViewProviders :\n // 2) `previousTView != null` which means that we are now walking across the parent nodes.\n // In such a case we are only allowed to look into the ViewProviders if:\n // - We just crossed from child View to Parent View `previousTView != currentTView`\n // - AND the parent TNode is an Element.\n // This means that we just came from the Component's View and therefore are allowed to see\n // into the ViewProviders.\n previousTView != currentTView && (tNode.type & 3 /* TNodeType.AnyRNode */) !== 0;\n // This special case happens when there is a @host on the inject and when we are searching\n // on the host element node.\n const isHostSpecialCase = flags & InjectFlags.Host && hostTElementNode === tNode;\n const injectableIdx = locateDirectiveOrProvider(tNode, currentTView, token, canAccessViewProviders, isHostSpecialCase);\n if (injectableIdx !== null) {\n return getNodeInjectable(lView, currentTView, injectableIdx, tNode);\n } else {\n return NOT_FOUND;\n }\n}\n/**\n * Searches for the given token among the node's directives and providers.\n *\n * @param tNode TNode on which directives are present.\n * @param tView The tView we are currently processing\n * @param token Provider token or type of a directive to look for.\n * @param canAccessViewProviders Whether view providers should be considered.\n * @param isHostSpecialCase Whether the host special case applies.\n * @returns Index of a found directive or provider, or null when none found.\n */\nfunction locateDirectiveOrProvider(tNode, tView, token, canAccessViewProviders, isHostSpecialCase) {\n const nodeProviderIndexes = tNode.providerIndexes;\n const tInjectables = tView.data;\n const injectablesStart = nodeProviderIndexes & 1048575 /* TNodeProviderIndexes.ProvidersStartIndexMask */;\n const directivesStart = tNode.directiveStart;\n const directiveEnd = tNode.directiveEnd;\n const cptViewProvidersCount = nodeProviderIndexes >> 20 /* TNodeProviderIndexes.CptViewProvidersCountShift */;\n const startingIndex = canAccessViewProviders ? injectablesStart : injectablesStart + cptViewProvidersCount;\n // When the host special case applies, only the viewProviders and the component are visible\n const endIndex = isHostSpecialCase ? injectablesStart + cptViewProvidersCount : directiveEnd;\n for (let i = startingIndex; i < endIndex; i++) {\n const providerTokenOrDef = tInjectables[i];\n if (i < directivesStart && token === providerTokenOrDef || i >= directivesStart && providerTokenOrDef.type === token) {\n return i;\n }\n }\n if (isHostSpecialCase) {\n const dirDef = tInjectables[directivesStart];\n if (dirDef && isComponentDef(dirDef) && dirDef.type === token) {\n return directivesStart;\n }\n }\n return null;\n}\n/**\n * Retrieve or instantiate the injectable from the `LView` at particular `index`.\n *\n * This function checks to see if the value has already been instantiated and if so returns the\n * cached `injectable`. Otherwise if it detects that the value is still a factory it\n * instantiates the `injectable` and caches the value.\n */\nfunction getNodeInjectable(lView, tView, index, tNode) {\n let value = lView[index];\n const tData = tView.data;\n if (isFactory(value)) {\n const factory = value;\n if (factory.resolving) {\n throwCyclicDependencyError(stringifyForError(tData[index]));\n }\n const previousIncludeViewProviders = setIncludeViewProviders(factory.canSeeViewProviders);\n factory.resolving = true;\n let prevInjectContext;\n if (ngDevMode) {\n // tData indexes mirror the concrete instances in its corresponding LView.\n // lView[index] here is either the injectable instace itself or a factory,\n // therefore tData[index] is the constructor of that injectable or a\n // definition object that contains the constructor in a `.type` field.\n const token = tData[index].type || tData[index];\n const injector = new NodeInjector(tNode, lView);\n prevInjectContext = setInjectorProfilerContext({\n injector,\n token\n });\n }\n const previousInjectImplementation = factory.injectImpl ? setInjectImplementation(factory.injectImpl) : null;\n const success = enterDI(lView, tNode, InjectFlags.Default);\n ngDevMode && assertEqual(success, true, \"Because flags do not contain `SkipSelf' we expect this to always succeed.\");\n try {\n value = lView[index] = factory.factory(undefined, tData, lView, tNode);\n ngDevMode && emitInstanceCreatedByInjectorEvent(value);\n // This code path is hit for both directives and providers.\n // For perf reasons, we want to avoid searching for hooks on providers.\n // It does no harm to try (the hooks just won't exist), but the extra\n // checks are unnecessary and this is a hot path. So we check to see\n // if the index of the dependency is in the directive range for this\n // tNode. If it's not, we know it's a provider and skip hook registration.\n if (tView.firstCreatePass && index >= tNode.directiveStart) {\n ngDevMode && assertDirectiveDef(tData[index]);\n registerPreOrderHooks(index, tData[index], tView);\n }\n } finally {\n ngDevMode && setInjectorProfilerContext(prevInjectContext);\n previousInjectImplementation !== null && setInjectImplementation(previousInjectImplementation);\n setIncludeViewProviders(previousIncludeViewProviders);\n factory.resolving = false;\n leaveDI();\n }\n }\n return value;\n}\n/**\n * Returns the bit in an injector's bloom filter that should be used to determine whether or not\n * the directive might be provided by the injector.\n *\n * When a directive is public, it is added to the bloom filter and given a unique ID that can be\n * retrieved on the Type. When the directive isn't public or the token is not a directive `null`\n * is returned as the node injector can not possibly provide that token.\n *\n * @param token the injection token\n * @returns the matching bit to check in the bloom filter or `null` if the token is not known.\n * When the returned value is negative then it represents special values such as `Injector`.\n */\nfunction bloomHashBitOrFactory(token) {\n ngDevMode && assertDefined(token, 'token must be defined');\n if (typeof token === 'string') {\n return token.charCodeAt(0) || 0;\n }\n const tokenId =\n // First check with `hasOwnProperty` so we don't get an inherited ID.\n token.hasOwnProperty(NG_ELEMENT_ID) ? token[NG_ELEMENT_ID] : undefined;\n // Negative token IDs are used for special objects such as `Injector`\n if (typeof tokenId === 'number') {\n if (tokenId >= 0) {\n return tokenId & BLOOM_MASK;\n } else {\n ngDevMode && assertEqual(tokenId, -1 /* InjectorMarkers.Injector */, 'Expecting to get Special Injector Id');\n return createNodeInjector;\n }\n } else {\n return tokenId;\n }\n}\nfunction bloomHasToken(bloomHash, injectorIndex, injectorView) {\n // Create a mask that targets the specific bit associated with the directive we're looking for.\n // JS bit operations are 32 bits, so this will be a number between 2^0 and 2^31, corresponding\n // to bit positions 0 - 31 in a 32 bit integer.\n const mask = 1 << bloomHash;\n // Each bloom bucket in `injectorView` represents `BLOOM_BUCKET_BITS` number of bits of\n // `bloomHash`. Any bits in `bloomHash` beyond `BLOOM_BUCKET_BITS` indicate the bucket offset\n // that should be used.\n const value = injectorView[injectorIndex + (bloomHash >> BLOOM_BUCKET_BITS)];\n // If the bloom filter value has the bit corresponding to the directive's bloomBit flipped on,\n // this injector is a potential match.\n return !!(value & mask);\n}\n/** Returns true if flags prevent parent injector from being searched for tokens */\nfunction shouldSearchParent(flags, isFirstHostTNode) {\n return !(flags & InjectFlags.Self) && !(flags & InjectFlags.Host && isFirstHostTNode);\n}\nfunction getNodeInjectorLView(nodeInjector) {\n return nodeInjector._lView;\n}\nfunction getNodeInjectorTNode(nodeInjector) {\n return nodeInjector._tNode;\n}\nclass NodeInjector {\n constructor(_tNode, _lView) {\n this._tNode = _tNode;\n this._lView = _lView;\n }\n get(token, notFoundValue, flags) {\n return getOrCreateInjectable(this._tNode, this._lView, token, convertToBitFlags(flags), notFoundValue);\n }\n}\n/** Creates a `NodeInjector` for the current node. */\nfunction createNodeInjector() {\n return new NodeInjector(getCurrentTNode(), getLView());\n}\n/**\n * @codeGenApi\n */\nfunction ɵɵgetInheritedFactory(type) {\n return noSideEffects(() => {\n const ownConstructor = type.prototype.constructor;\n const ownFactory = ownConstructor[NG_FACTORY_DEF] || getFactoryOf(ownConstructor);\n const objectPrototype = Object.prototype;\n let parent = Object.getPrototypeOf(type.prototype).constructor;\n // Go up the prototype until we hit `Object`.\n while (parent && parent !== objectPrototype) {\n const factory = parent[NG_FACTORY_DEF] || getFactoryOf(parent);\n // If we hit something that has a factory and the factory isn't the same as the type,\n // we've found the inherited factory. Note the check that the factory isn't the type's\n // own factory is redundant in most cases, but if the user has custom decorators on the\n // class, this lookup will start one level down in the prototype chain, causing us to\n // find the own factory first and potentially triggering an infinite loop downstream.\n if (factory && factory !== ownFactory) {\n return factory;\n }\n parent = Object.getPrototypeOf(parent);\n }\n // There is no factory defined. Either this was improper usage of inheritance\n // (no Angular decorator on the superclass) or there is no constructor at all\n // in the inheritance chain. Since the two cases cannot be distinguished, the\n // latter has to be assumed.\n return t => new t();\n });\n}\nfunction getFactoryOf(type) {\n if (isForwardRef(type)) {\n return () => {\n const factory = getFactoryOf(resolveForwardRef(type));\n return factory && factory();\n };\n }\n return getFactoryDef(type);\n}\n/**\n * Returns a value from the closest embedded or node injector.\n *\n * @param tNode The Node where the search for the injector should start\n * @param lView The `LView` that contains the `tNode`\n * @param token The token to look for\n * @param flags Injection flags\n * @param notFoundValue The value to return when the injection flags is `InjectFlags.Optional`\n * @returns the value from the injector, `null` when not found, or `notFoundValue` if provided\n */\nfunction lookupTokenUsingEmbeddedInjector(tNode, lView, token, flags, notFoundValue) {\n let currentTNode = tNode;\n let currentLView = lView;\n // When an LView with an embedded view injector is inserted, it'll likely be interlaced with\n // nodes who may have injectors (e.g. node injector -> embedded view injector -> node injector).\n // Since the bloom filters for the node injectors have already been constructed and we don't\n // have a way of extracting the records from an injector, the only way to maintain the correct\n // hierarchy when resolving the value is to walk it node-by-node while attempting to resolve\n // the token at each level.\n while (currentTNode !== null && currentLView !== null && currentLView[FLAGS] & 2048 /* LViewFlags.HasEmbeddedViewInjector */ && !(currentLView[FLAGS] & 512 /* LViewFlags.IsRoot */)) {\n ngDevMode && assertTNodeForLView(currentTNode, currentLView);\n // Note that this lookup on the node injector is using the `Self` flag, because\n // we don't want the node injector to look at any parent injectors since we\n // may hit the embedded view injector first.\n const nodeInjectorValue = lookupTokenUsingNodeInjector(currentTNode, currentLView, token, flags | InjectFlags.Self, NOT_FOUND);\n if (nodeInjectorValue !== NOT_FOUND) {\n return nodeInjectorValue;\n }\n // Has an explicit type due to a TS bug: https://github.com/microsoft/TypeScript/issues/33191\n let parentTNode = currentTNode.parent;\n // `TNode.parent` includes the parent within the current view only. If it doesn't exist,\n // it means that we've hit the view boundary and we need to go up to the next view.\n if (!parentTNode) {\n // Before we go to the next LView, check if the token exists on the current embedded injector.\n const embeddedViewInjector = currentLView[EMBEDDED_VIEW_INJECTOR];\n if (embeddedViewInjector) {\n const embeddedViewInjectorValue = embeddedViewInjector.get(token, NOT_FOUND, flags);\n if (embeddedViewInjectorValue !== NOT_FOUND) {\n return embeddedViewInjectorValue;\n }\n }\n // Otherwise keep going up the tree.\n parentTNode = getTNodeFromLView(currentLView);\n currentLView = currentLView[DECLARATION_VIEW];\n }\n currentTNode = parentTNode;\n }\n return notFoundValue;\n}\n/** Gets the TNode associated with an LView inside of the declaration view. */\nfunction getTNodeFromLView(lView) {\n const tView = lView[TVIEW];\n const tViewType = tView.type;\n // The parent pointer differs based on `TView.type`.\n if (tViewType === 2 /* TViewType.Embedded */) {\n ngDevMode && assertDefined(tView.declTNode, 'Embedded TNodes should have declaration parents.');\n return tView.declTNode;\n } else if (tViewType === 1 /* TViewType.Component */) {\n // Components don't have `TView.declTNode` because each instance of component could be\n // inserted in different location, hence `TView.declTNode` is meaningless.\n return lView[T_HOST];\n }\n return null;\n}\n\n/**\n * Facade for the attribute injection from DI.\n *\n * @codeGenApi\n */\nfunction ɵɵinjectAttribute(attrNameToInject) {\n return injectAttributeImpl(getCurrentTNode(), attrNameToInject);\n}\n\n/**\n * Attribute decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nconst Attribute = /*#__PURE__*/makeParamDecorator('Attribute', attributeName => ({\n attributeName,\n __NG_ELEMENT_ID__: () => ɵɵinjectAttribute(attributeName)\n}));\nlet _reflect = null;\nfunction getReflect() {\n return _reflect = _reflect || new ReflectionCapabilities();\n}\nfunction reflectDependencies(type) {\n return convertDependencies(getReflect().parameters(type));\n}\nfunction convertDependencies(deps) {\n return deps.map(dep => reflectDependency(dep));\n}\nfunction reflectDependency(dep) {\n const meta = {\n token: null,\n attribute: null,\n host: false,\n optional: false,\n self: false,\n skipSelf: false\n };\n if (Array.isArray(dep) && dep.length > 0) {\n for (let j = 0; j < dep.length; j++) {\n const param = dep[j];\n if (param === undefined) {\n // param may be undefined if type of dep is not set by ngtsc\n continue;\n }\n const proto = Object.getPrototypeOf(param);\n if (param instanceof Optional || proto.ngMetadataName === 'Optional') {\n meta.optional = true;\n } else if (param instanceof SkipSelf || proto.ngMetadataName === 'SkipSelf') {\n meta.skipSelf = true;\n } else if (param instanceof Self || proto.ngMetadataName === 'Self') {\n meta.self = true;\n } else if (param instanceof Host || proto.ngMetadataName === 'Host') {\n meta.host = true;\n } else if (param instanceof Inject) {\n meta.token = param.token;\n } else if (param instanceof Attribute) {\n if (param.attributeName === undefined) {\n throw new RuntimeError(204 /* RuntimeErrorCode.INVALID_INJECTION_TOKEN */, ngDevMode && `Attribute name must be defined.`);\n }\n meta.attribute = param.attributeName;\n } else {\n meta.token = param;\n }\n }\n } else if (dep === undefined || Array.isArray(dep) && dep.length === 0) {\n meta.token = null;\n } else {\n meta.token = dep;\n }\n return meta;\n}\n\n/**\n * Compile an Angular injectable according to its `Injectable` metadata, and patch the resulting\n * injectable def (`ɵprov`) onto the injectable type.\n */\nfunction compileInjectable(type, meta) {\n let ngInjectableDef = null;\n let ngFactoryDef = null;\n // if NG_PROV_DEF is already defined on this class then don't overwrite it\n if (!type.hasOwnProperty(NG_PROV_DEF)) {\n Object.defineProperty(type, NG_PROV_DEF, {\n get: () => {\n if (ngInjectableDef === null) {\n const compiler = getCompilerFacade({\n usage: 0 /* JitCompilerUsage.Decorator */,\n kind: 'injectable',\n type\n });\n ngInjectableDef = compiler.compileInjectable(angularCoreDiEnv, `ng:///${type.name}/ɵprov.js`, getInjectableMetadata(type, meta));\n }\n return ngInjectableDef;\n }\n });\n }\n // if NG_FACTORY_DEF is already defined on this class then don't overwrite it\n if (!type.hasOwnProperty(NG_FACTORY_DEF)) {\n Object.defineProperty(type, NG_FACTORY_DEF, {\n get: () => {\n if (ngFactoryDef === null) {\n const compiler = getCompilerFacade({\n usage: 0 /* JitCompilerUsage.Decorator */,\n kind: 'injectable',\n type\n });\n ngFactoryDef = compiler.compileFactory(angularCoreDiEnv, `ng:///${type.name}/ɵfac.js`, {\n name: type.name,\n type,\n typeArgumentCount: 0,\n // In JIT mode types are not available nor used.\n deps: reflectDependencies(type),\n target: compiler.FactoryTarget.Injectable\n });\n }\n return ngFactoryDef;\n },\n // Leave this configurable so that the factories from directives or pipes can take precedence.\n configurable: true\n });\n }\n}\nconst USE_VALUE = /*#__PURE__*/getClosureSafeProperty({\n provide: String,\n useValue: getClosureSafeProperty\n});\nfunction isUseClassProvider(meta) {\n return meta.useClass !== undefined;\n}\nfunction isUseValueProvider(meta) {\n return USE_VALUE in meta;\n}\nfunction isUseFactoryProvider(meta) {\n return meta.useFactory !== undefined;\n}\nfunction isUseExistingProvider(meta) {\n return meta.useExisting !== undefined;\n}\nfunction getInjectableMetadata(type, srcMeta) {\n // Allow the compilation of a class with a `@Injectable()` decorator without parameters\n const meta = srcMeta || {\n providedIn: null\n };\n const compilerMeta = {\n name: type.name,\n type: type,\n typeArgumentCount: 0,\n providedIn: meta.providedIn\n };\n if ((isUseClassProvider(meta) || isUseFactoryProvider(meta)) && meta.deps !== undefined) {\n compilerMeta.deps = convertDependencies(meta.deps);\n }\n // Check to see if the user explicitly provided a `useXxxx` property.\n if (isUseClassProvider(meta)) {\n compilerMeta.useClass = meta.useClass;\n } else if (isUseValueProvider(meta)) {\n compilerMeta.useValue = meta.useValue;\n } else if (isUseFactoryProvider(meta)) {\n compilerMeta.useFactory = meta.useFactory;\n } else if (isUseExistingProvider(meta)) {\n compilerMeta.useExisting = meta.useExisting;\n }\n return compilerMeta;\n}\n\n/**\n * Injectable decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nconst Injectable = /*#__PURE__*/makeDecorator('Injectable', undefined, undefined, undefined, (type, meta) => compileInjectable(type, meta));\n\n/**\n * Create a new `Injector` which is configured using a `defType` of `InjectorType`s.\n */\nfunction createInjector(defType, parent = null, additionalProviders = null, name) {\n const injector = createInjectorWithoutInjectorInstances(defType, parent, additionalProviders, name);\n injector.resolveInjectorInitializers();\n return injector;\n}\n/**\n * Creates a new injector without eagerly resolving its injector types. Can be used in places\n * where resolving the injector types immediately can lead to an infinite loop. The injector types\n * should be resolved at a later point by calling `_resolveInjectorDefTypes`.\n */\nfunction createInjectorWithoutInjectorInstances(defType, parent = null, additionalProviders = null, name, scopes = new Set()) {\n const providers = [additionalProviders || EMPTY_ARRAY, importProvidersFrom(defType)];\n name = name || (typeof defType === 'object' ? undefined : stringify(defType));\n return new R3Injector(providers, parent || getNullInjector(), name || null, scopes);\n}\n\n/**\n * Concrete injectors implement this interface. Injectors are configured\n * with [providers](guide/di/dependency-injection-providers) that associate\n * dependencies of various types with [injection tokens](guide/di/dependency-injection-providers).\n *\n * @see [DI Providers](guide/di/dependency-injection-providers).\n * @see {@link StaticProvider}\n *\n * @usageNotes\n *\n * The following example creates a service injector instance.\n *\n * {@example core/di/ts/provider_spec.ts region='ConstructorProvider'}\n *\n * ### Usage example\n *\n * {@example core/di/ts/injector_spec.ts region='Injector'}\n *\n * `Injector` returns itself when given `Injector` as a token:\n *\n * {@example core/di/ts/injector_spec.ts region='injectInjector'}\n *\n * @publicApi\n */\nclass Injector {\n static {\n this.THROW_IF_NOT_FOUND = THROW_IF_NOT_FOUND;\n }\n static {\n this.NULL = /*#__PURE__*/new NullInjector();\n }\n static create(options, parent) {\n if (Array.isArray(options)) {\n return createInjector({\n name: ''\n }, parent, options, '');\n } else {\n const name = options.name ?? '';\n return createInjector({\n name\n }, options.parent, options.providers, name);\n }\n }\n /** @nocollapse */\n static {\n this.ɵprov = /*#__PURE__*/ɵɵdefineInjectable({\n token: Injector,\n providedIn: 'any',\n factory: () => ɵɵinject(INJECTOR$1)\n });\n }\n /**\n * @internal\n * @nocollapse\n */\n static {\n this.__NG_ELEMENT_ID__ = -1 /* InjectorMarkers.Injector */;\n }\n}\n\n/*!\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n/**\n * Creates a token that can be used to inject static attributes of the host node.\n *\n * @usageNotes\n * ### Injecting an attribute that is known to exist\n * ```typescript\n * @Directive()\n * class MyDir {\n * attr: string = inject(new HostAttributeToken('some-attr'));\n * }\n * ```\n *\n * ### Optionally injecting an attribute\n * ```typescript\n * @Directive()\n * class MyDir {\n * attr: string | null = inject(new HostAttributeToken('some-attr'), {optional: true});\n * }\n * ```\n * @publicApi\n */\nclass HostAttributeToken {\n constructor(attributeName) {\n this.attributeName = attributeName;\n /** @internal */\n this.__NG_ELEMENT_ID__ = () => ɵɵinjectAttribute(this.attributeName);\n }\n toString() {\n return `HostAttributeToken ${this.attributeName}`;\n }\n}\n\n/**\n * A token that can be used to inject the tag name of the host node.\n *\n * @usageNotes\n * ### Injecting a tag name that is known to exist\n * ```typescript\n * @Directive()\n * class MyDir {\n * tagName: string = inject(HOST_TAG_NAME);\n * }\n * ```\n *\n * ### Optionally injecting a tag name\n * ```typescript\n * @Directive()\n * class MyDir {\n * tagName: string | null = inject(HOST_TAG_NAME, {optional: true});\n * }\n * ```\n * @publicApi\n */\nconst HOST_TAG_NAME = /*#__PURE__*/new InjectionToken(ngDevMode ? 'HOST_TAG_NAME' : '');\n// HOST_TAG_NAME should be resolved at the current node, similar to e.g. ElementRef,\n// so we manually specify __NG_ELEMENT_ID__ here, instead of using a factory.\n// tslint:disable-next-line:no-toplevel-property-access\nHOST_TAG_NAME.__NG_ELEMENT_ID__ = flags => {\n const tNode = getCurrentTNode();\n if (tNode === null) {\n throw new RuntimeError(204 /* RuntimeErrorCode.INVALID_INJECTION_TOKEN */, ngDevMode && 'HOST_TAG_NAME can only be injected in directives and components ' + 'during construction time (in a class constructor or as a class field initializer)');\n }\n if (tNode.type & 2 /* TNodeType.Element */) {\n return tNode.value;\n }\n if (flags & InjectFlags.Optional) {\n return null;\n }\n throw new RuntimeError(204 /* RuntimeErrorCode.INVALID_INJECTION_TOKEN */, ngDevMode && `HOST_TAG_NAME was used on ${getDevModeNodeName(tNode)} which doesn't have an underlying element in the DOM. ` + `This is invalid, and so the dependency should be marked as optional.`);\n};\nfunction getDevModeNodeName(tNode) {\n if (tNode.type & 8 /* TNodeType.ElementContainer */) {\n return 'an ';\n } else if (tNode.type & 4 /* TNodeType.Container */) {\n return 'an ';\n } else if (tNode.type & 128 /* TNodeType.LetDeclaration */) {\n return 'an @let declaration';\n } else {\n return 'a node';\n }\n}\n\n/**\n * @module\n * @description\n * The `di` module provides dependency injection container services.\n */\n\n/**\n * This file should not be necessary because node resolution should just default to `./di/index`!\n *\n * However it does not seem to work and it breaks:\n * - //packages/animations/browser/test:test_web_chromium-local\n * - //packages/compiler-cli/test:extract_i18n\n * - //packages/compiler-cli/test:ngc\n * - //packages/compiler-cli/test:perform_watch\n * - //packages/compiler-cli/test/diagnostics:check_types\n * - //packages/compiler-cli/test/transformers:test\n * - //packages/compiler/test:test\n * - //tools/public_api_guard:core_api\n *\n * Remove this file once the above is solved or wait until `ngc` is deleted and then it should be\n * safe to delete this file.\n */\n\nconst ERROR_ORIGINAL_ERROR = 'ngOriginalError';\nfunction wrappedError(message, originalError) {\n const msg = `${message} caused by: ${originalError instanceof Error ? originalError.message : originalError}`;\n const error = Error(msg);\n error[ERROR_ORIGINAL_ERROR] = originalError;\n return error;\n}\nfunction getOriginalError(error) {\n return error[ERROR_ORIGINAL_ERROR];\n}\nconst SCHEDULE_IN_ROOT_ZONE_DEFAULT = true;\n\n/**\n * `DestroyRef` lets you set callbacks to run for any cleanup or destruction behavior.\n * The scope of this destruction depends on where `DestroyRef` is injected. If `DestroyRef`\n * is injected in a component or directive, the callbacks run when that component or\n * directive is destroyed. Otherwise the callbacks run when a corresponding injector is destroyed.\n *\n * @publicApi\n */\nlet DestroyRef = /*#__PURE__*/(() => {\n class DestroyRef {\n /**\n * @internal\n * @nocollapse\n */\n static {\n this.__NG_ELEMENT_ID__ = injectDestroyRef;\n }\n /**\n * @internal\n * @nocollapse\n */\n static {\n this.__NG_ENV_ID__ = injector => injector;\n }\n }\n return DestroyRef;\n})();\nclass NodeInjectorDestroyRef extends DestroyRef {\n constructor(_lView) {\n super();\n this._lView = _lView;\n }\n onDestroy(callback) {\n storeLViewOnDestroy(this._lView, callback);\n return () => removeLViewOnDestroy(this._lView, callback);\n }\n}\nfunction injectDestroyRef() {\n return new NodeInjectorDestroyRef(getLView());\n}\n\n/**\n * Internal implementation of the pending tasks service.\n */\nlet PendingTasks = /*#__PURE__*/(() => {\n class PendingTasks {\n constructor() {\n this.taskId = 0;\n this.pendingTasks = new Set();\n this.hasPendingTasks = new BehaviorSubject(false);\n }\n get _hasPendingTasks() {\n return this.hasPendingTasks.value;\n }\n add() {\n if (!this._hasPendingTasks) {\n this.hasPendingTasks.next(true);\n }\n const taskId = this.taskId++;\n this.pendingTasks.add(taskId);\n return taskId;\n }\n remove(taskId) {\n this.pendingTasks.delete(taskId);\n if (this.pendingTasks.size === 0 && this._hasPendingTasks) {\n this.hasPendingTasks.next(false);\n }\n }\n ngOnDestroy() {\n this.pendingTasks.clear();\n if (this._hasPendingTasks) {\n this.hasPendingTasks.next(false);\n }\n }\n /** @nocollapse */\n static {\n this.ɵprov = ɵɵdefineInjectable({\n token: PendingTasks,\n providedIn: 'root',\n factory: () => new PendingTasks()\n });\n }\n }\n return PendingTasks;\n})();\n/**\n * Experimental service that keeps track of pending tasks contributing to the stableness of Angular\n * application. While several existing Angular services (ex.: `HttpClient`) will internally manage\n * tasks influencing stability, this API gives control over stability to library and application\n * developers for specific cases not covered by Angular internals.\n *\n * The concept of stability comes into play in several important scenarios:\n * - SSR process needs to wait for the application stability before serializing and sending rendered\n * HTML;\n * - tests might want to delay assertions until the application becomes stable;\n *\n * @usageNotes\n * ```typescript\n * const pendingTasks = inject(ExperimentalPendingTasks);\n * const taskCleanup = pendingTasks.add();\n * // do work that should block application's stability and then:\n * taskCleanup();\n * ```\n *\n * This API is experimental. Neither the shape, nor the underlying behavior is stable and can change\n * in patch versions. We will iterate on the exact API based on the feedback and our understanding\n * of the problem and solution space.\n *\n * @publicApi\n * @experimental\n */\nlet ExperimentalPendingTasks = /*#__PURE__*/(() => {\n class ExperimentalPendingTasks {\n constructor() {\n this.internalPendingTasks = inject(PendingTasks);\n }\n /**\n * Adds a new task that should block application's stability.\n * @returns A cleanup function that removes a task when called.\n */\n add() {\n const taskId = this.internalPendingTasks.add();\n return () => this.internalPendingTasks.remove(taskId);\n }\n /** @nocollapse */\n static {\n this.ɵprov = ɵɵdefineInjectable({\n token: ExperimentalPendingTasks,\n providedIn: 'root',\n factory: () => new ExperimentalPendingTasks()\n });\n }\n }\n return ExperimentalPendingTasks;\n})();\nclass EventEmitter_ extends Subject {\n constructor(isAsync = false) {\n super();\n this.destroyRef = undefined;\n this.pendingTasks = undefined;\n this.__isAsync = isAsync;\n // Attempt to retrieve a `DestroyRef` and `PendingTasks` optionally.\n // For backwards compatibility reasons, this cannot be required.\n if (isInInjectionContext()) {\n // `DestroyRef` is optional because it is not available in all contexts.\n // But it is useful to properly complete the `EventEmitter` if used with `outputToObservable`\n // when the component/directive is destroyed. (See `outputToObservable` for more details.)\n this.destroyRef = inject(DestroyRef, {\n optional: true\n }) ?? undefined;\n this.pendingTasks = inject(PendingTasks, {\n optional: true\n }) ?? undefined;\n }\n }\n emit(value) {\n const prevConsumer = setActiveConsumer$1(null);\n try {\n super.next(value);\n } finally {\n setActiveConsumer$1(prevConsumer);\n }\n }\n subscribe(observerOrNext, error, complete) {\n let nextFn = observerOrNext;\n let errorFn = error || (() => null);\n let completeFn = complete;\n if (observerOrNext && typeof observerOrNext === 'object') {\n const observer = observerOrNext;\n nextFn = observer.next?.bind(observer);\n errorFn = observer.error?.bind(observer);\n completeFn = observer.complete?.bind(observer);\n }\n if (this.__isAsync) {\n errorFn = this.wrapInTimeout(errorFn);\n if (nextFn) {\n nextFn = this.wrapInTimeout(nextFn);\n }\n if (completeFn) {\n completeFn = this.wrapInTimeout(completeFn);\n }\n }\n const sink = super.subscribe({\n next: nextFn,\n error: errorFn,\n complete: completeFn\n });\n if (observerOrNext instanceof Subscription) {\n observerOrNext.add(sink);\n }\n return sink;\n }\n wrapInTimeout(fn) {\n return value => {\n const taskId = this.pendingTasks?.add();\n setTimeout(() => {\n fn(value);\n if (taskId !== undefined) {\n this.pendingTasks?.remove(taskId);\n }\n });\n };\n }\n}\n/**\n * @publicApi\n */\nconst EventEmitter = EventEmitter_;\nfunction noop(...args) {\n // Do nothing.\n}\n\n/**\n * Gets a scheduling function that runs the callback after the first of setTimeout and\n * requestAnimationFrame resolves.\n *\n * - `requestAnimationFrame` ensures that change detection runs ahead of a browser repaint.\n * This ensures that the create and update passes of a change detection always happen\n * in the same frame.\n * - When the browser is resource-starved, `rAF` can execute _before_ a `setTimeout` because\n * rendering is a very high priority process. This means that `setTimeout` cannot guarantee\n * same-frame create and update pass, when `setTimeout` is used to schedule the update phase.\n * - While `rAF` gives us the desirable same-frame updates, it has two limitations that\n * prevent it from being used alone. First, it does not run in background tabs, which would\n * prevent Angular from initializing an application when opened in a new tab (for example).\n * Second, repeated calls to requestAnimationFrame will execute at the refresh rate of the\n * hardware (~16ms for a 60Hz display). This would cause significant slowdown of tests that\n * are written with several updates and asserts in the form of \"update; await stable; assert;\".\n * - Both `setTimeout` and `rAF` are able to \"coalesce\" several events from a single user\n * interaction into a single change detection. Importantly, this reduces view tree traversals when\n * compared to an alternative timing mechanism like `queueMicrotask`, where change detection would\n * then be interleaves between each event.\n *\n * By running change detection after the first of `setTimeout` and `rAF` to execute, we get the\n * best of both worlds.\n *\n * @returns a function to cancel the scheduled callback\n */\nfunction scheduleCallbackWithRafRace(callback) {\n let timeoutId;\n let animationFrameId;\n function cleanup() {\n callback = noop;\n try {\n if (animationFrameId !== undefined && typeof cancelAnimationFrame === 'function') {\n cancelAnimationFrame(animationFrameId);\n }\n if (timeoutId !== undefined) {\n clearTimeout(timeoutId);\n }\n } catch {\n // Clearing/canceling can fail in tests due to the timing of functions being patched and unpatched\n // Just ignore the errors - we protect ourselves from this issue by also making the callback a no-op.\n }\n }\n timeoutId = setTimeout(() => {\n callback();\n cleanup();\n });\n if (typeof requestAnimationFrame === 'function') {\n animationFrameId = requestAnimationFrame(() => {\n callback();\n cleanup();\n });\n }\n return () => cleanup();\n}\nfunction scheduleCallbackWithMicrotask(callback) {\n queueMicrotask(() => callback());\n return () => {\n callback = noop;\n };\n}\nclass AsyncStackTaggingZoneSpec {\n constructor(namePrefix, consoleAsyncStackTaggingImpl = console) {\n this.name = 'asyncStackTagging for ' + namePrefix;\n this.createTask = consoleAsyncStackTaggingImpl?.createTask ?? (() => null);\n }\n onScheduleTask(delegate, _current, target, task) {\n task.consoleTask = this.createTask(`Zone - ${task.source || task.type}`);\n return delegate.scheduleTask(target, task);\n }\n onInvokeTask(delegate, _currentZone, targetZone, task, applyThis, applyArgs) {\n let ret;\n if (task.consoleTask) {\n ret = task.consoleTask.run(() => delegate.invokeTask(targetZone, task, applyThis, applyArgs));\n } else {\n ret = delegate.invokeTask(targetZone, task, applyThis, applyArgs);\n }\n return ret;\n }\n}\nconst isAngularZoneProperty = 'isAngularZone';\nconst angularZoneInstanceIdProperty = isAngularZoneProperty + '_ID';\nlet ngZoneInstanceId = 0;\n/**\n * An injectable service for executing work inside or outside of the Angular zone.\n *\n * The most common use of this service is to optimize performance when starting a work consisting of\n * one or more asynchronous tasks that don't require UI updates or error handling to be handled by\n * Angular. Such tasks can be kicked off via {@link #runOutsideAngular} and if needed, these tasks\n * can reenter the Angular zone via {@link #run}.\n *\n * \n *\n * @usageNotes\n * ### Example\n *\n * ```\n * import {Component, NgZone} from '@angular/core';\n * import {NgIf} from '@angular/common';\n *\n * @Component({\n * selector: 'ng-zone-demo',\n * template: `\n *

Demo: NgZone

\n *\n *

Progress: {{progress}}%

\n *

= 100\">Done processing {{label}} of Angular zone!

\n *\n * \n * \n * `,\n * })\n * export class NgZoneDemo {\n * progress: number = 0;\n * label: string;\n *\n * constructor(private _ngZone: NgZone) {}\n *\n * // Loop inside the Angular zone\n * // so the UI DOES refresh after each setTimeout cycle\n * processWithinAngularZone() {\n * this.label = 'inside';\n * this.progress = 0;\n * this._increaseProgress(() => console.log('Inside Done!'));\n * }\n *\n * // Loop outside of the Angular zone\n * // so the UI DOES NOT refresh after each setTimeout cycle\n * processOutsideOfAngularZone() {\n * this.label = 'outside';\n * this.progress = 0;\n * this._ngZone.runOutsideAngular(() => {\n * this._increaseProgress(() => {\n * // reenter the Angular zone and display done\n * this._ngZone.run(() => { console.log('Outside Done!'); });\n * });\n * });\n * }\n *\n * _increaseProgress(doneCallback: () => void) {\n * this.progress += 1;\n * console.log(`Current progress: ${this.progress}%`);\n *\n * if (this.progress < 100) {\n * window.setTimeout(() => this._increaseProgress(doneCallback), 10);\n * } else {\n * doneCallback();\n * }\n * }\n * }\n * ```\n *\n * @publicApi\n */\nclass NgZone {\n constructor(options) {\n this.hasPendingMacrotasks = false;\n this.hasPendingMicrotasks = false;\n /**\n * Whether there are no outstanding microtasks or macrotasks.\n */\n this.isStable = true;\n /**\n * Notifies when code enters Angular Zone. This gets fired first on VM Turn.\n */\n this.onUnstable = new EventEmitter(false);\n /**\n * Notifies when there is no more microtasks enqueued in the current VM Turn.\n * This is a hint for Angular to do change detection, which may enqueue more microtasks.\n * For this reason this event can fire multiple times per VM Turn.\n */\n this.onMicrotaskEmpty = new EventEmitter(false);\n /**\n * Notifies when the last `onMicrotaskEmpty` has run and there are no more microtasks, which\n * implies we are about to relinquish VM turn.\n * This event gets called just once.\n */\n this.onStable = new EventEmitter(false);\n /**\n * Notifies that an error has been delivered.\n */\n this.onError = new EventEmitter(false);\n const {\n enableLongStackTrace = false,\n shouldCoalesceEventChangeDetection = false,\n shouldCoalesceRunChangeDetection = false,\n scheduleInRootZone = SCHEDULE_IN_ROOT_ZONE_DEFAULT\n } = options;\n if (typeof Zone == 'undefined') {\n throw new RuntimeError(908 /* RuntimeErrorCode.MISSING_ZONEJS */, ngDevMode && `In this configuration Angular requires Zone.js`);\n }\n Zone.assertZonePatched();\n const self = this;\n self._nesting = 0;\n self._outer = self._inner = Zone.current;\n // AsyncStackTaggingZoneSpec provides `linked stack traces` to show\n // where the async operation is scheduled. For more details, refer\n // to this article, https://developer.chrome.com/blog/devtools-better-angular-debugging/\n // And we only import this AsyncStackTaggingZoneSpec in development mode,\n // in the production mode, the AsyncStackTaggingZoneSpec will be tree shaken away.\n if (ngDevMode) {\n self._inner = self._inner.fork(new AsyncStackTaggingZoneSpec('Angular'));\n }\n if (Zone['TaskTrackingZoneSpec']) {\n self._inner = self._inner.fork(new Zone['TaskTrackingZoneSpec']());\n }\n if (enableLongStackTrace && Zone['longStackTraceZoneSpec']) {\n self._inner = self._inner.fork(Zone['longStackTraceZoneSpec']);\n }\n // if shouldCoalesceRunChangeDetection is true, all tasks including event tasks will be\n // coalesced, so shouldCoalesceEventChangeDetection option is not necessary and can be skipped.\n self.shouldCoalesceEventChangeDetection = !shouldCoalesceRunChangeDetection && shouldCoalesceEventChangeDetection;\n self.shouldCoalesceRunChangeDetection = shouldCoalesceRunChangeDetection;\n self.callbackScheduled = false;\n self.scheduleInRootZone = scheduleInRootZone;\n forkInnerZoneWithAngularBehavior(self);\n }\n /**\n This method checks whether the method call happens within an Angular Zone instance.\n */\n static isInAngularZone() {\n // Zone needs to be checked, because this method might be called even when NoopNgZone is used.\n return typeof Zone !== 'undefined' && Zone.current.get(isAngularZoneProperty) === true;\n }\n /**\n Assures that the method is called within the Angular Zone, otherwise throws an error.\n */\n static assertInAngularZone() {\n if (!NgZone.isInAngularZone()) {\n throw new RuntimeError(909 /* RuntimeErrorCode.UNEXPECTED_ZONE_STATE */, ngDevMode && 'Expected to be in Angular Zone, but it is not!');\n }\n }\n /**\n Assures that the method is called outside of the Angular Zone, otherwise throws an error.\n */\n static assertNotInAngularZone() {\n if (NgZone.isInAngularZone()) {\n throw new RuntimeError(909 /* RuntimeErrorCode.UNEXPECTED_ZONE_STATE */, ngDevMode && 'Expected to not be in Angular Zone, but it is!');\n }\n }\n /**\n * Executes the `fn` function synchronously within the Angular zone and returns value returned by\n * the function.\n *\n * Running functions via `run` allows you to reenter Angular zone from a task that was executed\n * outside of the Angular zone (typically started via {@link #runOutsideAngular}).\n *\n * Any future tasks or microtasks scheduled from within this function will continue executing from\n * within the Angular zone.\n *\n * If a synchronous error happens it will be rethrown and not reported via `onError`.\n */\n run(fn, applyThis, applyArgs) {\n return this._inner.run(fn, applyThis, applyArgs);\n }\n /**\n * Executes the `fn` function synchronously within the Angular zone as a task and returns value\n * returned by the function.\n *\n * Running functions via `run` allows you to reenter Angular zone from a task that was executed\n * outside of the Angular zone (typically started via {@link #runOutsideAngular}).\n *\n * Any future tasks or microtasks scheduled from within this function will continue executing from\n * within the Angular zone.\n *\n * If a synchronous error happens it will be rethrown and not reported via `onError`.\n */\n runTask(fn, applyThis, applyArgs, name) {\n const zone = this._inner;\n const task = zone.scheduleEventTask('NgZoneEvent: ' + name, fn, EMPTY_PAYLOAD, noop, noop);\n try {\n return zone.runTask(task, applyThis, applyArgs);\n } finally {\n zone.cancelTask(task);\n }\n }\n /**\n * Same as `run`, except that synchronous errors are caught and forwarded via `onError` and not\n * rethrown.\n */\n runGuarded(fn, applyThis, applyArgs) {\n return this._inner.runGuarded(fn, applyThis, applyArgs);\n }\n /**\n * Executes the `fn` function synchronously in Angular's parent zone and returns value returned by\n * the function.\n *\n * Running functions via {@link #runOutsideAngular} allows you to escape Angular's zone and do\n * work that\n * doesn't trigger Angular change-detection or is subject to Angular's error handling.\n *\n * Any future tasks or microtasks scheduled from within this function will continue executing from\n * outside of the Angular zone.\n *\n * Use {@link #run} to reenter the Angular zone and do work that updates the application model.\n */\n runOutsideAngular(fn) {\n return this._outer.run(fn);\n }\n}\nconst EMPTY_PAYLOAD = {};\nfunction checkStable(zone) {\n // TODO: @JiaLiPassion, should check zone.isCheckStableRunning to prevent\n // re-entry. The case is:\n //\n // @Component({...})\n // export class AppComponent {\n // constructor(private ngZone: NgZone) {\n // this.ngZone.onStable.subscribe(() => {\n // this.ngZone.run(() => console.log('stable'););\n // });\n // }\n //\n // The onStable subscriber run another function inside ngZone\n // which causes `checkStable()` re-entry.\n // But this fix causes some issues in g3, so this fix will be\n // launched in another PR.\n if (zone._nesting == 0 && !zone.hasPendingMicrotasks && !zone.isStable) {\n try {\n zone._nesting++;\n zone.onMicrotaskEmpty.emit(null);\n } finally {\n zone._nesting--;\n if (!zone.hasPendingMicrotasks) {\n try {\n zone.runOutsideAngular(() => zone.onStable.emit(null));\n } finally {\n zone.isStable = true;\n }\n }\n }\n }\n}\nfunction delayChangeDetectionForEvents(zone) {\n /**\n * We also need to check _nesting here\n * Consider the following case with shouldCoalesceRunChangeDetection = true\n *\n * ngZone.run(() => {});\n * ngZone.run(() => {});\n *\n * We want the two `ngZone.run()` only trigger one change detection\n * when shouldCoalesceRunChangeDetection is true.\n * And because in this case, change detection run in async way(requestAnimationFrame),\n * so we also need to check the _nesting here to prevent multiple\n * change detections.\n */\n if (zone.isCheckStableRunning || zone.callbackScheduled) {\n return;\n }\n zone.callbackScheduled = true;\n function scheduleCheckStable() {\n scheduleCallbackWithRafRace(() => {\n zone.callbackScheduled = false;\n updateMicroTaskStatus(zone);\n zone.isCheckStableRunning = true;\n checkStable(zone);\n zone.isCheckStableRunning = false;\n });\n }\n if (zone.scheduleInRootZone) {\n Zone.root.run(() => {\n scheduleCheckStable();\n });\n } else {\n zone._outer.run(() => {\n scheduleCheckStable();\n });\n }\n updateMicroTaskStatus(zone);\n}\nfunction forkInnerZoneWithAngularBehavior(zone) {\n const delayChangeDetectionForEventsDelegate = () => {\n delayChangeDetectionForEvents(zone);\n };\n const instanceId = ngZoneInstanceId++;\n zone._inner = zone._inner.fork({\n name: 'angular',\n properties: {\n [isAngularZoneProperty]: true,\n [angularZoneInstanceIdProperty]: instanceId,\n [angularZoneInstanceIdProperty + instanceId]: true\n },\n onInvokeTask: (delegate, current, target, task, applyThis, applyArgs) => {\n // Prevent triggering change detection when the flag is detected.\n if (shouldBeIgnoredByZone(applyArgs)) {\n return delegate.invokeTask(target, task, applyThis, applyArgs);\n }\n try {\n onEnter(zone);\n return delegate.invokeTask(target, task, applyThis, applyArgs);\n } finally {\n if (zone.shouldCoalesceEventChangeDetection && task.type === 'eventTask' || zone.shouldCoalesceRunChangeDetection) {\n delayChangeDetectionForEventsDelegate();\n }\n onLeave(zone);\n }\n },\n onInvoke: (delegate, current, target, callback, applyThis, applyArgs, source) => {\n try {\n onEnter(zone);\n return delegate.invoke(target, callback, applyThis, applyArgs, source);\n } finally {\n if (zone.shouldCoalesceRunChangeDetection &&\n // Do not delay change detection when the task is the scheduler's tick.\n // We need to synchronously trigger the stability logic so that the\n // zone-based scheduler can prevent a duplicate ApplicationRef.tick\n // by first checking if the scheduler tick is running. This does seem a bit roundabout,\n // but we _do_ still want to trigger all the correct events when we exit the zone.run\n // (`onMicrotaskEmpty` and `onStable` _should_ emit; developers can have code which\n // relies on these events happening after change detection runs).\n // Note: `zone.callbackScheduled` is already in delayChangeDetectionForEventsDelegate\n // but is added here as well to prevent reads of applyArgs when not necessary\n !zone.callbackScheduled && !isSchedulerTick(applyArgs)) {\n delayChangeDetectionForEventsDelegate();\n }\n onLeave(zone);\n }\n },\n onHasTask: (delegate, current, target, hasTaskState) => {\n delegate.hasTask(target, hasTaskState);\n if (current === target) {\n // We are only interested in hasTask events which originate from our zone\n // (A child hasTask event is not interesting to us)\n if (hasTaskState.change == 'microTask') {\n zone._hasPendingMicrotasks = hasTaskState.microTask;\n updateMicroTaskStatus(zone);\n checkStable(zone);\n } else if (hasTaskState.change == 'macroTask') {\n zone.hasPendingMacrotasks = hasTaskState.macroTask;\n }\n }\n },\n onHandleError: (delegate, current, target, error) => {\n delegate.handleError(target, error);\n zone.runOutsideAngular(() => zone.onError.emit(error));\n return false;\n }\n });\n}\nfunction updateMicroTaskStatus(zone) {\n if (zone._hasPendingMicrotasks || (zone.shouldCoalesceEventChangeDetection || zone.shouldCoalesceRunChangeDetection) && zone.callbackScheduled === true) {\n zone.hasPendingMicrotasks = true;\n } else {\n zone.hasPendingMicrotasks = false;\n }\n}\nfunction onEnter(zone) {\n zone._nesting++;\n if (zone.isStable) {\n zone.isStable = false;\n zone.onUnstable.emit(null);\n }\n}\nfunction onLeave(zone) {\n zone._nesting--;\n checkStable(zone);\n}\n/**\n * Provides a noop implementation of `NgZone` which does nothing. This zone requires explicit calls\n * to framework to perform rendering.\n */\nclass NoopNgZone {\n constructor() {\n this.hasPendingMicrotasks = false;\n this.hasPendingMacrotasks = false;\n this.isStable = true;\n this.onUnstable = new EventEmitter();\n this.onMicrotaskEmpty = new EventEmitter();\n this.onStable = new EventEmitter();\n this.onError = new EventEmitter();\n }\n run(fn, applyThis, applyArgs) {\n return fn.apply(applyThis, applyArgs);\n }\n runGuarded(fn, applyThis, applyArgs) {\n return fn.apply(applyThis, applyArgs);\n }\n runOutsideAngular(fn) {\n return fn();\n }\n runTask(fn, applyThis, applyArgs, name) {\n return fn.apply(applyThis, applyArgs);\n }\n}\nfunction shouldBeIgnoredByZone(applyArgs) {\n return hasApplyArgsData(applyArgs, '__ignore_ng_zone__');\n}\nfunction isSchedulerTick(applyArgs) {\n return hasApplyArgsData(applyArgs, '__scheduler_tick__');\n}\nfunction hasApplyArgsData(applyArgs, key) {\n if (!Array.isArray(applyArgs)) {\n return false;\n }\n // We should only ever get 1 arg passed through to invokeTask.\n // Short circuit here incase that behavior changes.\n if (applyArgs.length !== 1) {\n return false;\n }\n return applyArgs[0]?.data?.[key] === true;\n}\nfunction getNgZone(ngZoneToUse = 'zone.js', options) {\n if (ngZoneToUse === 'noop') {\n return new NoopNgZone();\n }\n if (ngZoneToUse === 'zone.js') {\n return new NgZone(options);\n }\n return ngZoneToUse;\n}\n\n// Public API for Zone\n\n/**\n * Provides a hook for centralized exception handling.\n *\n * The default implementation of `ErrorHandler` prints error messages to the `console`. To\n * intercept error handling, write a custom exception handler that replaces this default as\n * appropriate for your app.\n *\n * @usageNotes\n * ### Example\n *\n * ```\n * class MyErrorHandler implements ErrorHandler {\n * handleError(error) {\n * // do something with the exception\n * }\n * }\n *\n * @NgModule({\n * providers: [{provide: ErrorHandler, useClass: MyErrorHandler}]\n * })\n * class MyModule {}\n * ```\n *\n * @publicApi\n */\nclass ErrorHandler {\n constructor() {\n /**\n * @internal\n */\n this._console = console;\n }\n handleError(error) {\n const originalError = this._findOriginalError(error);\n this._console.error('ERROR', error);\n if (originalError) {\n this._console.error('ORIGINAL ERROR', originalError);\n }\n }\n /** @internal */\n _findOriginalError(error) {\n let e = error && getOriginalError(error);\n while (e && getOriginalError(e)) {\n e = getOriginalError(e);\n }\n return e || null;\n }\n}\n/**\n * `InjectionToken` used to configure how to call the `ErrorHandler`.\n *\n * `NgZone` is provided by default today so the default (and only) implementation for this\n * is calling `ErrorHandler.handleError` outside of the Angular zone.\n */\nconst INTERNAL_APPLICATION_ERROR_HANDLER = /*#__PURE__*/new InjectionToken(typeof ngDevMode === 'undefined' || ngDevMode ? 'internal error handler' : '', {\n providedIn: 'root',\n factory: () => {\n const zone = inject(NgZone);\n const userErrorHandler = inject(ErrorHandler);\n return e => zone.runOutsideAngular(() => userErrorHandler.handleError(e));\n }\n});\n\n/**\n * An `OutputEmitterRef` is created by the `output()` function and can be\n * used to emit values to consumers of your directive or component.\n *\n * Consumers of your directive/component can bind to the output and\n * subscribe to changes via the bound event syntax. For example:\n *\n * ```html\n * \n * ```\n *\n * @developerPreview\n */\nclass OutputEmitterRef {\n constructor() {\n this.destroyed = false;\n this.listeners = null;\n this.errorHandler = inject(ErrorHandler, {\n optional: true\n });\n /** @internal */\n this.destroyRef = inject(DestroyRef);\n // Clean-up all listeners and mark as destroyed upon destroy.\n this.destroyRef.onDestroy(() => {\n this.destroyed = true;\n this.listeners = null;\n });\n }\n subscribe(callback) {\n if (this.destroyed) {\n throw new RuntimeError(953 /* RuntimeErrorCode.OUTPUT_REF_DESTROYED */, ngDevMode && 'Unexpected subscription to destroyed `OutputRef`. ' + 'The owning directive/component is destroyed.');\n }\n (this.listeners ??= []).push(callback);\n return {\n unsubscribe: () => {\n const idx = this.listeners?.indexOf(callback);\n if (idx !== undefined && idx !== -1) {\n this.listeners?.splice(idx, 1);\n }\n }\n };\n }\n /** Emits a new value to the output. */\n emit(value) {\n if (this.destroyed) {\n throw new RuntimeError(953 /* RuntimeErrorCode.OUTPUT_REF_DESTROYED */, ngDevMode && 'Unexpected emit for destroyed `OutputRef`. ' + 'The owning directive/component is destroyed.');\n }\n if (this.listeners === null) {\n return;\n }\n const previousConsumer = setActiveConsumer$1(null);\n try {\n for (const listenerFn of this.listeners) {\n try {\n listenerFn(value);\n } catch (err) {\n this.errorHandler?.handleError(err);\n }\n }\n } finally {\n setActiveConsumer$1(previousConsumer);\n }\n }\n}\n/** Gets the owning `DestroyRef` for the given output. */\nfunction getOutputDestroyRef(ref) {\n return ref.destroyRef;\n}\n\n/**\n * The `output` function allows declaration of Angular outputs in\n * directives and components.\n *\n * You can use outputs to emit values to parent directives and component.\n * Parents can subscribe to changes via:\n *\n * - template event bindings. For example, `(myOutput)=\"doSomething($event)\"`\n * - programmatic subscription by using `OutputRef#subscribe`.\n *\n * @usageNotes\n *\n * To use `output()`, import the function from `@angular/core`.\n *\n * ```ts\n * import {output} from '@angular/core';\n * ```\n *\n * Inside your component, introduce a new class member and initialize\n * it with a call to `output`.\n *\n * ```ts\n * @Directive({\n * ...\n * })\n * export class MyDir {\n * nameChange = output(); // OutputEmitterRef\n * onClick = output(); // OutputEmitterRef\n * }\n * ```\n *\n * You can emit values to consumers of your directive, by using\n * the `emit` method from `OutputEmitterRef`.\n *\n * ```ts\n * updateName(newName: string): void {\n * this.nameChange.emit(newName);\n * }\n * ```\n *\n * @developerPreview\n * @initializerApiFunction {\"showTypesInSignaturePreview\": true}\n */\nfunction output(opts) {\n ngDevMode && assertInInjectionContext(output);\n return new OutputEmitterRef();\n}\nfunction inputFunction(initialValue, opts) {\n ngDevMode && assertInInjectionContext(input);\n return createInputSignal(initialValue, opts);\n}\nfunction inputRequiredFunction(opts) {\n ngDevMode && assertInInjectionContext(input);\n return createInputSignal(REQUIRED_UNSET_VALUE, opts);\n}\n/**\n * The `input` function allows declaration of Angular inputs in directives\n * and components.\n *\n * There are two variants of inputs that can be declared:\n *\n * 1. **Optional inputs** with an initial value.\n * 2. **Required inputs** that consumers need to set.\n *\n * By default, the `input` function will declare optional inputs that\n * always have an initial value. Required inputs can be declared\n * using the `input.required()` function.\n *\n * Inputs are signals. The values of an input are exposed as a `Signal`.\n * The signal always holds the latest value of the input that is bound\n * from the parent.\n *\n * @usageNotes\n * To use signal-based inputs, import `input` from `@angular/core`.\n *\n * ```\n * import {input} from '@angular/core`;\n * ```\n *\n * Inside your component, introduce a new class member and initialize\n * it with a call to `input` or `input.required`.\n *\n * ```ts\n * @Component({\n * ...\n * })\n * export class UserProfileComponent {\n * firstName = input(); // Signal\n * lastName = input.required(); // Signal\n * age = input(0) // Signal\n * }\n * ```\n *\n * Inside your component template, you can display values of the inputs\n * by calling the signal.\n *\n * ```html\n * {{firstName()}}\n * ```\n *\n * @developerPreview\n * @initializerApiFunction\n */\nconst input = /*#__PURE__*/(() => {\n // Note: This may be considered a side-effect, but nothing will depend on\n // this assignment, unless this `input` constant export is accessed. It's a\n // self-contained side effect that is local to the user facing`input` export.\n inputFunction.required = inputRequiredFunction;\n return inputFunction;\n})();\n\n/**\n * Creates an ElementRef from the most recent node.\n *\n * @returns The ElementRef instance to use\n */\nfunction injectElementRef() {\n return createElementRef(getCurrentTNode(), getLView());\n}\n/**\n * Creates an ElementRef given a node.\n *\n * @param tNode The node for which you'd like an ElementRef\n * @param lView The view to which the node belongs\n * @returns The ElementRef instance to use\n */\nfunction createElementRef(tNode, lView) {\n return new ElementRef(getNativeByTNode(tNode, lView));\n}\n/**\n * A wrapper around a native element inside of a View.\n *\n * An `ElementRef` is backed by a render-specific element. In the browser, this is usually a DOM\n * element.\n *\n * @security Permitting direct access to the DOM can make your application more vulnerable to\n * XSS attacks. Carefully review any use of `ElementRef` in your code. For more detail, see the\n * [Security Guide](https://g.co/ng/security).\n *\n * @publicApi\n */\n// Note: We don't expose things like `Injector`, `ViewContainer`, ... here,\n// i.e. users have to ask for what they need. With that, we can build better analysis tools\n// and could do better codegen in the future.\nlet ElementRef = /*#__PURE__*/(() => {\n class ElementRef {\n constructor(nativeElement) {\n this.nativeElement = nativeElement;\n }\n /**\n * @internal\n * @nocollapse\n */\n static {\n this.__NG_ELEMENT_ID__ = injectElementRef;\n }\n }\n return ElementRef;\n})();\n/**\n * Unwraps `ElementRef` and return the `nativeElement`.\n *\n * @param value value to unwrap\n * @returns `nativeElement` if `ElementRef` otherwise returns value as is.\n */\nfunction unwrapElementRef(value) {\n return value instanceof ElementRef ? value.nativeElement : value;\n}\nfunction symbolIterator() {\n // @ts-expect-error accessing a private member\n return this._results[Symbol.iterator]();\n}\n/**\n * An unmodifiable list of items that Angular keeps up to date when the state\n * of the application changes.\n *\n * The type of object that {@link ViewChildren}, {@link ContentChildren}, and {@link QueryList}\n * provide.\n *\n * Implements an iterable interface, therefore it can be used in both ES6\n * javascript `for (var i of items)` loops as well as in Angular templates with\n * `*ngFor=\"let i of myList\"`.\n *\n * Changes can be observed by subscribing to the changes `Observable`.\n *\n * NOTE: In the future this class will implement an `Observable` interface.\n *\n * @usageNotes\n * ### Example\n * ```typescript\n * @Component({...})\n * class Container {\n * @ViewChildren(Item) items:QueryList;\n * }\n * ```\n *\n * @publicApi\n */\nclass QueryList {\n static {\n Symbol.iterator;\n }\n /**\n * Returns `Observable` of `QueryList` notifying the subscriber of changes.\n */\n get changes() {\n return this._changes ??= new EventEmitter();\n }\n /**\n * @param emitDistinctChangesOnly Whether `QueryList.changes` should fire only when actual change\n * has occurred. Or if it should fire when query is recomputed. (recomputing could resolve in\n * the same result)\n */\n constructor(_emitDistinctChangesOnly = false) {\n this._emitDistinctChangesOnly = _emitDistinctChangesOnly;\n this.dirty = true;\n this._onDirty = undefined;\n this._results = [];\n this._changesDetected = false;\n this._changes = undefined;\n this.length = 0;\n this.first = undefined;\n this.last = undefined;\n // This function should be declared on the prototype, but doing so there will cause the class\n // declaration to have side-effects and become not tree-shakable. For this reason we do it in\n // the constructor.\n // [Symbol.iterator](): Iterator { ... }\n const proto = QueryList.prototype;\n if (!proto[Symbol.iterator]) proto[Symbol.iterator] = symbolIterator;\n }\n /**\n * Returns the QueryList entry at `index`.\n */\n get(index) {\n return this._results[index];\n }\n /**\n * See\n * [Array.map](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map)\n */\n map(fn) {\n return this._results.map(fn);\n }\n filter(fn) {\n return this._results.filter(fn);\n }\n /**\n * See\n * [Array.find](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find)\n */\n find(fn) {\n return this._results.find(fn);\n }\n /**\n * See\n * [Array.reduce](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce)\n */\n reduce(fn, init) {\n return this._results.reduce(fn, init);\n }\n /**\n * See\n * [Array.forEach](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach)\n */\n forEach(fn) {\n this._results.forEach(fn);\n }\n /**\n * See\n * [Array.some](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/some)\n */\n some(fn) {\n return this._results.some(fn);\n }\n /**\n * Returns a copy of the internal results list as an Array.\n */\n toArray() {\n return this._results.slice();\n }\n toString() {\n return this._results.toString();\n }\n /**\n * Updates the stored data of the query list, and resets the `dirty` flag to `false`, so that\n * on change detection, it will not notify of changes to the queries, unless a new change\n * occurs.\n *\n * @param resultsTree The query results to store\n * @param identityAccessor Optional function for extracting stable object identity from a value\n * in the array. This function is executed for each element of the query result list while\n * comparing current query list with the new one (provided as a first argument of the `reset`\n * function) to detect if the lists are different. If the function is not provided, elements\n * are compared as is (without any pre-processing).\n */\n reset(resultsTree, identityAccessor) {\n this.dirty = false;\n const newResultFlat = flatten(resultsTree);\n if (this._changesDetected = !arrayEquals(this._results, newResultFlat, identityAccessor)) {\n this._results = newResultFlat;\n this.length = newResultFlat.length;\n this.last = newResultFlat[this.length - 1];\n this.first = newResultFlat[0];\n }\n }\n /**\n * Triggers a change event by emitting on the `changes` {@link EventEmitter}.\n */\n notifyOnChanges() {\n if (this._changes !== undefined && (this._changesDetected || !this._emitDistinctChangesOnly)) this._changes.emit(this);\n }\n /** @internal */\n onDirty(cb) {\n this._onDirty = cb;\n }\n /** internal */\n setDirty() {\n this.dirty = true;\n this._onDirty?.();\n }\n /** internal */\n destroy() {\n if (this._changes !== undefined) {\n this._changes.complete();\n this._changes.unsubscribe();\n }\n }\n}\n\n/**\n * The name of an attribute that can be added to the hydration boundary node\n * (component host node) to disable hydration for the content within that boundary.\n */\nconst SKIP_HYDRATION_ATTR_NAME = 'ngSkipHydration';\n/** Lowercase name of the `ngSkipHydration` attribute used for case-insensitive comparisons. */\nconst SKIP_HYDRATION_ATTR_NAME_LOWER_CASE = 'ngskiphydration';\n/**\n * Helper function to check if a given TNode has the 'ngSkipHydration' attribute.\n */\nfunction hasSkipHydrationAttrOnTNode(tNode) {\n const attrs = tNode.mergedAttrs;\n if (attrs === null) return false;\n // only ever look at the attribute name and skip the values\n for (let i = 0; i < attrs.length; i += 2) {\n const value = attrs[i];\n // This is a marker, which means that the static attributes section is over,\n // so we can exit early.\n if (typeof value === 'number') return false;\n if (typeof value === 'string' && value.toLowerCase() === SKIP_HYDRATION_ATTR_NAME_LOWER_CASE) {\n return true;\n }\n }\n return false;\n}\n/**\n * Helper function to check if a given RElement has the 'ngSkipHydration' attribute.\n */\nfunction hasSkipHydrationAttrOnRElement(rNode) {\n return rNode.hasAttribute(SKIP_HYDRATION_ATTR_NAME);\n}\n/**\n * Checks whether a TNode has a flag to indicate that it's a part of\n * a skip hydration block.\n */\nfunction hasInSkipHydrationBlockFlag(tNode) {\n return (tNode.flags & 128 /* TNodeFlags.inSkipHydrationBlock */) === 128 /* TNodeFlags.inSkipHydrationBlock */;\n}\n/**\n * Helper function that determines if a given node is within a skip hydration block\n * by navigating up the TNode tree to see if any parent nodes have skip hydration\n * attribute.\n */\nfunction isInSkipHydrationBlock(tNode) {\n if (hasInSkipHydrationBlockFlag(tNode)) {\n return true;\n }\n let currentTNode = tNode.parent;\n while (currentTNode) {\n if (hasInSkipHydrationBlockFlag(tNode) || hasSkipHydrationAttrOnTNode(currentTNode)) {\n return true;\n }\n currentTNode = currentTNode.parent;\n }\n return false;\n}\n/**\n * Check if an i18n block is in a skip hydration section by looking at a parent TNode\n * to determine if this TNode is in a skip hydration section or the TNode has\n * the `ngSkipHydration` attribute.\n */\nfunction isI18nInSkipHydrationBlock(parentTNode) {\n return hasInSkipHydrationBlockFlag(parentTNode) || hasSkipHydrationAttrOnTNode(parentTNode) || isInSkipHydrationBlock(parentTNode);\n}\n\n// Keeps track of the currently-active LViews.\nconst TRACKED_LVIEWS = /*#__PURE__*/new Map();\n// Used for generating unique IDs for LViews.\nlet uniqueIdCounter = 0;\n/** Gets a unique ID that can be assigned to an LView. */\nfunction getUniqueLViewId() {\n return uniqueIdCounter++;\n}\n/** Starts tracking an LView. */\nfunction registerLView(lView) {\n ngDevMode && assertNumber(lView[ID], 'LView must have an ID in order to be registered');\n TRACKED_LVIEWS.set(lView[ID], lView);\n}\n/** Gets an LView by its unique ID. */\nfunction getLViewById(id) {\n ngDevMode && assertNumber(id, 'ID used for LView lookup must be a number');\n return TRACKED_LVIEWS.get(id) || null;\n}\n/** Stops tracking an LView. */\nfunction unregisterLView(lView) {\n ngDevMode && assertNumber(lView[ID], 'Cannot stop tracking an LView that does not have an ID');\n TRACKED_LVIEWS.delete(lView[ID]);\n}\n\n/**\n * The internal view context which is specific to a given DOM element, directive or\n * component instance. Each value in here (besides the LView and element node details)\n * can be present, null or undefined. If undefined then it implies the value has not been\n * looked up yet, otherwise, if null, then a lookup was executed and nothing was found.\n *\n * Each value will get filled when the respective value is examined within the getContext\n * function. The component, element and each directive instance will share the same instance\n * of the context.\n */\nclass LContext {\n /** Component's parent view data. */\n get lView() {\n return getLViewById(this.lViewId);\n }\n constructor(\n /**\n * ID of the component's parent view data.\n */\n lViewId,\n /**\n * The index instance of the node.\n */\n nodeIndex,\n /**\n * The instance of the DOM node that is attached to the lNode.\n */\n native) {\n this.lViewId = lViewId;\n this.nodeIndex = nodeIndex;\n this.native = native;\n }\n}\n\n/**\n * Returns the matching `LContext` data for a given DOM node, directive or component instance.\n *\n * This function will examine the provided DOM element, component, or directive instance\\'s\n * monkey-patched property to derive the `LContext` data. Once called then the monkey-patched\n * value will be that of the newly created `LContext`.\n *\n * If the monkey-patched value is the `LView` instance then the context value for that\n * target will be created and the monkey-patch reference will be updated. Therefore when this\n * function is called it may mutate the provided element\\'s, component\\'s or any of the associated\n * directive\\'s monkey-patch values.\n *\n * If the monkey-patch value is not detected then the code will walk up the DOM until an element\n * is found which contains a monkey-patch reference. When that occurs then the provided element\n * will be updated with a new context (which is then returned). If the monkey-patch value is not\n * detected for a component/directive instance then it will throw an error (all components and\n * directives should be automatically monkey-patched by ivy).\n *\n * @param target Component, Directive or DOM Node.\n */\nfunction getLContext(target) {\n let mpValue = readPatchedData(target);\n if (mpValue) {\n // only when it's an array is it considered an LView instance\n // ... otherwise it's an already constructed LContext instance\n if (isLView(mpValue)) {\n const lView = mpValue;\n let nodeIndex;\n let component = undefined;\n let directives = undefined;\n if (isComponentInstance(target)) {\n nodeIndex = findViaComponent(lView, target);\n if (nodeIndex == -1) {\n throw new Error('The provided component was not found in the application');\n }\n component = target;\n } else if (isDirectiveInstance(target)) {\n nodeIndex = findViaDirective(lView, target);\n if (nodeIndex == -1) {\n throw new Error('The provided directive was not found in the application');\n }\n directives = getDirectivesAtNodeIndex(nodeIndex, lView);\n } else {\n nodeIndex = findViaNativeElement(lView, target);\n if (nodeIndex == -1) {\n return null;\n }\n }\n // the goal is not to fill the entire context full of data because the lookups\n // are expensive. Instead, only the target data (the element, component, container, ICU\n // expression or directive details) are filled into the context. If called multiple times\n // with different target values then the missing target data will be filled in.\n const native = unwrapRNode(lView[nodeIndex]);\n const existingCtx = readPatchedData(native);\n const context = existingCtx && !Array.isArray(existingCtx) ? existingCtx : createLContext(lView, nodeIndex, native);\n // only when the component has been discovered then update the monkey-patch\n if (component && context.component === undefined) {\n context.component = component;\n attachPatchData(context.component, context);\n }\n // only when the directives have been discovered then update the monkey-patch\n if (directives && context.directives === undefined) {\n context.directives = directives;\n for (let i = 0; i < directives.length; i++) {\n attachPatchData(directives[i], context);\n }\n }\n attachPatchData(context.native, context);\n mpValue = context;\n }\n } else {\n const rElement = target;\n ngDevMode && assertDomNode(rElement);\n // if the context is not found then we need to traverse upwards up the DOM\n // to find the nearest element that has already been monkey patched with data\n let parent = rElement;\n while (parent = parent.parentNode) {\n const parentContext = readPatchedData(parent);\n if (parentContext) {\n const lView = Array.isArray(parentContext) ? parentContext : parentContext.lView;\n // the edge of the app was also reached here through another means\n // (maybe because the DOM was changed manually).\n if (!lView) {\n return null;\n }\n const index = findViaNativeElement(lView, rElement);\n if (index >= 0) {\n const native = unwrapRNode(lView[index]);\n const context = createLContext(lView, index, native);\n attachPatchData(native, context);\n mpValue = context;\n break;\n }\n }\n }\n }\n return mpValue || null;\n}\n/**\n * Creates an empty instance of a `LContext` context\n */\nfunction createLContext(lView, nodeIndex, native) {\n return new LContext(lView[ID], nodeIndex, native);\n}\n/**\n * Takes a component instance and returns the view for that component.\n *\n * @param componentInstance\n * @returns The component's view\n */\nfunction getComponentViewByInstance(componentInstance) {\n let patchedData = readPatchedData(componentInstance);\n let lView;\n if (isLView(patchedData)) {\n const contextLView = patchedData;\n const nodeIndex = findViaComponent(contextLView, componentInstance);\n lView = getComponentLViewByIndex(nodeIndex, contextLView);\n const context = createLContext(contextLView, nodeIndex, lView[HOST]);\n context.component = componentInstance;\n attachPatchData(componentInstance, context);\n attachPatchData(context.native, context);\n } else {\n const context = patchedData;\n const contextLView = context.lView;\n ngDevMode && assertLView(contextLView);\n lView = getComponentLViewByIndex(context.nodeIndex, contextLView);\n }\n return lView;\n}\n/**\n * This property will be monkey-patched on elements, components and directives.\n */\nconst MONKEY_PATCH_KEY_NAME = '__ngContext__';\nfunction attachLViewId(target, data) {\n target[MONKEY_PATCH_KEY_NAME] = data[ID];\n}\n/**\n * Returns the monkey-patch value data present on the target (which could be\n * a component, directive or a DOM node).\n */\nfunction readLView(target) {\n const data = readPatchedData(target);\n if (isLView(data)) {\n return data;\n }\n return data ? data.lView : null;\n}\n/**\n * Assigns the given data to the given target (which could be a component,\n * directive or DOM node instance) using monkey-patching.\n */\nfunction attachPatchData(target, data) {\n ngDevMode && assertDefined(target, 'Target expected');\n // Only attach the ID of the view in order to avoid memory leaks (see #41047). We only do this\n // for `LView`, because we have control over when an `LView` is created and destroyed, whereas\n // we can't know when to remove an `LContext`.\n if (isLView(data)) {\n target[MONKEY_PATCH_KEY_NAME] = data[ID];\n registerLView(data);\n } else {\n target[MONKEY_PATCH_KEY_NAME] = data;\n }\n}\n/**\n * Returns the monkey-patch value data present on the target (which could be\n * a component, directive or a DOM node).\n */\nfunction readPatchedData(target) {\n ngDevMode && assertDefined(target, 'Target expected');\n const data = target[MONKEY_PATCH_KEY_NAME];\n return typeof data === 'number' ? getLViewById(data) : data || null;\n}\nfunction readPatchedLView(target) {\n const value = readPatchedData(target);\n if (value) {\n return isLView(value) ? value : value.lView;\n }\n return null;\n}\nfunction isComponentInstance(instance) {\n return instance && instance.constructor && instance.constructor.ɵcmp;\n}\nfunction isDirectiveInstance(instance) {\n return instance && instance.constructor && instance.constructor.ɵdir;\n}\n/**\n * Locates the element within the given LView and returns the matching index\n */\nfunction findViaNativeElement(lView, target) {\n const tView = lView[TVIEW];\n for (let i = HEADER_OFFSET; i < tView.bindingStartIndex; i++) {\n if (unwrapRNode(lView[i]) === target) {\n return i;\n }\n }\n return -1;\n}\n/**\n * Locates the next tNode (child, sibling or parent).\n */\nfunction traverseNextElement(tNode) {\n if (tNode.child) {\n return tNode.child;\n } else if (tNode.next) {\n return tNode.next;\n } else {\n // Let's take the following template:
text
\n // After checking the text node, we need to find the next parent that has a \"next\" TNode,\n // in this case the parent `div`, so that we can find the component.\n while (tNode.parent && !tNode.parent.next) {\n tNode = tNode.parent;\n }\n return tNode.parent && tNode.parent.next;\n }\n}\n/**\n * Locates the component within the given LView and returns the matching index\n */\nfunction findViaComponent(lView, componentInstance) {\n const componentIndices = lView[TVIEW].components;\n if (componentIndices) {\n for (let i = 0; i < componentIndices.length; i++) {\n const elementComponentIndex = componentIndices[i];\n const componentView = getComponentLViewByIndex(elementComponentIndex, lView);\n if (componentView[CONTEXT] === componentInstance) {\n return elementComponentIndex;\n }\n }\n } else {\n const rootComponentView = getComponentLViewByIndex(HEADER_OFFSET, lView);\n const rootComponent = rootComponentView[CONTEXT];\n if (rootComponent === componentInstance) {\n // we are dealing with the root element here therefore we know that the\n // element is the very first element after the HEADER data in the lView\n return HEADER_OFFSET;\n }\n }\n return -1;\n}\n/**\n * Locates the directive within the given LView and returns the matching index\n */\nfunction findViaDirective(lView, directiveInstance) {\n // if a directive is monkey patched then it will (by default)\n // have a reference to the LView of the current view. The\n // element bound to the directive being search lives somewhere\n // in the view data. We loop through the nodes and check their\n // list of directives for the instance.\n let tNode = lView[TVIEW].firstChild;\n while (tNode) {\n const directiveIndexStart = tNode.directiveStart;\n const directiveIndexEnd = tNode.directiveEnd;\n for (let i = directiveIndexStart; i < directiveIndexEnd; i++) {\n if (lView[i] === directiveInstance) {\n return tNode.index;\n }\n }\n tNode = traverseNextElement(tNode);\n }\n return -1;\n}\n/**\n * Returns a list of directives applied to a node at a specific index. The list includes\n * directives matched by selector and any host directives, but it excludes components.\n * Use `getComponentAtNodeIndex` to find the component applied to a node.\n *\n * @param nodeIndex The node index\n * @param lView The target view data\n */\nfunction getDirectivesAtNodeIndex(nodeIndex, lView) {\n const tNode = lView[TVIEW].data[nodeIndex];\n if (tNode.directiveStart === 0) return EMPTY_ARRAY;\n const results = [];\n for (let i = tNode.directiveStart; i < tNode.directiveEnd; i++) {\n const directiveInstance = lView[i];\n if (!isComponentInstance(directiveInstance)) {\n results.push(directiveInstance);\n }\n }\n return results;\n}\nfunction getComponentAtNodeIndex(nodeIndex, lView) {\n const tNode = lView[TVIEW].data[nodeIndex];\n const {\n directiveStart,\n componentOffset\n } = tNode;\n return componentOffset > -1 ? lView[directiveStart + componentOffset] : null;\n}\n/**\n * Returns a map of local references (local reference name => element or directive instance) that\n * exist on a given element.\n */\nfunction discoverLocalRefs(lView, nodeIndex) {\n const tNode = lView[TVIEW].data[nodeIndex];\n if (tNode && tNode.localNames) {\n const result = {};\n let localIndex = tNode.index + 1;\n for (let i = 0; i < tNode.localNames.length; i += 2) {\n result[tNode.localNames[i]] = lView[localIndex];\n localIndex++;\n }\n return result;\n }\n return null;\n}\n\n/**\n * Retrieve the root view from any component or `LView` by walking the parent `LView` until\n * reaching the root `LView`.\n *\n * @param componentOrLView any component or `LView`\n */\nfunction getRootView(componentOrLView) {\n ngDevMode && assertDefined(componentOrLView, 'component');\n let lView = isLView(componentOrLView) ? componentOrLView : readPatchedLView(componentOrLView);\n while (lView && !(lView[FLAGS] & 512 /* LViewFlags.IsRoot */)) {\n lView = getLViewParent(lView);\n }\n ngDevMode && assertLView(lView);\n return lView;\n}\n/**\n * Returns the context information associated with the application where the target is situated. It\n * does this by walking the parent views until it gets to the root view, then getting the context\n * off of that.\n *\n * @param viewOrComponent the `LView` or component to get the root context for.\n */\nfunction getRootContext(viewOrComponent) {\n const rootView = getRootView(viewOrComponent);\n ngDevMode && assertDefined(rootView[CONTEXT], 'Root view has no context. Perhaps it is disconnected?');\n return rootView[CONTEXT];\n}\n/**\n * Gets the first `LContainer` in the LView or `null` if none exists.\n */\nfunction getFirstLContainer(lView) {\n return getNearestLContainer(lView[CHILD_HEAD]);\n}\n/**\n * Gets the next `LContainer` that is a sibling of the given container.\n */\nfunction getNextLContainer(container) {\n return getNearestLContainer(container[NEXT]);\n}\nfunction getNearestLContainer(viewOrContainer) {\n while (viewOrContainer !== null && !isLContainer(viewOrContainer)) {\n viewOrContainer = viewOrContainer[NEXT];\n }\n return viewOrContainer;\n}\n\n/**\n * Retrieves the component instance associated with a given DOM element.\n *\n * @usageNotes\n * Given the following DOM structure:\n *\n * ```html\n * \n *
\n * \n *
\n *
\n * ```\n *\n * Calling `getComponent` on `` will return the instance of `ChildComponent`\n * associated with this DOM element.\n *\n * Calling the function on `` will return the `MyApp` instance.\n *\n *\n * @param element DOM element from which the component should be retrieved.\n * @returns Component instance associated with the element or `null` if there\n * is no component associated with it.\n *\n * @publicApi\n */\nfunction getComponent$1(element) {\n ngDevMode && assertDomElement(element);\n const context = getLContext(element);\n if (context === null) return null;\n if (context.component === undefined) {\n const lView = context.lView;\n if (lView === null) {\n return null;\n }\n context.component = getComponentAtNodeIndex(context.nodeIndex, lView);\n }\n return context.component;\n}\n/**\n * If inside an embedded view (e.g. `*ngIf` or `*ngFor`), retrieves the context of the embedded\n * view that the element is part of. Otherwise retrieves the instance of the component whose view\n * owns the element (in this case, the result is the same as calling `getOwningComponent`).\n *\n * @param element Element for which to get the surrounding component instance.\n * @returns Instance of the component that is around the element or null if the element isn't\n * inside any component.\n *\n * @publicApi\n */\nfunction getContext(element) {\n assertDomElement(element);\n const context = getLContext(element);\n const lView = context ? context.lView : null;\n return lView === null ? null : lView[CONTEXT];\n}\n/**\n * Retrieves the component instance whose view contains the DOM element.\n *\n * For example, if `` is used in the template of ``\n * (i.e. a `ViewChild` of ``), calling `getOwningComponent` on ``\n * would return ``.\n *\n * @param elementOrDir DOM element, component or directive instance\n * for which to retrieve the root components.\n * @returns Component instance whose view owns the DOM element or null if the element is not\n * part of a component view.\n *\n * @publicApi\n */\nfunction getOwningComponent(elementOrDir) {\n const context = getLContext(elementOrDir);\n let lView = context ? context.lView : null;\n if (lView === null) return null;\n let parent;\n while (lView[TVIEW].type === 2 /* TViewType.Embedded */ && (parent = getLViewParent(lView))) {\n lView = parent;\n }\n return lView[FLAGS] & 512 /* LViewFlags.IsRoot */ ? null : lView[CONTEXT];\n}\n/**\n * Retrieves all root components associated with a DOM element, directive or component instance.\n * Root components are those which have been bootstrapped by Angular.\n *\n * @param elementOrDir DOM element, component or directive instance\n * for which to retrieve the root components.\n * @returns Root components associated with the target object.\n *\n * @publicApi\n */\nfunction getRootComponents(elementOrDir) {\n const lView = readPatchedLView(elementOrDir);\n return lView !== null ? [getRootContext(lView)] : [];\n}\n/**\n * Retrieves an `Injector` associated with an element, component or directive instance.\n *\n * @param elementOrDir DOM element, component or directive instance for which to\n * retrieve the injector.\n * @returns Injector associated with the element, component or directive instance.\n *\n * @publicApi\n */\nfunction getInjector(elementOrDir) {\n const context = getLContext(elementOrDir);\n const lView = context ? context.lView : null;\n if (lView === null) return Injector.NULL;\n const tNode = lView[TVIEW].data[context.nodeIndex];\n return new NodeInjector(tNode, lView);\n}\n/**\n * Retrieve a set of injection tokens at a given DOM node.\n *\n * @param element Element for which the injection tokens should be retrieved.\n */\nfunction getInjectionTokens(element) {\n const context = getLContext(element);\n const lView = context ? context.lView : null;\n if (lView === null) return [];\n const tView = lView[TVIEW];\n const tNode = tView.data[context.nodeIndex];\n const providerTokens = [];\n const startIndex = tNode.providerIndexes & 1048575 /* TNodeProviderIndexes.ProvidersStartIndexMask */;\n const endIndex = tNode.directiveEnd;\n for (let i = startIndex; i < endIndex; i++) {\n let value = tView.data[i];\n if (isDirectiveDefHack(value)) {\n // The fact that we sometimes store Type and sometimes DirectiveDef in this location is a\n // design flaw. We should always store same type so that we can be monomorphic. The issue\n // is that for Components/Directives we store the def instead the type. The correct behavior\n // is that we should always be storing injectable type in this location.\n value = value.type;\n }\n providerTokens.push(value);\n }\n return providerTokens;\n}\n/**\n * Retrieves directive instances associated with a given DOM node. Does not include\n * component instances.\n *\n * @usageNotes\n * Given the following DOM structure:\n *\n * ```html\n * \n * \n * \n * \n * ```\n *\n * Calling `getDirectives` on `