Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Log warning for bad cache control #1317

Merged
merged 3 commits into from
Feb 21, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions packages/workbox-core/_default.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import {WorkboxError} from './_private/WorkboxError.mjs';
import {cacheNames} from './_private/cacheNames.mjs';
import {logger} from './_private/logger.mjs';
import {assert} from './_private/assert.mjs';
import {checkSWFileCacheHeaders} from './_private/checkSWFileCacheHeaders.mjs';
import {setLoggerLevel, getLoggerLevel} from './_private/logger.mjs';
import './_version.mjs';

Expand Down Expand Up @@ -61,6 +62,10 @@ class WorkboxCore {
`${padding}https://github.com/GoogleChrome/workbox/issues/new`
);
logger.groupEnd();

if (typeof checkSWFileCacheHeaders === 'function') {
checkSWFileCacheHeaders();
}
}
}

Expand Down
4 changes: 2 additions & 2 deletions packages/workbox-core/_private/assert.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ const isArrayOfClass = (value, expectedClass,
}
};

const finalExports = process.env.NODE_ENV === 'production' ? null : {
const finalAssertExports = process.env.NODE_ENV === 'production' ? null : {
hasMethod,
isArray,
isInstance,
Expand All @@ -106,4 +106,4 @@ const finalExports = process.env.NODE_ENV === 'production' ? null : {
isArrayOfClass,
};

export {finalExports as assert};
export {finalAssertExports as assert};
86 changes: 86 additions & 0 deletions packages/workbox-core/_private/checkSWFileCacheHeaders.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
/*
Copyright 2017 Google Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

https://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

import {logger} from './logger.mjs';
import '../_version.mjs';

const MAX_AGE_REGEX = /max-age\s*=\s*(\d*)/g;

/**
* Logs a warning to the user recommending changing
* to max-age=0 or no-cache.
*
* @param {string} cacheControlHeader
*
* @private
*/
function showWarning(cacheControlHeader) {
const docsUrl = 'https://developers.google.com/web/tools/workbox/guides/service-worker-checklist#cache-control_of_your_service_worker_file';
logger.warn(`You are setting a 'cache-control' header of ` +
`'${cacheControlHeader}' on your service worker file. This should be ` +
`set to 'max-age=0' or 'no-cache' to ensure the latest service worker ` +
`is served to your users. Learn more here: ${docsUrl}`
);
}

/**
* Checks for cache-control header on SW file and
* warns the developer if it exists with a value
* other than max-age=0 or no-cache.
*
* @private
*/
function checkSWFileCacheHeaders() {
// This is wrapped as an iife to allow async/await while making
// rollup exclude it in builds.
(async () => {
try {
const swFile = self.location.href;
const response = await fetch(swFile);
if (!response.ok) {
// Response failed so nothing we can check;
return;
}

if (!response.headers.has('cache-control')) {
// No cache control header.
return;
}

const cacheControlHeader = response.headers.get('cache-control');

const maxAgeResult = MAX_AGE_REGEX.exec(cacheControlHeader);
if (maxAgeResult) {
if (parseInt(maxAgeResult[1], 10) === 0) {
return;
}
}

if (cacheControlHeader.indexOf('no-cache') !== -1) {
return;
}

showWarning(cacheControlHeader);
} catch (err) {
// NOOP
}
})();
}

const finalCheckSWFileCacheHeaders =
process.env.NODE_ENV === 'production' ? null : checkSWFileCacheHeaders;

export {finalCheckSWFileCacheHeaders as checkSWFileCacheHeaders};