UNPKG

polyserve

Version:
53 lines (48 loc) 2.35 kB
/** * @license * Copyright (c) 2016 The Polymer Project Authors. All rights reserved. * This code may only be used under the BSD style license found at * http://polymer.github.io/LICENSE.txt * The complete set of authors may be found at * http://polymer.github.io/AUTHORS.txt * The complete set of contributors may be found at * http://polymer.github.io/CONTRIBUTORS.txt * Code distributed by Google as part of the polymer project is also * subject to an additional IP rights grant found at * http://polymer.github.io/PATENTS.txt */ import {browserCapabilities} from 'browser-capabilities'; import {parse as parseContentType} from 'content-type'; import {Request, RequestHandler, Response} from 'express'; import {addCustomElementsEs5Adapter} from 'polymer-build'; import {getCompileTarget} from './get-compile-target'; import {transformResponse} from './transform-middleware'; /** * Returns an express middleware that injects the Custom Elements ES5 Adapter * into the entry point when we are serving ES5. * * This is a *transforming* middleware, so it must be installed before the * middleware that actually serves the entry point. */ export function injectCustomElementsEs5Adapter(compile?: 'always'|'never'| 'auto'): RequestHandler { return transformResponse({ shouldTransform(request: Request, response: Response): boolean { const capabilities = browserCapabilities(request.get('user-agent')); const compileTarget = getCompileTarget(capabilities, compile); const contentTypeHeader = response.get('Content-Type'); const contentType = contentTypeHeader && parseContentType(contentTypeHeader).type; // We only need to inject the adapter if we are compiling to ES5. return contentType === 'text/html' && compileTarget === 'es5'; }, transform(_request: Request, _response: Response, body: string): string { // TODO(aomarks) This function will make no changes if the body does // not find a web components polyfill script tag. This is the heuristic // we use to determine if a file is the entry point. We would instead // be able to check explicitly for the entry point in `shouldTransform` // if we had the project config available. return addCustomElementsEs5Adapter(body); }, }); }