Created
October 6, 2020 18:20
-
-
Save csells/b4bf5fef1fbf89fb95be832b4dee2fb9 to your computer and use it in GitHub Desktop.
is this the right flutter_service_worker.js?
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| 'use strict'; | |
| const MANIFEST = 'flutter-app-manifest'; | |
| const TEMP = 'flutter-temp-cache'; | |
| const CACHE_NAME = 'flutter-app-cache'; | |
| const RESOURCES = { | |
| "index.html": "a58c88636d635d4e0c49558074bc4ef2", | |
| "/": "a58c88636d635d4e0c49558074bc4ef2", | |
| "main.dart.js": "5bb905324f0943ab98284299b6b0e012", | |
| "favicon.png": "5dcef449791fa27946b3d35ad8803796", | |
| "icons/Icon-192.png": "ac9a721a12bbc803b44f645561ecb1e1", | |
| "icons/Icon-512.png": "96e752610906ba2a93c65f8abe1645f1", | |
| "manifest.json": "a8d2721574ea9f8a6bfd302ff5596df3", | |
| "assets/AssetManifest.json": "34d289a12dfce32ddd083a2bfc1f6f5a", | |
| "assets/NOTICES": "c5317f19163f34bfe9478d0168c1176c", | |
| "assets/FontManifest.json": "7b2a36307916a9721811788013e65289", | |
| "assets/packages/flutter_markdown/assets/logo.png": "67642a0b80f3d50277c44cde8f450e50", | |
| "assets/fonts/MaterialIcons-Regular.otf": "a68d2a28c526b3b070aefca4bac93d25", | |
| "assets/assets/dysonlogos-compass-rose.png": "ed0a63490106f23554b1e40504e04fcb", | |
| "assets/assets/starter-adv.json": "b5873fdefd5ccd2eed1e67b1a9f60e76", | |
| "assets/assets/d20_48px.png": "fc2393c393a7ec2c253f7ce0162314ff" | |
| }; | |
| // The application shell files that are downloaded before a service worker can | |
| // start. | |
| const CORE = [ | |
| "/", | |
| "main.dart.js", | |
| "index.html", | |
| "assets/NOTICES", | |
| "assets/AssetManifest.json", | |
| "assets/FontManifest.json"]; | |
| // During install, the TEMP cache is populated with the application shell files. | |
| self.addEventListener("install", (event) => { | |
| return event.waitUntil( | |
| caches.open(TEMP).then((cache) => { | |
| return cache.addAll( | |
| CORE.map((value) => new Request(value + '?revision=' + RESOURCES[value], {'cache': 'reload'}))); | |
| }) | |
| ); | |
| }); | |
| // During activate, the cache is populated with the temp files downloaded in | |
| // install. If this service worker is upgrading from one with a saved | |
| // MANIFEST, then use this to retain unchanged resource files. | |
| self.addEventListener("activate", function(event) { | |
| return event.waitUntil(async function() { | |
| try { | |
| var contentCache = await caches.open(CACHE_NAME); | |
| var tempCache = await caches.open(TEMP); | |
| var manifestCache = await caches.open(MANIFEST); | |
| var manifest = await manifestCache.match('manifest'); | |
| // When there is no prior manifest, clear the entire cache. | |
| if (!manifest) { | |
| await caches.delete(CACHE_NAME); | |
| contentCache = await caches.open(CACHE_NAME); | |
| for (var request of await tempCache.keys()) { | |
| var response = await tempCache.match(request); | |
| await contentCache.put(request, response); | |
| } | |
| await caches.delete(TEMP); | |
| // Save the manifest to make future upgrades efficient. | |
| await manifestCache.put('manifest', new Response(JSON.stringify(RESOURCES))); | |
| return; | |
| } | |
| var oldManifest = await manifest.json(); | |
| var origin = self.location.origin; | |
| for (var request of await contentCache.keys()) { | |
| var key = request.url.substring(origin.length + 1); | |
| if (key == "") { | |
| key = "/"; | |
| } | |
| // If a resource from the old manifest is not in the new cache, or if | |
| // the MD5 sum has changed, delete it. Otherwise the resource is left | |
| // in the cache and can be reused by the new service worker. | |
| if (!RESOURCES[key] || RESOURCES[key] != oldManifest[key]) { | |
| await contentCache.delete(request); | |
| } | |
| } | |
| // Populate the cache with the app shell TEMP files, potentially overwriting | |
| // cache files preserved above. | |
| for (var request of await tempCache.keys()) { | |
| var response = await tempCache.match(request); | |
| await contentCache.put(request, response); | |
| } | |
| await caches.delete(TEMP); | |
| // Save the manifest to make future upgrades efficient. | |
| await manifestCache.put('manifest', new Response(JSON.stringify(RESOURCES))); | |
| return; | |
| } catch (err) { | |
| // On an unhandled exception the state of the cache cannot be guaranteed. | |
| console.error('Failed to upgrade service worker: ' + err); | |
| await caches.delete(CACHE_NAME); | |
| await caches.delete(TEMP); | |
| await caches.delete(MANIFEST); | |
| } | |
| }()); | |
| }); | |
| // The fetch handler redirects requests for RESOURCE files to the service | |
| // worker cache. | |
| self.addEventListener("fetch", (event) => { | |
| var origin = self.location.origin; | |
| var key = event.request.url.substring(origin.length + 1); | |
| // Redirect URLs to the index.html | |
| if (event.request.url == origin || event.request.url.startsWith(origin + '/#')) { | |
| key = '/'; | |
| } | |
| // If the URL is not the RESOURCE list, skip the cache. | |
| if (!RESOURCES[key]) { | |
| return event.respondWith(fetch(event.request)); | |
| } | |
| event.respondWith(caches.open(CACHE_NAME) | |
| .then((cache) => { | |
| return cache.match(event.request).then((response) => { | |
| // Either respond with the cached resource, or perform a fetch and | |
| // lazily populate the cache. Ensure the resources are not cached | |
| // by the browser for longer than the service worker expects. | |
| var modifiedRequest = new Request(event.request, {'cache': 'reload'}); | |
| return response || fetch(modifiedRequest).then((response) => { | |
| cache.put(event.request, response.clone()); | |
| return response; | |
| }); | |
| }) | |
| }) | |
| ); | |
| }); | |
| self.addEventListener('message', (event) => { | |
| // SkipWaiting can be used to immediately activate a waiting service worker. | |
| // This will also require a page refresh triggered by the main worker. | |
| if (event.data === 'skipWaiting') { | |
| return self.skipWaiting(); | |
| } | |
| if (event.message === 'downloadOffline') { | |
| downloadOffline(); | |
| } | |
| }); | |
| // Download offline will check the RESOURCES for all files not in the cache | |
| // and populate them. | |
| async function downloadOffline() { | |
| var resources = []; | |
| var contentCache = await caches.open(CACHE_NAME); | |
| var currentContent = {}; | |
| for (var request of await contentCache.keys()) { | |
| var key = request.url.substring(origin.length + 1); | |
| if (key == "") { | |
| key = "/"; | |
| } | |
| currentContent[key] = true; | |
| } | |
| for (var resourceKey in Object.keys(RESOURCES)) { | |
| if (!currentContent[resourceKey]) { | |
| resources.push(resourceKey); | |
| } | |
| } | |
| return contentCache.addAll(resources); | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment