@anansi/core 0.16.1 → 0.16.3

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.
Files changed (80) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/dist/client.js +84 -8
  3. package/dist/client.js.map +1 -1
  4. package/dist/server.js +21 -15
  5. package/dist/server.js.map +1 -1
  6. package/lib/floodSpouts.d.ts +7 -0
  7. package/lib/floodSpouts.d.ts.map +1 -0
  8. package/lib/floodSpouts.js +4 -8
  9. package/lib/index.d.ts +9 -0
  10. package/lib/index.d.ts.map +1 -0
  11. package/lib/index.js +7 -18
  12. package/lib/index.server.js +9 -22
  13. package/lib/laySpouts.d.ts +10 -0
  14. package/lib/laySpouts.d.ts.map +1 -0
  15. package/lib/laySpouts.js +6 -11
  16. package/lib/scripts/getProxyMiddlewares.d.ts +3 -0
  17. package/lib/scripts/getProxyMiddlewares.d.ts.map +1 -0
  18. package/lib/scripts/getProxyMiddlewares.js +2 -6
  19. package/lib/scripts/index.d.ts +3 -0
  20. package/lib/scripts/index.d.ts.map +1 -0
  21. package/lib/scripts/index.js +3 -10
  22. package/lib/scripts/serve.d.ts +7 -0
  23. package/lib/scripts/serve.d.ts.map +1 -0
  24. package/lib/scripts/serve.js +20 -25
  25. package/lib/scripts/startDevserver.d.ts +4 -0
  26. package/lib/scripts/startDevserver.d.ts.map +1 -0
  27. package/lib/scripts/startDevserver.js +29 -34
  28. package/lib/scripts/types.d.ts +7 -0
  29. package/lib/scripts/types.d.ts.map +1 -0
  30. package/lib/scripts/types.js +1 -3
  31. package/lib/spouts/DocumentComponent.js +13 -18
  32. package/lib/spouts/antd.server.d.ts.map +1 -1
  33. package/lib/spouts/antd.server.js +14 -15
  34. package/lib/spouts/app.d.ts +6 -0
  35. package/lib/spouts/app.d.ts.map +1 -0
  36. package/lib/spouts/app.js +2 -7
  37. package/lib/spouts/app.server.d.ts +7 -0
  38. package/lib/spouts/app.server.d.ts.map +1 -0
  39. package/lib/spouts/app.server.js +2 -7
  40. package/lib/spouts/csp.d.ts +5 -0
  41. package/lib/spouts/csp.d.ts.map +1 -0
  42. package/lib/spouts/csp.js +2 -6
  43. package/lib/spouts/document.d.ts +7 -0
  44. package/lib/spouts/document.d.ts.map +1 -0
  45. package/lib/spouts/document.js +2 -6
  46. package/lib/spouts/document.server.js +5 -10
  47. package/lib/spouts/json.d.ts +7 -0
  48. package/lib/spouts/json.d.ts.map +1 -0
  49. package/lib/spouts/json.js +2 -6
  50. package/lib/spouts/json.server.d.ts +11 -0
  51. package/lib/spouts/json.server.d.ts.map +1 -0
  52. package/lib/spouts/json.server.js +6 -12
  53. package/lib/spouts/prefetch.server.d.ts +8 -0
  54. package/lib/spouts/prefetch.server.d.ts.map +1 -0
  55. package/lib/spouts/prefetch.server.js +2 -6
  56. package/lib/spouts/restHooks.d.ts +8 -0
  57. package/lib/spouts/restHooks.d.ts.map +1 -0
  58. package/lib/spouts/restHooks.js +9 -15
  59. package/lib/spouts/restHooks.provider.d.ts +2 -0
  60. package/lib/spouts/restHooks.provider.d.ts.map +1 -0
  61. package/lib/spouts/restHooks.provider.js +2 -0
  62. package/lib/spouts/restHooks.server.d.ts +15 -0
  63. package/lib/spouts/restHooks.server.d.ts.map +1 -0
  64. package/lib/spouts/restHooks.server.js +11 -16
  65. package/lib/spouts/router.d.ts +14 -0
  66. package/lib/spouts/router.d.ts.map +1 -0
  67. package/lib/spouts/router.js +9 -14
  68. package/lib/spouts/router.server.d.ts +12 -0
  69. package/lib/spouts/router.server.d.ts.map +1 -0
  70. package/lib/spouts/router.server.js +9 -14
  71. package/lib/spouts/types.d.ts +20 -0
  72. package/lib/spouts/types.d.ts.map +1 -0
  73. package/lib/spouts/types.js +1 -3
  74. package/package.json +16 -16
  75. package/src/spouts/antd.server.tsx +3 -1
  76. package/src/spouts/restHooks.provider.tsx +1 -0
  77. package/src/spouts/restHooks.server.tsx +7 -10
  78. package/src/spouts/restHooks.tsx +8 -5
  79. package/lib/spouts/antd.js +0 -18
  80. package/lib/spouts/document copy.js +0 -11
@@ -0,0 +1,3 @@
1
+ import { ProxyConfigArray, ProxyConfigArrayItem, ProxyConfigMap } from 'webpack-dev-server';
2
+ export default function getProxyMiddlewares(proxyConfig: ProxyConfigArrayItem | ProxyConfigMap | ProxyConfigArray): any[];
3
+ //# sourceMappingURL=getProxyMiddlewares.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getProxyMiddlewares.d.ts","sourceRoot":"","sources":["../../src/scripts/getProxyMiddlewares.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,gBAAgB,EAKhB,oBAAoB,EACpB,cAAc,EACf,MAAM,oBAAoB,CAAC;AAG5B,MAAM,CAAC,OAAO,UAAU,mBAAmB,CACzC,WAAW,EAAE,oBAAoB,GAAG,cAAc,GAAG,gBAAgB,SAmHtE"}
@@ -1,9 +1,5 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
4
- exports.default = getProxyMiddlewares;
5
1
  // Essentially taken from https://github.com/webpack/webpack-dev-server/blob/b5e5b67398f97c7a2934e12ebe34fb03cc06c473/lib/Server.js#L2123
6
- function getProxyMiddlewares(proxyConfig) {
2
+ export default function getProxyMiddlewares(proxyConfig) {
7
3
  const middlewares = [];
8
4
  // eslint-disable-next-line @typescript-eslint/no-var-requires
9
5
  const {
@@ -94,4 +90,4 @@ function getProxyMiddlewares(proxyConfig) {
94
90
  });
95
91
  return middlewares;
96
92
  }
97
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["getProxyMiddlewares","proxyConfig","middlewares","createProxyMiddleware","require","proxy","Array","isArray","Object","keys","length","startsWith","entries","map","path","v","getProxyMiddleware","target","context","router","forEach","proxyConfigOrCallback","proxyMiddleware","handler","req","res","next","newProxyConfig","bypassUrl","bypass","url","push","name","middleware","error"],"sources":["../../src/scripts/getProxyMiddlewares.ts"],"sourcesContent":["import {\n  RequestHandler,\n  ProxyConfigArray,\n  Response,\n  Request,\n  NextFunction,\n  ByPass,\n  ProxyConfigArrayItem,\n  ProxyConfigMap,\n} from 'webpack-dev-server';\n\n// Essentially taken from https://github.com/webpack/webpack-dev-server/blob/b5e5b67398f97c7a2934e12ebe34fb03cc06c473/lib/Server.js#L2123\nexport default function getProxyMiddlewares(\n  proxyConfig: ProxyConfigArrayItem | ProxyConfigMap | ProxyConfigArray,\n) {\n  const middlewares: any[] = [];\n  // eslint-disable-next-line @typescript-eslint/no-var-requires\n  const { createProxyMiddleware } = require('http-proxy-middleware');\n\n  const proxy: ProxyConfigArray =\n    !Array.isArray(proxyConfig) && typeof proxyConfig === 'object'\n      ? Object.keys(proxyConfig).length &&\n        Object.keys(proxyConfig)[0].startsWith('/')\n        ? Object.entries(proxyConfig).map(([path, v]) => ({ path, ...v }))\n        : [proxyConfig]\n      : proxyConfig;\n\n  const getProxyMiddleware = (\n    proxyConfig: ProxyConfigArrayItem,\n  ): RequestHandler | undefined => {\n    // It is possible to use the `bypass` method without a `target` or `router`.\n    // However, the proxy middleware has no use in this case, and will fail to instantiate.\n    if (proxyConfig.target) {\n      const context = proxyConfig.context || proxyConfig.path;\n\n      return createProxyMiddleware(/** @type {string} */ context, proxyConfig);\n    }\n\n    if (proxyConfig.router) {\n      return createProxyMiddleware(proxyConfig);\n    }\n  };\n\n  /**\n   * Assume a proxy configuration specified as:\n   * proxy: [\n   *   {\n   *     context: \"value\",\n   *     ...options,\n   *   },\n   *   // or:\n   *   function() {\n   *     return {\n   *       context: \"context\",\n   *       ...options,\n   *     };\n   *   }\n   * ]\n   */\n  proxy.forEach(proxyConfigOrCallback => {\n    let proxyMiddleware: RequestHandler | undefined;\n\n    let proxyConfig =\n      typeof proxyConfigOrCallback === 'function'\n        ? proxyConfigOrCallback()\n        : proxyConfigOrCallback;\n\n    proxyMiddleware = getProxyMiddleware(proxyConfig);\n\n    /* TODO: figure out how to make this work\n    if (proxyConfig.ws) {\n      this.webSocketProxies.push(proxyMiddleware);\n    }\n    */\n\n    const handler = async (req: Request, res: Response, next: NextFunction) => {\n      if (typeof proxyConfigOrCallback === 'function') {\n        const newProxyConfig = proxyConfigOrCallback(req, res, next);\n\n        if (newProxyConfig !== proxyConfig) {\n          proxyConfig = newProxyConfig;\n          proxyMiddleware = getProxyMiddleware(proxyConfig);\n        }\n      }\n\n      // - Check if we have a bypass function defined\n      // - In case the bypass function is defined we'll retrieve the\n      // bypassUrl from it otherwise bypassUrl would be null\n      // TODO remove in the next major in favor `context` and `router` options\n      const bypassUrl: ByPass | null =\n        typeof proxyConfig.bypass === 'function'\n          ? await proxyConfig.bypass(req, res, proxyConfig)\n          : null;\n\n      if (typeof bypassUrl === 'boolean') {\n        // skip the proxy\n        // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n        // @ts-ignore\n        req.url = null;\n        next();\n      } else if (typeof bypassUrl === 'string') {\n        // byPass to that url\n        req.url = bypassUrl;\n        next();\n      } else if (proxyMiddleware) {\n        return proxyMiddleware(req, res, next);\n      } else {\n        next();\n      }\n    };\n\n    middlewares.push({\n      name: 'http-proxy-middleware',\n      middleware: handler,\n    });\n    // Also forward error requests to the proxy so it can handle them.\n    middlewares.push({\n      name: 'http-proxy-middleware-error-handler',\n      middleware: (\n        error: Error,\n        req: Request,\n        res: Response,\n        next: NextFunction,\n      ) => handler(req, res, next),\n    });\n  });\n\n  return middlewares;\n}\n"],"mappings":";;;;AAWA;AACe,SAASA,mBAAmB,CACzCC,WAAqE,EACrE;EACA,MAAMC,WAAkB,GAAG,EAAE;EAC7B;EACA,MAAM;IAAEC;EAAsB,CAAC,GAAGC,OAAO,CAAC,uBAAuB,CAAC;EAElE,MAAMC,KAAuB,GAC3B,CAACC,KAAK,CAACC,OAAO,CAACN,WAAW,CAAC,IAAI,OAAOA,WAAW,KAAK,QAAQ,GAC1DO,MAAM,CAACC,IAAI,CAACR,WAAW,CAAC,CAACS,MAAM,IAC/BF,MAAM,CAACC,IAAI,CAACR,WAAW,CAAC,CAAC,CAAC,CAAC,CAACU,UAAU,CAAC,GAAG,CAAC,GACzCH,MAAM,CAACI,OAAO,CAACX,WAAW,CAAC,CAACY,GAAG,CAAC,CAAC,CAACC,IAAI,EAAEC,CAAC,CAAC,MAAM;IAAED,IAAI;IAAE,GAAGC;EAAE,CAAC,CAAC,CAAC,GAChE,CAACd,WAAW,CAAC,GACfA,WAAW;EAEjB,MAAMe,kBAAkB,GACtBf,WAAiC,IACF;IAC/B;IACA;IACA,IAAIA,WAAW,CAACgB,MAAM,EAAE;MACtB,MAAMC,OAAO,GAAGjB,WAAW,CAACiB,OAAO,IAAIjB,WAAW,CAACa,IAAI;MAEvD,OAAOX,qBAAqB,EAAC,qBAAsBe,OAAO,EAAEjB,WAAW,CAAC;IAC1E;IAEA,IAAIA,WAAW,CAACkB,MAAM,EAAE;MACtB,OAAOhB,qBAAqB,CAACF,WAAW,CAAC;IAC3C;EACF,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEI,KAAK,CAACe,OAAO,CAACC,qBAAqB,IAAI;IACrC,IAAIC,eAA2C;IAE/C,IAAIrB,WAAW,GACb,OAAOoB,qBAAqB,KAAK,UAAU,GACvCA,qBAAqB,EAAE,GACvBA,qBAAqB;IAE3BC,eAAe,GAAGN,kBAAkB,CAACf,WAAW,CAAC;;IAEjD;AACJ;AACA;AACA;AACA;;IAEI,MAAMsB,OAAO,GAAG,OAAOC,GAAY,EAAEC,GAAa,EAAEC,IAAkB,KAAK;MACzE,IAAI,OAAOL,qBAAqB,KAAK,UAAU,EAAE;QAC/C,MAAMM,cAAc,GAAGN,qBAAqB,CAACG,GAAG,EAAEC,GAAG,EAAEC,IAAI,CAAC;QAE5D,IAAIC,cAAc,KAAK1B,WAAW,EAAE;UAClCA,WAAW,GAAG0B,cAAc;UAC5BL,eAAe,GAAGN,kBAAkB,CAACf,WAAW,CAAC;QACnD;MACF;;MAEA;MACA;MACA;MACA;MACA,MAAM2B,SAAwB,GAC5B,OAAO3B,WAAW,CAAC4B,MAAM,KAAK,UAAU,GACpC,MAAM5B,WAAW,CAAC4B,MAAM,CAACL,GAAG,EAAEC,GAAG,EAAExB,WAAW,CAAC,GAC/C,IAAI;MAEV,IAAI,OAAO2B,SAAS,KAAK,SAAS,EAAE;QAClC;QACA;QACA;QACAJ,GAAG,CAACM,GAAG,GAAG,IAAI;QACdJ,IAAI,EAAE;MACR,CAAC,MAAM,IAAI,OAAOE,SAAS,KAAK,QAAQ,EAAE;QACxC;QACAJ,GAAG,CAACM,GAAG,GAAGF,SAAS;QACnBF,IAAI,EAAE;MACR,CAAC,MAAM,IAAIJ,eAAe,EAAE;QAC1B,OAAOA,eAAe,CAACE,GAAG,EAAEC,GAAG,EAAEC,IAAI,CAAC;MACxC,CAAC,MAAM;QACLA,IAAI,EAAE;MACR;IACF,CAAC;IAEDxB,WAAW,CAAC6B,IAAI,CAAC;MACfC,IAAI,EAAE,uBAAuB;MAC7BC,UAAU,EAAEV;IACd,CAAC,CAAC;IACF;IACArB,WAAW,CAAC6B,IAAI,CAAC;MACfC,IAAI,EAAE,qCAAqC;MAC3CC,UAAU,EAAE,CACVC,KAAY,EACZV,GAAY,EACZC,GAAa,EACbC,IAAkB,KACfH,OAAO,CAACC,GAAG,EAAEC,GAAG,EAAEC,IAAI;IAC7B,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF,OAAOxB,WAAW;AACpB"}
93
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["getProxyMiddlewares","proxyConfig","middlewares","createProxyMiddleware","require","proxy","Array","isArray","Object","keys","length","startsWith","entries","map","path","v","getProxyMiddleware","target","context","router","forEach","proxyConfigOrCallback","proxyMiddleware","handler","req","res","next","newProxyConfig","bypassUrl","bypass","url","push","name","middleware","error"],"sources":["../../src/scripts/getProxyMiddlewares.ts"],"sourcesContent":["import {\n  RequestHandler,\n  ProxyConfigArray,\n  Response,\n  Request,\n  NextFunction,\n  ByPass,\n  ProxyConfigArrayItem,\n  ProxyConfigMap,\n} from 'webpack-dev-server';\n\n// Essentially taken from https://github.com/webpack/webpack-dev-server/blob/b5e5b67398f97c7a2934e12ebe34fb03cc06c473/lib/Server.js#L2123\nexport default function getProxyMiddlewares(\n  proxyConfig: ProxyConfigArrayItem | ProxyConfigMap | ProxyConfigArray,\n) {\n  const middlewares: any[] = [];\n  // eslint-disable-next-line @typescript-eslint/no-var-requires\n  const { createProxyMiddleware } = require('http-proxy-middleware');\n\n  const proxy: ProxyConfigArray =\n    !Array.isArray(proxyConfig) && typeof proxyConfig === 'object'\n      ? Object.keys(proxyConfig).length &&\n        Object.keys(proxyConfig)[0].startsWith('/')\n        ? Object.entries(proxyConfig).map(([path, v]) => ({ path, ...v }))\n        : [proxyConfig]\n      : proxyConfig;\n\n  const getProxyMiddleware = (\n    proxyConfig: ProxyConfigArrayItem,\n  ): RequestHandler | undefined => {\n    // It is possible to use the `bypass` method without a `target` or `router`.\n    // However, the proxy middleware has no use in this case, and will fail to instantiate.\n    if (proxyConfig.target) {\n      const context = proxyConfig.context || proxyConfig.path;\n\n      return createProxyMiddleware(/** @type {string} */ context, proxyConfig);\n    }\n\n    if (proxyConfig.router) {\n      return createProxyMiddleware(proxyConfig);\n    }\n  };\n\n  /**\n   * Assume a proxy configuration specified as:\n   * proxy: [\n   *   {\n   *     context: \"value\",\n   *     ...options,\n   *   },\n   *   // or:\n   *   function() {\n   *     return {\n   *       context: \"context\",\n   *       ...options,\n   *     };\n   *   }\n   * ]\n   */\n  proxy.forEach(proxyConfigOrCallback => {\n    let proxyMiddleware: RequestHandler | undefined;\n\n    let proxyConfig =\n      typeof proxyConfigOrCallback === 'function'\n        ? proxyConfigOrCallback()\n        : proxyConfigOrCallback;\n\n    proxyMiddleware = getProxyMiddleware(proxyConfig);\n\n    /* TODO: figure out how to make this work\n    if (proxyConfig.ws) {\n      this.webSocketProxies.push(proxyMiddleware);\n    }\n    */\n\n    const handler = async (req: Request, res: Response, next: NextFunction) => {\n      if (typeof proxyConfigOrCallback === 'function') {\n        const newProxyConfig = proxyConfigOrCallback(req, res, next);\n\n        if (newProxyConfig !== proxyConfig) {\n          proxyConfig = newProxyConfig;\n          proxyMiddleware = getProxyMiddleware(proxyConfig);\n        }\n      }\n\n      // - Check if we have a bypass function defined\n      // - In case the bypass function is defined we'll retrieve the\n      // bypassUrl from it otherwise bypassUrl would be null\n      // TODO remove in the next major in favor `context` and `router` options\n      const bypassUrl: ByPass | null =\n        typeof proxyConfig.bypass === 'function'\n          ? await proxyConfig.bypass(req, res, proxyConfig)\n          : null;\n\n      if (typeof bypassUrl === 'boolean') {\n        // skip the proxy\n        // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n        // @ts-ignore\n        req.url = null;\n        next();\n      } else if (typeof bypassUrl === 'string') {\n        // byPass to that url\n        req.url = bypassUrl;\n        next();\n      } else if (proxyMiddleware) {\n        return proxyMiddleware(req, res, next);\n      } else {\n        next();\n      }\n    };\n\n    middlewares.push({\n      name: 'http-proxy-middleware',\n      middleware: handler,\n    });\n    // Also forward error requests to the proxy so it can handle them.\n    middlewares.push({\n      name: 'http-proxy-middleware-error-handler',\n      middleware: (\n        error: Error,\n        req: Request,\n        res: Response,\n        next: NextFunction,\n      ) => handler(req, res, next),\n    });\n  });\n\n  return middlewares;\n}\n"],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export { default as serve } from './serve';
2
+ export { default as devServe } from './startDevserver';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/scripts/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,kBAAkB,CAAC"}
@@ -1,10 +1,3 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- exports.__esModule = true;
5
- exports.serve = exports.devServe = void 0;
6
- var _serve = _interopRequireDefault(require("./serve"));
7
- exports.serve = _serve.default;
8
- var _startDevserver = _interopRequireDefault(require("./startDevserver"));
9
- exports.devServe = _startDevserver.default;
10
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmlwdHMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgZGVmYXVsdCBhcyBzZXJ2ZSB9IGZyb20gJy4vc2VydmUnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBkZXZTZXJ2ZSB9IGZyb20gJy4vc3RhcnREZXZzZXJ2ZXInO1xuIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBO0FBQTJDO0FBQzNDO0FBQXVEIn0=
1
+ export { default as serve } from './serve';
2
+ export { default as devServe } from './startDevserver';
3
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZWZhdWx0Iiwic2VydmUiLCJkZXZTZXJ2ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JpcHRzL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IGRlZmF1bHQgYXMgc2VydmUgfSBmcm9tICcuL3NlcnZlJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgZGV2U2VydmUgfSBmcm9tICcuL3N0YXJ0RGV2c2VydmVyJztcbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsT0FBTyxJQUFJQyxLQUFLLFFBQVEsU0FBUztBQUMxQyxTQUFTRCxPQUFPLElBQUlFLFFBQVEsUUFBUSxrQkFBa0IifQ==
@@ -0,0 +1,7 @@
1
+ #!/usr/bin/env node
2
+ import 'cross-fetch/polyfill';
3
+ export default function serve(entrypoint: string, options?: {
4
+ serveAssets?: boolean;
5
+ serveProxy?: boolean;
6
+ }): void;
7
+ //# sourceMappingURL=serve.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serve.d.ts","sourceRoot":"","sources":["../../src/scripts/serve.ts"],"names":[],"mappings":";AAeA,OAAO,sBAAsB,CAAC;AAe9B,MAAM,CAAC,OAAO,UAAU,KAAK,CAC3B,UAAU,EAAE,MAAM,EAClB,OAAO,GAAE;IAAE,WAAW,CAAC,EAAE,OAAO,CAAC;IAAC,UAAU,CAAC,EAAE,OAAO,CAAA;CAAO,QAqK9D"}
@@ -1,20 +1,15 @@
1
1
  #!/usr/bin/env node
2
- "use strict";
3
-
4
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
- exports.__esModule = true;
6
- exports.default = serve;
7
- var _compression = _interopRequireDefault(require("compression"));
8
- var _express = _interopRequireDefault(require("express"));
9
- var _fs = _interopRequireDefault(require("fs"));
10
- var _ora = _interopRequireDefault(require("ora"));
11
- var _path = _interopRequireDefault(require("path"));
12
- var _util = require("util");
13
- require("cross-fetch/polyfill");
14
- var _getProxyMiddlewares = _interopRequireDefault(require("./getProxyMiddlewares"));
15
2
  Object.hasOwn = Object.hasOwn || /* istanbul ignore next */function hasOwn(it, key) {
16
3
  return Object.prototype.hasOwnProperty.call(it, key);
17
4
  };
5
+ import compress from 'compression';
6
+ import express from 'express';
7
+ import diskFs from 'fs';
8
+ import ora from 'ora';
9
+ import path from 'path';
10
+ import { promisify } from 'util';
11
+ import 'cross-fetch/polyfill';
12
+ import getProxyMiddlewares from './getProxyMiddlewares';
18
13
  // run directly from node
19
14
  if (require.main === module) {
20
15
  const entrypoint = process.argv[2];
@@ -24,16 +19,16 @@ if (require.main === module) {
24
19
  }
25
20
  serve(entrypoint);
26
21
  }
27
- function serve(entrypoint, options = {}) {
22
+ export default function serve(entrypoint, options = {}) {
28
23
  const PORT = process.env.PORT || 8080;
29
- const loader = (0, _ora.default)('Initializing').start();
24
+ const loader = ora('Initializing').start();
30
25
  const webpackConfig = require(require.resolve(
31
26
  // TODO: use normal resolution algorithm to find webpack file
32
- _path.default.join(process.cwd(), 'webpack.config')));
27
+ path.join(process.cwd(), 'webpack.config')));
33
28
  const manifestPath = getManifestPathFromWebpackconfig(webpackConfig({}, {
34
29
  mode: 'production'
35
30
  }));
36
- const readFile = (0, _util.promisify)(_fs.default.readFile);
31
+ const readFile = promisify(diskFs.readFile);
37
32
  let server;
38
33
  function handleErrors(fn) {
39
34
  return async function (req, res, next) {
@@ -53,18 +48,18 @@ function serve(entrypoint, options = {}) {
53
48
  // TODO: handle more gracefully
54
49
  process.exit(-1);
55
50
  }
56
- const wrappingApp = (0, _express.default)();
51
+ const wrappingApp = express();
57
52
  // eslint-disable-next-line
58
53
  //@ts-ignore
59
- wrappingApp.use((0, _compression.default)());
54
+ wrappingApp.use(compress());
60
55
 
61
56
  // ASSETS
62
57
  if (options.serveAssets) {
63
58
  wrappingApp.use(async (req, res, next) => {
64
59
  var _req$url$substr, _req$url, _clientManifest$outpu;
65
60
  const filename = (_req$url$substr = (_req$url = req.url) == null ? void 0 : _req$url.substr(process.env.WEBPACK_PUBLIC_PATH.length)) != null ? _req$url$substr : '';
66
- const assetPath = _path.default.join((_clientManifest$outpu = clientManifest.outputPath) != null ? _clientManifest$outpu : '', filename);
67
- if (_fs.default.existsSync(assetPath) && !_fs.default.lstatSync(assetPath).isDirectory()) {
61
+ const assetPath = path.join((_clientManifest$outpu = clientManifest.outputPath) != null ? _clientManifest$outpu : '', filename);
62
+ if (diskFs.existsSync(assetPath) && !diskFs.lstatSync(assetPath).isDirectory()) {
68
63
  try {
69
64
  const fileContent = (await readFile(assetPath)).toString();
70
65
  res.contentType(filename);
@@ -86,7 +81,7 @@ function serve(entrypoint, options = {}) {
86
81
  });
87
82
  if ((_devConfig$devServer = devConfig.devServer) != null && _devConfig$devServer.proxy) {
88
83
  var _devConfig$devServer2;
89
- const middlewares = (0, _getProxyMiddlewares.default)((_devConfig$devServer2 = devConfig.devServer) == null ? void 0 : _devConfig$devServer2.proxy);
84
+ const middlewares = getProxyMiddlewares((_devConfig$devServer2 = devConfig.devServer) == null ? void 0 : _devConfig$devServer2.proxy);
90
85
  if (middlewares) {
91
86
  wrappingApp.use(...middlewares.map(({
92
87
  middleware
@@ -97,7 +92,7 @@ function serve(entrypoint, options = {}) {
97
92
 
98
93
  // SERVER SIDE RENDERING
99
94
  // eslint-disable-next-line @typescript-eslint/no-var-requires
100
- const render = require(_path.default.join(process.cwd(), entrypoint)).default;
95
+ const render = require(path.join(process.cwd(), entrypoint)).default;
101
96
  wrappingApp.get('/*', handleErrors(async function (req, res) {
102
97
  if (req.url.endsWith('favicon.ico')) {
103
98
  res.statusCode = 404;
@@ -150,7 +145,7 @@ function getManifestPathFromWebpackconfig(webpackConfig) {
150
145
  const manifestFilename = (_opts$filename = webpackConfig == null ? void 0 : (_webpackConfig$plugin = webpackConfig.plugins) == null ? void 0 : (_webpackConfig$plugin2 = _webpackConfig$plugin.find(plugin => {
151
146
  return plugin.constructor.name === 'StatsWriterPlugin';
152
147
  })) == null ? void 0 : (_webpackConfig$plugin3 = _webpackConfig$plugin2.opts) == null ? void 0 : _webpackConfig$plugin3.filename) != null ? _opts$filename : 'manifest.json';
153
- const manifestPath = _path.default.join((_webpackConfig$output = webpackConfig == null ? void 0 : (_webpackConfig$output2 = webpackConfig.output) == null ? void 0 : _webpackConfig$output2.path) != null ? _webpackConfig$output : '', manifestFilename);
148
+ const manifestPath = path.join((_webpackConfig$output = webpackConfig == null ? void 0 : (_webpackConfig$output2 = webpackConfig.output) == null ? void 0 : _webpackConfig$output2.path) != null ? _webpackConfig$output : '', manifestFilename);
154
149
  return manifestPath;
155
150
  }
156
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Object","hasOwn","it","key","prototype","hasOwnProperty","call","require","main","module","entrypoint","process","argv","console","log","exit","serve","options","PORT","env","loader","ora","start","webpackConfig","resolve","path","join","cwd","manifestPath","getManifestPathFromWebpackconfig","mode","readFile","promisify","diskFs","server","handleErrors","fn","req","res","next","x","initializeApp","clientManifest","info","fail","wrappingApp","express","use","compress","serveAssets","filename","url","substr","WEBPACK_PUBLIC_PATH","length","assetPath","outputPath","existsSync","lstatSync","isDirectory","fileContent","toString","contentType","send","e","serveProxy","devConfig","devServer","proxy","middlewares","getProxyMiddlewares","map","middleware","render","default","get","endsWith","statusCode","setHeader","socket","on","error","listen","syscall","isPipe","portOrPipe","Number","isNaN","bind","code","warn","close","manifestFilename","plugins","find","plugin","constructor","name","opts","output"],"sources":["../../src/scripts/serve.ts"],"sourcesContent":["#!/usr/bin/env node\nObject.hasOwn =\n  Object.hasOwn ||\n  /* istanbul ignore next */ function hasOwn(it, key) {\n    return Object.prototype.hasOwnProperty.call(it, key);\n  };\nimport compress from 'compression';\nimport express, { NextFunction } from 'express';\nimport diskFs from 'fs';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport ora from 'ora';\nimport path from 'path';\nimport { promisify } from 'util';\nimport webpack, { web } from 'webpack';\n\nimport 'cross-fetch/polyfill';\nimport getProxyMiddlewares from './getProxyMiddlewares';\nimport { Render } from './types';\n\n// run directly from node\nif (require.main === module) {\n  const entrypoint = process.argv[2];\n\n  if (!entrypoint) {\n    console.log(`Usage: ${process.argv[0]} <server-entrypoint>`);\n    process.exit(-1);\n  }\n  serve(entrypoint);\n}\n\nexport default function serve(\n  entrypoint: string,\n  options: { serveAssets?: boolean; serveProxy?: boolean } = {},\n) {\n  const PORT = process.env.PORT || 8080;\n\n  const loader = ora('Initializing').start();\n\n  const webpackConfig: (\n    env: any,\n    argv: any,\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n  ) => webpack.Configuration = require(require.resolve(\n    // TODO: use normal resolution algorithm to find webpack file\n    path.join(process.cwd(), 'webpack.config'),\n  ));\n\n  const manifestPath = getManifestPathFromWebpackconfig(\n    webpackConfig({}, { mode: 'production' }),\n  );\n\n  const readFile = promisify(diskFs.readFile);\n  let server: Server | undefined;\n\n  function handleErrors<\n    F extends (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n    ) => Promise<void>,\n  >(fn: F) {\n    return async function (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n      next: NextFunction,\n    ) {\n      try {\n        return await fn(req, res);\n      } catch (x) {\n        next(x);\n      }\n    };\n  }\n\n  // Start the express server after the first compilation\n  function initializeApp(clientManifest: webpack.StatsCompilation) {\n    loader.info('Launching server');\n    if (!clientManifest) {\n      loader.fail('Manifest not found');\n      // TODO: handle more gracefully\n      process.exit(-1);\n    }\n\n    const wrappingApp = express();\n    // eslint-disable-next-line\n    //@ts-ignore\n    wrappingApp.use(compress());\n\n    // ASSETS\n    if (options.serveAssets) {\n      wrappingApp.use(\n        async (\n          req: Request | IncomingMessage,\n          res: any,\n          next: NextFunction,\n        ) => {\n          const filename =\n            req.url?.substr(\n              (process.env.WEBPACK_PUBLIC_PATH as string).length,\n            ) ?? '';\n          const assetPath = path.join(\n            clientManifest.outputPath ?? '',\n            filename,\n          );\n\n          if (\n            diskFs.existsSync(assetPath) &&\n            !diskFs.lstatSync(assetPath).isDirectory()\n          ) {\n            try {\n              const fileContent = (await readFile(assetPath)).toString();\n              res.contentType(filename);\n              res.send(fileContent);\n            } catch (e) {\n              return next();\n            }\n          } else {\n            next();\n          }\n        },\n      );\n    }\n\n    // PROXIES\n    if (options.serveProxy) {\n      const devConfig: webpack.Configuration = webpackConfig(\n        {},\n        { mode: 'development' },\n      );\n      if (devConfig.devServer?.proxy) {\n        const middlewares = getProxyMiddlewares(devConfig.devServer?.proxy);\n        if (middlewares) {\n          wrappingApp.use(...middlewares.map(({ middleware }) => middleware));\n        }\n      }\n    }\n\n    // SERVER SIDE RENDERING\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n    const render: Render = require(path.join(\n      process.cwd(),\n      entrypoint,\n    )).default;\n\n    wrappingApp.get(\n      '/*',\n      handleErrors(async function (req: any, res: any) {\n        if (req.url.endsWith('favicon.ico')) {\n          res.statusCode = 404;\n          res.setHeader('Content-type', 'text/html');\n          res.send('not found');\n          return;\n        }\n        res.socket.on('error', (error: unknown) => {\n          console.error('Fatal', error);\n        });\n\n        await render(clientManifest, req, res);\n      }),\n    );\n\n    server = wrappingApp\n      .listen(PORT, () => {\n        loader.info(`Listening at ${PORT}...`);\n      })\n      .on('error', function (error: any) {\n        if (error.syscall !== 'listen') {\n          throw error;\n        }\n        const isPipe = (portOrPipe: string | number) =>\n          Number.isNaN(portOrPipe);\n        const bind = isPipe(PORT) ? 'Pipe ' + PORT : 'Port ' + PORT;\n        switch (error.code) {\n          case 'EACCES':\n            loader.fail(bind + ' requires elevated privileges');\n            process.exit(1);\n          // eslint-disable-next-line no-fallthrough\n          case 'EADDRINUSE':\n            loader.fail(bind + ' is already in use');\n            process.exit(1);\n          // eslint-disable-next-line no-fallthrough\n          default:\n            throw error;\n        }\n      });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-var-requires\n  initializeApp(require(manifestPath));\n\n  process.on('SIGINT', () => {\n    loader.warn('Received SIGINT, devserver shutting down');\n    if (server) console.log('Closing server');\n    server?.close(() => {\n      loader.info('Server closed');\n    });\n    process.exit(-1);\n  });\n}\n\nfunction getManifestPathFromWebpackconfig(\n  webpackConfig: webpack.Configuration,\n) {\n  const manifestFilename: string =\n    (\n      webpackConfig?.plugins?.find(plugin => {\n        return plugin.constructor.name === 'StatsWriterPlugin';\n      }) as any\n    )?.opts?.filename ?? 'manifest.json';\n\n  const manifestPath = path.join(\n    webpackConfig?.output?.path ?? '',\n    manifestFilename,\n  );\n  return manifestPath;\n}\n"],"mappings":"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"}
151
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Object","hasOwn","it","key","prototype","hasOwnProperty","call","compress","express","diskFs","ora","path","promisify","getProxyMiddlewares","require","main","module","entrypoint","process","argv","console","log","exit","serve","options","PORT","env","loader","start","webpackConfig","resolve","join","cwd","manifestPath","getManifestPathFromWebpackconfig","mode","readFile","server","handleErrors","fn","req","res","next","x","initializeApp","clientManifest","info","fail","wrappingApp","use","serveAssets","filename","url","substr","WEBPACK_PUBLIC_PATH","length","assetPath","outputPath","existsSync","lstatSync","isDirectory","fileContent","toString","contentType","send","e","serveProxy","devConfig","devServer","proxy","middlewares","map","middleware","render","default","get","endsWith","statusCode","setHeader","socket","on","error","listen","syscall","isPipe","portOrPipe","Number","isNaN","bind","code","warn","close","manifestFilename","plugins","find","plugin","constructor","name","opts","output"],"sources":["../../src/scripts/serve.ts"],"sourcesContent":["#!/usr/bin/env node\nObject.hasOwn =\n  Object.hasOwn ||\n  /* istanbul ignore next */ function hasOwn(it, key) {\n    return Object.prototype.hasOwnProperty.call(it, key);\n  };\nimport compress from 'compression';\nimport express, { NextFunction } from 'express';\nimport diskFs from 'fs';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport ora from 'ora';\nimport path from 'path';\nimport { promisify } from 'util';\nimport webpack, { web } from 'webpack';\n\nimport 'cross-fetch/polyfill';\nimport getProxyMiddlewares from './getProxyMiddlewares';\nimport { Render } from './types';\n\n// run directly from node\nif (require.main === module) {\n  const entrypoint = process.argv[2];\n\n  if (!entrypoint) {\n    console.log(`Usage: ${process.argv[0]} <server-entrypoint>`);\n    process.exit(-1);\n  }\n  serve(entrypoint);\n}\n\nexport default function serve(\n  entrypoint: string,\n  options: { serveAssets?: boolean; serveProxy?: boolean } = {},\n) {\n  const PORT = process.env.PORT || 8080;\n\n  const loader = ora('Initializing').start();\n\n  const webpackConfig: (\n    env: any,\n    argv: any,\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n  ) => webpack.Configuration = require(require.resolve(\n    // TODO: use normal resolution algorithm to find webpack file\n    path.join(process.cwd(), 'webpack.config'),\n  ));\n\n  const manifestPath = getManifestPathFromWebpackconfig(\n    webpackConfig({}, { mode: 'production' }),\n  );\n\n  const readFile = promisify(diskFs.readFile);\n  let server: Server | undefined;\n\n  function handleErrors<\n    F extends (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n    ) => Promise<void>,\n  >(fn: F) {\n    return async function (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n      next: NextFunction,\n    ) {\n      try {\n        return await fn(req, res);\n      } catch (x) {\n        next(x);\n      }\n    };\n  }\n\n  // Start the express server after the first compilation\n  function initializeApp(clientManifest: webpack.StatsCompilation) {\n    loader.info('Launching server');\n    if (!clientManifest) {\n      loader.fail('Manifest not found');\n      // TODO: handle more gracefully\n      process.exit(-1);\n    }\n\n    const wrappingApp = express();\n    // eslint-disable-next-line\n    //@ts-ignore\n    wrappingApp.use(compress());\n\n    // ASSETS\n    if (options.serveAssets) {\n      wrappingApp.use(\n        async (\n          req: Request | IncomingMessage,\n          res: any,\n          next: NextFunction,\n        ) => {\n          const filename =\n            req.url?.substr(\n              (process.env.WEBPACK_PUBLIC_PATH as string).length,\n            ) ?? '';\n          const assetPath = path.join(\n            clientManifest.outputPath ?? '',\n            filename,\n          );\n\n          if (\n            diskFs.existsSync(assetPath) &&\n            !diskFs.lstatSync(assetPath).isDirectory()\n          ) {\n            try {\n              const fileContent = (await readFile(assetPath)).toString();\n              res.contentType(filename);\n              res.send(fileContent);\n            } catch (e) {\n              return next();\n            }\n          } else {\n            next();\n          }\n        },\n      );\n    }\n\n    // PROXIES\n    if (options.serveProxy) {\n      const devConfig: webpack.Configuration = webpackConfig(\n        {},\n        { mode: 'development' },\n      );\n      if (devConfig.devServer?.proxy) {\n        const middlewares = getProxyMiddlewares(devConfig.devServer?.proxy);\n        if (middlewares) {\n          wrappingApp.use(...middlewares.map(({ middleware }) => middleware));\n        }\n      }\n    }\n\n    // SERVER SIDE RENDERING\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n    const render: Render = require(path.join(\n      process.cwd(),\n      entrypoint,\n    )).default;\n\n    wrappingApp.get(\n      '/*',\n      handleErrors(async function (req: any, res: any) {\n        if (req.url.endsWith('favicon.ico')) {\n          res.statusCode = 404;\n          res.setHeader('Content-type', 'text/html');\n          res.send('not found');\n          return;\n        }\n        res.socket.on('error', (error: unknown) => {\n          console.error('Fatal', error);\n        });\n\n        await render(clientManifest, req, res);\n      }),\n    );\n\n    server = wrappingApp\n      .listen(PORT, () => {\n        loader.info(`Listening at ${PORT}...`);\n      })\n      .on('error', function (error: any) {\n        if (error.syscall !== 'listen') {\n          throw error;\n        }\n        const isPipe = (portOrPipe: string | number) =>\n          Number.isNaN(portOrPipe);\n        const bind = isPipe(PORT) ? 'Pipe ' + PORT : 'Port ' + PORT;\n        switch (error.code) {\n          case 'EACCES':\n            loader.fail(bind + ' requires elevated privileges');\n            process.exit(1);\n          // eslint-disable-next-line no-fallthrough\n          case 'EADDRINUSE':\n            loader.fail(bind + ' is already in use');\n            process.exit(1);\n          // eslint-disable-next-line no-fallthrough\n          default:\n            throw error;\n        }\n      });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-var-requires\n  initializeApp(require(manifestPath));\n\n  process.on('SIGINT', () => {\n    loader.warn('Received SIGINT, devserver shutting down');\n    if (server) console.log('Closing server');\n    server?.close(() => {\n      loader.info('Server closed');\n    });\n    process.exit(-1);\n  });\n}\n\nfunction getManifestPathFromWebpackconfig(\n  webpackConfig: webpack.Configuration,\n) {\n  const manifestFilename: string =\n    (\n      webpackConfig?.plugins?.find(plugin => {\n        return plugin.constructor.name === 'StatsWriterPlugin';\n      }) as any\n    )?.opts?.filename ?? 'manifest.json';\n\n  const manifestPath = path.join(\n    webpackConfig?.output?.path ?? '',\n    manifestFilename,\n  );\n  return manifestPath;\n}\n"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env node
2
+ import 'cross-fetch/polyfill';
3
+ export default function startDevServer(entrypoint: string, env?: Record<string, unknown>): void;
4
+ //# sourceMappingURL=startDevserver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"startDevserver.d.ts","sourceRoot":"","sources":["../../src/scripts/startDevserver.ts"],"names":[],"mappings":";AAoBA,OAAO,sBAAsB,CAAC;AAe9B,MAAM,CAAC,OAAO,UAAU,cAAc,CACpC,UAAU,EAAE,MAAM,EAClB,GAAG,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,QAqOlC"}
@@ -1,24 +1,19 @@
1
1
  #!/usr/bin/env node
2
- "use strict";
3
-
4
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
- exports.__esModule = true;
6
- exports.default = startDevServer;
7
- var _fs = _interopRequireDefault(require("fs"));
8
- var _fsRequire = require("fs-require");
9
- var _memfs = require("memfs");
10
- var _path = _interopRequireDefault(require("path"));
11
- var _sourceMapSupport = _interopRequireDefault(require("source-map-support"));
12
- var _tmp = _interopRequireDefault(require("tmp"));
13
- var _unionfs = require("unionfs");
14
- var _util = require("util");
15
- var _webpack = _interopRequireDefault(require("webpack"));
16
- var _runtime = _interopRequireDefault(require("webpack/lib/logging/runtime"));
17
- var _webpackDevServer = _interopRequireDefault(require("webpack-dev-server"));
18
- require("cross-fetch/polyfill");
19
2
  Object.hasOwn = Object.hasOwn || /* istanbul ignore next */function hasOwn(it, key) {
20
3
  return Object.prototype.hasOwnProperty.call(it, key);
21
4
  };
5
+ import diskFs from 'fs';
6
+ import { createFsRequire } from 'fs-require';
7
+ import { createFsFromVolume, Volume } from 'memfs';
8
+ import path from 'path';
9
+ import sourceMapSupport from 'source-map-support';
10
+ import tmp from 'tmp';
11
+ import { ufs } from 'unionfs';
12
+ import { promisify } from 'util';
13
+ import webpack from 'webpack';
14
+ import logging from 'webpack/lib/logging/runtime';
15
+ import WebpackDevServer from 'webpack-dev-server';
16
+ import 'cross-fetch/polyfill';
22
17
  // run directly from node
23
18
  if (require.main === module) {
24
19
  const entrypoint = process.argv[2];
@@ -28,31 +23,31 @@ if (require.main === module) {
28
23
  }
29
24
  startDevServer(entrypoint);
30
25
  }
31
- function startDevServer(entrypoint, env = {}) {
26
+ export default function startDevServer(entrypoint, env = {}) {
32
27
  var _webpackConfigs$, _webpackConfigs$$devS;
33
28
  // eslint-disable-next-line @typescript-eslint/no-var-requires
34
29
  const webpackConfig = require(require.resolve(
35
30
  // TODO: use normal resolution algorithm to find webpack file
36
- _path.default.join(process.cwd(), 'webpack.config')));
37
- const log = _runtime.default.getLogger('anansi-devserver');
31
+ path.join(process.cwd(), 'webpack.config')));
32
+ const log = logging.getLogger('anansi-devserver');
38
33
 
39
34
  // Set up in memory filesystem
40
- const volume = new _memfs.Volume();
41
- const fs = (0, _memfs.createFsFromVolume)(volume);
42
- _unionfs.ufs.use(_fs.default).use(fs);
43
- const fsRequire = (0, _fsRequire.createFsRequire)(_unionfs.ufs);
44
- const readFile = (0, _util.promisify)(_unionfs.ufs.readFile);
35
+ const volume = new Volume();
36
+ const fs = createFsFromVolume(volume);
37
+ ufs.use(diskFs).use(fs);
38
+ const fsRequire = createFsRequire(ufs);
39
+ const readFile = promisify(ufs.readFile);
45
40
  let server;
46
41
 
47
42
  // Generate a temporary file so we can hot reload from the root of the application
48
43
  function hotEntry(entryPath) {
49
44
  // eslint-disable-next-line
50
45
  // @ts-ignore for some reason it's not picking up that other options are optional
51
- const generatedEntrypoint = _tmp.default.fileSync({
46
+ const generatedEntrypoint = tmp.fileSync({
52
47
  postfix: '.js'
53
48
  });
54
- _fs.default.writeSync(generatedEntrypoint.fd, `
55
- import entry from "${_path.default.resolve(process.cwd(), entryPath)}";
49
+ diskFs.writeSync(generatedEntrypoint.fd, `
50
+ import entry from "${path.resolve(process.cwd(), entryPath)}";
56
51
 
57
52
  if (module.hot) {
58
53
  module.hot.accept();
@@ -79,8 +74,8 @@ function startDevServer(entrypoint, env = {}) {
79
74
  })];
80
75
 
81
76
  // initialize the webpack compiler
82
- const compiler = (0, _webpack.default)(webpackConfigs);
83
- _sourceMapSupport.default.install({
77
+ const compiler = webpack(webpackConfigs);
78
+ sourceMapSupport.install({
84
79
  hookRequire: true
85
80
  });
86
81
  function getServerBundle(serverStats) {
@@ -88,7 +83,7 @@ function startDevServer(entrypoint, env = {}) {
88
83
  const serverJson = serverStats.toJson({
89
84
  assets: true
90
85
  });
91
- return _path.default.join((_serverJson$outputPat = serverJson.outputPath) != null ? _serverJson$outputPat : '', 'server.js');
86
+ return path.join((_serverJson$outputPat = serverJson.outputPath) != null ? _serverJson$outputPat : '', 'server.js');
92
87
  }
93
88
  function handleErrors(fn) {
94
89
  return async function (req, res, next) {
@@ -147,7 +142,7 @@ function startDevServer(entrypoint, env = {}) {
147
142
  initRender = undefined;
148
143
  }
149
144
  }
150
- const devServer = new _webpackDevServer.default(
145
+ const devServer = new WebpackDevServer(
151
146
  // write to memory filesystem so we can import
152
147
  {
153
148
  ...webpackConfigs[0].devServer,
@@ -155,7 +150,7 @@ function startDevServer(entrypoint, env = {}) {
155
150
  ...((_webpackConfigs$ = webpackConfigs[0]) == null ? void 0 : (_webpackConfigs$$devS = _webpackConfigs$.devServer) == null ? void 0 : _webpackConfigs$$devS.devMiddleware),
156
151
  outputFileSystem: {
157
152
  ...fs,
158
- join: _path.default.join
153
+ join: path.join
159
154
  }
160
155
  },
161
156
  setupMiddlewares: (middlewares, devServer) => {
@@ -215,4 +210,4 @@ function startDevServer(entrypoint, env = {}) {
215
210
  });
216
211
  runServer();
217
212
  }
218
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Object","hasOwn","it","key","prototype","hasOwnProperty","call","require","main","module","entrypoint","process","argv","console","log","exit","startDevServer","env","webpackConfig","resolve","path","join","cwd","logging","getLogger","volume","Volume","fs","createFsFromVolume","ufs","use","diskFs","fsRequire","createFsRequire","readFile","promisify","server","hotEntry","entryPath","generatedEntrypoint","tmp","fileSync","postfix","writeSync","fd","webpackConfigs","entrypath","name","mode","replace","BROWSERSLIST_ENV","target","compiler","webpack","sourceMapSupport","install","hookRequire","getServerBundle","serverStats","serverJson","toJson","assets","outputPath","handleErrors","fn","req","res","next","x","initRender","render","args","Promise","push","importRender","stats","clientStats","compilation","errors","length","error","Array","isArray","info","clientManifest","serverEntry","keys","cache","forEach","default","bind","undefined","init","e","devServer","WebpackDevServer","devMiddleware","outputFileSystem","setupMiddlewares","middlewares","Error","otherRoutes","WEBPACK_PUBLIC_PATH","proxy","app","get","RegExp","url","endsWith","statusCode","setHeader","send","socket","on","runServer","start","hooks","done","tap","multiStats","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\nObject.hasOwn =\n  Object.hasOwn ||\n  /* istanbul ignore next */ function hasOwn(it, key) {\n    return Object.prototype.hasOwnProperty.call(it, key);\n  };\nimport type { NextFunction } from 'express';\nimport diskFs from 'fs';\nimport { createFsRequire } from 'fs-require';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport path from 'path';\nimport sourceMapSupport from 'source-map-support';\nimport tmp from 'tmp';\nimport { ufs } from 'unionfs';\nimport { promisify } from 'util';\nimport webpack, { MultiCompiler } from 'webpack';\nimport logging from 'webpack/lib/logging/runtime';\nimport WebpackDevServer from 'webpack-dev-server';\n\nimport 'cross-fetch/polyfill';\nimport { BoundRender } from './types';\n\n// run directly from node\nif (require.main === module) {\n  const entrypoint = process.argv[2];\n\n  if (!entrypoint) {\n    console.log(`Usage: start-anansi <entrypoint-file>`);\n    process.exit(-1);\n  }\n\n  startDevServer(entrypoint);\n}\n\nexport default function startDevServer(\n  entrypoint: string,\n  env: Record<string, unknown> = {},\n) {\n  // eslint-disable-next-line @typescript-eslint/no-var-requires\n  const webpackConfig = require(require.resolve(\n    // TODO: use normal resolution algorithm to find webpack file\n    path.join(process.cwd(), 'webpack.config'),\n  ));\n\n  const log = logging.getLogger('anansi-devserver');\n\n  // Set up in memory filesystem\n  const volume = new Volume();\n  const fs = createFsFromVolume(volume);\n  ufs.use(diskFs).use(fs as any);\n\n  const fsRequire = createFsRequire(ufs);\n  const readFile = promisify(ufs.readFile);\n  let server: Server | undefined;\n\n  // Generate a temporary file so we can hot reload from the root of the application\n  function hotEntry(entryPath: string) {\n    // eslint-disable-next-line\n    // @ts-ignore for some reason it's not picking up that other options are optional\n    const generatedEntrypoint = tmp.fileSync({ postfix: '.js' });\n    diskFs.writeSync(\n      generatedEntrypoint.fd,\n      `\n  import entry from \"${path.resolve(process.cwd(), entryPath)}\";\n\n  if (module.hot) {\n    module.hot.accept();\n  }\n\n  export default entry;\n    `,\n    );\n    return generatedEntrypoint;\n  }\n\n  const webpackConfigs = [\n    webpackConfig(\n      {\n        ...env,\n        entrypath: hotEntry(entrypoint).name,\n        name: 'client',\n      },\n      { mode: 'development' },\n    ),\n    webpackConfig(\n      {\n        ...env,\n        entrypath: entrypoint.replace('.tsx', '.server.tsx'),\n        name: 'server',\n        BROWSERSLIST_ENV: 'current node',\n      },\n      { mode: 'development', target: 'node' },\n    ),\n  ] as const;\n\n  // initialize the webpack compiler\n  const compiler: MultiCompiler = webpack(webpackConfigs);\n\n  sourceMapSupport.install({ hookRequire: true });\n\n  function getServerBundle(serverStats: webpack.Stats) {\n    const serverJson = serverStats.toJson({ assets: true });\n    return path.join(serverJson.outputPath ?? '', 'server.js');\n  }\n  function handleErrors<\n    F extends (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n    ) => Promise<void>,\n  >(fn: F) {\n    return async function (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n      next: NextFunction,\n    ) {\n      try {\n        return await fn(req, res);\n      } catch (x) {\n        next(x);\n      }\n    };\n  }\n\n  let initRender:\n    | { args: Parameters<BoundRender>; resolve: () => void }[]\n    | undefined = [];\n  let render: BoundRender = (...args) =>\n    new Promise(resolve => {\n      initRender?.push({ args, resolve });\n    });\n\n  function importRender(stats: webpack.Stats[]) {\n    const [clientStats, serverStats] = stats;\n    if (\n      clientStats?.compilation?.errors?.length ||\n      serverStats?.compilation?.errors?.length\n    ) {\n      log.error('Errors for client build: ' + clientStats.compilation.errors);\n      log.error('Errors for server build: ' + serverStats.compilation.errors);\n      // first time, rather than re-render\n      if (Array.isArray(initRender)) {\n        process.exit(-1);\n      }\n      log.error('Above compiler errors blocking reload');\n      return;\n    } else {\n      log.info('Launching SSR');\n    }\n\n    // ASSETS\n    const clientManifest = clientStats.toJson();\n\n    const serverEntry = getServerBundle(serverStats);\n    // reload modules\n    Object.keys(fsRequire.cache).forEach(key => {\n      delete fsRequire.cache[key];\n    });\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n    render = (fsRequire(serverEntry) as any).default.bind(\n      undefined,\n      clientManifest,\n    );\n    // SERVER SIDE ENTRYPOINT\n    if (Array.isArray(initRender)) {\n      initRender.forEach(async init => {\n        try {\n          log.info('Resolving queued requests');\n          await render(...init.args);\n          init.resolve();\n        } catch (e) {\n          log.error('Error when attempting to render queued requests');\n          log.error(e);\n        }\n      });\n      initRender = undefined;\n    }\n  }\n\n  const devServer = new WebpackDevServer(\n    // write to memory filesystem so we can import\n    {\n      ...webpackConfigs[0].devServer,\n      devMiddleware: {\n        ...webpackConfigs[0]?.devServer?.devMiddleware,\n        outputFileSystem: {\n          ...fs,\n          join: path.join as any,\n        } as any as typeof fs,\n      },\n      setupMiddlewares: (middlewares, devServer) => {\n        if (!devServer) {\n          throw new Error('webpack-dev-server is not defined');\n        }\n\n        const otherRoutes = [\n          process.env.WEBPACK_PUBLIC_PATH,\n          ...Object.keys(webpackConfigs[0].devServer?.proxy ?? {}),\n        ];\n        // serve SSR for non-WEBPACK_PUBLIC_PATH\n        devServer.app?.get(\n          new RegExp(`^(?!${otherRoutes.join('|')})`),\n          handleErrors(async function (req: any, res: any) {\n            if (req.url.endsWith('favicon.ico')) {\n              res.statusCode = 404;\n              res.setHeader('Content-type', 'text/html');\n              res.send('not found');\n              return;\n            }\n            res.socket.on('error', (error: unknown) => {\n              console.error('Fatal', error);\n            });\n\n            await render(req, res);\n          }),\n        );\n\n        if (webpackConfigs[0].devServer?.setupMiddlewares) {\n          return webpackConfigs[0].devServer.setupMiddlewares(\n            middlewares,\n            devServer,\n          );\n        }\n\n        return middlewares;\n      },\n    },\n    compiler,\n  );\n  const runServer = async () => {\n    await devServer.start();\n    devServer.compiler.hooks.done.tap(\n      'Anansi Server',\n      (multiStats: webpack.MultiStats | webpack.Stats) => {\n        if (!multiStats) {\n          log.error('stats not send');\n          process.exit(-1);\n        }\n\n        if (!Object.hasOwn(multiStats, 'stats')) return;\n        if ((multiStats as webpack.MultiStats).stats.length > 1) {\n          try {\n            importRender((multiStats as webpack.MultiStats).stats);\n          } catch (e: any) {\n            log.error('Failed to load serve entrypoint');\n            throw e;\n          }\n        } else {\n          log.error('Only compiler one stat');\n        }\n      },\n    );\n  };\n  const stopServer = async () => {\n    log.info('Stopping server...');\n    await devServer.stop();\n    log.info('Server closed');\n  };\n\n  process.on('SIGINT', () => {\n    log.warn('Received SIGINT, devserver shutting down');\n    stopServer();\n    process.exit(-1);\n  });\n\n  runServer();\n}\n"],"mappings":"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"}
213
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Object","hasOwn","it","key","prototype","hasOwnProperty","call","diskFs","createFsRequire","createFsFromVolume","Volume","path","sourceMapSupport","tmp","ufs","promisify","webpack","logging","WebpackDevServer","require","main","module","entrypoint","process","argv","console","log","exit","startDevServer","env","webpackConfig","resolve","join","cwd","getLogger","volume","fs","use","fsRequire","readFile","server","hotEntry","entryPath","generatedEntrypoint","fileSync","postfix","writeSync","fd","webpackConfigs","entrypath","name","mode","replace","BROWSERSLIST_ENV","target","compiler","install","hookRequire","getServerBundle","serverStats","serverJson","toJson","assets","outputPath","handleErrors","fn","req","res","next","x","initRender","render","args","Promise","push","importRender","stats","clientStats","compilation","errors","length","error","Array","isArray","info","clientManifest","serverEntry","keys","cache","forEach","default","bind","undefined","init","e","devServer","devMiddleware","outputFileSystem","setupMiddlewares","middlewares","Error","otherRoutes","WEBPACK_PUBLIC_PATH","proxy","app","get","RegExp","url","endsWith","statusCode","setHeader","send","socket","on","runServer","start","hooks","done","tap","multiStats","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\nObject.hasOwn =\n  Object.hasOwn ||\n  /* istanbul ignore next */ function hasOwn(it, key) {\n    return Object.prototype.hasOwnProperty.call(it, key);\n  };\nimport type { NextFunction } from 'express';\nimport diskFs from 'fs';\nimport { createFsRequire } from 'fs-require';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport path from 'path';\nimport sourceMapSupport from 'source-map-support';\nimport tmp from 'tmp';\nimport { ufs } from 'unionfs';\nimport { promisify } from 'util';\nimport webpack, { MultiCompiler } from 'webpack';\nimport logging from 'webpack/lib/logging/runtime';\nimport WebpackDevServer from 'webpack-dev-server';\n\nimport 'cross-fetch/polyfill';\nimport { BoundRender } from './types';\n\n// run directly from node\nif (require.main === module) {\n  const entrypoint = process.argv[2];\n\n  if (!entrypoint) {\n    console.log(`Usage: start-anansi <entrypoint-file>`);\n    process.exit(-1);\n  }\n\n  startDevServer(entrypoint);\n}\n\nexport default function startDevServer(\n  entrypoint: string,\n  env: Record<string, unknown> = {},\n) {\n  // eslint-disable-next-line @typescript-eslint/no-var-requires\n  const webpackConfig = require(require.resolve(\n    // TODO: use normal resolution algorithm to find webpack file\n    path.join(process.cwd(), 'webpack.config'),\n  ));\n\n  const log = logging.getLogger('anansi-devserver');\n\n  // Set up in memory filesystem\n  const volume = new Volume();\n  const fs = createFsFromVolume(volume);\n  ufs.use(diskFs).use(fs as any);\n\n  const fsRequire = createFsRequire(ufs);\n  const readFile = promisify(ufs.readFile);\n  let server: Server | undefined;\n\n  // Generate a temporary file so we can hot reload from the root of the application\n  function hotEntry(entryPath: string) {\n    // eslint-disable-next-line\n    // @ts-ignore for some reason it's not picking up that other options are optional\n    const generatedEntrypoint = tmp.fileSync({ postfix: '.js' });\n    diskFs.writeSync(\n      generatedEntrypoint.fd,\n      `\n  import entry from \"${path.resolve(process.cwd(), entryPath)}\";\n\n  if (module.hot) {\n    module.hot.accept();\n  }\n\n  export default entry;\n    `,\n    );\n    return generatedEntrypoint;\n  }\n\n  const webpackConfigs = [\n    webpackConfig(\n      {\n        ...env,\n        entrypath: hotEntry(entrypoint).name,\n        name: 'client',\n      },\n      { mode: 'development' },\n    ),\n    webpackConfig(\n      {\n        ...env,\n        entrypath: entrypoint.replace('.tsx', '.server.tsx'),\n        name: 'server',\n        BROWSERSLIST_ENV: 'current node',\n      },\n      { mode: 'development', target: 'node' },\n    ),\n  ] as const;\n\n  // initialize the webpack compiler\n  const compiler: MultiCompiler = webpack(webpackConfigs);\n\n  sourceMapSupport.install({ hookRequire: true });\n\n  function getServerBundle(serverStats: webpack.Stats) {\n    const serverJson = serverStats.toJson({ assets: true });\n    return path.join(serverJson.outputPath ?? '', 'server.js');\n  }\n  function handleErrors<\n    F extends (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n    ) => Promise<void>,\n  >(fn: F) {\n    return async function (\n      req: Request | IncomingMessage,\n      res: Response | ServerResponse,\n      next: NextFunction,\n    ) {\n      try {\n        return await fn(req, res);\n      } catch (x) {\n        next(x);\n      }\n    };\n  }\n\n  let initRender:\n    | { args: Parameters<BoundRender>; resolve: () => void }[]\n    | undefined = [];\n  let render: BoundRender = (...args) =>\n    new Promise(resolve => {\n      initRender?.push({ args, resolve });\n    });\n\n  function importRender(stats: webpack.Stats[]) {\n    const [clientStats, serverStats] = stats;\n    if (\n      clientStats?.compilation?.errors?.length ||\n      serverStats?.compilation?.errors?.length\n    ) {\n      log.error('Errors for client build: ' + clientStats.compilation.errors);\n      log.error('Errors for server build: ' + serverStats.compilation.errors);\n      // first time, rather than re-render\n      if (Array.isArray(initRender)) {\n        process.exit(-1);\n      }\n      log.error('Above compiler errors blocking reload');\n      return;\n    } else {\n      log.info('Launching SSR');\n    }\n\n    // ASSETS\n    const clientManifest = clientStats.toJson();\n\n    const serverEntry = getServerBundle(serverStats);\n    // reload modules\n    Object.keys(fsRequire.cache).forEach(key => {\n      delete fsRequire.cache[key];\n    });\n    // eslint-disable-next-line @typescript-eslint/no-var-requires\n    render = (fsRequire(serverEntry) as any).default.bind(\n      undefined,\n      clientManifest,\n    );\n    // SERVER SIDE ENTRYPOINT\n    if (Array.isArray(initRender)) {\n      initRender.forEach(async init => {\n        try {\n          log.info('Resolving queued requests');\n          await render(...init.args);\n          init.resolve();\n        } catch (e) {\n          log.error('Error when attempting to render queued requests');\n          log.error(e);\n        }\n      });\n      initRender = undefined;\n    }\n  }\n\n  const devServer = new WebpackDevServer(\n    // write to memory filesystem so we can import\n    {\n      ...webpackConfigs[0].devServer,\n      devMiddleware: {\n        ...webpackConfigs[0]?.devServer?.devMiddleware,\n        outputFileSystem: {\n          ...fs,\n          join: path.join as any,\n        } as any as typeof fs,\n      },\n      setupMiddlewares: (middlewares, devServer) => {\n        if (!devServer) {\n          throw new Error('webpack-dev-server is not defined');\n        }\n\n        const otherRoutes = [\n          process.env.WEBPACK_PUBLIC_PATH,\n          ...Object.keys(webpackConfigs[0].devServer?.proxy ?? {}),\n        ];\n        // serve SSR for non-WEBPACK_PUBLIC_PATH\n        devServer.app?.get(\n          new RegExp(`^(?!${otherRoutes.join('|')})`),\n          handleErrors(async function (req: any, res: any) {\n            if (req.url.endsWith('favicon.ico')) {\n              res.statusCode = 404;\n              res.setHeader('Content-type', 'text/html');\n              res.send('not found');\n              return;\n            }\n            res.socket.on('error', (error: unknown) => {\n              console.error('Fatal', error);\n            });\n\n            await render(req, res);\n          }),\n        );\n\n        if (webpackConfigs[0].devServer?.setupMiddlewares) {\n          return webpackConfigs[0].devServer.setupMiddlewares(\n            middlewares,\n            devServer,\n          );\n        }\n\n        return middlewares;\n      },\n    },\n    compiler,\n  );\n  const runServer = async () => {\n    await devServer.start();\n    devServer.compiler.hooks.done.tap(\n      'Anansi Server',\n      (multiStats: webpack.MultiStats | webpack.Stats) => {\n        if (!multiStats) {\n          log.error('stats not send');\n          process.exit(-1);\n        }\n\n        if (!Object.hasOwn(multiStats, 'stats')) return;\n        if ((multiStats as webpack.MultiStats).stats.length > 1) {\n          try {\n            importRender((multiStats as webpack.MultiStats).stats);\n          } catch (e: any) {\n            log.error('Failed to load serve entrypoint');\n            throw e;\n          }\n        } else {\n          log.error('Only compiler one stat');\n        }\n      },\n    );\n  };\n  const stopServer = async () => {\n    log.info('Stopping server...');\n    await devServer.stop();\n    log.info('Server closed');\n  };\n\n  process.on('SIGINT', () => {\n    log.warn('Received SIGINT, devserver shutting down');\n    stopServer();\n    process.exit(-1);\n  });\n\n  runServer();\n}\n"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /// <reference types="node" />
2
+ import { Request, Response } from 'express';
3
+ import { ServerResponse, IncomingMessage } from 'http';
4
+ import { StatsCompilation } from 'webpack';
5
+ export type Render = (clientManifest: StatsCompilation, req: Request | IncomingMessage, res: Response | ServerResponse) => Promise<void>;
6
+ export type BoundRender = (req: Request | IncomingMessage, res: Response | ServerResponse) => Promise<void>;
7
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/scripts/types.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3C,MAAM,MAAM,MAAM,GAAG,CACnB,cAAc,EAAE,gBAAgB,EAChC,GAAG,EAAE,OAAO,GAAG,eAAe,EAC9B,GAAG,EAAE,QAAQ,GAAG,cAAc,KAC3B,OAAO,CAAC,IAAI,CAAC,CAAC;AAEnB,MAAM,MAAM,WAAW,GAAG,CACxB,GAAG,EAAE,OAAO,GAAG,eAAe,EAC9B,GAAG,EAAE,QAAQ,GAAG,cAAc,KAC3B,OAAO,CAAC,IAAI,CAAC,CAAC"}
@@ -1,4 +1,2 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
1
+ export {};
4
2
  //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmlwdHMvdHlwZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVxdWVzdCwgUmVzcG9uc2UgfSBmcm9tICdleHByZXNzJztcbmltcG9ydCB7IFNlcnZlclJlc3BvbnNlLCBJbmNvbWluZ01lc3NhZ2UgfSBmcm9tICdodHRwJztcbmltcG9ydCB7IFN0YXRzQ29tcGlsYXRpb24gfSBmcm9tICd3ZWJwYWNrJztcblxuZXhwb3J0IHR5cGUgUmVuZGVyID0gKFxuICBjbGllbnRNYW5pZmVzdDogU3RhdHNDb21waWxhdGlvbixcbiAgcmVxOiBSZXF1ZXN0IHwgSW5jb21pbmdNZXNzYWdlLFxuICByZXM6IFJlc3BvbnNlIHwgU2VydmVyUmVzcG9uc2UsXG4pID0+IFByb21pc2U8dm9pZD47XG5cbmV4cG9ydCB0eXBlIEJvdW5kUmVuZGVyID0gKFxuICByZXE6IFJlcXVlc3QgfCBJbmNvbWluZ01lc3NhZ2UsXG4gIHJlczogUmVzcG9uc2UgfCBTZXJ2ZXJSZXNwb25zZSxcbikgPT4gUHJvbWlzZTx2b2lkPjtcbiJdLCJtYXBwaW5ncyI6IiJ9
@@ -1,13 +1,8 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- exports.__esModule = true;
5
- exports.default = Document;
6
- var _jsx2 = _interopRequireDefault(require("@babel/runtime/helpers/jsx"));
7
- var _react = _interopRequireDefault(require("react"));
8
- var _csp = require("./csp");
1
+ import _jsx from "@babel/runtime/helpers/jsx";
9
2
  var _process$env$WEBPACK_;
10
- function Document({
3
+ import React from "react";
4
+ import { buildPolicy } from './csp';
5
+ export default function Document({
11
6
  assets,
12
7
  head,
13
8
  children,
@@ -34,33 +29,33 @@ function Document({
34
29
  policy['script-src'] = [...policy['script-src'], `'nonce-${nonce}'`];
35
30
  }
36
31
  }
37
- cspMeta = /*#__PURE__*/(0, _jsx2.default)("meta", {
32
+ cspMeta = /*#__PURE__*/_jsx("meta", {
38
33
  httpEquiv: "Content-Security-Policy",
39
- content: (0, _csp.buildPolicy)(policy)
34
+ content: buildPolicy(policy)
40
35
  });
41
36
  }
42
- return /*#__PURE__*/(0, _jsx2.default)("html", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("head", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("meta", {
37
+ return /*#__PURE__*/_jsx("html", {}, void 0, /*#__PURE__*/_jsx("head", {}, void 0, /*#__PURE__*/_jsx("meta", {
43
38
  charSet: charSet
44
- }), cspMeta, head, extraStyle, assets.map((asset, i) => /*#__PURE__*/_react.default.createElement("link", {
39
+ }), cspMeta, head, extraStyle, assets.map((asset, i) => /*#__PURE__*/React.createElement("link", {
45
40
  key: i,
46
41
  rel: "preload",
47
42
  ...asset
48
- })), /*#__PURE__*/(0, _jsx2.default)("title", {}, void 0, title)), /*#__PURE__*/(0, _jsx2.default)("body", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("div", {
43
+ })), /*#__PURE__*/_jsx("title", {}, void 0, title)), /*#__PURE__*/_jsx("body", {}, void 0, /*#__PURE__*/_jsx("div", {
49
44
  id: rootId
50
45
  }, void 0, children), scripts, assets.filter(({
51
46
  href
52
47
  }) => href.endsWith('.js')).map(({
53
48
  href
54
- }, i) => /*#__PURE__*/(0, _jsx2.default)("script", {
49
+ }, i) => /*#__PURE__*/_jsx("script", {
55
50
  src: href,
56
51
  async: true
57
52
  }, i))));
58
53
  }
59
54
  Document.defaultProps = {
60
- head: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/(0, _jsx2.default)("meta", {
55
+ head: /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/_jsx("meta", {
61
56
  name: "viewport",
62
57
  content: "width=device-width, initial-scale=1"
63
- }), /*#__PURE__*/(0, _jsx2.default)("link", {
58
+ }), /*#__PURE__*/_jsx("link", {
64
59
  rel: "shortcut icon",
65
60
  href: `${(_process$env$WEBPACK_ = process.env.WEBPACK_PUBLIC_PATH) != null ? _process$env$WEBPACK_ : '/'}favicon.ico`
66
61
  })),
@@ -68,4 +63,4 @@ Document.defaultProps = {
68
63
  rootId: 'anansi-root',
69
64
  scripts: null
70
65
  };
71
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEb2N1bWVudCIsImFzc2V0cyIsImhlYWQiLCJjaGlsZHJlbiIsInRpdGxlIiwicm9vdElkIiwiY2hhclNldCIsImNzUG9saWN5Iiwibm9uY2UiLCJzY3JpcHRzIiwiZXh0cmFTdHlsZSIsImNzcE1ldGEiLCJwb2xpY3kiLCJpbmNsdWRlcyIsImJ1aWxkUG9saWN5IiwibWFwIiwiYXNzZXQiLCJpIiwiZmlsdGVyIiwiaHJlZiIsImVuZHNXaXRoIiwiZGVmYXVsdFByb3BzIiwicHJvY2VzcyIsImVudiIsIldFQlBBQ0tfUFVCTElDX1BBVEgiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL0RvY3VtZW50Q29tcG9uZW50LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBvbGljeSB9IGZyb20gJy4vY3NwJztcbmltcG9ydCB7IGJ1aWxkUG9saWN5IH0gZnJvbSAnLi9jc3AnO1xuXG50eXBlIFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xuICBhc3NldHM6IHsgaHJlZjogc3RyaW5nOyBhcz86IHN0cmluZzsgcmVsPzogc3RyaW5nIH1bXTtcbiAgaGVhZDogUmVhY3QuUmVhY3ROb2RlO1xuICBleHRyYVN0eWxlOiBSZWFjdC5SZWFjdE5vZGU7XG4gIHNjcmlwdHM6IFJlYWN0LlJlYWN0Tm9kZTtcbiAgdGl0bGU6IHN0cmluZztcbiAgcm9vdElkOiBzdHJpbmc7XG4gIGNoYXJTZXQ6IHN0cmluZztcbiAgY3NQb2xpY3k/OiBQb2xpY3k7XG4gIG5vbmNlPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRG9jdW1lbnQoe1xuICBhc3NldHMsXG4gIGhlYWQsXG4gIGNoaWxkcmVuLFxuICB0aXRsZSxcbiAgcm9vdElkLFxuICBjaGFyU2V0LFxuICBjc1BvbGljeSxcbiAgbm9uY2UsXG4gIHNjcmlwdHMsXG4gIGV4dHJhU3R5bGUsXG59OiBQcm9wcykge1xuICBsZXQgY3NwTWV0YTogbnVsbCB8IFJlYWN0LlJlYWN0Tm9kZSA9IG51bGw7XG4gIGlmIChjc1BvbGljeSkge1xuICAgIC8vIGFkZCBub25jZSB0byBwb2xpY3lcbiAgICBjb25zdCBwb2xpY3kgPSB7XG4gICAgICAuLi5jc1BvbGljeSxcbiAgICB9O1xuICAgIGlmIChcbiAgICAgIG5vbmNlICYmXG4gICAgICAvLyBub25jZXMgbmVnYXRlICd1bnNhZmUtaW5saW5lJyBzbyBkbyBub3QgYWRkIGl0IGlmIHRoYXQgZGlyZWN0aXZlIGV4aXN0c1xuICAgICAgKCFwb2xpY3lbJ3NjcmlwdC1zcmMnXSB8fFxuICAgICAgICAhcG9saWN5WydzY3JpcHQtc3JjJ10uaW5jbHVkZXMoXCIndW5zYWZlLWlubGluZSdcIikpXG4gICAgKSB7XG4gICAgICBpZiAodHlwZW9mIHBvbGljeVsnc2NyaXB0LXNyYyddID09PSAnc3RyaW5nJykge1xuICAgICAgICBwb2xpY3lbJ3NjcmlwdC1zcmMnXSA9IFtwb2xpY3lbJ3NjcmlwdC1zcmMnXSwgYCdub25jZS0ke25vbmNlfSdgXTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHBvbGljeVsnc2NyaXB0LXNyYyddID0gWy4uLnBvbGljeVsnc2NyaXB0LXNyYyddLCBgJ25vbmNlLSR7bm9uY2V9J2BdO1xuICAgICAgfVxuICAgIH1cbiAgICBjc3BNZXRhID0gKFxuICAgICAgPG1ldGEgaHR0cEVxdWl2PVwiQ29udGVudC1TZWN1cml0eS1Qb2xpY3lcIiBjb250ZW50PXtidWlsZFBvbGljeShwb2xpY3kpfSAvPlxuICAgICk7XG4gIH1cbiAgcmV0dXJuIChcbiAgICA8aHRtbD5cbiAgICAgIDxoZWFkPlxuICAgICAgICA8bWV0YSBjaGFyU2V0PXtjaGFyU2V0fSAvPlxuICAgICAgICB7Y3NwTWV0YX1cbiAgICAgICAge2hlYWR9XG4gICAgICAgIHtleHRyYVN0eWxlfVxuICAgICAgICB7YXNzZXRzLm1hcCgoYXNzZXQsIGkpID0+IChcbiAgICAgICAgICA8bGluayBrZXk9e2l9IHJlbD1cInByZWxvYWRcIiB7Li4uYXNzZXR9IC8+XG4gICAgICAgICkpfVxuICAgICAgICA8dGl0bGU+e3RpdGxlfTwvdGl0bGU+XG4gICAgICA8L2hlYWQ+XG4gICAgICA8Ym9keT5cbiAgICAgICAgPGRpdiBpZD17cm9vdElkfT57Y2hpbGRyZW59PC9kaXY+XG4gICAgICAgIHtzY3JpcHRzfVxuICAgICAgICB7YXNzZXRzXG4gICAgICAgICAgLmZpbHRlcigoeyBocmVmIH0pID0+IGhyZWYuZW5kc1dpdGgoJy5qcycpKVxuICAgICAgICAgIC5tYXAoKHsgaHJlZiB9LCBpKSA9PiAoXG4gICAgICAgICAgICA8c2NyaXB0IGtleT17aX0gc3JjPXtocmVmfSBhc3luYyAvPlxuICAgICAgICAgICkpfVxuICAgICAgPC9ib2R5PlxuICAgIDwvaHRtbD5cbiAgKTtcbn1cbkRvY3VtZW50LmRlZmF1bHRQcm9wcyA9IHtcbiAgaGVhZDogKFxuICAgIDw+XG4gICAgICA8bWV0YSBuYW1lPVwidmlld3BvcnRcIiBjb250ZW50PVwid2lkdGg9ZGV2aWNlLXdpZHRoLCBpbml0aWFsLXNjYWxlPTFcIiAvPlxuICAgICAgPGxpbmtcbiAgICAgICAgcmVsPVwic2hvcnRjdXQgaWNvblwiXG4gICAgICAgIGhyZWY9e2Ake3Byb2Nlc3MuZW52LldFQlBBQ0tfUFVCTElDX1BBVEggPz8gJy8nfWZhdmljb24uaWNvYH1cbiAgICAgIC8+XG4gICAgPC8+XG4gICksXG4gIGNoYXJTZXQ6ICd1dGYtOCcsXG4gIHJvb3RJZDogJ2FuYW5zaS1yb290JyxcbiAgc2NyaXB0czogbnVsbCxcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFDQTtBQUFvQztBQWVyQixTQUFTQSxRQUFRLENBQUM7RUFDL0JDLE1BQU07RUFDTkMsSUFBSTtFQUNKQyxRQUFRO0VBQ1JDLEtBQUs7RUFDTEMsTUFBTTtFQUNOQyxPQUFPO0VBQ1BDLFFBQVE7RUFDUkMsS0FBSztFQUNMQyxPQUFPO0VBQ1BDO0FBQ0ssQ0FBQyxFQUFFO0VBQ1IsSUFBSUMsT0FBK0IsR0FBRyxJQUFJO0VBQzFDLElBQUlKLFFBQVEsRUFBRTtJQUNaO0lBQ0EsTUFBTUssTUFBTSxHQUFHO01BQ2IsR0FBR0w7SUFDTCxDQUFDO0lBQ0QsSUFDRUMsS0FBSztJQUNMO0lBQ0MsQ0FBQ0ksTUFBTSxDQUFDLFlBQVksQ0FBQyxJQUNwQixDQUFDQSxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUNDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLEVBQ3BEO01BQ0EsSUFBSSxPQUFPRCxNQUFNLENBQUMsWUFBWSxDQUFDLEtBQUssUUFBUSxFQUFFO1FBQzVDQSxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQ0EsTUFBTSxDQUFDLFlBQVksQ0FBQyxFQUFHLFVBQVNKLEtBQU0sR0FBRSxDQUFDO01BQ25FLENBQUMsTUFBTTtRQUNMSSxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxHQUFHQSxNQUFNLENBQUMsWUFBWSxDQUFDLEVBQUcsVUFBU0osS0FBTSxHQUFFLENBQUM7TUFDdEU7SUFDRjtJQUNBRyxPQUFPLGdCQUNMO01BQU0sU0FBUyxFQUFDLHlCQUF5QjtNQUFDLE9BQU8sRUFBRSxJQUFBRyxnQkFBVyxFQUFDRixNQUFNO0lBQUUsRUFDeEU7RUFDSDtFQUNBLG9CQUNFLG9EQUNFLG9EQUNFO0lBQU0sT0FBTyxFQUFFTjtFQUFRLEVBQUcsRUFDekJLLE9BQU8sRUFDUFQsSUFBSSxFQUNKUSxVQUFVLEVBQ1ZULE1BQU0sQ0FBQ2MsR0FBRyxDQUFDLENBQUNDLEtBQUssRUFBRUMsQ0FBQyxrQkFDbkI7SUFBTSxHQUFHLEVBQUVBLENBQUU7SUFBQyxHQUFHLEVBQUMsU0FBUztJQUFBLEdBQUtEO0VBQUssRUFDdEMsQ0FBQyxlQUNGLHdDQUFRWixLQUFLLENBQVMsQ0FDakIsZUFDUCxvREFDRTtJQUFLLEVBQUUsRUFBRUM7RUFBTyxXQUFFRixRQUFRLENBQU8sRUFDaENNLE9BQU8sRUFDUFIsTUFBTSxDQUNKaUIsTUFBTSxDQUFDLENBQUM7SUFBRUM7RUFBSyxDQUFDLEtBQUtBLElBQUksQ0FBQ0MsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQzFDTCxHQUFHLENBQUMsQ0FBQztJQUFFSTtFQUFLLENBQUMsRUFBRUYsQ0FBQyxrQkFDZjtJQUFnQixHQUFHLEVBQUVFLElBQUs7SUFBQyxLQUFLO0VBQUEsR0FBbkJGLENBQUMsQ0FDZixDQUFDLENBQ0MsQ0FDRjtBQUVYO0FBQ0FqQixRQUFRLENBQUNxQixZQUFZLEdBQUc7RUFDdEJuQixJQUFJLGVBQ0YseUVBQ0U7SUFBTSxJQUFJLEVBQUMsVUFBVTtJQUFDLE9BQU8sRUFBQztFQUFxQyxFQUFHLGVBQ3RFO0lBQ0UsR0FBRyxFQUFDLGVBQWU7SUFDbkIsSUFBSSxFQUFHLDRCQUFFb0IsT0FBTyxDQUFDQyxHQUFHLENBQUNDLG1CQUFtQixvQ0FBSSxHQUFJO0VBQWEsRUFDN0QsQ0FFTDtFQUNEbEIsT0FBTyxFQUFFLE9BQU87RUFDaEJELE1BQU0sRUFBRSxhQUFhO0VBQ3JCSSxPQUFPLEVBQUU7QUFDWCxDQUFDIn0=
66
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZFBvbGljeSIsIkRvY3VtZW50IiwiYXNzZXRzIiwiaGVhZCIsImNoaWxkcmVuIiwidGl0bGUiLCJyb290SWQiLCJjaGFyU2V0IiwiY3NQb2xpY3kiLCJub25jZSIsInNjcmlwdHMiLCJleHRyYVN0eWxlIiwiY3NwTWV0YSIsInBvbGljeSIsImluY2x1ZGVzIiwibWFwIiwiYXNzZXQiLCJpIiwiZmlsdGVyIiwiaHJlZiIsImVuZHNXaXRoIiwiZGVmYXVsdFByb3BzIiwicHJvY2VzcyIsImVudiIsIldFQlBBQ0tfUFVCTElDX1BBVEgiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL0RvY3VtZW50Q29tcG9uZW50LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFBvbGljeSB9IGZyb20gJy4vY3NwJztcbmltcG9ydCB7IGJ1aWxkUG9saWN5IH0gZnJvbSAnLi9jc3AnO1xuXG50eXBlIFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlO1xuICBhc3NldHM6IHsgaHJlZjogc3RyaW5nOyBhcz86IHN0cmluZzsgcmVsPzogc3RyaW5nIH1bXTtcbiAgaGVhZDogUmVhY3QuUmVhY3ROb2RlO1xuICBleHRyYVN0eWxlOiBSZWFjdC5SZWFjdE5vZGU7XG4gIHNjcmlwdHM6IFJlYWN0LlJlYWN0Tm9kZTtcbiAgdGl0bGU6IHN0cmluZztcbiAgcm9vdElkOiBzdHJpbmc7XG4gIGNoYXJTZXQ6IHN0cmluZztcbiAgY3NQb2xpY3k/OiBQb2xpY3k7XG4gIG5vbmNlPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRG9jdW1lbnQoe1xuICBhc3NldHMsXG4gIGhlYWQsXG4gIGNoaWxkcmVuLFxuICB0aXRsZSxcbiAgcm9vdElkLFxuICBjaGFyU2V0LFxuICBjc1BvbGljeSxcbiAgbm9uY2UsXG4gIHNjcmlwdHMsXG4gIGV4dHJhU3R5bGUsXG59OiBQcm9wcykge1xuICBsZXQgY3NwTWV0YTogbnVsbCB8IFJlYWN0LlJlYWN0Tm9kZSA9IG51bGw7XG4gIGlmIChjc1BvbGljeSkge1xuICAgIC8vIGFkZCBub25jZSB0byBwb2xpY3lcbiAgICBjb25zdCBwb2xpY3kgPSB7XG4gICAgICAuLi5jc1BvbGljeSxcbiAgICB9O1xuICAgIGlmIChcbiAgICAgIG5vbmNlICYmXG4gICAgICAvLyBub25jZXMgbmVnYXRlICd1bnNhZmUtaW5saW5lJyBzbyBkbyBub3QgYWRkIGl0IGlmIHRoYXQgZGlyZWN0aXZlIGV4aXN0c1xuICAgICAgKCFwb2xpY3lbJ3NjcmlwdC1zcmMnXSB8fFxuICAgICAgICAhcG9saWN5WydzY3JpcHQtc3JjJ10uaW5jbHVkZXMoXCIndW5zYWZlLWlubGluZSdcIikpXG4gICAgKSB7XG4gICAgICBpZiAodHlwZW9mIHBvbGljeVsnc2NyaXB0LXNyYyddID09PSAnc3RyaW5nJykge1xuICAgICAgICBwb2xpY3lbJ3NjcmlwdC1zcmMnXSA9IFtwb2xpY3lbJ3NjcmlwdC1zcmMnXSwgYCdub25jZS0ke25vbmNlfSdgXTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHBvbGljeVsnc2NyaXB0LXNyYyddID0gWy4uLnBvbGljeVsnc2NyaXB0LXNyYyddLCBgJ25vbmNlLSR7bm9uY2V9J2BdO1xuICAgICAgfVxuICAgIH1cbiAgICBjc3BNZXRhID0gKFxuICAgICAgPG1ldGEgaHR0cEVxdWl2PVwiQ29udGVudC1TZWN1cml0eS1Qb2xpY3lcIiBjb250ZW50PXtidWlsZFBvbGljeShwb2xpY3kpfSAvPlxuICAgICk7XG4gIH1cbiAgcmV0dXJuIChcbiAgICA8aHRtbD5cbiAgICAgIDxoZWFkPlxuICAgICAgICA8bWV0YSBjaGFyU2V0PXtjaGFyU2V0fSAvPlxuICAgICAgICB7Y3NwTWV0YX1cbiAgICAgICAge2hlYWR9XG4gICAgICAgIHtleHRyYVN0eWxlfVxuICAgICAgICB7YXNzZXRzLm1hcCgoYXNzZXQsIGkpID0+IChcbiAgICAgICAgICA8bGluayBrZXk9e2l9IHJlbD1cInByZWxvYWRcIiB7Li4uYXNzZXR9IC8+XG4gICAgICAgICkpfVxuICAgICAgICA8dGl0bGU+e3RpdGxlfTwvdGl0bGU+XG4gICAgICA8L2hlYWQ+XG4gICAgICA8Ym9keT5cbiAgICAgICAgPGRpdiBpZD17cm9vdElkfT57Y2hpbGRyZW59PC9kaXY+XG4gICAgICAgIHtzY3JpcHRzfVxuICAgICAgICB7YXNzZXRzXG4gICAgICAgICAgLmZpbHRlcigoeyBocmVmIH0pID0+IGhyZWYuZW5kc1dpdGgoJy5qcycpKVxuICAgICAgICAgIC5tYXAoKHsgaHJlZiB9LCBpKSA9PiAoXG4gICAgICAgICAgICA8c2NyaXB0IGtleT17aX0gc3JjPXtocmVmfSBhc3luYyAvPlxuICAgICAgICAgICkpfVxuICAgICAgPC9ib2R5PlxuICAgIDwvaHRtbD5cbiAgKTtcbn1cbkRvY3VtZW50LmRlZmF1bHRQcm9wcyA9IHtcbiAgaGVhZDogKFxuICAgIDw+XG4gICAgICA8bWV0YSBuYW1lPVwidmlld3BvcnRcIiBjb250ZW50PVwid2lkdGg9ZGV2aWNlLXdpZHRoLCBpbml0aWFsLXNjYWxlPTFcIiAvPlxuICAgICAgPGxpbmtcbiAgICAgICAgcmVsPVwic2hvcnRjdXQgaWNvblwiXG4gICAgICAgIGhyZWY9e2Ake3Byb2Nlc3MuZW52LldFQlBBQ0tfUFVCTElDX1BBVEggPz8gJy8nfWZhdmljb24uaWNvYH1cbiAgICAgIC8+XG4gICAgPC8+XG4gICksXG4gIGNoYXJTZXQ6ICd1dGYtOCcsXG4gIHJvb3RJZDogJ2FuYW5zaS1yb290JyxcbiAgc2NyaXB0czogbnVsbCxcbn07XG4iXSwibWFwcGluZ3MiOiI7OztBQUNBLFNBQVNBLFdBQVcsUUFBUSxPQUFPO0FBZW5DLGVBQWUsU0FBU0MsUUFBUSxDQUFDO0VBQy9CQyxNQUFNO0VBQ05DLElBQUk7RUFDSkMsUUFBUTtFQUNSQyxLQUFLO0VBQ0xDLE1BQU07RUFDTkMsT0FBTztFQUNQQyxRQUFRO0VBQ1JDLEtBQUs7RUFDTEMsT0FBTztFQUNQQztBQUNLLENBQUMsRUFBRTtFQUNSLElBQUlDLE9BQStCLEdBQUcsSUFBSTtFQUMxQyxJQUFJSixRQUFRLEVBQUU7SUFDWjtJQUNBLE1BQU1LLE1BQU0sR0FBRztNQUNiLEdBQUdMO0lBQ0wsQ0FBQztJQUNELElBQ0VDLEtBQUs7SUFDTDtJQUNDLENBQUNJLE1BQU0sQ0FBQyxZQUFZLENBQUMsSUFDcEIsQ0FBQ0EsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxFQUNwRDtNQUNBLElBQUksT0FBT0QsTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLFFBQVEsRUFBRTtRQUM1Q0EsTUFBTSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUNBLE1BQU0sQ0FBQyxZQUFZLENBQUMsRUFBRyxVQUFTSixLQUFNLEdBQUUsQ0FBQztNQUNuRSxDQUFDLE1BQU07UUFDTEksTUFBTSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsR0FBR0EsTUFBTSxDQUFDLFlBQVksQ0FBQyxFQUFHLFVBQVNKLEtBQU0sR0FBRSxDQUFDO01BQ3RFO0lBQ0Y7SUFDQUcsT0FBTyxnQkFDTDtNQUFNLFNBQVMsRUFBQyx5QkFBeUI7TUFBQyxPQUFPLEVBQUVaLFdBQVcsQ0FBQ2EsTUFBTTtJQUFFLEVBQ3hFO0VBQ0g7RUFDQSxvQkFDRSxzQ0FDRSxzQ0FDRTtJQUFNLE9BQU8sRUFBRU47RUFBUSxFQUFHLEVBQ3pCSyxPQUFPLEVBQ1BULElBQUksRUFDSlEsVUFBVSxFQUNWVCxNQUFNLENBQUNhLEdBQUcsQ0FBQyxDQUFDQyxLQUFLLEVBQUVDLENBQUMsa0JBQ25CO0lBQU0sR0FBRyxFQUFFQSxDQUFFO0lBQUMsR0FBRyxFQUFDLFNBQVM7SUFBQSxHQUFLRDtFQUFLLEVBQ3RDLENBQUMsZUFDRiwwQkFBUVgsS0FBSyxDQUFTLENBQ2pCLGVBQ1Asc0NBQ0U7SUFBSyxFQUFFLEVBQUVDO0VBQU8sV0FBRUYsUUFBUSxDQUFPLEVBQ2hDTSxPQUFPLEVBQ1BSLE1BQU0sQ0FDSmdCLE1BQU0sQ0FBQyxDQUFDO0lBQUVDO0VBQUssQ0FBQyxLQUFLQSxJQUFJLENBQUNDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUMxQ0wsR0FBRyxDQUFDLENBQUM7SUFBRUk7RUFBSyxDQUFDLEVBQUVGLENBQUMsa0JBQ2Y7SUFBZ0IsR0FBRyxFQUFFRSxJQUFLO0lBQUMsS0FBSztFQUFBLEdBQW5CRixDQUFDLENBQ2YsQ0FBQyxDQUNDLENBQ0Y7QUFFWDtBQUNBaEIsUUFBUSxDQUFDb0IsWUFBWSxHQUFHO0VBQ3RCbEIsSUFBSSxlQUNGLHVEQUNFO0lBQU0sSUFBSSxFQUFDLFVBQVU7SUFBQyxPQUFPLEVBQUM7RUFBcUMsRUFBRyxlQUN0RTtJQUNFLEdBQUcsRUFBQyxlQUFlO0lBQ25CLElBQUksRUFBRyw0QkFBRW1CLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxtQkFBbUIsb0NBQUksR0FBSTtFQUFhLEVBQzdELENBRUw7RUFDRGpCLE9BQU8sRUFBRSxPQUFPO0VBQ2hCRCxNQUFNLEVBQUUsYUFBYTtFQUNyQkksT0FBTyxFQUFFO0FBQ1gsQ0FBQyJ9