jekyll-pwa-workbox 0.0.7 → 0.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/jekyll-pwa-workbox.rb +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-background-sync.dev.js +818 -818
- data/lib/vendor/workbox-v5.1.1/workbox-background-sync.dev.js.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-background-sync.prod.js +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-background-sync.prod.js.map +1 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-broadcast-update.dev.js +288 -288
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-broadcast-update.dev.js.map +1 -1
- data/lib/vendor/workbox-v5.1.1/workbox-broadcast-update.prod.js +2 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-broadcast-update.prod.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-cacheable-response.dev.js +191 -191
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-cacheable-response.dev.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-cacheable-response.prod.js +2 -2
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-cacheable-response.prod.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-core.dev.js +1880 -1882
- data/lib/vendor/workbox-v5.1.1/workbox-core.dev.js.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-core.prod.js +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-core.prod.js.map +1 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-expiration.dev.js +649 -651
- data/lib/vendor/workbox-v5.1.1/workbox-expiration.dev.js.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-expiration.prod.js +2 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-expiration.prod.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-navigation-preload.dev.js +102 -102
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-navigation-preload.dev.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-navigation-preload.prod.js +2 -2
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-navigation-preload.prod.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-offline-ga.dev.js +235 -235
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-offline-ga.dev.js.map +1 -1
- data/lib/vendor/workbox-v5.1.1/workbox-offline-ga.prod.js +2 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-offline-ga.prod.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-precaching.dev.js +1222 -1222
- data/lib/vendor/workbox-v5.1.1/workbox-precaching.dev.js.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-precaching.prod.js +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-precaching.prod.js.map +1 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-range-requests.dev.js +262 -262
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-range-requests.dev.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-range-requests.prod.js +2 -2
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-range-requests.prod.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-routing.dev.js +923 -923
- data/lib/vendor/workbox-v5.1.1/workbox-routing.dev.js.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-routing.prod.js +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-routing.prod.js.map +1 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-strategies.dev.js +923 -923
- data/lib/vendor/workbox-v5.1.1/workbox-strategies.dev.js.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-strategies.prod.js +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-strategies.prod.js.map +1 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-streams.dev.js +318 -318
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-streams.dev.js.map +1 -1
- data/lib/vendor/workbox-v5.1.1/workbox-streams.prod.js +2 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-streams.prod.js.map +1 -1
- data/lib/vendor/workbox-v5.1.1/workbox-sw.js +2 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-sw.js.map +1 -1
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-window.dev.es5.mjs +1094 -1075
- data/lib/vendor/workbox-v5.1.1/workbox-window.dev.es5.mjs.map +1 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-window.dev.mjs +943 -943
- data/lib/vendor/workbox-v5.1.1/workbox-window.dev.mjs.map +1 -0
- data/lib/vendor/{workbox-v5.0.0 → workbox-v5.1.1}/workbox-window.dev.umd.js +1105 -1086
- data/lib/vendor/workbox-v5.1.1/workbox-window.dev.umd.js.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-window.prod.es5.mjs +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-window.prod.es5.mjs.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-window.prod.mjs +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-window.prod.mjs.map +1 -0
- data/lib/vendor/workbox-v5.1.1/workbox-window.prod.umd.js +2 -0
- data/lib/vendor/workbox-v5.1.1/workbox-window.prod.umd.js.map +1 -0
- metadata +65 -65
- data/lib/vendor/workbox-v5.0.0/workbox-background-sync.dev.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-background-sync.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-background-sync.prod.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-broadcast-update.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-core.dev.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-core.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-core.prod.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-expiration.dev.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-expiration.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-offline-ga.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-precaching.dev.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-precaching.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-precaching.prod.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-routing.dev.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-routing.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-routing.prod.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-strategies.dev.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-strategies.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-strategies.prod.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-streams.prod.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-sw.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-window.dev.es5.mjs.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-window.dev.mjs.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-window.dev.umd.js.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-window.prod.es5.mjs +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-window.prod.es5.mjs.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-window.prod.mjs +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-window.prod.mjs.map +0 -1
- data/lib/vendor/workbox-v5.0.0/workbox-window.prod.umd.js +0 -2
- data/lib/vendor/workbox-v5.0.0/workbox-window.prod.umd.js.map +0 -1
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"workbox-core.dev.js","sources":["../_version.js","../_private/logger.js","../models/messages/messages.js","../models/messages/messageGenerator.js","../_private/WorkboxError.js","../_private/assert.js","../models/quotaErrorCallbacks.js","../registerQuotaErrorCallback.js","../_private/cacheNames.js","../_private/executeQuotaErrorCallbacks.js","../_private/getFriendlyURL.js","../utils/pluginUtils.js","../_private/cacheWrapper.js","../_private/canConstructReadableStream.js","../_private/canConstructResponseFromBodyStream.js","../_private/dontWaitFor.js","../_private/DBWrapper.js","../_private/Deferred.js","../_private/deleteDatabase.js","../_private/fetchWrapper.js","../_private/timeout.js","../_private/resultingClientExists.js","../_private.js","../cacheNames.js","../copyResponse.js","../clientsClaim.js","../setCacheNameDetails.js","../skipWaiting.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:5.1.1'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst logger = (process.env.NODE_ENV === 'production' ? null : (() => {\n // Don't overwrite this value if it's already set.\n // See https://github.com/GoogleChrome/workbox/pull/2284#issuecomment-560470923\n if (!('__WB_DISABLE_DEV_LOGS' in self)) {\n self.__WB_DISABLE_DEV_LOGS = false;\n }\n let inGroup = false;\n const methodToColorMap = {\n debug: `#7f8c8d`,\n log: `#2ecc71`,\n warn: `#f39c12`,\n error: `#c0392b`,\n groupCollapsed: `#3498db`,\n groupEnd: null,\n };\n const print = function (method, args) {\n if (self.__WB_DISABLE_DEV_LOGS) {\n return;\n }\n if (method === 'groupCollapsed') {\n // Safari doesn't print all console.groupCollapsed() arguments:\n // https://bugs.webkit.org/show_bug.cgi?id=182754\n if (/^((?!chrome|android).)*safari/i.test(navigator.userAgent)) {\n console[method](...args);\n return;\n }\n }\n const styles = [\n `background: ${methodToColorMap[method]}`,\n `border-radius: 0.5em`,\n `color: white`,\n `font-weight: bold`,\n `padding: 2px 0.5em`,\n ];\n // When in a group, the workbox prefix is not displayed.\n const logPrefix = inGroup ? [] : ['%cworkbox', styles.join(';')];\n console[method](...logPrefix, ...args);\n if (method === 'groupCollapsed') {\n inGroup = true;\n }\n if (method === 'groupEnd') {\n inGroup = false;\n }\n };\n const api = {};\n const loggerMethods = Object.keys(methodToColorMap);\n for (const key of loggerMethods) {\n const method = key;\n api[method] = (...args) => {\n print(method, args);\n };\n }\n return api;\n})());\nexport { logger };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../../_version.js';\nexport const messages = {\n 'invalid-value': ({ paramName, validValueDescription, value }) => {\n if (!paramName || !validValueDescription) {\n throw new Error(`Unexpected input to 'invalid-value' error.`);\n }\n return `The '${paramName}' parameter was given a value with an ` +\n `unexpected value. ${validValueDescription} Received a value of ` +\n `${JSON.stringify(value)}.`;\n },\n 'not-in-sw': ({ moduleName }) => {\n if (!moduleName) {\n throw new Error(`Unexpected input to 'not-in-sw' error.`);\n }\n return `The '${moduleName}' must be used in a service worker.`;\n },\n 'not-an-array': ({ moduleName, className, funcName, paramName }) => {\n if (!moduleName || !className || !funcName || !paramName) {\n throw new Error(`Unexpected input to 'not-an-array' error.`);\n }\n return `The parameter '${paramName}' passed into ` +\n `'${moduleName}.${className}.${funcName}()' must be an array.`;\n },\n 'incorrect-type': ({ expectedType, paramName, moduleName, className, funcName }) => {\n if (!expectedType || !paramName || !moduleName || !funcName) {\n throw new Error(`Unexpected input to 'incorrect-type' error.`);\n }\n return `The parameter '${paramName}' passed into ` +\n `'${moduleName}.${className ? (className + '.') : ''}` +\n `${funcName}()' must be of type ${expectedType}.`;\n },\n 'incorrect-class': ({ expectedClass, paramName, moduleName, className, funcName, isReturnValueProblem }) => {\n if (!expectedClass || !moduleName || !funcName) {\n throw new Error(`Unexpected input to 'incorrect-class' error.`);\n }\n if (isReturnValueProblem) {\n return `The return value from ` +\n `'${moduleName}.${className ? (className + '.') : ''}${funcName}()' ` +\n `must be an instance of class ${expectedClass.name}.`;\n }\n return `The parameter '${paramName}' passed into ` +\n `'${moduleName}.${className ? (className + '.') : ''}${funcName}()' ` +\n `must be an instance of class ${expectedClass.name}.`;\n },\n 'missing-a-method': ({ expectedMethod, paramName, moduleName, className, funcName }) => {\n if (!expectedMethod || !paramName || !moduleName || !className\n || !funcName) {\n throw new Error(`Unexpected input to 'missing-a-method' error.`);\n }\n return `${moduleName}.${className}.${funcName}() expected the ` +\n `'${paramName}' parameter to expose a '${expectedMethod}' method.`;\n },\n 'add-to-cache-list-unexpected-type': ({ entry }) => {\n return `An unexpected entry was passed to ` +\n `'workbox-precaching.PrecacheController.addToCacheList()' The entry ` +\n `'${JSON.stringify(entry)}' isn't supported. You must supply an array of ` +\n `strings with one or more characters, objects with a url property or ` +\n `Request objects.`;\n },\n 'add-to-cache-list-conflicting-entries': ({ firstEntry, secondEntry }) => {\n if (!firstEntry || !secondEntry) {\n throw new Error(`Unexpected input to ` +\n `'add-to-cache-list-duplicate-entries' error.`);\n }\n return `Two of the entries passed to ` +\n `'workbox-precaching.PrecacheController.addToCacheList()' had the URL ` +\n `${firstEntry._entryId} but different revision details. Workbox is ` +\n `is unable to cache and version the asset correctly. Please remove one ` +\n `of the entries.`;\n },\n 'plugin-error-request-will-fetch': ({ thrownError }) => {\n if (!thrownError) {\n throw new Error(`Unexpected input to ` +\n `'plugin-error-request-will-fetch', error.`);\n }\n return `An error was thrown by a plugins 'requestWillFetch()' method. ` +\n `The thrown error message was: '${thrownError.message}'.`;\n },\n 'invalid-cache-name': ({ cacheNameId, value }) => {\n if (!cacheNameId) {\n throw new Error(`Expected a 'cacheNameId' for error 'invalid-cache-name'`);\n }\n return `You must provide a name containing at least one character for ` +\n `setCacheDetails({${cacheNameId}: '...'}). Received a value of ` +\n `'${JSON.stringify(value)}'`;\n },\n 'unregister-route-but-not-found-with-method': ({ method }) => {\n if (!method) {\n throw new Error(`Unexpected input to ` +\n `'unregister-route-but-not-found-with-method' error.`);\n }\n return `The route you're trying to unregister was not previously ` +\n `registered for the method type '${method}'.`;\n },\n 'unregister-route-route-not-registered': () => {\n return `The route you're trying to unregister was not previously ` +\n `registered.`;\n },\n 'queue-replay-failed': ({ name }) => {\n return `Replaying the background sync queue '${name}' failed.`;\n },\n 'duplicate-queue-name': ({ name }) => {\n return `The Queue name '${name}' is already being used. ` +\n `All instances of backgroundSync.Queue must be given unique names.`;\n },\n 'expired-test-without-max-age': ({ methodName, paramName }) => {\n return `The '${methodName}()' method can only be used when the ` +\n `'${paramName}' is used in the constructor.`;\n },\n 'unsupported-route-type': ({ moduleName, className, funcName, paramName }) => {\n return `The supplied '${paramName}' parameter was an unsupported type. ` +\n `Please check the docs for ${moduleName}.${className}.${funcName} for ` +\n `valid input types.`;\n },\n 'not-array-of-class': ({ value, expectedClass, moduleName, className, funcName, paramName }) => {\n return `The supplied '${paramName}' parameter must be an array of ` +\n `'${expectedClass}' objects. Received '${JSON.stringify(value)},'. ` +\n `Please check the call to ${moduleName}.${className}.${funcName}() ` +\n `to fix the issue.`;\n },\n 'max-entries-or-age-required': ({ moduleName, className, funcName }) => {\n return `You must define either config.maxEntries or config.maxAgeSeconds` +\n `in ${moduleName}.${className}.${funcName}`;\n },\n 'statuses-or-headers-required': ({ moduleName, className, funcName }) => {\n return `You must define either config.statuses or config.headers` +\n `in ${moduleName}.${className}.${funcName}`;\n },\n 'invalid-string': ({ moduleName, funcName, paramName }) => {\n if (!paramName || !moduleName || !funcName) {\n throw new Error(`Unexpected input to 'invalid-string' error.`);\n }\n return `When using strings, the '${paramName}' parameter must start with ` +\n `'http' (for cross-origin matches) or '/' (for same-origin matches). ` +\n `Please see the docs for ${moduleName}.${funcName}() for ` +\n `more info.`;\n },\n 'channel-name-required': () => {\n return `You must provide a channelName to construct a ` +\n `BroadcastCacheUpdate instance.`;\n },\n 'invalid-responses-are-same-args': () => {\n return `The arguments passed into responsesAreSame() appear to be ` +\n `invalid. Please ensure valid Responses are used.`;\n },\n 'expire-custom-caches-only': () => {\n return `You must provide a 'cacheName' property when using the ` +\n `expiration plugin with a runtime caching strategy.`;\n },\n 'unit-must-be-bytes': ({ normalizedRangeHeader }) => {\n if (!normalizedRangeHeader) {\n throw new Error(`Unexpected input to 'unit-must-be-bytes' error.`);\n }\n return `The 'unit' portion of the Range header must be set to 'bytes'. ` +\n `The Range header provided was \"${normalizedRangeHeader}\"`;\n },\n 'single-range-only': ({ normalizedRangeHeader }) => {\n if (!normalizedRangeHeader) {\n throw new Error(`Unexpected input to 'single-range-only' error.`);\n }\n return `Multiple ranges are not supported. Please use a single start ` +\n `value, and optional end value. The Range header provided was ` +\n `\"${normalizedRangeHeader}\"`;\n },\n 'invalid-range-values': ({ normalizedRangeHeader }) => {\n if (!normalizedRangeHeader) {\n throw new Error(`Unexpected input to 'invalid-range-values' error.`);\n }\n return `The Range header is missing both start and end values. At least ` +\n `one of those values is needed. The Range header provided was ` +\n `\"${normalizedRangeHeader}\"`;\n },\n 'no-range-header': () => {\n return `No Range header was found in the Request provided.`;\n },\n 'range-not-satisfiable': ({ size, start, end }) => {\n return `The start (${start}) and end (${end}) values in the Range are ` +\n `not satisfiable by the cached response, which is ${size} bytes.`;\n },\n 'attempt-to-cache-non-get-request': ({ url, method }) => {\n return `Unable to cache '${url}' because it is a '${method}' request and ` +\n `only 'GET' requests can be cached.`;\n },\n 'cache-put-with-no-response': ({ url }) => {\n return `There was an attempt to cache '${url}' but the response was not ` +\n `defined.`;\n },\n 'no-response': ({ url, error }) => {\n let message = `The strategy could not generate a response for '${url}'.`;\n if (error) {\n message += ` The underlying error is ${error}.`;\n }\n return message;\n },\n 'bad-precaching-response': ({ url, status }) => {\n return `The precaching request for '${url}' failed with an HTTP ` +\n `status of ${status}.`;\n },\n 'non-precached-url': ({ url }) => {\n return `createHandlerBoundToURL('${url}') was called, but that URL is ` +\n `not precached. Please pass in a URL that is precached instead.`;\n },\n 'add-to-cache-list-conflicting-integrities': ({ url }) => {\n return `Two of the entries passed to ` +\n `'workbox-precaching.PrecacheController.addToCacheList()' had the URL ` +\n `${url} with different integrity values. Please remove one of them.`;\n },\n 'missing-precache-entry': ({ cacheName, url }) => {\n return `Unable to find a precached response in ${cacheName} for ${url}.`;\n },\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { messages } from './messages.js';\nimport '../../_version.js';\nconst fallback = (code, ...args) => {\n let msg = code;\n if (args.length > 0) {\n msg += ` :: ${JSON.stringify(args)}`;\n }\n return msg;\n};\nconst generatorFunction = (code, details = {}) => {\n const message = messages[code];\n if (!message) {\n throw new Error(`Unable to find message for code '${code}'.`);\n }\n return message(details);\n};\nexport const messageGenerator = (process.env.NODE_ENV === 'production') ?\n fallback : generatorFunction;\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { messageGenerator } from '../models/messages/messageGenerator.js';\nimport '../_version.js';\n/**\n * Workbox errors should be thrown with this class.\n * This allows use to ensure the type easily in tests,\n * helps developers identify errors from workbox\n * easily and allows use to optimise error\n * messages correctly.\n *\n * @private\n */\nclass WorkboxError extends Error {\n /**\n *\n * @param {string} errorCode The error code that\n * identifies this particular error.\n * @param {Object=} details Any relevant arguments\n * that will help developers identify issues should\n * be added as a key on the context object.\n */\n constructor(errorCode, details) {\n const message = messageGenerator(errorCode, details);\n super(message);\n this.name = errorCode;\n this.details = details;\n }\n}\nexport { WorkboxError };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { WorkboxError } from '../_private/WorkboxError.js';\nimport '../_version.js';\n/*\n * This method returns true if the current context is a service worker.\n */\nconst isSWEnv = (moduleName) => {\n if (!('ServiceWorkerGlobalScope' in self)) {\n throw new WorkboxError('not-in-sw', { moduleName });\n }\n};\n/*\n * This method throws if the supplied value is not an array.\n * The destructed values are required to produce a meaningful error for users.\n * The destructed and restructured object is so it's clear what is\n * needed.\n */\nconst isArray = (value, details) => {\n if (!Array.isArray(value)) {\n throw new WorkboxError('not-an-array', details);\n }\n};\nconst hasMethod = (object, expectedMethod, details) => {\n const type = typeof object[expectedMethod];\n if (type !== 'function') {\n details['expectedMethod'] = expectedMethod;\n throw new WorkboxError('missing-a-method', details);\n }\n};\nconst isType = (object, expectedType, details) => {\n if (typeof object !== expectedType) {\n details['expectedType'] = expectedType;\n throw new WorkboxError('incorrect-type', details);\n }\n};\nconst isInstance = (object, expectedClass, details) => {\n if (!(object instanceof expectedClass)) {\n details['expectedClass'] = expectedClass;\n throw new WorkboxError('incorrect-class', details);\n }\n};\nconst isOneOf = (value, validValues, details) => {\n if (!validValues.includes(value)) {\n details['validValueDescription'] =\n `Valid values are ${JSON.stringify(validValues)}.`;\n throw new WorkboxError('invalid-value', details);\n }\n};\nconst isArrayOfClass = (value, expectedClass, details) => {\n const error = new WorkboxError('not-array-of-class', details);\n if (!Array.isArray(value)) {\n throw error;\n }\n for (const item of value) {\n if (!(item instanceof expectedClass)) {\n throw error;\n }\n }\n};\nconst finalAssertExports = process.env.NODE_ENV === 'production' ? null : {\n hasMethod,\n isArray,\n isInstance,\n isOneOf,\n isSWEnv,\n isType,\n isArrayOfClass,\n};\nexport { finalAssertExports as assert };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n// Callbacks to be executed whenever there's a quota error.\nconst quotaErrorCallbacks = new Set();\nexport { quotaErrorCallbacks };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { logger } from './_private/logger.js';\nimport { assert } from './_private/assert.js';\nimport { quotaErrorCallbacks } from './models/quotaErrorCallbacks.js';\nimport './_version.js';\n/**\n * Adds a function to the set of quotaErrorCallbacks that will be executed if\n * there's a quota error.\n *\n * @param {Function} callback\n * @memberof module:workbox-core\n */\nfunction registerQuotaErrorCallback(callback) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(callback, 'function', {\n moduleName: 'workbox-core',\n funcName: 'register',\n paramName: 'callback',\n });\n }\n quotaErrorCallbacks.add(callback);\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Registered a callback to respond to quota errors.', callback);\n }\n}\nexport { registerQuotaErrorCallback };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst _cacheNameDetails = {\n googleAnalytics: 'googleAnalytics',\n precache: 'precache-v2',\n prefix: 'workbox',\n runtime: 'runtime',\n suffix: typeof registration !== 'undefined' ? registration.scope : '',\n};\nconst _createCacheName = (cacheName) => {\n return [_cacheNameDetails.prefix, cacheName, _cacheNameDetails.suffix]\n .filter((value) => value && value.length > 0)\n .join('-');\n};\nconst eachCacheNameDetail = (fn) => {\n for (const key of Object.keys(_cacheNameDetails)) {\n fn(key);\n }\n};\nexport const cacheNames = {\n updateDetails: (details) => {\n eachCacheNameDetail((key) => {\n if (typeof details[key] === 'string') {\n _cacheNameDetails[key] = details[key];\n }\n });\n },\n getGoogleAnalyticsName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.googleAnalytics);\n },\n getPrecacheName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.precache);\n },\n getPrefix: () => {\n return _cacheNameDetails.prefix;\n },\n getRuntimeName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.runtime);\n },\n getSuffix: () => {\n return _cacheNameDetails.suffix;\n },\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { logger } from '../_private/logger.js';\nimport { quotaErrorCallbacks } from '../models/quotaErrorCallbacks.js';\nimport '../_version.js';\n/**\n * Runs all of the callback functions, one at a time sequentially, in the order\n * in which they were registered.\n *\n * @memberof module:workbox-core\n * @private\n */\nasync function executeQuotaErrorCallbacks() {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`About to run ${quotaErrorCallbacks.size} ` +\n `callbacks to clean up caches.`);\n }\n for (const callback of quotaErrorCallbacks) {\n await callback();\n if (process.env.NODE_ENV !== 'production') {\n logger.log(callback, 'is complete.');\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Finished running callbacks.');\n }\n}\nexport { executeQuotaErrorCallbacks };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst getFriendlyURL = (url) => {\n const urlObj = new URL(String(url), location.href);\n // See https://github.com/GoogleChrome/workbox/issues/2323\n // We want to include everything, except for the origin if it's same-origin.\n return urlObj.href.replace(new RegExp(`^${location.origin}`), '');\n};\nexport { getFriendlyURL };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nexport const pluginUtils = {\n filter: (plugins, callbackName) => {\n return plugins.filter((plugin) => callbackName in plugin);\n },\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from './assert.js';\nimport { executeQuotaErrorCallbacks } from './executeQuotaErrorCallbacks.js';\nimport { getFriendlyURL } from './getFriendlyURL.js';\nimport { logger } from './logger.js';\nimport { pluginUtils } from '../utils/pluginUtils.js';\nimport { WorkboxError } from './WorkboxError.js';\nimport '../_version.js';\n/**\n * Checks the list of plugins for the cacheKeyWillBeUsed callback, and\n * executes any of those callbacks found in sequence. The final `Request` object\n * returned by the last plugin is treated as the cache key for cache reads\n * and/or writes.\n *\n * @param {Object} options\n * @param {Request} options.request\n * @param {string} options.mode\n * @param {Array<Object>} [options.plugins=[]]\n * @return {Promise<Request>}\n *\n * @private\n * @memberof module:workbox-core\n */\nconst _getEffectiveRequest = async ({ request, mode, plugins = [], }) => {\n const cacheKeyWillBeUsedPlugins = pluginUtils.filter(plugins, \"cacheKeyWillBeUsed\" /* CACHE_KEY_WILL_BE_USED */);\n let effectiveRequest = request;\n for (const plugin of cacheKeyWillBeUsedPlugins) {\n effectiveRequest = await plugin[\"cacheKeyWillBeUsed\" /* CACHE_KEY_WILL_BE_USED */].call(plugin, { mode, request: effectiveRequest });\n if (typeof effectiveRequest === 'string') {\n effectiveRequest = new Request(effectiveRequest);\n }\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(effectiveRequest, Request, {\n moduleName: 'Plugin',\n funcName: \"cacheKeyWillBeUsed\" /* CACHE_KEY_WILL_BE_USED */,\n isReturnValueProblem: true,\n });\n }\n }\n return effectiveRequest;\n};\n/**\n * This method will call cacheWillUpdate on the available plugins (or use\n * status === 200) to determine if the Response is safe and valid to cache.\n *\n * @param {Object} options\n * @param {Request} options.request\n * @param {Response} options.response\n * @param {Event} [options.event]\n * @param {Array<Object>} [options.plugins=[]]\n * @return {Promise<Response>}\n *\n * @private\n * @memberof module:workbox-core\n */\nconst _isResponseSafeToCache = async ({ request, response, event, plugins = [], }) => {\n let responseToCache = response;\n let pluginsUsed = false;\n for (const plugin of plugins) {\n if (\"cacheWillUpdate\" /* CACHE_WILL_UPDATE */ in plugin) {\n pluginsUsed = true;\n const pluginMethod = plugin[\"cacheWillUpdate\" /* CACHE_WILL_UPDATE */];\n responseToCache = await pluginMethod.call(plugin, {\n request,\n response: responseToCache,\n event,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (responseToCache) {\n assert.isInstance(responseToCache, Response, {\n moduleName: 'Plugin',\n funcName: \"cacheWillUpdate\" /* CACHE_WILL_UPDATE */,\n isReturnValueProblem: true,\n });\n }\n }\n if (!responseToCache) {\n break;\n }\n }\n }\n if (!pluginsUsed) {\n if (process.env.NODE_ENV !== 'production') {\n if (responseToCache) {\n if (responseToCache.status !== 200) {\n if (responseToCache.status === 0) {\n logger.warn(`The response for '${request.url}' is an opaque ` +\n `response. The caching strategy that you're using will not ` +\n `cache opaque responses by default.`);\n }\n else {\n logger.debug(`The response for '${request.url}' returned ` +\n `a status code of '${response.status}' and won't be cached as a ` +\n `result.`);\n }\n }\n }\n }\n responseToCache = responseToCache && responseToCache.status === 200 ?\n responseToCache : undefined;\n }\n return responseToCache ? responseToCache : null;\n};\n/**\n * This is a wrapper around cache.match().\n *\n * @param {Object} options\n * @param {string} options.cacheName Name of the cache to match against.\n * @param {Request} options.request The Request that will be used to look up\n * cache entries.\n * @param {Event} [options.event] The event that prompted the action.\n * @param {Object} [options.matchOptions] Options passed to cache.match().\n * @param {Array<Object>} [options.plugins=[]] Array of plugins.\n * @return {Response} A cached response if available.\n *\n * @private\n * @memberof module:workbox-core\n */\nconst matchWrapper = async ({ cacheName, request, event, matchOptions, plugins = [], }) => {\n const cache = await self.caches.open(cacheName);\n const effectiveRequest = await _getEffectiveRequest({\n plugins, request, mode: 'read'\n });\n let cachedResponse = await cache.match(effectiveRequest, matchOptions);\n if (process.env.NODE_ENV !== 'production') {\n if (cachedResponse) {\n logger.debug(`Found a cached response in '${cacheName}'.`);\n }\n else {\n logger.debug(`No cached response found in '${cacheName}'.`);\n }\n }\n for (const plugin of plugins) {\n if (\"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */ in plugin) {\n const pluginMethod = plugin[\"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */];\n cachedResponse = await pluginMethod.call(plugin, {\n cacheName,\n event,\n matchOptions,\n cachedResponse,\n request: effectiveRequest,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (cachedResponse) {\n assert.isInstance(cachedResponse, Response, {\n moduleName: 'Plugin',\n funcName: \"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */,\n isReturnValueProblem: true,\n });\n }\n }\n }\n }\n return cachedResponse;\n};\n/**\n * Wrapper around cache.put().\n *\n * Will call `cacheDidUpdate` on plugins if the cache was updated, using\n * `matchOptions` when determining what the old entry is.\n *\n * @param {Object} options\n * @param {string} options.cacheName\n * @param {Request} options.request\n * @param {Response} options.response\n * @param {Event} [options.event]\n * @param {Array<Object>} [options.plugins=[]]\n * @param {Object} [options.matchOptions]\n *\n * @private\n * @memberof module:workbox-core\n */\nconst putWrapper = async ({ cacheName, request, response, event, plugins = [], matchOptions, }) => {\n if (process.env.NODE_ENV !== 'production') {\n if (request.method && request.method !== 'GET') {\n throw new WorkboxError('attempt-to-cache-non-get-request', {\n url: getFriendlyURL(request.url),\n method: request.method,\n });\n }\n }\n const effectiveRequest = await _getEffectiveRequest({\n plugins, request, mode: 'write'\n });\n if (!response) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(`Cannot cache non-existent response for ` +\n `'${getFriendlyURL(effectiveRequest.url)}'.`);\n }\n throw new WorkboxError('cache-put-with-no-response', {\n url: getFriendlyURL(effectiveRequest.url),\n });\n }\n const responseToCache = await _isResponseSafeToCache({\n event,\n plugins,\n response,\n request: effectiveRequest,\n });\n if (!responseToCache) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Response '${getFriendlyURL(effectiveRequest.url)}' will ` +\n `not be cached.`, responseToCache);\n }\n return;\n }\n const cache = await self.caches.open(cacheName);\n const updatePlugins = pluginUtils.filter(plugins, \"cacheDidUpdate\" /* CACHE_DID_UPDATE */);\n const oldResponse = updatePlugins.length > 0 ?\n await matchWrapper({ cacheName, matchOptions, request: effectiveRequest }) :\n null;\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Updating the '${cacheName}' cache with a new Response for ` +\n `${getFriendlyURL(effectiveRequest.url)}.`);\n }\n try {\n await cache.put(effectiveRequest, responseToCache);\n }\n catch (error) {\n // See https://developer.mozilla.org/en-US/docs/Web/API/DOMException#exception-QuotaExceededError\n if (error.name === 'QuotaExceededError') {\n await executeQuotaErrorCallbacks();\n }\n throw error;\n }\n for (const plugin of updatePlugins) {\n await plugin[\"cacheDidUpdate\" /* CACHE_DID_UPDATE */].call(plugin, {\n cacheName,\n event,\n oldResponse,\n newResponse: responseToCache,\n request: effectiveRequest,\n });\n }\n};\nexport const cacheWrapper = {\n put: putWrapper,\n match: matchWrapper,\n};\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nlet supportStatus;\n/**\n * A utility function that determines whether the current browser supports\n * constructing a [`ReadableStream`](https://developer.mozilla.org/en-US/docs/Web/API/ReadableStream/ReadableStream)\n * object.\n *\n * @return {boolean} `true`, if the current browser can successfully\n * construct a `ReadableStream`, `false` otherwise.\n *\n * @private\n */\nfunction canConstructReadableStream() {\n if (supportStatus === undefined) {\n // See https://github.com/GoogleChrome/workbox/issues/1473\n try {\n new ReadableStream({ start() { } });\n supportStatus = true;\n }\n catch (error) {\n supportStatus = false;\n }\n }\n return supportStatus;\n}\nexport { canConstructReadableStream };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nlet supportStatus;\n/**\n * A utility function that determines whether the current browser supports\n * constructing a new `Response` from a `response.body` stream.\n *\n * @return {boolean} `true`, if the current browser can successfully\n * construct a `Response` from a `response.body` stream, `false` otherwise.\n *\n * @private\n */\nfunction canConstructResponseFromBodyStream() {\n if (supportStatus === undefined) {\n const testResponse = new Response('');\n if ('body' in testResponse) {\n try {\n new Response(testResponse.body);\n supportStatus = true;\n }\n catch (error) {\n supportStatus = false;\n }\n }\n supportStatus = false;\n }\n return supportStatus;\n}\nexport { canConstructResponseFromBodyStream };\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A helper function that prevents a promise from being flagged as unused.\n *\n * @private\n **/\nexport function dontWaitFor(promise) {\n // Effective no-op.\n promise.then(() => { });\n}\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A class that wraps common IndexedDB functionality in a promise-based API.\n * It exposes all the underlying power and functionality of IndexedDB, but\n * wraps the most commonly used features in a way that's much simpler to use.\n *\n * @private\n */\nexport class DBWrapper {\n /**\n * @param {string} name\n * @param {number} version\n * @param {Object=} [callback]\n * @param {!Function} [callbacks.onupgradeneeded]\n * @param {!Function} [callbacks.onversionchange] Defaults to\n * DBWrapper.prototype._onversionchange when not specified.\n * @private\n */\n constructor(name, version, { onupgradeneeded, onversionchange, } = {}) {\n this._db = null;\n this._name = name;\n this._version = version;\n this._onupgradeneeded = onupgradeneeded;\n this._onversionchange = onversionchange || (() => this.close());\n }\n /**\n * Returns the IDBDatabase instance (not normally needed).\n * @return {IDBDatabase|undefined}\n *\n * @private\n */\n get db() {\n return this._db;\n }\n /**\n * Opens a connected to an IDBDatabase, invokes any onupgradedneeded\n * callback, and added an onversionchange callback to the database.\n *\n * @return {IDBDatabase}\n * @private\n */\n async open() {\n if (this._db)\n return;\n this._db = await new Promise((resolve, reject) => {\n // This flag is flipped to true if the timeout callback runs prior\n // to the request failing or succeeding. Note: we use a timeout instead\n // of an onblocked handler since there are cases where onblocked will\n // never never run. A timeout better handles all possible scenarios:\n // https://github.com/w3c/IndexedDB/issues/223\n let openRequestTimedOut = false;\n setTimeout(() => {\n openRequestTimedOut = true;\n reject(new Error('The open request was blocked and timed out'));\n }, this.OPEN_TIMEOUT);\n const openRequest = indexedDB.open(this._name, this._version);\n openRequest.onerror = () => reject(openRequest.error);\n openRequest.onupgradeneeded = (evt) => {\n if (openRequestTimedOut) {\n openRequest.transaction.abort();\n openRequest.result.close();\n }\n else if (typeof this._onupgradeneeded === 'function') {\n this._onupgradeneeded(evt);\n }\n };\n openRequest.onsuccess = () => {\n const db = openRequest.result;\n if (openRequestTimedOut) {\n db.close();\n }\n else {\n db.onversionchange = this._onversionchange.bind(this);\n resolve(db);\n }\n };\n });\n return this;\n }\n /**\n * Polyfills the native `getKey()` method. Note, this is overridden at\n * runtime if the browser supports the native method.\n *\n * @param {string} storeName\n * @param {*} query\n * @return {Array}\n * @private\n */\n async getKey(storeName, query) {\n return (await this.getAllKeys(storeName, query, 1))[0];\n }\n /**\n * Polyfills the native `getAll()` method. Note, this is overridden at\n * runtime if the browser supports the native method.\n *\n * @param {string} storeName\n * @param {*} query\n * @param {number} count\n * @return {Array}\n * @private\n */\n async getAll(storeName, query, count) {\n return await this.getAllMatching(storeName, { query, count });\n }\n /**\n * Polyfills the native `getAllKeys()` method. Note, this is overridden at\n * runtime if the browser supports the native method.\n *\n * @param {string} storeName\n * @param {*} query\n * @param {number} count\n * @return {Array}\n * @private\n */\n async getAllKeys(storeName, query, count) {\n const entries = await this.getAllMatching(storeName, { query, count, includeKeys: true });\n return entries.map((entry) => entry.key);\n }\n /**\n * Supports flexible lookup in an object store by specifying an index,\n * query, direction, and count. This method returns an array of objects\n * with the signature .\n *\n * @param {string} storeName\n * @param {Object} [opts]\n * @param {string} [opts.index] The index to use (if specified).\n * @param {*} [opts.query]\n * @param {IDBCursorDirection} [opts.direction]\n * @param {number} [opts.count] The max number of results to return.\n * @param {boolean} [opts.includeKeys] When true, the structure of the\n * returned objects is changed from an array of values to an array of\n * objects in the form {key, primaryKey, value}.\n * @return {Array}\n * @private\n */\n async getAllMatching(storeName, { index, query = null, // IE/Edge errors if query === `undefined`.\n direction = 'next', count, includeKeys = false, } = {}) {\n return await this.transaction([storeName], 'readonly', (txn, done) => {\n const store = txn.objectStore(storeName);\n const target = index ? store.index(index) : store;\n const results = [];\n const request = target.openCursor(query, direction);\n request.onsuccess = () => {\n const cursor = request.result;\n if (cursor) {\n results.push(includeKeys ? cursor : cursor.value);\n if (count && results.length >= count) {\n done(results);\n }\n else {\n cursor.continue();\n }\n }\n else {\n done(results);\n }\n };\n });\n }\n /**\n * Accepts a list of stores, a transaction type, and a callback and\n * performs a transaction. A promise is returned that resolves to whatever\n * value the callback chooses. The callback holds all the transaction logic\n * and is invoked with two arguments:\n * 1. The IDBTransaction object\n * 2. A `done` function, that's used to resolve the promise when\n * when the transaction is done, if passed a value, the promise is\n * resolved to that value.\n *\n * @param {Array<string>} storeNames An array of object store names\n * involved in the transaction.\n * @param {string} type Can be `readonly` or `readwrite`.\n * @param {!Function} callback\n * @return {*} The result of the transaction ran by the callback.\n * @private\n */\n async transaction(storeNames, type, callback) {\n await this.open();\n return await new Promise((resolve, reject) => {\n const txn = this._db.transaction(storeNames, type);\n txn.onabort = () => reject(txn.error);\n txn.oncomplete = () => resolve();\n callback(txn, (value) => resolve(value));\n });\n }\n /**\n * Delegates async to a native IDBObjectStore method.\n *\n * @param {string} method The method name.\n * @param {string} storeName The object store name.\n * @param {string} type Can be `readonly` or `readwrite`.\n * @param {...*} args The list of args to pass to the native method.\n * @return {*} The result of the transaction.\n * @private\n */\n async _call(method, storeName, type, ...args) {\n const callback = (txn, done) => {\n const objStore = txn.objectStore(storeName);\n // TODO(philipwalton): Fix this underlying TS2684 error.\n // @ts-ignore\n const request = objStore[method].apply(objStore, args);\n request.onsuccess = () => done(request.result);\n };\n return await this.transaction([storeName], type, callback);\n }\n /**\n * Closes the connection opened by `DBWrapper.open()`. Generally this method\n * doesn't need to be called since:\n * 1. It's usually better to keep a connection open since opening\n * a new connection is somewhat slow.\n * 2. Connections are automatically closed when the reference is\n * garbage collected.\n * The primary use case for needing to close a connection is when another\n * reference (typically in another tab) needs to upgrade it and would be\n * blocked by the current, open connection.\n *\n * @private\n */\n close() {\n if (this._db) {\n this._db.close();\n this._db = null;\n }\n }\n}\n// Exposed on the prototype to let users modify the default timeout on a\n// per-instance or global basis.\nDBWrapper.prototype.OPEN_TIMEOUT = 2000;\n// Wrap native IDBObjectStore methods according to their mode.\nconst methodsToWrap = {\n readonly: ['get', 'count', 'getKey', 'getAll', 'getAllKeys'],\n readwrite: ['add', 'put', 'clear', 'delete'],\n};\nfor (const [mode, methods] of Object.entries(methodsToWrap)) {\n for (const method of methods) {\n if (method in IDBObjectStore.prototype) {\n // Don't use arrow functions here since we're outside of the class.\n DBWrapper.prototype[method] =\n async function (storeName, ...args) {\n return await this._call(method, storeName, mode, ...args);\n };\n }\n }\n}\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The Deferred class composes Promises in a way that allows for them to be\n * resolved or rejected from outside the constructor. In most cases promises\n * should be used directly, but Deferreds can be necessary when the logic to\n * resolve a promise must be separate.\n *\n * @private\n */\nclass Deferred {\n /**\n * Creates a promise and exposes its resolve and reject functions as methods.\n */\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n}\nexport { Deferred };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Deletes the database.\n * Note: this is exported separately from the DBWrapper module because most\n * usages of IndexedDB in workbox dont need deleting, and this way it can be\n * reused in tests to delete databases without creating DBWrapper instances.\n *\n * @param {string} name The database name.\n * @private\n */\nexport const deleteDatabase = async (name) => {\n await new Promise((resolve, reject) => {\n const request = indexedDB.deleteDatabase(name);\n request.onerror = () => {\n reject(request.error);\n };\n request.onblocked = () => {\n reject(new Error('Delete blocked'));\n };\n request.onsuccess = () => {\n resolve();\n };\n });\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { WorkboxError } from './WorkboxError.js';\nimport { logger } from './logger.js';\nimport { assert } from './assert.js';\nimport { getFriendlyURL } from '../_private/getFriendlyURL.js';\nimport { pluginUtils } from '../utils/pluginUtils.js';\nimport '../_version.js';\n/**\n * Wrapper around the fetch API.\n *\n * Will call requestWillFetch on available plugins.\n *\n * @param {Object} options\n * @param {Request|string} options.request\n * @param {Object} [options.fetchOptions]\n * @param {ExtendableEvent} [options.event]\n * @param {Array<Object>} [options.plugins=[]]\n * @return {Promise<Response>}\n *\n * @private\n * @memberof module:workbox-core\n */\nconst wrappedFetch = async ({ request, fetchOptions, event, plugins = [], }) => {\n if (typeof request === 'string') {\n request = new Request(request);\n }\n // We *should* be able to call `await event.preloadResponse` even if it's\n // undefined, but for some reason, doing so leads to errors in our Node unit\n // tests. To work around that, explicitly check preloadResponse's value first.\n if (event instanceof FetchEvent && event.preloadResponse) {\n const possiblePreloadResponse = await event.preloadResponse;\n if (possiblePreloadResponse) {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`Using a preloaded navigation response for ` +\n `'${getFriendlyURL(request.url)}'`);\n }\n return possiblePreloadResponse;\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(request, Request, {\n paramName: 'request',\n expectedClass: Request,\n moduleName: 'workbox-core',\n className: 'fetchWrapper',\n funcName: 'wrappedFetch',\n });\n }\n const failedFetchPlugins = pluginUtils.filter(plugins, \"fetchDidFail\" /* FETCH_DID_FAIL */);\n // If there is a fetchDidFail plugin, we need to save a clone of the\n // original request before it's either modified by a requestWillFetch\n // plugin or before the original request's body is consumed via fetch().\n const originalRequest = failedFetchPlugins.length > 0 ?\n request.clone() : null;\n try {\n for (const plugin of plugins) {\n if (\"requestWillFetch\" /* REQUEST_WILL_FETCH */ in plugin) {\n const pluginMethod = plugin[\"requestWillFetch\" /* REQUEST_WILL_FETCH */];\n const requestClone = request.clone();\n request = await pluginMethod.call(plugin, {\n request: requestClone,\n event,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (request) {\n assert.isInstance(request, Request, {\n moduleName: 'Plugin',\n funcName: \"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */,\n isReturnValueProblem: true,\n });\n }\n }\n }\n }\n }\n catch (err) {\n throw new WorkboxError('plugin-error-request-will-fetch', {\n thrownError: err,\n });\n }\n // The request can be altered by plugins with `requestWillFetch` making\n // the original request (Most likely from a `fetch` event) to be different\n // to the Request we make. Pass both to `fetchDidFail` to aid debugging.\n const pluginFilteredRequest = request.clone();\n try {\n let fetchResponse;\n // See https://github.com/GoogleChrome/workbox/issues/1796\n if (request.mode === 'navigate') {\n fetchResponse = await fetch(request);\n }\n else {\n fetchResponse = await fetch(request, fetchOptions);\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Network request for ` +\n `'${getFriendlyURL(request.url)}' returned a response with ` +\n `status '${fetchResponse.status}'.`);\n }\n for (const plugin of plugins) {\n if (\"fetchDidSucceed\" /* FETCH_DID_SUCCEED */ in plugin) {\n fetchResponse = await plugin[\"fetchDidSucceed\" /* FETCH_DID_SUCCEED */]\n .call(plugin, {\n event,\n request: pluginFilteredRequest,\n response: fetchResponse,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (fetchResponse) {\n assert.isInstance(fetchResponse, Response, {\n moduleName: 'Plugin',\n funcName: \"fetchDidSucceed\" /* FETCH_DID_SUCCEED */,\n isReturnValueProblem: true,\n });\n }\n }\n }\n }\n return fetchResponse;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(`Network request for ` +\n `'${getFriendlyURL(request.url)}' threw an error.`, error);\n }\n for (const plugin of failedFetchPlugins) {\n await plugin[\"fetchDidFail\" /* FETCH_DID_FAIL */].call(plugin, {\n error,\n event,\n originalRequest: originalRequest.clone(),\n request: pluginFilteredRequest.clone(),\n });\n }\n throw error;\n }\n};\nconst fetchWrapper = {\n fetch: wrappedFetch,\n};\nexport { fetchWrapper };\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Returns a promise that resolves and the passed number of milliseconds.\n * This utility is an async/await-friendly version of `setTimeout`.\n *\n * @param {number} ms\n * @return {Promise}\n * @private\n */\nexport function timeout(ms) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { timeout } from './timeout.js';\nimport '../_version.js';\nconst MAX_RETRY_TIME = 2000;\n/**\n * Returns a promise that resolves to a window client matching the passed\n * `resultingClientId`. For browsers that don't support `resultingClientId`\n * or if waiting for the resulting client to apper takes too long, resolve to\n * `undefined`.\n *\n * @param {string} [resultingClientId]\n * @return {Promise<Client|undefined>}\n * @private\n */\nexport async function resultingClientExists(resultingClientId) {\n if (!resultingClientId) {\n return;\n }\n let existingWindows = await self.clients.matchAll({ type: 'window' });\n const existingWindowIds = new Set(existingWindows.map((w) => w.id));\n let resultingWindow;\n const startTime = performance.now();\n // Only wait up to `MAX_RETRY_TIME` to find a matching client.\n while (performance.now() - startTime < MAX_RETRY_TIME) {\n existingWindows = await self.clients.matchAll({ type: 'window' });\n resultingWindow = existingWindows.find((w) => {\n if (resultingClientId) {\n // If we have a `resultingClientId`, we can match on that.\n return w.id === resultingClientId;\n }\n else {\n // Otherwise match on finding a window not in `existingWindowIds`.\n return !existingWindowIds.has(w.id);\n }\n });\n if (resultingWindow) {\n break;\n }\n // Sleep for 100ms and retry.\n await timeout(100);\n }\n return resultingWindow;\n}\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\n// We either expose defaults or we expose every named export.\nimport { assert } from './_private/assert.js';\nimport { cacheNames } from './_private/cacheNames.js';\nimport { cacheWrapper } from './_private/cacheWrapper.js';\nimport { canConstructReadableStream } from './_private/canConstructReadableStream.js';\nimport { canConstructResponseFromBodyStream } from './_private/canConstructResponseFromBodyStream.js';\nimport { dontWaitFor } from './_private/dontWaitFor.js';\nimport { DBWrapper } from './_private/DBWrapper.js';\nimport { Deferred } from './_private/Deferred.js';\nimport { deleteDatabase } from './_private/deleteDatabase.js';\nimport { executeQuotaErrorCallbacks } from './_private/executeQuotaErrorCallbacks.js';\nimport { fetchWrapper } from './_private/fetchWrapper.js';\nimport { getFriendlyURL } from './_private/getFriendlyURL.js';\nimport { logger } from './_private/logger.js';\nimport { resultingClientExists } from './_private/resultingClientExists.js';\nimport { timeout } from './_private/timeout.js';\nimport { WorkboxError } from './_private/WorkboxError.js';\nimport './_version.js';\nexport { assert, cacheNames, cacheWrapper, canConstructReadableStream, canConstructResponseFromBodyStream, dontWaitFor, DBWrapper, Deferred, deleteDatabase, executeQuotaErrorCallbacks, fetchWrapper, getFriendlyURL, logger, resultingClientExists, timeout, WorkboxError, };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { cacheNames as _cacheNames } from './_private/cacheNames.js';\nimport './_version.js';\n/**\n * Get the current cache names and prefix/suffix used by Workbox.\n *\n * `cacheNames.precache` is used for precached assets,\n * `cacheNames.googleAnalytics` is used by `workbox-google-analytics` to\n * store `analytics.js`, and `cacheNames.runtime` is used for everything else.\n *\n * `cacheNames.prefix` can be used to retrieve just the current prefix value.\n * `cacheNames.suffix` can be used to retrieve just the current suffix value.\n *\n * @return {Object} An object with `precache`, `runtime`, `prefix`, and\n * `googleAnalytics` properties.\n *\n * @memberof module:workbox-core\n */\nconst cacheNames = {\n get googleAnalytics() {\n return _cacheNames.getGoogleAnalyticsName();\n },\n get precache() {\n return _cacheNames.getPrecacheName();\n },\n get prefix() {\n return _cacheNames.getPrefix();\n },\n get runtime() {\n return _cacheNames.getRuntimeName();\n },\n get suffix() {\n return _cacheNames.getSuffix();\n },\n};\nexport { cacheNames };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { canConstructResponseFromBodyStream } from './_private/canConstructResponseFromBodyStream.js';\nimport './_version.js';\n/**\n * Allows developers to copy a response and modify its `headers`, `status`,\n * or `statusText` values (the values settable via a\n * [`ResponseInit`]{@link https://developer.mozilla.org/en-US/docs/Web/API/Response/Response#Syntax}\n * object in the constructor).\n * To modify these values, pass a function as the second argument. That\n * function will be invoked with a single object with the response properties\n * `{headers, status, statusText}`. The return value of this function will\n * be used as the `ResponseInit` for the new `Response`. To change the values\n * either modify the passed parameter(s) and return it, or return a totally\n * new object.\n *\n * @param {Response} response\n * @param {Function} modifier\n * @memberof module:workbox-core\n */\nasync function copyResponse(response, modifier) {\n const clonedResponse = response.clone();\n // Create a fresh `ResponseInit` object by cloning the headers.\n const responseInit = {\n headers: new Headers(clonedResponse.headers),\n status: clonedResponse.status,\n statusText: clonedResponse.statusText,\n };\n // Apply any user modifications.\n const modifiedResponseInit = modifier ? modifier(responseInit) : responseInit;\n // Create the new response from the body stream and `ResponseInit`\n // modifications. Note: not all browsers support the Response.body stream,\n // so fall back to reading the entire body into memory as a blob.\n const body = canConstructResponseFromBodyStream() ?\n clonedResponse.body : await clonedResponse.blob();\n return new Response(body, modifiedResponseInit);\n}\nexport { copyResponse };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Claim any currently available clients once the service worker\n * becomes active. This is normally used in conjunction with `skipWaiting()`.\n *\n * @memberof module:workbox-core\n */\nfunction clientsClaim() {\n self.addEventListener('activate', () => self.clients.claim());\n}\nexport { clientsClaim };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from './_private/assert.js';\nimport { cacheNames } from './_private/cacheNames.js';\nimport { WorkboxError } from './_private/WorkboxError.js';\nimport './_version.js';\n/**\n * Modifies the default cache names used by the Workbox packages.\n * Cache names are generated as `<prefix>-<Cache Name>-<suffix>`.\n *\n * @param {Object} details\n * @param {Object} [details.prefix] The string to add to the beginning of\n * the precache and runtime cache names.\n * @param {Object} [details.suffix] The string to add to the end of\n * the precache and runtime cache names.\n * @param {Object} [details.precache] The cache name to use for precache\n * caching.\n * @param {Object} [details.runtime] The cache name to use for runtime caching.\n * @param {Object} [details.googleAnalytics] The cache name to use for\n * `workbox-google-analytics` caching.\n *\n * @memberof module:workbox-core\n */\nfunction setCacheNameDetails(details) {\n if (process.env.NODE_ENV !== 'production') {\n Object.keys(details).forEach((key) => {\n assert.isType(details[key], 'string', {\n moduleName: 'workbox-core',\n funcName: 'setCacheNameDetails',\n paramName: `details.${key}`,\n });\n });\n if ('precache' in details && details['precache'].length === 0) {\n throw new WorkboxError('invalid-cache-name', {\n cacheNameId: 'precache',\n value: details['precache'],\n });\n }\n if ('runtime' in details && details['runtime'].length === 0) {\n throw new WorkboxError('invalid-cache-name', {\n cacheNameId: 'runtime',\n value: details['runtime'],\n });\n }\n if ('googleAnalytics' in details && details['googleAnalytics'].length === 0) {\n throw new WorkboxError('invalid-cache-name', {\n cacheNameId: 'googleAnalytics',\n value: details['googleAnalytics'],\n });\n }\n }\n cacheNames.updateDetails(details);\n}\nexport { setCacheNameDetails };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Force a service worker to activate immediately, instead of\n * [waiting](https://developers.google.com/web/fundamentals/primers/service-workers/lifecycle#waiting)\n * for existing clients to close.\n *\n * @memberof module:workbox-core\n */\nfunction skipWaiting() {\n // We need to explicitly call `self.skipWaiting()` here because we're\n // shadowing `skipWaiting` with this local function.\n self.addEventListener('install', () => self.skipWaiting());\n}\nexport { skipWaiting };\n"],"names":["self","_","e","logger","process","__WB_DISABLE_DEV_LOGS","inGroup","methodToColorMap","debug","log","warn","error","groupCollapsed","groupEnd","print","method","args","test","navigator","userAgent","console","styles","logPrefix","join","api","loggerMethods","Object","keys","key","messages","paramName","validValueDescription","value","Error","JSON","stringify","moduleName","className","funcName","expectedType","expectedClass","isReturnValueProblem","name","expectedMethod","entry","firstEntry","secondEntry","_entryId","thrownError","message","cacheNameId","methodName","normalizedRangeHeader","size","start","end","url","status","cacheName","generatorFunction","code","details","messageGenerator","WorkboxError","constructor","errorCode","isSWEnv","isArray","Array","hasMethod","object","type","isType","isInstance","isOneOf","validValues","includes","isArrayOfClass","item","finalAssertExports","quotaErrorCallbacks","Set","registerQuotaErrorCallback","callback","assert","add","_cacheNameDetails","googleAnalytics","precache","prefix","runtime","suffix","registration","scope","_createCacheName","filter","length","eachCacheNameDetail","fn","cacheNames","updateDetails","getGoogleAnalyticsName","userCacheName","getPrecacheName","getPrefix","getRuntimeName","getSuffix","executeQuotaErrorCallbacks","getFriendlyURL","urlObj","URL","String","location","href","replace","RegExp","origin","pluginUtils","plugins","callbackName","plugin","_getEffectiveRequest","request","mode","cacheKeyWillBeUsedPlugins","effectiveRequest","call","Request","_isResponseSafeToCache","response","event","responseToCache","pluginsUsed","pluginMethod","Response","undefined","matchWrapper","matchOptions","cache","caches","open","cachedResponse","match","putWrapper","updatePlugins","oldResponse","put","newResponse","cacheWrapper","supportStatus","canConstructReadableStream","ReadableStream","canConstructResponseFromBodyStream","testResponse","body","dontWaitFor","promise","then","DBWrapper","version","onupgradeneeded","onversionchange","_db","_name","_version","_onupgradeneeded","_onversionchange","close","db","Promise","resolve","reject","openRequestTimedOut","setTimeout","OPEN_TIMEOUT","openRequest","indexedDB","onerror","evt","transaction","abort","result","onsuccess","bind","getKey","storeName","query","getAllKeys","getAll","count","getAllMatching","entries","includeKeys","map","index","direction","txn","done","store","objectStore","target","results","openCursor","cursor","push","continue","storeNames","onabort","oncomplete","_call","objStore","apply","prototype","methodsToWrap","readonly","readwrite","methods","IDBObjectStore","Deferred","deleteDatabase","onblocked","wrappedFetch","fetchOptions","FetchEvent","preloadResponse","possiblePreloadResponse","failedFetchPlugins","originalRequest","clone","requestClone","err","pluginFilteredRequest","fetchResponse","fetch","fetchWrapper","timeout","ms","MAX_RETRY_TIME","resultingClientExists","resultingClientId","existingWindows","clients","matchAll","existingWindowIds","w","id","resultingWindow","startTime","performance","now","find","has","_cacheNames","copyResponse","modifier","clonedResponse","responseInit","headers","Headers","statusText","modifiedResponseInit","blob","clientsClaim","addEventListener","claim","setCacheNameDetails","forEach","skipWaiting"],"mappings":"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"}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
this.workbox=this.workbox||{},this.workbox.core=function(e){"use strict";try{self["workbox:core:5.1.1"]&&_()}catch(e){}const t=(e,...t)=>{let n=e;return t.length>0&&(n+=` :: ${JSON.stringify(t)}`),n};class n extends Error{constructor(e,n){super(t(e,n)),this.name=e,this.details=n}}const s=new Set;const r={googleAnalytics:"googleAnalytics",precache:"precache-v2",prefix:"workbox",runtime:"runtime",suffix:"undefined"!=typeof registration?registration.scope:""},i=e=>[r.prefix,e,r.suffix].filter(e=>e&&e.length>0).join("-"),o={updateDetails:e=>{(e=>{for(const t of Object.keys(r))e(t)})(t=>{"string"==typeof e[t]&&(r[t]=e[t])})},getGoogleAnalyticsName:e=>e||i(r.googleAnalytics),getPrecacheName:e=>e||i(r.precache),getPrefix:()=>r.prefix,getRuntimeName:e=>e||i(r.runtime),getSuffix:()=>r.suffix};async function a(){for(const e of s)await e()}const c=e=>new URL(String(e),location.href).href.replace(new RegExp(`^${location.origin}`),""),u=(e,t)=>e.filter(e=>t in e),l=async({request:e,mode:t,plugins:n=[]})=>{const s=u(n,"cacheKeyWillBeUsed");let r=e;for(const e of s)r=await e.cacheKeyWillBeUsed.call(e,{mode:t,request:r}),"string"==typeof r&&(r=new Request(r));return r},f=async({cacheName:e,request:t,event:n,matchOptions:s,plugins:r=[]})=>{const i=await self.caches.open(e),o=await l({plugins:r,request:t,mode:"read"});let a=await i.match(o,s);for(const t of r)if("cachedResponseWillBeUsed"in t){const r=t.cachedResponseWillBeUsed;a=await r.call(t,{cacheName:e,event:n,matchOptions:s,cachedResponse:a,request:o})}return a},h={put:async({cacheName:e,request:t,response:s,event:r,plugins:i=[],matchOptions:o})=>{const h=await l({plugins:i,request:t,mode:"write"});if(!s)throw new n("cache-put-with-no-response",{url:c(h.url)});const w=await(async({request:e,response:t,event:n,plugins:s=[]})=>{let r=t,i=!1;for(const t of s)if("cacheWillUpdate"in t){i=!0;const s=t.cacheWillUpdate;if(r=await s.call(t,{request:e,response:r,event:n}),!r)break}return i||(r=r&&200===r.status?r:void 0),r||null})({event:r,plugins:i,response:s,request:h});if(!w)return;const p=await self.caches.open(e),d=u(i,"cacheDidUpdate"),g=d.length>0?await f({cacheName:e,matchOptions:o,request:h}):null;try{await p.put(h,w)}catch(e){throw"QuotaExceededError"===e.name&&await a(),e}for(const t of d)await t.cacheDidUpdate.call(t,{cacheName:e,event:r,oldResponse:g,newResponse:w,request:h})},match:f};let w,p;function d(){if(void 0===p){const e=new Response("");if("body"in e)try{new Response(e.body),p=!0}catch(e){p=!1}p=!1}return p}class g{constructor(e,t,{onupgradeneeded:n,onversionchange:s}={}){this.t=null,this.s=e,this.i=t,this.o=n,this.u=s||(()=>this.close())}get db(){return this.t}async open(){if(!this.t)return this.t=await new Promise((e,t)=>{let n=!1;setTimeout(()=>{n=!0,t(new Error("The open request was blocked and timed out"))},this.OPEN_TIMEOUT);const s=indexedDB.open(this.s,this.i);s.onerror=()=>t(s.error),s.onupgradeneeded=e=>{n?(s.transaction.abort(),s.result.close()):"function"==typeof this.o&&this.o(e)},s.onsuccess=()=>{const t=s.result;n?t.close():(t.onversionchange=this.u.bind(this),e(t))}}),this}async getKey(e,t){return(await this.getAllKeys(e,t,1))[0]}async getAll(e,t,n){return await this.getAllMatching(e,{query:t,count:n})}async getAllKeys(e,t,n){return(await this.getAllMatching(e,{query:t,count:n,includeKeys:!0})).map(e=>e.key)}async getAllMatching(e,{index:t,query:n=null,direction:s="next",count:r,includeKeys:i=!1}={}){return await this.transaction([e],"readonly",(o,a)=>{const c=o.objectStore(e),u=t?c.index(t):c,l=[],f=u.openCursor(n,s);f.onsuccess=()=>{const e=f.result;e?(l.push(i?e:e.value),r&&l.length>=r?a(l):e.continue()):a(l)}})}async transaction(e,t,n){return await this.open(),await new Promise((s,r)=>{const i=this.t.transaction(e,t);i.onabort=()=>r(i.error),i.oncomplete=()=>s(),n(i,e=>s(e))})}async l(e,t,n,...s){return await this.transaction([t],n,(n,r)=>{const i=n.objectStore(t),o=i[e].apply(i,s);o.onsuccess=()=>r(o.result)})}close(){this.t&&(this.t.close(),this.t=null)}}g.prototype.OPEN_TIMEOUT=2e3;const y={readonly:["get","count","getKey","getAll","getAllKeys"],readwrite:["add","put","clear","delete"]};for(const[e,t]of Object.entries(y))for(const n of t)n in IDBObjectStore.prototype&&(g.prototype[n]=async function(t,...s){return await this.l(n,t,e,...s)});const m={fetch:async({request:e,fetchOptions:t,event:s,plugins:r=[]})=>{if("string"==typeof e&&(e=new Request(e)),s instanceof FetchEvent&&s.preloadResponse){const e=await s.preloadResponse;if(e)return e}const i=u(r,"fetchDidFail"),o=i.length>0?e.clone():null;try{for(const t of r)if("requestWillFetch"in t){const n=t.requestWillFetch,r=e.clone();e=await n.call(t,{request:r,event:s})}}catch(e){throw new n("plugin-error-request-will-fetch",{thrownError:e})}const a=e.clone();try{let n;n="navigate"===e.mode?await fetch(e):await fetch(e,t);for(const e of r)"fetchDidSucceed"in e&&(n=await e.fetchDidSucceed.call(e,{event:s,request:a,response:n}));return n}catch(e){for(const t of i)await t.fetchDidFail.call(t,{error:e,event:s,originalRequest:o.clone(),request:a.clone()});throw e}}};function q(e){return new Promise(t=>setTimeout(t,e))}var v=Object.freeze({__proto__:null,assert:null,cacheNames:o,cacheWrapper:h,canConstructReadableStream:function(){if(void 0===w)try{new ReadableStream({start(){}}),w=!0}catch(e){w=!1}return w},canConstructResponseFromBodyStream:d,dontWaitFor:function(e){e.then(()=>{})},DBWrapper:g,Deferred:class{constructor(){this.promise=new Promise((e,t)=>{this.resolve=e,this.reject=t})}},deleteDatabase:async e=>{await new Promise((t,n)=>{const s=indexedDB.deleteDatabase(e);s.onerror=()=>{n(s.error)},s.onblocked=()=>{n(new Error("Delete blocked"))},s.onsuccess=()=>{t()}})},executeQuotaErrorCallbacks:a,fetchWrapper:m,getFriendlyURL:c,logger:null,resultingClientExists:async function(e){if(!e)return;let t=await self.clients.matchAll({type:"window"});const n=new Set(t.map(e=>e.id));let s;const r=performance.now();for(;performance.now()-r<2e3&&(t=await self.clients.matchAll({type:"window"}),s=t.find(t=>e?t.id===e:!n.has(t.id)),!s);)await q(100);return s},timeout:q,WorkboxError:n});const x={get googleAnalytics(){return o.getGoogleAnalyticsName()},get precache(){return o.getPrecacheName()},get prefix(){return o.getPrefix()},get runtime(){return o.getRuntimeName()},get suffix(){return o.getSuffix()}};return e._private=v,e.cacheNames=x,e.clientsClaim=function(){self.addEventListener("activate",()=>self.clients.claim())},e.copyResponse=async function(e,t){const n=e.clone(),s={headers:new Headers(n.headers),status:n.status,statusText:n.statusText},r=t?t(s):s,i=d()?n.body:await n.blob();return new Response(i,r)},e.registerQuotaErrorCallback=function(e){s.add(e)},e.setCacheNameDetails=function(e){o.updateDetails(e)},e.skipWaiting=function(){self.addEventListener("install",()=>self.skipWaiting())},e}({});
|
2
|
+
//# sourceMappingURL=workbox-core.prod.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"workbox-core.prod.js","sources":["../_version.js","../_private/logger.js","../models/messages/messageGenerator.js","../_private/WorkboxError.js","../_private/assert.js","../models/quotaErrorCallbacks.js","../_private/cacheNames.js","../_private/executeQuotaErrorCallbacks.js","../_private/getFriendlyURL.js","../utils/pluginUtils.js","../_private/cacheWrapper.js","../_private/canConstructReadableStream.js","../_private/canConstructResponseFromBodyStream.js","../_private/DBWrapper.js","../_private/deleteDatabase.js","../_private/fetchWrapper.js","../_private/timeout.js","../_private/dontWaitFor.js","../_private/Deferred.js","../_private/resultingClientExists.js","../cacheNames.js","../clientsClaim.js","../copyResponse.js","../registerQuotaErrorCallback.js","../setCacheNameDetails.js","../skipWaiting.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:5.1.1'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst logger = (process.env.NODE_ENV === 'production' ? null : (() => {\n // Don't overwrite this value if it's already set.\n // See https://github.com/GoogleChrome/workbox/pull/2284#issuecomment-560470923\n if (!('__WB_DISABLE_DEV_LOGS' in self)) {\n self.__WB_DISABLE_DEV_LOGS = false;\n }\n let inGroup = false;\n const methodToColorMap = {\n debug: `#7f8c8d`,\n log: `#2ecc71`,\n warn: `#f39c12`,\n error: `#c0392b`,\n groupCollapsed: `#3498db`,\n groupEnd: null,\n };\n const print = function (method, args) {\n if (self.__WB_DISABLE_DEV_LOGS) {\n return;\n }\n if (method === 'groupCollapsed') {\n // Safari doesn't print all console.groupCollapsed() arguments:\n // https://bugs.webkit.org/show_bug.cgi?id=182754\n if (/^((?!chrome|android).)*safari/i.test(navigator.userAgent)) {\n console[method](...args);\n return;\n }\n }\n const styles = [\n `background: ${methodToColorMap[method]}`,\n `border-radius: 0.5em`,\n `color: white`,\n `font-weight: bold`,\n `padding: 2px 0.5em`,\n ];\n // When in a group, the workbox prefix is not displayed.\n const logPrefix = inGroup ? [] : ['%cworkbox', styles.join(';')];\n console[method](...logPrefix, ...args);\n if (method === 'groupCollapsed') {\n inGroup = true;\n }\n if (method === 'groupEnd') {\n inGroup = false;\n }\n };\n const api = {};\n const loggerMethods = Object.keys(methodToColorMap);\n for (const key of loggerMethods) {\n const method = key;\n api[method] = (...args) => {\n print(method, args);\n };\n }\n return api;\n})());\nexport { logger };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { messages } from './messages.js';\nimport '../../_version.js';\nconst fallback = (code, ...args) => {\n let msg = code;\n if (args.length > 0) {\n msg += ` :: ${JSON.stringify(args)}`;\n }\n return msg;\n};\nconst generatorFunction = (code, details = {}) => {\n const message = messages[code];\n if (!message) {\n throw new Error(`Unable to find message for code '${code}'.`);\n }\n return message(details);\n};\nexport const messageGenerator = (process.env.NODE_ENV === 'production') ?\n fallback : generatorFunction;\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { messageGenerator } from '../models/messages/messageGenerator.js';\nimport '../_version.js';\n/**\n * Workbox errors should be thrown with this class.\n * This allows use to ensure the type easily in tests,\n * helps developers identify errors from workbox\n * easily and allows use to optimise error\n * messages correctly.\n *\n * @private\n */\nclass WorkboxError extends Error {\n /**\n *\n * @param {string} errorCode The error code that\n * identifies this particular error.\n * @param {Object=} details Any relevant arguments\n * that will help developers identify issues should\n * be added as a key on the context object.\n */\n constructor(errorCode, details) {\n const message = messageGenerator(errorCode, details);\n super(message);\n this.name = errorCode;\n this.details = details;\n }\n}\nexport { WorkboxError };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { WorkboxError } from '../_private/WorkboxError.js';\nimport '../_version.js';\n/*\n * This method returns true if the current context is a service worker.\n */\nconst isSWEnv = (moduleName) => {\n if (!('ServiceWorkerGlobalScope' in self)) {\n throw new WorkboxError('not-in-sw', { moduleName });\n }\n};\n/*\n * This method throws if the supplied value is not an array.\n * The destructed values are required to produce a meaningful error for users.\n * The destructed and restructured object is so it's clear what is\n * needed.\n */\nconst isArray = (value, details) => {\n if (!Array.isArray(value)) {\n throw new WorkboxError('not-an-array', details);\n }\n};\nconst hasMethod = (object, expectedMethod, details) => {\n const type = typeof object[expectedMethod];\n if (type !== 'function') {\n details['expectedMethod'] = expectedMethod;\n throw new WorkboxError('missing-a-method', details);\n }\n};\nconst isType = (object, expectedType, details) => {\n if (typeof object !== expectedType) {\n details['expectedType'] = expectedType;\n throw new WorkboxError('incorrect-type', details);\n }\n};\nconst isInstance = (object, expectedClass, details) => {\n if (!(object instanceof expectedClass)) {\n details['expectedClass'] = expectedClass;\n throw new WorkboxError('incorrect-class', details);\n }\n};\nconst isOneOf = (value, validValues, details) => {\n if (!validValues.includes(value)) {\n details['validValueDescription'] =\n `Valid values are ${JSON.stringify(validValues)}.`;\n throw new WorkboxError('invalid-value', details);\n }\n};\nconst isArrayOfClass = (value, expectedClass, details) => {\n const error = new WorkboxError('not-array-of-class', details);\n if (!Array.isArray(value)) {\n throw error;\n }\n for (const item of value) {\n if (!(item instanceof expectedClass)) {\n throw error;\n }\n }\n};\nconst finalAssertExports = process.env.NODE_ENV === 'production' ? null : {\n hasMethod,\n isArray,\n isInstance,\n isOneOf,\n isSWEnv,\n isType,\n isArrayOfClass,\n};\nexport { finalAssertExports as assert };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n// Callbacks to be executed whenever there's a quota error.\nconst quotaErrorCallbacks = new Set();\nexport { quotaErrorCallbacks };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst _cacheNameDetails = {\n googleAnalytics: 'googleAnalytics',\n precache: 'precache-v2',\n prefix: 'workbox',\n runtime: 'runtime',\n suffix: typeof registration !== 'undefined' ? registration.scope : '',\n};\nconst _createCacheName = (cacheName) => {\n return [_cacheNameDetails.prefix, cacheName, _cacheNameDetails.suffix]\n .filter((value) => value && value.length > 0)\n .join('-');\n};\nconst eachCacheNameDetail = (fn) => {\n for (const key of Object.keys(_cacheNameDetails)) {\n fn(key);\n }\n};\nexport const cacheNames = {\n updateDetails: (details) => {\n eachCacheNameDetail((key) => {\n if (typeof details[key] === 'string') {\n _cacheNameDetails[key] = details[key];\n }\n });\n },\n getGoogleAnalyticsName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.googleAnalytics);\n },\n getPrecacheName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.precache);\n },\n getPrefix: () => {\n return _cacheNameDetails.prefix;\n },\n getRuntimeName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.runtime);\n },\n getSuffix: () => {\n return _cacheNameDetails.suffix;\n },\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { logger } from '../_private/logger.js';\nimport { quotaErrorCallbacks } from '../models/quotaErrorCallbacks.js';\nimport '../_version.js';\n/**\n * Runs all of the callback functions, one at a time sequentially, in the order\n * in which they were registered.\n *\n * @memberof module:workbox-core\n * @private\n */\nasync function executeQuotaErrorCallbacks() {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`About to run ${quotaErrorCallbacks.size} ` +\n `callbacks to clean up caches.`);\n }\n for (const callback of quotaErrorCallbacks) {\n await callback();\n if (process.env.NODE_ENV !== 'production') {\n logger.log(callback, 'is complete.');\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Finished running callbacks.');\n }\n}\nexport { executeQuotaErrorCallbacks };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst getFriendlyURL = (url) => {\n const urlObj = new URL(String(url), location.href);\n // See https://github.com/GoogleChrome/workbox/issues/2323\n // We want to include everything, except for the origin if it's same-origin.\n return urlObj.href.replace(new RegExp(`^${location.origin}`), '');\n};\nexport { getFriendlyURL };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nexport const pluginUtils = {\n filter: (plugins, callbackName) => {\n return plugins.filter((plugin) => callbackName in plugin);\n },\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from './assert.js';\nimport { executeQuotaErrorCallbacks } from './executeQuotaErrorCallbacks.js';\nimport { getFriendlyURL } from './getFriendlyURL.js';\nimport { logger } from './logger.js';\nimport { pluginUtils } from '../utils/pluginUtils.js';\nimport { WorkboxError } from './WorkboxError.js';\nimport '../_version.js';\n/**\n * Checks the list of plugins for the cacheKeyWillBeUsed callback, and\n * executes any of those callbacks found in sequence. The final `Request` object\n * returned by the last plugin is treated as the cache key for cache reads\n * and/or writes.\n *\n * @param {Object} options\n * @param {Request} options.request\n * @param {string} options.mode\n * @param {Array<Object>} [options.plugins=[]]\n * @return {Promise<Request>}\n *\n * @private\n * @memberof module:workbox-core\n */\nconst _getEffectiveRequest = async ({ request, mode, plugins = [], }) => {\n const cacheKeyWillBeUsedPlugins = pluginUtils.filter(plugins, \"cacheKeyWillBeUsed\" /* CACHE_KEY_WILL_BE_USED */);\n let effectiveRequest = request;\n for (const plugin of cacheKeyWillBeUsedPlugins) {\n effectiveRequest = await plugin[\"cacheKeyWillBeUsed\" /* CACHE_KEY_WILL_BE_USED */].call(plugin, { mode, request: effectiveRequest });\n if (typeof effectiveRequest === 'string') {\n effectiveRequest = new Request(effectiveRequest);\n }\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(effectiveRequest, Request, {\n moduleName: 'Plugin',\n funcName: \"cacheKeyWillBeUsed\" /* CACHE_KEY_WILL_BE_USED */,\n isReturnValueProblem: true,\n });\n }\n }\n return effectiveRequest;\n};\n/**\n * This method will call cacheWillUpdate on the available plugins (or use\n * status === 200) to determine if the Response is safe and valid to cache.\n *\n * @param {Object} options\n * @param {Request} options.request\n * @param {Response} options.response\n * @param {Event} [options.event]\n * @param {Array<Object>} [options.plugins=[]]\n * @return {Promise<Response>}\n *\n * @private\n * @memberof module:workbox-core\n */\nconst _isResponseSafeToCache = async ({ request, response, event, plugins = [], }) => {\n let responseToCache = response;\n let pluginsUsed = false;\n for (const plugin of plugins) {\n if (\"cacheWillUpdate\" /* CACHE_WILL_UPDATE */ in plugin) {\n pluginsUsed = true;\n const pluginMethod = plugin[\"cacheWillUpdate\" /* CACHE_WILL_UPDATE */];\n responseToCache = await pluginMethod.call(plugin, {\n request,\n response: responseToCache,\n event,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (responseToCache) {\n assert.isInstance(responseToCache, Response, {\n moduleName: 'Plugin',\n funcName: \"cacheWillUpdate\" /* CACHE_WILL_UPDATE */,\n isReturnValueProblem: true,\n });\n }\n }\n if (!responseToCache) {\n break;\n }\n }\n }\n if (!pluginsUsed) {\n if (process.env.NODE_ENV !== 'production') {\n if (responseToCache) {\n if (responseToCache.status !== 200) {\n if (responseToCache.status === 0) {\n logger.warn(`The response for '${request.url}' is an opaque ` +\n `response. The caching strategy that you're using will not ` +\n `cache opaque responses by default.`);\n }\n else {\n logger.debug(`The response for '${request.url}' returned ` +\n `a status code of '${response.status}' and won't be cached as a ` +\n `result.`);\n }\n }\n }\n }\n responseToCache = responseToCache && responseToCache.status === 200 ?\n responseToCache : undefined;\n }\n return responseToCache ? responseToCache : null;\n};\n/**\n * This is a wrapper around cache.match().\n *\n * @param {Object} options\n * @param {string} options.cacheName Name of the cache to match against.\n * @param {Request} options.request The Request that will be used to look up\n * cache entries.\n * @param {Event} [options.event] The event that prompted the action.\n * @param {Object} [options.matchOptions] Options passed to cache.match().\n * @param {Array<Object>} [options.plugins=[]] Array of plugins.\n * @return {Response} A cached response if available.\n *\n * @private\n * @memberof module:workbox-core\n */\nconst matchWrapper = async ({ cacheName, request, event, matchOptions, plugins = [], }) => {\n const cache = await self.caches.open(cacheName);\n const effectiveRequest = await _getEffectiveRequest({\n plugins, request, mode: 'read'\n });\n let cachedResponse = await cache.match(effectiveRequest, matchOptions);\n if (process.env.NODE_ENV !== 'production') {\n if (cachedResponse) {\n logger.debug(`Found a cached response in '${cacheName}'.`);\n }\n else {\n logger.debug(`No cached response found in '${cacheName}'.`);\n }\n }\n for (const plugin of plugins) {\n if (\"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */ in plugin) {\n const pluginMethod = plugin[\"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */];\n cachedResponse = await pluginMethod.call(plugin, {\n cacheName,\n event,\n matchOptions,\n cachedResponse,\n request: effectiveRequest,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (cachedResponse) {\n assert.isInstance(cachedResponse, Response, {\n moduleName: 'Plugin',\n funcName: \"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */,\n isReturnValueProblem: true,\n });\n }\n }\n }\n }\n return cachedResponse;\n};\n/**\n * Wrapper around cache.put().\n *\n * Will call `cacheDidUpdate` on plugins if the cache was updated, using\n * `matchOptions` when determining what the old entry is.\n *\n * @param {Object} options\n * @param {string} options.cacheName\n * @param {Request} options.request\n * @param {Response} options.response\n * @param {Event} [options.event]\n * @param {Array<Object>} [options.plugins=[]]\n * @param {Object} [options.matchOptions]\n *\n * @private\n * @memberof module:workbox-core\n */\nconst putWrapper = async ({ cacheName, request, response, event, plugins = [], matchOptions, }) => {\n if (process.env.NODE_ENV !== 'production') {\n if (request.method && request.method !== 'GET') {\n throw new WorkboxError('attempt-to-cache-non-get-request', {\n url: getFriendlyURL(request.url),\n method: request.method,\n });\n }\n }\n const effectiveRequest = await _getEffectiveRequest({\n plugins, request, mode: 'write'\n });\n if (!response) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(`Cannot cache non-existent response for ` +\n `'${getFriendlyURL(effectiveRequest.url)}'.`);\n }\n throw new WorkboxError('cache-put-with-no-response', {\n url: getFriendlyURL(effectiveRequest.url),\n });\n }\n const responseToCache = await _isResponseSafeToCache({\n event,\n plugins,\n response,\n request: effectiveRequest,\n });\n if (!responseToCache) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Response '${getFriendlyURL(effectiveRequest.url)}' will ` +\n `not be cached.`, responseToCache);\n }\n return;\n }\n const cache = await self.caches.open(cacheName);\n const updatePlugins = pluginUtils.filter(plugins, \"cacheDidUpdate\" /* CACHE_DID_UPDATE */);\n const oldResponse = updatePlugins.length > 0 ?\n await matchWrapper({ cacheName, matchOptions, request: effectiveRequest }) :\n null;\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Updating the '${cacheName}' cache with a new Response for ` +\n `${getFriendlyURL(effectiveRequest.url)}.`);\n }\n try {\n await cache.put(effectiveRequest, responseToCache);\n }\n catch (error) {\n // See https://developer.mozilla.org/en-US/docs/Web/API/DOMException#exception-QuotaExceededError\n if (error.name === 'QuotaExceededError') {\n await executeQuotaErrorCallbacks();\n }\n throw error;\n }\n for (const plugin of updatePlugins) {\n await plugin[\"cacheDidUpdate\" /* CACHE_DID_UPDATE */].call(plugin, {\n cacheName,\n event,\n oldResponse,\n newResponse: responseToCache,\n request: effectiveRequest,\n });\n }\n};\nexport const cacheWrapper = {\n put: putWrapper,\n match: matchWrapper,\n};\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nlet supportStatus;\n/**\n * A utility function that determines whether the current browser supports\n * constructing a [`ReadableStream`](https://developer.mozilla.org/en-US/docs/Web/API/ReadableStream/ReadableStream)\n * object.\n *\n * @return {boolean} `true`, if the current browser can successfully\n * construct a `ReadableStream`, `false` otherwise.\n *\n * @private\n */\nfunction canConstructReadableStream() {\n if (supportStatus === undefined) {\n // See https://github.com/GoogleChrome/workbox/issues/1473\n try {\n new ReadableStream({ start() { } });\n supportStatus = true;\n }\n catch (error) {\n supportStatus = false;\n }\n }\n return supportStatus;\n}\nexport { canConstructReadableStream };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nlet supportStatus;\n/**\n * A utility function that determines whether the current browser supports\n * constructing a new `Response` from a `response.body` stream.\n *\n * @return {boolean} `true`, if the current browser can successfully\n * construct a `Response` from a `response.body` stream, `false` otherwise.\n *\n * @private\n */\nfunction canConstructResponseFromBodyStream() {\n if (supportStatus === undefined) {\n const testResponse = new Response('');\n if ('body' in testResponse) {\n try {\n new Response(testResponse.body);\n supportStatus = true;\n }\n catch (error) {\n supportStatus = false;\n }\n }\n supportStatus = false;\n }\n return supportStatus;\n}\nexport { canConstructResponseFromBodyStream };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A class that wraps common IndexedDB functionality in a promise-based API.\n * It exposes all the underlying power and functionality of IndexedDB, but\n * wraps the most commonly used features in a way that's much simpler to use.\n *\n * @private\n */\nexport class DBWrapper {\n /**\n * @param {string} name\n * @param {number} version\n * @param {Object=} [callback]\n * @param {!Function} [callbacks.onupgradeneeded]\n * @param {!Function} [callbacks.onversionchange] Defaults to\n * DBWrapper.prototype._onversionchange when not specified.\n * @private\n */\n constructor(name, version, { onupgradeneeded, onversionchange, } = {}) {\n this._db = null;\n this._name = name;\n this._version = version;\n this._onupgradeneeded = onupgradeneeded;\n this._onversionchange = onversionchange || (() => this.close());\n }\n /**\n * Returns the IDBDatabase instance (not normally needed).\n * @return {IDBDatabase|undefined}\n *\n * @private\n */\n get db() {\n return this._db;\n }\n /**\n * Opens a connected to an IDBDatabase, invokes any onupgradedneeded\n * callback, and added an onversionchange callback to the database.\n *\n * @return {IDBDatabase}\n * @private\n */\n async open() {\n if (this._db)\n return;\n this._db = await new Promise((resolve, reject) => {\n // This flag is flipped to true if the timeout callback runs prior\n // to the request failing or succeeding. Note: we use a timeout instead\n // of an onblocked handler since there are cases where onblocked will\n // never never run. A timeout better handles all possible scenarios:\n // https://github.com/w3c/IndexedDB/issues/223\n let openRequestTimedOut = false;\n setTimeout(() => {\n openRequestTimedOut = true;\n reject(new Error('The open request was blocked and timed out'));\n }, this.OPEN_TIMEOUT);\n const openRequest = indexedDB.open(this._name, this._version);\n openRequest.onerror = () => reject(openRequest.error);\n openRequest.onupgradeneeded = (evt) => {\n if (openRequestTimedOut) {\n openRequest.transaction.abort();\n openRequest.result.close();\n }\n else if (typeof this._onupgradeneeded === 'function') {\n this._onupgradeneeded(evt);\n }\n };\n openRequest.onsuccess = () => {\n const db = openRequest.result;\n if (openRequestTimedOut) {\n db.close();\n }\n else {\n db.onversionchange = this._onversionchange.bind(this);\n resolve(db);\n }\n };\n });\n return this;\n }\n /**\n * Polyfills the native `getKey()` method. Note, this is overridden at\n * runtime if the browser supports the native method.\n *\n * @param {string} storeName\n * @param {*} query\n * @return {Array}\n * @private\n */\n async getKey(storeName, query) {\n return (await this.getAllKeys(storeName, query, 1))[0];\n }\n /**\n * Polyfills the native `getAll()` method. Note, this is overridden at\n * runtime if the browser supports the native method.\n *\n * @param {string} storeName\n * @param {*} query\n * @param {number} count\n * @return {Array}\n * @private\n */\n async getAll(storeName, query, count) {\n return await this.getAllMatching(storeName, { query, count });\n }\n /**\n * Polyfills the native `getAllKeys()` method. Note, this is overridden at\n * runtime if the browser supports the native method.\n *\n * @param {string} storeName\n * @param {*} query\n * @param {number} count\n * @return {Array}\n * @private\n */\n async getAllKeys(storeName, query, count) {\n const entries = await this.getAllMatching(storeName, { query, count, includeKeys: true });\n return entries.map((entry) => entry.key);\n }\n /**\n * Supports flexible lookup in an object store by specifying an index,\n * query, direction, and count. This method returns an array of objects\n * with the signature .\n *\n * @param {string} storeName\n * @param {Object} [opts]\n * @param {string} [opts.index] The index to use (if specified).\n * @param {*} [opts.query]\n * @param {IDBCursorDirection} [opts.direction]\n * @param {number} [opts.count] The max number of results to return.\n * @param {boolean} [opts.includeKeys] When true, the structure of the\n * returned objects is changed from an array of values to an array of\n * objects in the form {key, primaryKey, value}.\n * @return {Array}\n * @private\n */\n async getAllMatching(storeName, { index, query = null, // IE/Edge errors if query === `undefined`.\n direction = 'next', count, includeKeys = false, } = {}) {\n return await this.transaction([storeName], 'readonly', (txn, done) => {\n const store = txn.objectStore(storeName);\n const target = index ? store.index(index) : store;\n const results = [];\n const request = target.openCursor(query, direction);\n request.onsuccess = () => {\n const cursor = request.result;\n if (cursor) {\n results.push(includeKeys ? cursor : cursor.value);\n if (count && results.length >= count) {\n done(results);\n }\n else {\n cursor.continue();\n }\n }\n else {\n done(results);\n }\n };\n });\n }\n /**\n * Accepts a list of stores, a transaction type, and a callback and\n * performs a transaction. A promise is returned that resolves to whatever\n * value the callback chooses. The callback holds all the transaction logic\n * and is invoked with two arguments:\n * 1. The IDBTransaction object\n * 2. A `done` function, that's used to resolve the promise when\n * when the transaction is done, if passed a value, the promise is\n * resolved to that value.\n *\n * @param {Array<string>} storeNames An array of object store names\n * involved in the transaction.\n * @param {string} type Can be `readonly` or `readwrite`.\n * @param {!Function} callback\n * @return {*} The result of the transaction ran by the callback.\n * @private\n */\n async transaction(storeNames, type, callback) {\n await this.open();\n return await new Promise((resolve, reject) => {\n const txn = this._db.transaction(storeNames, type);\n txn.onabort = () => reject(txn.error);\n txn.oncomplete = () => resolve();\n callback(txn, (value) => resolve(value));\n });\n }\n /**\n * Delegates async to a native IDBObjectStore method.\n *\n * @param {string} method The method name.\n * @param {string} storeName The object store name.\n * @param {string} type Can be `readonly` or `readwrite`.\n * @param {...*} args The list of args to pass to the native method.\n * @return {*} The result of the transaction.\n * @private\n */\n async _call(method, storeName, type, ...args) {\n const callback = (txn, done) => {\n const objStore = txn.objectStore(storeName);\n // TODO(philipwalton): Fix this underlying TS2684 error.\n // @ts-ignore\n const request = objStore[method].apply(objStore, args);\n request.onsuccess = () => done(request.result);\n };\n return await this.transaction([storeName], type, callback);\n }\n /**\n * Closes the connection opened by `DBWrapper.open()`. Generally this method\n * doesn't need to be called since:\n * 1. It's usually better to keep a connection open since opening\n * a new connection is somewhat slow.\n * 2. Connections are automatically closed when the reference is\n * garbage collected.\n * The primary use case for needing to close a connection is when another\n * reference (typically in another tab) needs to upgrade it and would be\n * blocked by the current, open connection.\n *\n * @private\n */\n close() {\n if (this._db) {\n this._db.close();\n this._db = null;\n }\n }\n}\n// Exposed on the prototype to let users modify the default timeout on a\n// per-instance or global basis.\nDBWrapper.prototype.OPEN_TIMEOUT = 2000;\n// Wrap native IDBObjectStore methods according to their mode.\nconst methodsToWrap = {\n readonly: ['get', 'count', 'getKey', 'getAll', 'getAllKeys'],\n readwrite: ['add', 'put', 'clear', 'delete'],\n};\nfor (const [mode, methods] of Object.entries(methodsToWrap)) {\n for (const method of methods) {\n if (method in IDBObjectStore.prototype) {\n // Don't use arrow functions here since we're outside of the class.\n DBWrapper.prototype[method] =\n async function (storeName, ...args) {\n return await this._call(method, storeName, mode, ...args);\n };\n }\n }\n}\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Deletes the database.\n * Note: this is exported separately from the DBWrapper module because most\n * usages of IndexedDB in workbox dont need deleting, and this way it can be\n * reused in tests to delete databases without creating DBWrapper instances.\n *\n * @param {string} name The database name.\n * @private\n */\nexport const deleteDatabase = async (name) => {\n await new Promise((resolve, reject) => {\n const request = indexedDB.deleteDatabase(name);\n request.onerror = () => {\n reject(request.error);\n };\n request.onblocked = () => {\n reject(new Error('Delete blocked'));\n };\n request.onsuccess = () => {\n resolve();\n };\n });\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { WorkboxError } from './WorkboxError.js';\nimport { logger } from './logger.js';\nimport { assert } from './assert.js';\nimport { getFriendlyURL } from '../_private/getFriendlyURL.js';\nimport { pluginUtils } from '../utils/pluginUtils.js';\nimport '../_version.js';\n/**\n * Wrapper around the fetch API.\n *\n * Will call requestWillFetch on available plugins.\n *\n * @param {Object} options\n * @param {Request|string} options.request\n * @param {Object} [options.fetchOptions]\n * @param {ExtendableEvent} [options.event]\n * @param {Array<Object>} [options.plugins=[]]\n * @return {Promise<Response>}\n *\n * @private\n * @memberof module:workbox-core\n */\nconst wrappedFetch = async ({ request, fetchOptions, event, plugins = [], }) => {\n if (typeof request === 'string') {\n request = new Request(request);\n }\n // We *should* be able to call `await event.preloadResponse` even if it's\n // undefined, but for some reason, doing so leads to errors in our Node unit\n // tests. To work around that, explicitly check preloadResponse's value first.\n if (event instanceof FetchEvent && event.preloadResponse) {\n const possiblePreloadResponse = await event.preloadResponse;\n if (possiblePreloadResponse) {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`Using a preloaded navigation response for ` +\n `'${getFriendlyURL(request.url)}'`);\n }\n return possiblePreloadResponse;\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(request, Request, {\n paramName: 'request',\n expectedClass: Request,\n moduleName: 'workbox-core',\n className: 'fetchWrapper',\n funcName: 'wrappedFetch',\n });\n }\n const failedFetchPlugins = pluginUtils.filter(plugins, \"fetchDidFail\" /* FETCH_DID_FAIL */);\n // If there is a fetchDidFail plugin, we need to save a clone of the\n // original request before it's either modified by a requestWillFetch\n // plugin or before the original request's body is consumed via fetch().\n const originalRequest = failedFetchPlugins.length > 0 ?\n request.clone() : null;\n try {\n for (const plugin of plugins) {\n if (\"requestWillFetch\" /* REQUEST_WILL_FETCH */ in plugin) {\n const pluginMethod = plugin[\"requestWillFetch\" /* REQUEST_WILL_FETCH */];\n const requestClone = request.clone();\n request = await pluginMethod.call(plugin, {\n request: requestClone,\n event,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (request) {\n assert.isInstance(request, Request, {\n moduleName: 'Plugin',\n funcName: \"cachedResponseWillBeUsed\" /* CACHED_RESPONSE_WILL_BE_USED */,\n isReturnValueProblem: true,\n });\n }\n }\n }\n }\n }\n catch (err) {\n throw new WorkboxError('plugin-error-request-will-fetch', {\n thrownError: err,\n });\n }\n // The request can be altered by plugins with `requestWillFetch` making\n // the original request (Most likely from a `fetch` event) to be different\n // to the Request we make. Pass both to `fetchDidFail` to aid debugging.\n const pluginFilteredRequest = request.clone();\n try {\n let fetchResponse;\n // See https://github.com/GoogleChrome/workbox/issues/1796\n if (request.mode === 'navigate') {\n fetchResponse = await fetch(request);\n }\n else {\n fetchResponse = await fetch(request, fetchOptions);\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Network request for ` +\n `'${getFriendlyURL(request.url)}' returned a response with ` +\n `status '${fetchResponse.status}'.`);\n }\n for (const plugin of plugins) {\n if (\"fetchDidSucceed\" /* FETCH_DID_SUCCEED */ in plugin) {\n fetchResponse = await plugin[\"fetchDidSucceed\" /* FETCH_DID_SUCCEED */]\n .call(plugin, {\n event,\n request: pluginFilteredRequest,\n response: fetchResponse,\n });\n if (process.env.NODE_ENV !== 'production') {\n if (fetchResponse) {\n assert.isInstance(fetchResponse, Response, {\n moduleName: 'Plugin',\n funcName: \"fetchDidSucceed\" /* FETCH_DID_SUCCEED */,\n isReturnValueProblem: true,\n });\n }\n }\n }\n }\n return fetchResponse;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(`Network request for ` +\n `'${getFriendlyURL(request.url)}' threw an error.`, error);\n }\n for (const plugin of failedFetchPlugins) {\n await plugin[\"fetchDidFail\" /* FETCH_DID_FAIL */].call(plugin, {\n error,\n event,\n originalRequest: originalRequest.clone(),\n request: pluginFilteredRequest.clone(),\n });\n }\n throw error;\n }\n};\nconst fetchWrapper = {\n fetch: wrappedFetch,\n};\nexport { fetchWrapper };\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Returns a promise that resolves and the passed number of milliseconds.\n * This utility is an async/await-friendly version of `setTimeout`.\n *\n * @param {number} ms\n * @return {Promise}\n * @private\n */\nexport function timeout(ms) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A helper function that prevents a promise from being flagged as unused.\n *\n * @private\n **/\nexport function dontWaitFor(promise) {\n // Effective no-op.\n promise.then(() => { });\n}\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The Deferred class composes Promises in a way that allows for them to be\n * resolved or rejected from outside the constructor. In most cases promises\n * should be used directly, but Deferreds can be necessary when the logic to\n * resolve a promise must be separate.\n *\n * @private\n */\nclass Deferred {\n /**\n * Creates a promise and exposes its resolve and reject functions as methods.\n */\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n}\nexport { Deferred };\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { timeout } from './timeout.js';\nimport '../_version.js';\nconst MAX_RETRY_TIME = 2000;\n/**\n * Returns a promise that resolves to a window client matching the passed\n * `resultingClientId`. For browsers that don't support `resultingClientId`\n * or if waiting for the resulting client to apper takes too long, resolve to\n * `undefined`.\n *\n * @param {string} [resultingClientId]\n * @return {Promise<Client|undefined>}\n * @private\n */\nexport async function resultingClientExists(resultingClientId) {\n if (!resultingClientId) {\n return;\n }\n let existingWindows = await self.clients.matchAll({ type: 'window' });\n const existingWindowIds = new Set(existingWindows.map((w) => w.id));\n let resultingWindow;\n const startTime = performance.now();\n // Only wait up to `MAX_RETRY_TIME` to find a matching client.\n while (performance.now() - startTime < MAX_RETRY_TIME) {\n existingWindows = await self.clients.matchAll({ type: 'window' });\n resultingWindow = existingWindows.find((w) => {\n if (resultingClientId) {\n // If we have a `resultingClientId`, we can match on that.\n return w.id === resultingClientId;\n }\n else {\n // Otherwise match on finding a window not in `existingWindowIds`.\n return !existingWindowIds.has(w.id);\n }\n });\n if (resultingWindow) {\n break;\n }\n // Sleep for 100ms and retry.\n await timeout(100);\n }\n return resultingWindow;\n}\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { cacheNames as _cacheNames } from './_private/cacheNames.js';\nimport './_version.js';\n/**\n * Get the current cache names and prefix/suffix used by Workbox.\n *\n * `cacheNames.precache` is used for precached assets,\n * `cacheNames.googleAnalytics` is used by `workbox-google-analytics` to\n * store `analytics.js`, and `cacheNames.runtime` is used for everything else.\n *\n * `cacheNames.prefix` can be used to retrieve just the current prefix value.\n * `cacheNames.suffix` can be used to retrieve just the current suffix value.\n *\n * @return {Object} An object with `precache`, `runtime`, `prefix`, and\n * `googleAnalytics` properties.\n *\n * @memberof module:workbox-core\n */\nconst cacheNames = {\n get googleAnalytics() {\n return _cacheNames.getGoogleAnalyticsName();\n },\n get precache() {\n return _cacheNames.getPrecacheName();\n },\n get prefix() {\n return _cacheNames.getPrefix();\n },\n get runtime() {\n return _cacheNames.getRuntimeName();\n },\n get suffix() {\n return _cacheNames.getSuffix();\n },\n};\nexport { cacheNames };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Claim any currently available clients once the service worker\n * becomes active. This is normally used in conjunction with `skipWaiting()`.\n *\n * @memberof module:workbox-core\n */\nfunction clientsClaim() {\n self.addEventListener('activate', () => self.clients.claim());\n}\nexport { clientsClaim };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { canConstructResponseFromBodyStream } from './_private/canConstructResponseFromBodyStream.js';\nimport './_version.js';\n/**\n * Allows developers to copy a response and modify its `headers`, `status`,\n * or `statusText` values (the values settable via a\n * [`ResponseInit`]{@link https://developer.mozilla.org/en-US/docs/Web/API/Response/Response#Syntax}\n * object in the constructor).\n * To modify these values, pass a function as the second argument. That\n * function will be invoked with a single object with the response properties\n * `{headers, status, statusText}`. The return value of this function will\n * be used as the `ResponseInit` for the new `Response`. To change the values\n * either modify the passed parameter(s) and return it, or return a totally\n * new object.\n *\n * @param {Response} response\n * @param {Function} modifier\n * @memberof module:workbox-core\n */\nasync function copyResponse(response, modifier) {\n const clonedResponse = response.clone();\n // Create a fresh `ResponseInit` object by cloning the headers.\n const responseInit = {\n headers: new Headers(clonedResponse.headers),\n status: clonedResponse.status,\n statusText: clonedResponse.statusText,\n };\n // Apply any user modifications.\n const modifiedResponseInit = modifier ? modifier(responseInit) : responseInit;\n // Create the new response from the body stream and `ResponseInit`\n // modifications. Note: not all browsers support the Response.body stream,\n // so fall back to reading the entire body into memory as a blob.\n const body = canConstructResponseFromBodyStream() ?\n clonedResponse.body : await clonedResponse.blob();\n return new Response(body, modifiedResponseInit);\n}\nexport { copyResponse };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { logger } from './_private/logger.js';\nimport { assert } from './_private/assert.js';\nimport { quotaErrorCallbacks } from './models/quotaErrorCallbacks.js';\nimport './_version.js';\n/**\n * Adds a function to the set of quotaErrorCallbacks that will be executed if\n * there's a quota error.\n *\n * @param {Function} callback\n * @memberof module:workbox-core\n */\nfunction registerQuotaErrorCallback(callback) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(callback, 'function', {\n moduleName: 'workbox-core',\n funcName: 'register',\n paramName: 'callback',\n });\n }\n quotaErrorCallbacks.add(callback);\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Registered a callback to respond to quota errors.', callback);\n }\n}\nexport { registerQuotaErrorCallback };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from './_private/assert.js';\nimport { cacheNames } from './_private/cacheNames.js';\nimport { WorkboxError } from './_private/WorkboxError.js';\nimport './_version.js';\n/**\n * Modifies the default cache names used by the Workbox packages.\n * Cache names are generated as `<prefix>-<Cache Name>-<suffix>`.\n *\n * @param {Object} details\n * @param {Object} [details.prefix] The string to add to the beginning of\n * the precache and runtime cache names.\n * @param {Object} [details.suffix] The string to add to the end of\n * the precache and runtime cache names.\n * @param {Object} [details.precache] The cache name to use for precache\n * caching.\n * @param {Object} [details.runtime] The cache name to use for runtime caching.\n * @param {Object} [details.googleAnalytics] The cache name to use for\n * `workbox-google-analytics` caching.\n *\n * @memberof module:workbox-core\n */\nfunction setCacheNameDetails(details) {\n if (process.env.NODE_ENV !== 'production') {\n Object.keys(details).forEach((key) => {\n assert.isType(details[key], 'string', {\n moduleName: 'workbox-core',\n funcName: 'setCacheNameDetails',\n paramName: `details.${key}`,\n });\n });\n if ('precache' in details && details['precache'].length === 0) {\n throw new WorkboxError('invalid-cache-name', {\n cacheNameId: 'precache',\n value: details['precache'],\n });\n }\n if ('runtime' in details && details['runtime'].length === 0) {\n throw new WorkboxError('invalid-cache-name', {\n cacheNameId: 'runtime',\n value: details['runtime'],\n });\n }\n if ('googleAnalytics' in details && details['googleAnalytics'].length === 0) {\n throw new WorkboxError('invalid-cache-name', {\n cacheNameId: 'googleAnalytics',\n value: details['googleAnalytics'],\n });\n }\n }\n cacheNames.updateDetails(details);\n}\nexport { setCacheNameDetails };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Force a service worker to activate immediately, instead of\n * [waiting](https://developers.google.com/web/fundamentals/primers/service-workers/lifecycle#waiting)\n * for existing clients to close.\n *\n * @memberof module:workbox-core\n */\nfunction skipWaiting() {\n // We need to explicitly call `self.skipWaiting()` here because we're\n // shadowing `skipWaiting` with this local function.\n self.addEventListener('install', () => self.skipWaiting());\n}\nexport { skipWaiting };\n"],"names":["self","_","e","messageGenerator","code","args","msg","length","JSON","stringify","WorkboxError","Error","constructor","errorCode","details","name","quotaErrorCallbacks","Set","_cacheNameDetails","googleAnalytics","precache","prefix","runtime","suffix","registration","scope","_createCacheName","cacheName","filter","value","join","cacheNames","updateDetails","fn","key","Object","keys","eachCacheNameDetail","getGoogleAnalyticsName","userCacheName","getPrecacheName","getPrefix","getRuntimeName","getSuffix","async","executeQuotaErrorCallbacks","callback","getFriendlyURL","url","URL","String","location","href","replace","RegExp","origin","pluginUtils","plugins","callbackName","plugin","_getEffectiveRequest","request","mode","cacheKeyWillBeUsedPlugins","effectiveRequest","call","Request","matchWrapper","event","matchOptions","cache","caches","open","cachedResponse","match","pluginMethod","cacheWrapper","put","response","responseToCache","pluginsUsed","status","undefined","_isResponseSafeToCache","updatePlugins","oldResponse","error","newResponse","supportStatus","canConstructResponseFromBodyStream","testResponse","Response","body","DBWrapper","version","onupgradeneeded","onversionchange","_db","_name","_version","_onupgradeneeded","_onversionchange","this","close","Promise","resolve","reject","openRequestTimedOut","setTimeout","OPEN_TIMEOUT","openRequest","indexedDB","onerror","evt","transaction","abort","result","onsuccess","db","bind","storeName","query","getAllKeys","count","getAllMatching","includeKeys","map","entry","index","direction","txn","done","store","objectStore","target","results","openCursor","cursor","push","continue","storeNames","type","onabort","oncomplete","method","objStore","apply","prototype","methodsToWrap","readonly","readwrite","methods","entries","IDBObjectStore","_call","fetchWrapper","fetch","fetchOptions","FetchEvent","preloadResponse","possiblePreloadResponse","failedFetchPlugins","originalRequest","clone","requestClone","err","thrownError","pluginFilteredRequest","fetchResponse","timeout","ms","ReadableStream","start","promise","then","deleteDatabase","onblocked","resultingClientId","existingWindows","clients","matchAll","existingWindowIds","w","id","resultingWindow","startTime","performance","now","find","has","_cacheNames","addEventListener","claim","modifier","clonedResponse","responseInit","headers","Headers","statusText","modifiedResponseInit","blob","add","skipWaiting"],"mappings":"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"}
|
@@ -1,651 +1,649 @@
|
|
1
|
-
this.workbox = this.workbox || {};
|
2
|
-
this.workbox.expiration = (function (exports, assert_js, dontWaitFor_js, logger_js, WorkboxError_js, DBWrapper_js, deleteDatabase_js, cacheNames_js, getFriendlyURL_js, registerQuotaErrorCallback_js) {
|
3
|
-
'use strict';
|
4
|
-
|
5
|
-
try {
|
6
|
-
self['workbox:expiration:5.
|
7
|
-
} catch (e) {}
|
8
|
-
|
9
|
-
/*
|
10
|
-
Copyright 2018 Google LLC
|
11
|
-
|
12
|
-
Use of this source code is governed by an MIT-style
|
13
|
-
license that can be found in the LICENSE file or at
|
14
|
-
https://opensource.org/licenses/MIT.
|
15
|
-
*/
|
16
|
-
const DB_NAME = 'workbox-expiration';
|
17
|
-
const OBJECT_STORE_NAME = 'cache-entries';
|
18
|
-
|
19
|
-
const normalizeURL = unNormalizedUrl => {
|
20
|
-
const url = new URL(unNormalizedUrl, location.href);
|
21
|
-
url.hash = '';
|
22
|
-
return url.href;
|
23
|
-
};
|
24
|
-
/**
|
25
|
-
* Returns the timestamp model.
|
26
|
-
*
|
27
|
-
* @private
|
28
|
-
*/
|
29
|
-
|
30
|
-
|
31
|
-
class CacheTimestampsModel {
|
32
|
-
/**
|
33
|
-
*
|
34
|
-
* @param {string} cacheName
|
35
|
-
*
|
36
|
-
* @private
|
37
|
-
*/
|
38
|
-
constructor(cacheName) {
|
39
|
-
this._cacheName = cacheName;
|
40
|
-
this._db = new DBWrapper_js.DBWrapper(DB_NAME, 1, {
|
41
|
-
onupgradeneeded: event => this._handleUpgrade(event)
|
42
|
-
});
|
43
|
-
}
|
44
|
-
/**
|
45
|
-
* Should perform an upgrade of indexedDB.
|
46
|
-
*
|
47
|
-
* @param {Event} event
|
48
|
-
*
|
49
|
-
* @private
|
50
|
-
*/
|
51
|
-
|
52
|
-
|
53
|
-
_handleUpgrade(event) {
|
54
|
-
const db = event.target.result; // TODO(philipwalton): EdgeHTML doesn't support arrays as a keyPath, so we
|
55
|
-
// have to use the `id` keyPath here and create our own values (a
|
56
|
-
// concatenation of `url + cacheName`) instead of simply using
|
57
|
-
// `keyPath: ['url', 'cacheName']`, which is supported in other browsers.
|
58
|
-
|
59
|
-
const objStore = db.createObjectStore(OBJECT_STORE_NAME, {
|
60
|
-
keyPath: 'id'
|
61
|
-
}); // TODO(philipwalton): once we don't have to support EdgeHTML, we can
|
62
|
-
// create a single index with the keyPath `['cacheName', 'timestamp']`
|
63
|
-
// instead of doing both these indexes.
|
64
|
-
|
65
|
-
objStore.createIndex('cacheName', 'cacheName', {
|
66
|
-
unique: false
|
67
|
-
});
|
68
|
-
objStore.createIndex('timestamp', 'timestamp', {
|
69
|
-
unique: false
|
70
|
-
}); // Previous versions of `workbox-expiration` used `this._cacheName`
|
71
|
-
// as the IDBDatabase name.
|
72
|
-
|
73
|
-
deleteDatabase_js.deleteDatabase(this._cacheName);
|
74
|
-
}
|
75
|
-
/**
|
76
|
-
* @param {string} url
|
77
|
-
* @param {number} timestamp
|
78
|
-
*
|
79
|
-
* @private
|
80
|
-
*/
|
81
|
-
|
82
|
-
|
83
|
-
async setTimestamp(url, timestamp) {
|
84
|
-
url = normalizeURL(url);
|
85
|
-
const entry = {
|
86
|
-
url,
|
87
|
-
timestamp,
|
88
|
-
cacheName: this._cacheName,
|
89
|
-
// Creating an ID from the URL and cache name won't be necessary once
|
90
|
-
// Edge switches to Chromium and all browsers we support work with
|
91
|
-
// array keyPaths.
|
92
|
-
id: this._getId(url)
|
93
|
-
};
|
94
|
-
await this._db.put(OBJECT_STORE_NAME, entry);
|
95
|
-
}
|
96
|
-
/**
|
97
|
-
* Returns the timestamp stored for a given URL.
|
98
|
-
*
|
99
|
-
* @param {string} url
|
100
|
-
* @return {number}
|
101
|
-
*
|
102
|
-
* @private
|
103
|
-
*/
|
104
|
-
|
105
|
-
|
106
|
-
async getTimestamp(url) {
|
107
|
-
const entry = await this._db.get(OBJECT_STORE_NAME, this._getId(url));
|
108
|
-
return entry.timestamp;
|
109
|
-
}
|
110
|
-
/**
|
111
|
-
* Iterates through all the entries in the object store (from newest to
|
112
|
-
* oldest) and removes entries once either `maxCount` is reached or the
|
113
|
-
* entry's timestamp is less than `minTimestamp`.
|
114
|
-
*
|
115
|
-
* @param {number} minTimestamp
|
116
|
-
* @param {number} maxCount
|
117
|
-
* @return {Array<string>}
|
118
|
-
*
|
119
|
-
* @private
|
120
|
-
*/
|
121
|
-
|
122
|
-
|
123
|
-
async expireEntries(minTimestamp, maxCount) {
|
124
|
-
const entriesToDelete = await this._db.transaction(OBJECT_STORE_NAME, 'readwrite', (txn, done) => {
|
125
|
-
const store = txn.objectStore(OBJECT_STORE_NAME);
|
126
|
-
const request = store.index('timestamp').openCursor(null, 'prev');
|
127
|
-
const entriesToDelete = [];
|
128
|
-
let entriesNotDeletedCount = 0;
|
129
|
-
|
130
|
-
request.onsuccess = () => {
|
131
|
-
const cursor = request.result;
|
132
|
-
|
133
|
-
if (cursor) {
|
134
|
-
const result = cursor.value; // TODO(philipwalton): once we can use a multi-key index, we
|
135
|
-
// won't have to check `cacheName` here.
|
136
|
-
|
137
|
-
if (result.cacheName === this._cacheName) {
|
138
|
-
// Delete an entry if it's older than the max age or
|
139
|
-
// if we already have the max number allowed.
|
140
|
-
if (minTimestamp && result.timestamp < minTimestamp || maxCount && entriesNotDeletedCount >= maxCount) {
|
141
|
-
// TODO(philipwalton): we should be able to delete the
|
142
|
-
// entry right here, but doing so causes an iteration
|
143
|
-
// bug in Safari stable (fixed in TP). Instead we can
|
144
|
-
// store the keys of the entries to delete, and then
|
145
|
-
// delete the separate transactions.
|
146
|
-
// https://github.com/GoogleChrome/workbox/issues/1978
|
147
|
-
// cursor.delete();
|
148
|
-
// We only need to return the URL, not the whole entry.
|
149
|
-
entriesToDelete.push(cursor.value);
|
150
|
-
} else {
|
151
|
-
entriesNotDeletedCount++;
|
152
|
-
}
|
153
|
-
}
|
154
|
-
|
155
|
-
cursor.continue();
|
156
|
-
} else {
|
157
|
-
done(entriesToDelete);
|
158
|
-
}
|
159
|
-
};
|
160
|
-
}); // TODO(philipwalton): once the Safari bug in the following issue is fixed,
|
161
|
-
// we should be able to remove this loop and do the entry deletion in the
|
162
|
-
// cursor loop above:
|
163
|
-
// https://github.com/GoogleChrome/workbox/issues/1978
|
164
|
-
|
165
|
-
const urlsDeleted = [];
|
166
|
-
|
167
|
-
for (const entry of entriesToDelete) {
|
168
|
-
await this._db.delete(OBJECT_STORE_NAME, entry.id);
|
169
|
-
urlsDeleted.push(entry.url);
|
170
|
-
}
|
171
|
-
|
172
|
-
return urlsDeleted;
|
173
|
-
}
|
174
|
-
/**
|
175
|
-
* Takes a URL and returns an ID that will be unique in the object store.
|
176
|
-
*
|
177
|
-
* @param {string} url
|
178
|
-
* @return {string}
|
179
|
-
*
|
180
|
-
* @private
|
181
|
-
*/
|
182
|
-
|
183
|
-
|
184
|
-
_getId(url) {
|
185
|
-
// Creating an ID from the URL and cache name won't be necessary once
|
186
|
-
// Edge switches to Chromium and all browsers we support work with
|
187
|
-
// array keyPaths.
|
188
|
-
return this._cacheName + '|' + normalizeURL(url);
|
189
|
-
}
|
190
|
-
|
191
|
-
}
|
192
|
-
|
193
|
-
/*
|
194
|
-
Copyright 2018 Google LLC
|
195
|
-
|
196
|
-
Use of this source code is governed by an MIT-style
|
197
|
-
license that can be found in the LICENSE file or at
|
198
|
-
https://opensource.org/licenses/MIT.
|
199
|
-
*/
|
200
|
-
/**
|
201
|
-
* The `CacheExpiration` class allows you define an expiration and / or
|
202
|
-
* limit on the number of responses stored in a
|
203
|
-
* [`Cache`](https://developer.mozilla.org/en-US/docs/Web/API/Cache).
|
204
|
-
*
|
205
|
-
* @memberof module:workbox-expiration
|
206
|
-
*/
|
207
|
-
|
208
|
-
class CacheExpiration {
|
209
|
-
/**
|
210
|
-
* To construct a new CacheExpiration instance you must provide at least
|
211
|
-
* one of the `config` properties.
|
212
|
-
*
|
213
|
-
* @param {string} cacheName Name of the cache to apply restrictions to.
|
214
|
-
* @param {Object} config
|
215
|
-
* @param {number} [config.maxEntries] The maximum number of entries to cache.
|
216
|
-
* Entries used the least will be removed as the maximum is reached.
|
217
|
-
* @param {number} [config.maxAgeSeconds] The maximum age of an entry before
|
218
|
-
* it's treated as stale and removed.
|
219
|
-
*/
|
220
|
-
constructor(cacheName, config = {}) {
|
221
|
-
this._isRunning = false;
|
222
|
-
this._rerunRequested = false;
|
223
|
-
|
224
|
-
{
|
225
|
-
assert_js.assert.isType(cacheName, 'string', {
|
226
|
-
moduleName: 'workbox-expiration',
|
227
|
-
className: 'CacheExpiration',
|
228
|
-
funcName: 'constructor',
|
229
|
-
paramName: 'cacheName'
|
230
|
-
});
|
231
|
-
|
232
|
-
if (!(config.maxEntries || config.maxAgeSeconds)) {
|
233
|
-
throw new WorkboxError_js.WorkboxError('max-entries-or-age-required', {
|
234
|
-
moduleName: 'workbox-expiration',
|
235
|
-
className: 'CacheExpiration',
|
236
|
-
funcName: 'constructor'
|
237
|
-
});
|
238
|
-
}
|
239
|
-
|
240
|
-
if (config.maxEntries) {
|
241
|
-
assert_js.assert.isType(config.maxEntries, 'number', {
|
242
|
-
moduleName: 'workbox-expiration',
|
243
|
-
className: 'CacheExpiration',
|
244
|
-
funcName: 'constructor',
|
245
|
-
paramName: 'config.maxEntries'
|
246
|
-
}); // TODO: Assert is positive
|
247
|
-
}
|
248
|
-
|
249
|
-
if (config.maxAgeSeconds) {
|
250
|
-
assert_js.assert.isType(config.maxAgeSeconds, 'number', {
|
251
|
-
moduleName: 'workbox-expiration',
|
252
|
-
className: 'CacheExpiration',
|
253
|
-
funcName: 'constructor',
|
254
|
-
paramName: 'config.maxAgeSeconds'
|
255
|
-
}); // TODO: Assert is positive
|
256
|
-
}
|
257
|
-
}
|
258
|
-
|
259
|
-
this._maxEntries = config.maxEntries;
|
260
|
-
this._maxAgeSeconds = config.maxAgeSeconds;
|
261
|
-
this._cacheName = cacheName;
|
262
|
-
this._timestampModel = new CacheTimestampsModel(cacheName);
|
263
|
-
}
|
264
|
-
/**
|
265
|
-
* Expires entries for the given cache and given criteria.
|
266
|
-
*/
|
267
|
-
|
268
|
-
|
269
|
-
async expireEntries() {
|
270
|
-
if (this._isRunning) {
|
271
|
-
this._rerunRequested = true;
|
272
|
-
return;
|
273
|
-
}
|
274
|
-
|
275
|
-
this._isRunning = true;
|
276
|
-
const minTimestamp = this._maxAgeSeconds ? Date.now() - this._maxAgeSeconds * 1000 : 0;
|
277
|
-
const urlsExpired = await this._timestampModel.expireEntries(minTimestamp, this._maxEntries); // Delete URLs from the cache
|
278
|
-
|
279
|
-
const cache = await self.caches.open(this._cacheName);
|
280
|
-
|
281
|
-
for (const url of urlsExpired) {
|
282
|
-
await cache.delete(url);
|
283
|
-
}
|
284
|
-
|
285
|
-
{
|
286
|
-
if (urlsExpired.length > 0) {
|
287
|
-
logger_js.logger.groupCollapsed(`Expired ${urlsExpired.length} ` + `${urlsExpired.length === 1 ? 'entry' : 'entries'} and removed ` + `${urlsExpired.length === 1 ? 'it' : 'them'} from the ` + `'${this._cacheName}' cache.`);
|
288
|
-
logger_js.logger.log(`Expired the following ${urlsExpired.length === 1 ? 'URL' : 'URLs'}:`);
|
289
|
-
urlsExpired.forEach(url => logger_js.logger.log(` ${url}`));
|
290
|
-
logger_js.logger.groupEnd();
|
291
|
-
} else {
|
292
|
-
logger_js.logger.debug(`Cache expiration ran and found no entries to remove.`);
|
293
|
-
}
|
294
|
-
}
|
295
|
-
|
296
|
-
this._isRunning = false;
|
297
|
-
|
298
|
-
if (this._rerunRequested) {
|
299
|
-
this._rerunRequested = false;
|
300
|
-
dontWaitFor_js.dontWaitFor(this.expireEntries());
|
301
|
-
}
|
302
|
-
}
|
303
|
-
/**
|
304
|
-
* Update the timestamp for the given URL. This ensures the when
|
305
|
-
* removing entries based on maximum entries, most recently used
|
306
|
-
* is accurate or when expiring, the timestamp is up-to-date.
|
307
|
-
*
|
308
|
-
* @param {string} url
|
309
|
-
*/
|
310
|
-
|
311
|
-
|
312
|
-
async updateTimestamp(url) {
|
313
|
-
{
|
314
|
-
assert_js.assert.isType(url, 'string', {
|
315
|
-
moduleName: 'workbox-expiration',
|
316
|
-
className: 'CacheExpiration',
|
317
|
-
funcName: 'updateTimestamp',
|
318
|
-
paramName: 'url'
|
319
|
-
});
|
320
|
-
}
|
321
|
-
|
322
|
-
await this._timestampModel.setTimestamp(url, Date.now());
|
323
|
-
}
|
324
|
-
/**
|
325
|
-
* Can be used to check if a URL has expired or not before it's used.
|
326
|
-
*
|
327
|
-
* This requires a look up from IndexedDB, so can be slow.
|
328
|
-
*
|
329
|
-
* Note: This method will not remove the cached entry, call
|
330
|
-
* `expireEntries()` to remove indexedDB and Cache entries.
|
331
|
-
*
|
332
|
-
* @param {string} url
|
333
|
-
* @return {boolean}
|
334
|
-
*/
|
335
|
-
|
336
|
-
|
337
|
-
async isURLExpired(url) {
|
338
|
-
if (!this._maxAgeSeconds) {
|
339
|
-
{
|
340
|
-
throw new WorkboxError_js.WorkboxError(`expired-test-without-max-age`, {
|
341
|
-
methodName: 'isURLExpired',
|
342
|
-
paramName: 'maxAgeSeconds'
|
343
|
-
});
|
344
|
-
}
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
|
361
|
-
//
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
|
372
|
-
|
373
|
-
|
374
|
-
|
375
|
-
|
376
|
-
*
|
377
|
-
*
|
378
|
-
*
|
379
|
-
*
|
380
|
-
*
|
381
|
-
*
|
382
|
-
*
|
383
|
-
*
|
384
|
-
*
|
385
|
-
*
|
386
|
-
*
|
387
|
-
*
|
388
|
-
*
|
389
|
-
*
|
390
|
-
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
*
|
397
|
-
* @param {number} [config.
|
398
|
-
*
|
399
|
-
* @param {
|
400
|
-
*
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
*
|
407
|
-
*
|
408
|
-
* from
|
409
|
-
*
|
410
|
-
*
|
411
|
-
*
|
412
|
-
*
|
413
|
-
* @param {
|
414
|
-
*
|
415
|
-
* @
|
416
|
-
*
|
417
|
-
*
|
418
|
-
*
|
419
|
-
|
420
|
-
|
421
|
-
|
422
|
-
|
423
|
-
|
424
|
-
|
425
|
-
|
426
|
-
cachedResponse
|
427
|
-
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
|
451
|
-
|
452
|
-
|
453
|
-
|
454
|
-
|
455
|
-
|
456
|
-
|
457
|
-
|
458
|
-
|
459
|
-
*
|
460
|
-
*
|
461
|
-
*
|
462
|
-
* @param {
|
463
|
-
*
|
464
|
-
* @
|
465
|
-
|
466
|
-
|
467
|
-
|
468
|
-
|
469
|
-
|
470
|
-
|
471
|
-
|
472
|
-
|
473
|
-
|
474
|
-
|
475
|
-
|
476
|
-
|
477
|
-
|
478
|
-
|
479
|
-
|
480
|
-
|
481
|
-
|
482
|
-
|
483
|
-
|
484
|
-
|
485
|
-
|
486
|
-
|
487
|
-
|
488
|
-
|
489
|
-
|
490
|
-
|
491
|
-
|
492
|
-
|
493
|
-
|
494
|
-
|
495
|
-
|
496
|
-
|
497
|
-
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
|
509
|
-
|
510
|
-
|
511
|
-
|
512
|
-
|
513
|
-
|
514
|
-
|
515
|
-
|
516
|
-
|
517
|
-
|
518
|
-
|
519
|
-
|
520
|
-
|
521
|
-
|
522
|
-
|
523
|
-
this.
|
524
|
-
|
525
|
-
|
526
|
-
|
527
|
-
|
528
|
-
|
529
|
-
|
530
|
-
|
531
|
-
|
532
|
-
*
|
533
|
-
*
|
534
|
-
*
|
535
|
-
*
|
536
|
-
* @
|
537
|
-
|
538
|
-
|
539
|
-
|
540
|
-
|
541
|
-
|
542
|
-
|
543
|
-
|
544
|
-
|
545
|
-
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
|
550
|
-
|
551
|
-
|
552
|
-
|
553
|
-
|
554
|
-
|
555
|
-
|
556
|
-
|
557
|
-
|
558
|
-
*
|
559
|
-
* @
|
560
|
-
|
561
|
-
|
562
|
-
|
563
|
-
|
564
|
-
|
565
|
-
|
566
|
-
|
567
|
-
|
568
|
-
|
569
|
-
|
570
|
-
|
571
|
-
|
572
|
-
|
573
|
-
|
574
|
-
|
575
|
-
|
576
|
-
|
577
|
-
|
578
|
-
|
579
|
-
|
580
|
-
|
581
|
-
|
582
|
-
|
583
|
-
|
584
|
-
|
585
|
-
|
586
|
-
|
587
|
-
*
|
588
|
-
*
|
589
|
-
*
|
590
|
-
*
|
591
|
-
* @
|
592
|
-
|
593
|
-
|
594
|
-
|
595
|
-
|
596
|
-
|
597
|
-
|
598
|
-
|
599
|
-
|
600
|
-
|
601
|
-
|
602
|
-
const
|
603
|
-
|
604
|
-
|
605
|
-
|
606
|
-
|
607
|
-
|
608
|
-
|
609
|
-
|
610
|
-
|
611
|
-
|
612
|
-
|
613
|
-
|
614
|
-
*
|
615
|
-
*
|
616
|
-
* - Deletes
|
617
|
-
*
|
618
|
-
*
|
619
|
-
*
|
620
|
-
*
|
621
|
-
*
|
622
|
-
*
|
623
|
-
*
|
624
|
-
*
|
625
|
-
*
|
626
|
-
|
627
|
-
|
628
|
-
|
629
|
-
|
630
|
-
|
631
|
-
|
632
|
-
|
633
|
-
|
634
|
-
|
635
|
-
|
636
|
-
|
637
|
-
|
638
|
-
|
639
|
-
|
640
|
-
|
641
|
-
|
642
|
-
|
643
|
-
|
644
|
-
|
645
|
-
|
646
|
-
exports
|
647
|
-
|
648
|
-
|
649
|
-
|
650
|
-
}({}, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core));
|
651
|
-
//# sourceMappingURL=workbox-expiration.dev.js.map
|
1
|
+
this.workbox = this.workbox || {};
|
2
|
+
this.workbox.expiration = (function (exports, assert_js, dontWaitFor_js, logger_js, WorkboxError_js, DBWrapper_js, deleteDatabase_js, cacheNames_js, getFriendlyURL_js, registerQuotaErrorCallback_js) {
|
3
|
+
'use strict';
|
4
|
+
|
5
|
+
try {
|
6
|
+
self['workbox:expiration:5.1.1'] && _();
|
7
|
+
} catch (e) {}
|
8
|
+
|
9
|
+
/*
|
10
|
+
Copyright 2018 Google LLC
|
11
|
+
|
12
|
+
Use of this source code is governed by an MIT-style
|
13
|
+
license that can be found in the LICENSE file or at
|
14
|
+
https://opensource.org/licenses/MIT.
|
15
|
+
*/
|
16
|
+
const DB_NAME = 'workbox-expiration';
|
17
|
+
const OBJECT_STORE_NAME = 'cache-entries';
|
18
|
+
|
19
|
+
const normalizeURL = unNormalizedUrl => {
|
20
|
+
const url = new URL(unNormalizedUrl, location.href);
|
21
|
+
url.hash = '';
|
22
|
+
return url.href;
|
23
|
+
};
|
24
|
+
/**
|
25
|
+
* Returns the timestamp model.
|
26
|
+
*
|
27
|
+
* @private
|
28
|
+
*/
|
29
|
+
|
30
|
+
|
31
|
+
class CacheTimestampsModel {
|
32
|
+
/**
|
33
|
+
*
|
34
|
+
* @param {string} cacheName
|
35
|
+
*
|
36
|
+
* @private
|
37
|
+
*/
|
38
|
+
constructor(cacheName) {
|
39
|
+
this._cacheName = cacheName;
|
40
|
+
this._db = new DBWrapper_js.DBWrapper(DB_NAME, 1, {
|
41
|
+
onupgradeneeded: event => this._handleUpgrade(event)
|
42
|
+
});
|
43
|
+
}
|
44
|
+
/**
|
45
|
+
* Should perform an upgrade of indexedDB.
|
46
|
+
*
|
47
|
+
* @param {Event} event
|
48
|
+
*
|
49
|
+
* @private
|
50
|
+
*/
|
51
|
+
|
52
|
+
|
53
|
+
_handleUpgrade(event) {
|
54
|
+
const db = event.target.result; // TODO(philipwalton): EdgeHTML doesn't support arrays as a keyPath, so we
|
55
|
+
// have to use the `id` keyPath here and create our own values (a
|
56
|
+
// concatenation of `url + cacheName`) instead of simply using
|
57
|
+
// `keyPath: ['url', 'cacheName']`, which is supported in other browsers.
|
58
|
+
|
59
|
+
const objStore = db.createObjectStore(OBJECT_STORE_NAME, {
|
60
|
+
keyPath: 'id'
|
61
|
+
}); // TODO(philipwalton): once we don't have to support EdgeHTML, we can
|
62
|
+
// create a single index with the keyPath `['cacheName', 'timestamp']`
|
63
|
+
// instead of doing both these indexes.
|
64
|
+
|
65
|
+
objStore.createIndex('cacheName', 'cacheName', {
|
66
|
+
unique: false
|
67
|
+
});
|
68
|
+
objStore.createIndex('timestamp', 'timestamp', {
|
69
|
+
unique: false
|
70
|
+
}); // Previous versions of `workbox-expiration` used `this._cacheName`
|
71
|
+
// as the IDBDatabase name.
|
72
|
+
|
73
|
+
deleteDatabase_js.deleteDatabase(this._cacheName);
|
74
|
+
}
|
75
|
+
/**
|
76
|
+
* @param {string} url
|
77
|
+
* @param {number} timestamp
|
78
|
+
*
|
79
|
+
* @private
|
80
|
+
*/
|
81
|
+
|
82
|
+
|
83
|
+
async setTimestamp(url, timestamp) {
|
84
|
+
url = normalizeURL(url);
|
85
|
+
const entry = {
|
86
|
+
url,
|
87
|
+
timestamp,
|
88
|
+
cacheName: this._cacheName,
|
89
|
+
// Creating an ID from the URL and cache name won't be necessary once
|
90
|
+
// Edge switches to Chromium and all browsers we support work with
|
91
|
+
// array keyPaths.
|
92
|
+
id: this._getId(url)
|
93
|
+
};
|
94
|
+
await this._db.put(OBJECT_STORE_NAME, entry);
|
95
|
+
}
|
96
|
+
/**
|
97
|
+
* Returns the timestamp stored for a given URL.
|
98
|
+
*
|
99
|
+
* @param {string} url
|
100
|
+
* @return {number}
|
101
|
+
*
|
102
|
+
* @private
|
103
|
+
*/
|
104
|
+
|
105
|
+
|
106
|
+
async getTimestamp(url) {
|
107
|
+
const entry = await this._db.get(OBJECT_STORE_NAME, this._getId(url));
|
108
|
+
return entry.timestamp;
|
109
|
+
}
|
110
|
+
/**
|
111
|
+
* Iterates through all the entries in the object store (from newest to
|
112
|
+
* oldest) and removes entries once either `maxCount` is reached or the
|
113
|
+
* entry's timestamp is less than `minTimestamp`.
|
114
|
+
*
|
115
|
+
* @param {number} minTimestamp
|
116
|
+
* @param {number} maxCount
|
117
|
+
* @return {Array<string>}
|
118
|
+
*
|
119
|
+
* @private
|
120
|
+
*/
|
121
|
+
|
122
|
+
|
123
|
+
async expireEntries(minTimestamp, maxCount) {
|
124
|
+
const entriesToDelete = await this._db.transaction(OBJECT_STORE_NAME, 'readwrite', (txn, done) => {
|
125
|
+
const store = txn.objectStore(OBJECT_STORE_NAME);
|
126
|
+
const request = store.index('timestamp').openCursor(null, 'prev');
|
127
|
+
const entriesToDelete = [];
|
128
|
+
let entriesNotDeletedCount = 0;
|
129
|
+
|
130
|
+
request.onsuccess = () => {
|
131
|
+
const cursor = request.result;
|
132
|
+
|
133
|
+
if (cursor) {
|
134
|
+
const result = cursor.value; // TODO(philipwalton): once we can use a multi-key index, we
|
135
|
+
// won't have to check `cacheName` here.
|
136
|
+
|
137
|
+
if (result.cacheName === this._cacheName) {
|
138
|
+
// Delete an entry if it's older than the max age or
|
139
|
+
// if we already have the max number allowed.
|
140
|
+
if (minTimestamp && result.timestamp < minTimestamp || maxCount && entriesNotDeletedCount >= maxCount) {
|
141
|
+
// TODO(philipwalton): we should be able to delete the
|
142
|
+
// entry right here, but doing so causes an iteration
|
143
|
+
// bug in Safari stable (fixed in TP). Instead we can
|
144
|
+
// store the keys of the entries to delete, and then
|
145
|
+
// delete the separate transactions.
|
146
|
+
// https://github.com/GoogleChrome/workbox/issues/1978
|
147
|
+
// cursor.delete();
|
148
|
+
// We only need to return the URL, not the whole entry.
|
149
|
+
entriesToDelete.push(cursor.value);
|
150
|
+
} else {
|
151
|
+
entriesNotDeletedCount++;
|
152
|
+
}
|
153
|
+
}
|
154
|
+
|
155
|
+
cursor.continue();
|
156
|
+
} else {
|
157
|
+
done(entriesToDelete);
|
158
|
+
}
|
159
|
+
};
|
160
|
+
}); // TODO(philipwalton): once the Safari bug in the following issue is fixed,
|
161
|
+
// we should be able to remove this loop and do the entry deletion in the
|
162
|
+
// cursor loop above:
|
163
|
+
// https://github.com/GoogleChrome/workbox/issues/1978
|
164
|
+
|
165
|
+
const urlsDeleted = [];
|
166
|
+
|
167
|
+
for (const entry of entriesToDelete) {
|
168
|
+
await this._db.delete(OBJECT_STORE_NAME, entry.id);
|
169
|
+
urlsDeleted.push(entry.url);
|
170
|
+
}
|
171
|
+
|
172
|
+
return urlsDeleted;
|
173
|
+
}
|
174
|
+
/**
|
175
|
+
* Takes a URL and returns an ID that will be unique in the object store.
|
176
|
+
*
|
177
|
+
* @param {string} url
|
178
|
+
* @return {string}
|
179
|
+
*
|
180
|
+
* @private
|
181
|
+
*/
|
182
|
+
|
183
|
+
|
184
|
+
_getId(url) {
|
185
|
+
// Creating an ID from the URL and cache name won't be necessary once
|
186
|
+
// Edge switches to Chromium and all browsers we support work with
|
187
|
+
// array keyPaths.
|
188
|
+
return this._cacheName + '|' + normalizeURL(url);
|
189
|
+
}
|
190
|
+
|
191
|
+
}
|
192
|
+
|
193
|
+
/*
|
194
|
+
Copyright 2018 Google LLC
|
195
|
+
|
196
|
+
Use of this source code is governed by an MIT-style
|
197
|
+
license that can be found in the LICENSE file or at
|
198
|
+
https://opensource.org/licenses/MIT.
|
199
|
+
*/
|
200
|
+
/**
|
201
|
+
* The `CacheExpiration` class allows you define an expiration and / or
|
202
|
+
* limit on the number of responses stored in a
|
203
|
+
* [`Cache`](https://developer.mozilla.org/en-US/docs/Web/API/Cache).
|
204
|
+
*
|
205
|
+
* @memberof module:workbox-expiration
|
206
|
+
*/
|
207
|
+
|
208
|
+
class CacheExpiration {
|
209
|
+
/**
|
210
|
+
* To construct a new CacheExpiration instance you must provide at least
|
211
|
+
* one of the `config` properties.
|
212
|
+
*
|
213
|
+
* @param {string} cacheName Name of the cache to apply restrictions to.
|
214
|
+
* @param {Object} config
|
215
|
+
* @param {number} [config.maxEntries] The maximum number of entries to cache.
|
216
|
+
* Entries used the least will be removed as the maximum is reached.
|
217
|
+
* @param {number} [config.maxAgeSeconds] The maximum age of an entry before
|
218
|
+
* it's treated as stale and removed.
|
219
|
+
*/
|
220
|
+
constructor(cacheName, config = {}) {
|
221
|
+
this._isRunning = false;
|
222
|
+
this._rerunRequested = false;
|
223
|
+
|
224
|
+
{
|
225
|
+
assert_js.assert.isType(cacheName, 'string', {
|
226
|
+
moduleName: 'workbox-expiration',
|
227
|
+
className: 'CacheExpiration',
|
228
|
+
funcName: 'constructor',
|
229
|
+
paramName: 'cacheName'
|
230
|
+
});
|
231
|
+
|
232
|
+
if (!(config.maxEntries || config.maxAgeSeconds)) {
|
233
|
+
throw new WorkboxError_js.WorkboxError('max-entries-or-age-required', {
|
234
|
+
moduleName: 'workbox-expiration',
|
235
|
+
className: 'CacheExpiration',
|
236
|
+
funcName: 'constructor'
|
237
|
+
});
|
238
|
+
}
|
239
|
+
|
240
|
+
if (config.maxEntries) {
|
241
|
+
assert_js.assert.isType(config.maxEntries, 'number', {
|
242
|
+
moduleName: 'workbox-expiration',
|
243
|
+
className: 'CacheExpiration',
|
244
|
+
funcName: 'constructor',
|
245
|
+
paramName: 'config.maxEntries'
|
246
|
+
}); // TODO: Assert is positive
|
247
|
+
}
|
248
|
+
|
249
|
+
if (config.maxAgeSeconds) {
|
250
|
+
assert_js.assert.isType(config.maxAgeSeconds, 'number', {
|
251
|
+
moduleName: 'workbox-expiration',
|
252
|
+
className: 'CacheExpiration',
|
253
|
+
funcName: 'constructor',
|
254
|
+
paramName: 'config.maxAgeSeconds'
|
255
|
+
}); // TODO: Assert is positive
|
256
|
+
}
|
257
|
+
}
|
258
|
+
|
259
|
+
this._maxEntries = config.maxEntries;
|
260
|
+
this._maxAgeSeconds = config.maxAgeSeconds;
|
261
|
+
this._cacheName = cacheName;
|
262
|
+
this._timestampModel = new CacheTimestampsModel(cacheName);
|
263
|
+
}
|
264
|
+
/**
|
265
|
+
* Expires entries for the given cache and given criteria.
|
266
|
+
*/
|
267
|
+
|
268
|
+
|
269
|
+
async expireEntries() {
|
270
|
+
if (this._isRunning) {
|
271
|
+
this._rerunRequested = true;
|
272
|
+
return;
|
273
|
+
}
|
274
|
+
|
275
|
+
this._isRunning = true;
|
276
|
+
const minTimestamp = this._maxAgeSeconds ? Date.now() - this._maxAgeSeconds * 1000 : 0;
|
277
|
+
const urlsExpired = await this._timestampModel.expireEntries(minTimestamp, this._maxEntries); // Delete URLs from the cache
|
278
|
+
|
279
|
+
const cache = await self.caches.open(this._cacheName);
|
280
|
+
|
281
|
+
for (const url of urlsExpired) {
|
282
|
+
await cache.delete(url);
|
283
|
+
}
|
284
|
+
|
285
|
+
{
|
286
|
+
if (urlsExpired.length > 0) {
|
287
|
+
logger_js.logger.groupCollapsed(`Expired ${urlsExpired.length} ` + `${urlsExpired.length === 1 ? 'entry' : 'entries'} and removed ` + `${urlsExpired.length === 1 ? 'it' : 'them'} from the ` + `'${this._cacheName}' cache.`);
|
288
|
+
logger_js.logger.log(`Expired the following ${urlsExpired.length === 1 ? 'URL' : 'URLs'}:`);
|
289
|
+
urlsExpired.forEach(url => logger_js.logger.log(` ${url}`));
|
290
|
+
logger_js.logger.groupEnd();
|
291
|
+
} else {
|
292
|
+
logger_js.logger.debug(`Cache expiration ran and found no entries to remove.`);
|
293
|
+
}
|
294
|
+
}
|
295
|
+
|
296
|
+
this._isRunning = false;
|
297
|
+
|
298
|
+
if (this._rerunRequested) {
|
299
|
+
this._rerunRequested = false;
|
300
|
+
dontWaitFor_js.dontWaitFor(this.expireEntries());
|
301
|
+
}
|
302
|
+
}
|
303
|
+
/**
|
304
|
+
* Update the timestamp for the given URL. This ensures the when
|
305
|
+
* removing entries based on maximum entries, most recently used
|
306
|
+
* is accurate or when expiring, the timestamp is up-to-date.
|
307
|
+
*
|
308
|
+
* @param {string} url
|
309
|
+
*/
|
310
|
+
|
311
|
+
|
312
|
+
async updateTimestamp(url) {
|
313
|
+
{
|
314
|
+
assert_js.assert.isType(url, 'string', {
|
315
|
+
moduleName: 'workbox-expiration',
|
316
|
+
className: 'CacheExpiration',
|
317
|
+
funcName: 'updateTimestamp',
|
318
|
+
paramName: 'url'
|
319
|
+
});
|
320
|
+
}
|
321
|
+
|
322
|
+
await this._timestampModel.setTimestamp(url, Date.now());
|
323
|
+
}
|
324
|
+
/**
|
325
|
+
* Can be used to check if a URL has expired or not before it's used.
|
326
|
+
*
|
327
|
+
* This requires a look up from IndexedDB, so can be slow.
|
328
|
+
*
|
329
|
+
* Note: This method will not remove the cached entry, call
|
330
|
+
* `expireEntries()` to remove indexedDB and Cache entries.
|
331
|
+
*
|
332
|
+
* @param {string} url
|
333
|
+
* @return {boolean}
|
334
|
+
*/
|
335
|
+
|
336
|
+
|
337
|
+
async isURLExpired(url) {
|
338
|
+
if (!this._maxAgeSeconds) {
|
339
|
+
{
|
340
|
+
throw new WorkboxError_js.WorkboxError(`expired-test-without-max-age`, {
|
341
|
+
methodName: 'isURLExpired',
|
342
|
+
paramName: 'maxAgeSeconds'
|
343
|
+
});
|
344
|
+
}
|
345
|
+
} else {
|
346
|
+
const timestamp = await this._timestampModel.getTimestamp(url);
|
347
|
+
const expireOlderThan = Date.now() - this._maxAgeSeconds * 1000;
|
348
|
+
return timestamp < expireOlderThan;
|
349
|
+
}
|
350
|
+
}
|
351
|
+
/**
|
352
|
+
* Removes the IndexedDB object store used to keep track of cache expiration
|
353
|
+
* metadata.
|
354
|
+
*/
|
355
|
+
|
356
|
+
|
357
|
+
async delete() {
|
358
|
+
// Make sure we don't attempt another rerun if we're called in the middle of
|
359
|
+
// a cache expiration.
|
360
|
+
this._rerunRequested = false;
|
361
|
+
await this._timestampModel.expireEntries(Infinity); // Expires all.
|
362
|
+
}
|
363
|
+
|
364
|
+
}
|
365
|
+
|
366
|
+
/*
|
367
|
+
Copyright 2018 Google LLC
|
368
|
+
|
369
|
+
Use of this source code is governed by an MIT-style
|
370
|
+
license that can be found in the LICENSE file or at
|
371
|
+
https://opensource.org/licenses/MIT.
|
372
|
+
*/
|
373
|
+
/**
|
374
|
+
* This plugin can be used in the Workbox APIs to regularly enforce a
|
375
|
+
* limit on the age and / or the number of cached requests.
|
376
|
+
*
|
377
|
+
* Whenever a cached request is used or updated, this plugin will look
|
378
|
+
* at the used Cache and remove any old or extra requests.
|
379
|
+
*
|
380
|
+
* When using `maxAgeSeconds`, requests may be used *once* after expiring
|
381
|
+
* because the expiration clean up will not have occurred until *after* the
|
382
|
+
* cached request has been used. If the request has a "Date" header, then
|
383
|
+
* a light weight expiration check is performed and the request will not be
|
384
|
+
* used immediately.
|
385
|
+
*
|
386
|
+
* When using `maxEntries`, the entry least-recently requested will be removed
|
387
|
+
* from the cache first.
|
388
|
+
*
|
389
|
+
* @memberof module:workbox-expiration
|
390
|
+
*/
|
391
|
+
|
392
|
+
class ExpirationPlugin {
|
393
|
+
/**
|
394
|
+
* @param {Object} config
|
395
|
+
* @param {number} [config.maxEntries] The maximum number of entries to cache.
|
396
|
+
* Entries used the least will be removed as the maximum is reached.
|
397
|
+
* @param {number} [config.maxAgeSeconds] The maximum age of an entry before
|
398
|
+
* it's treated as stale and removed.
|
399
|
+
* @param {boolean} [config.purgeOnQuotaError] Whether to opt this cache in to
|
400
|
+
* automatic deletion if the available storage quota has been exceeded.
|
401
|
+
*/
|
402
|
+
constructor(config = {}) {
|
403
|
+
/**
|
404
|
+
* A "lifecycle" callback that will be triggered automatically by the
|
405
|
+
* `workbox-strategies` handlers when a `Response` is about to be returned
|
406
|
+
* from a [Cache](https://developer.mozilla.org/en-US/docs/Web/API/Cache) to
|
407
|
+
* the handler. It allows the `Response` to be inspected for freshness and
|
408
|
+
* prevents it from being used if the `Response`'s `Date` header value is
|
409
|
+
* older than the configured `maxAgeSeconds`.
|
410
|
+
*
|
411
|
+
* @param {Object} options
|
412
|
+
* @param {string} options.cacheName Name of the cache the response is in.
|
413
|
+
* @param {Response} options.cachedResponse The `Response` object that's been
|
414
|
+
* read from a cache and whose freshness should be checked.
|
415
|
+
* @return {Response} Either the `cachedResponse`, if it's
|
416
|
+
* fresh, or `null` if the `Response` is older than `maxAgeSeconds`.
|
417
|
+
*
|
418
|
+
* @private
|
419
|
+
*/
|
420
|
+
this.cachedResponseWillBeUsed = async ({
|
421
|
+
event,
|
422
|
+
request,
|
423
|
+
cacheName,
|
424
|
+
cachedResponse
|
425
|
+
}) => {
|
426
|
+
if (!cachedResponse) {
|
427
|
+
return null;
|
428
|
+
}
|
429
|
+
|
430
|
+
const isFresh = this._isResponseDateFresh(cachedResponse); // Expire entries to ensure that even if the expiration date has
|
431
|
+
// expired, it'll only be used once.
|
432
|
+
|
433
|
+
|
434
|
+
const cacheExpiration = this._getCacheExpiration(cacheName);
|
435
|
+
|
436
|
+
dontWaitFor_js.dontWaitFor(cacheExpiration.expireEntries()); // Update the metadata for the request URL to the current timestamp,
|
437
|
+
// but don't `await` it as we don't want to block the response.
|
438
|
+
|
439
|
+
const updateTimestampDone = cacheExpiration.updateTimestamp(request.url);
|
440
|
+
|
441
|
+
if (event) {
|
442
|
+
try {
|
443
|
+
event.waitUntil(updateTimestampDone);
|
444
|
+
} catch (error) {
|
445
|
+
{
|
446
|
+
// The event may not be a fetch event; only log the URL if it is.
|
447
|
+
if ('request' in event) {
|
448
|
+
logger_js.logger.warn(`Unable to ensure service worker stays alive when ` + `updating cache entry for ` + `'${getFriendlyURL_js.getFriendlyURL(event.request.url)}'.`);
|
449
|
+
}
|
450
|
+
}
|
451
|
+
}
|
452
|
+
}
|
453
|
+
|
454
|
+
return isFresh ? cachedResponse : null;
|
455
|
+
};
|
456
|
+
/**
|
457
|
+
* A "lifecycle" callback that will be triggered automatically by the
|
458
|
+
* `workbox-strategies` handlers when an entry is added to a cache.
|
459
|
+
*
|
460
|
+
* @param {Object} options
|
461
|
+
* @param {string} options.cacheName Name of the cache that was updated.
|
462
|
+
* @param {string} options.request The Request for the cached entry.
|
463
|
+
*
|
464
|
+
* @private
|
465
|
+
*/
|
466
|
+
|
467
|
+
|
468
|
+
this.cacheDidUpdate = async ({
|
469
|
+
cacheName,
|
470
|
+
request
|
471
|
+
}) => {
|
472
|
+
{
|
473
|
+
assert_js.assert.isType(cacheName, 'string', {
|
474
|
+
moduleName: 'workbox-expiration',
|
475
|
+
className: 'Plugin',
|
476
|
+
funcName: 'cacheDidUpdate',
|
477
|
+
paramName: 'cacheName'
|
478
|
+
});
|
479
|
+
assert_js.assert.isInstance(request, Request, {
|
480
|
+
moduleName: 'workbox-expiration',
|
481
|
+
className: 'Plugin',
|
482
|
+
funcName: 'cacheDidUpdate',
|
483
|
+
paramName: 'request'
|
484
|
+
});
|
485
|
+
}
|
486
|
+
|
487
|
+
const cacheExpiration = this._getCacheExpiration(cacheName);
|
488
|
+
|
489
|
+
await cacheExpiration.updateTimestamp(request.url);
|
490
|
+
await cacheExpiration.expireEntries();
|
491
|
+
};
|
492
|
+
|
493
|
+
{
|
494
|
+
if (!(config.maxEntries || config.maxAgeSeconds)) {
|
495
|
+
throw new WorkboxError_js.WorkboxError('max-entries-or-age-required', {
|
496
|
+
moduleName: 'workbox-expiration',
|
497
|
+
className: 'Plugin',
|
498
|
+
funcName: 'constructor'
|
499
|
+
});
|
500
|
+
}
|
501
|
+
|
502
|
+
if (config.maxEntries) {
|
503
|
+
assert_js.assert.isType(config.maxEntries, 'number', {
|
504
|
+
moduleName: 'workbox-expiration',
|
505
|
+
className: 'Plugin',
|
506
|
+
funcName: 'constructor',
|
507
|
+
paramName: 'config.maxEntries'
|
508
|
+
});
|
509
|
+
}
|
510
|
+
|
511
|
+
if (config.maxAgeSeconds) {
|
512
|
+
assert_js.assert.isType(config.maxAgeSeconds, 'number', {
|
513
|
+
moduleName: 'workbox-expiration',
|
514
|
+
className: 'Plugin',
|
515
|
+
funcName: 'constructor',
|
516
|
+
paramName: 'config.maxAgeSeconds'
|
517
|
+
});
|
518
|
+
}
|
519
|
+
}
|
520
|
+
|
521
|
+
this._config = config;
|
522
|
+
this._maxAgeSeconds = config.maxAgeSeconds;
|
523
|
+
this._cacheExpirations = new Map();
|
524
|
+
|
525
|
+
if (config.purgeOnQuotaError) {
|
526
|
+
registerQuotaErrorCallback_js.registerQuotaErrorCallback(() => this.deleteCacheAndMetadata());
|
527
|
+
}
|
528
|
+
}
|
529
|
+
/**
|
530
|
+
* A simple helper method to return a CacheExpiration instance for a given
|
531
|
+
* cache name.
|
532
|
+
*
|
533
|
+
* @param {string} cacheName
|
534
|
+
* @return {CacheExpiration}
|
535
|
+
*
|
536
|
+
* @private
|
537
|
+
*/
|
538
|
+
|
539
|
+
|
540
|
+
_getCacheExpiration(cacheName) {
|
541
|
+
if (cacheName === cacheNames_js.cacheNames.getRuntimeName()) {
|
542
|
+
throw new WorkboxError_js.WorkboxError('expire-custom-caches-only');
|
543
|
+
}
|
544
|
+
|
545
|
+
let cacheExpiration = this._cacheExpirations.get(cacheName);
|
546
|
+
|
547
|
+
if (!cacheExpiration) {
|
548
|
+
cacheExpiration = new CacheExpiration(cacheName, this._config);
|
549
|
+
|
550
|
+
this._cacheExpirations.set(cacheName, cacheExpiration);
|
551
|
+
}
|
552
|
+
|
553
|
+
return cacheExpiration;
|
554
|
+
}
|
555
|
+
/**
|
556
|
+
* @param {Response} cachedResponse
|
557
|
+
* @return {boolean}
|
558
|
+
*
|
559
|
+
* @private
|
560
|
+
*/
|
561
|
+
|
562
|
+
|
563
|
+
_isResponseDateFresh(cachedResponse) {
|
564
|
+
if (!this._maxAgeSeconds) {
|
565
|
+
// We aren't expiring by age, so return true, it's fresh
|
566
|
+
return true;
|
567
|
+
} // Check if the 'date' header will suffice a quick expiration check.
|
568
|
+
// See https://github.com/GoogleChromeLabs/sw-toolbox/issues/164 for
|
569
|
+
// discussion.
|
570
|
+
|
571
|
+
|
572
|
+
const dateHeaderTimestamp = this._getDateHeaderTimestamp(cachedResponse);
|
573
|
+
|
574
|
+
if (dateHeaderTimestamp === null) {
|
575
|
+
// Unable to parse date, so assume it's fresh.
|
576
|
+
return true;
|
577
|
+
} // If we have a valid headerTime, then our response is fresh iff the
|
578
|
+
// headerTime plus maxAgeSeconds is greater than the current time.
|
579
|
+
|
580
|
+
|
581
|
+
const now = Date.now();
|
582
|
+
return dateHeaderTimestamp >= now - this._maxAgeSeconds * 1000;
|
583
|
+
}
|
584
|
+
/**
|
585
|
+
* This method will extract the data header and parse it into a useful
|
586
|
+
* value.
|
587
|
+
*
|
588
|
+
* @param {Response} cachedResponse
|
589
|
+
* @return {number|null}
|
590
|
+
*
|
591
|
+
* @private
|
592
|
+
*/
|
593
|
+
|
594
|
+
|
595
|
+
_getDateHeaderTimestamp(cachedResponse) {
|
596
|
+
if (!cachedResponse.headers.has('date')) {
|
597
|
+
return null;
|
598
|
+
}
|
599
|
+
|
600
|
+
const dateHeader = cachedResponse.headers.get('date');
|
601
|
+
const parsedDate = new Date(dateHeader);
|
602
|
+
const headerTime = parsedDate.getTime(); // If the Date header was invalid for some reason, parsedDate.getTime()
|
603
|
+
// will return NaN.
|
604
|
+
|
605
|
+
if (isNaN(headerTime)) {
|
606
|
+
return null;
|
607
|
+
}
|
608
|
+
|
609
|
+
return headerTime;
|
610
|
+
}
|
611
|
+
/**
|
612
|
+
* This is a helper method that performs two operations:
|
613
|
+
*
|
614
|
+
* - Deletes *all* the underlying Cache instances associated with this plugin
|
615
|
+
* instance, by calling caches.delete() on your behalf.
|
616
|
+
* - Deletes the metadata from IndexedDB used to keep track of expiration
|
617
|
+
* details for each Cache instance.
|
618
|
+
*
|
619
|
+
* When using cache expiration, calling this method is preferable to calling
|
620
|
+
* `caches.delete()` directly, since this will ensure that the IndexedDB
|
621
|
+
* metadata is also cleanly removed and open IndexedDB instances are deleted.
|
622
|
+
*
|
623
|
+
* Note that if you're *not* using cache expiration for a given cache, calling
|
624
|
+
* `caches.delete()` and passing in the cache's name should be sufficient.
|
625
|
+
* There is no Workbox-specific method needed for cleanup in that case.
|
626
|
+
*/
|
627
|
+
|
628
|
+
|
629
|
+
async deleteCacheAndMetadata() {
|
630
|
+
// Do this one at a time instead of all at once via `Promise.all()` to
|
631
|
+
// reduce the chance of inconsistency if a promise rejects.
|
632
|
+
for (const [cacheName, cacheExpiration] of this._cacheExpirations) {
|
633
|
+
await self.caches.delete(cacheName);
|
634
|
+
await cacheExpiration.delete();
|
635
|
+
} // Reset this._cacheExpirations to its initial state.
|
636
|
+
|
637
|
+
|
638
|
+
this._cacheExpirations = new Map();
|
639
|
+
}
|
640
|
+
|
641
|
+
}
|
642
|
+
|
643
|
+
exports.CacheExpiration = CacheExpiration;
|
644
|
+
exports.ExpirationPlugin = ExpirationPlugin;
|
645
|
+
|
646
|
+
return exports;
|
647
|
+
|
648
|
+
}({}, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core._private, workbox.core));
|
649
|
+
//# sourceMappingURL=workbox-expiration.dev.js.map
|