@anansi/core 0.14.28 → 0.14.30

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.
@@ -2,72 +2,52 @@
2
2
  "use strict";
3
3
 
4
4
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5
-
6
5
  exports.__esModule = true;
7
6
  exports.default = startDevServer;
8
-
9
7
  var _util = require("util");
10
-
11
8
  var _fs = _interopRequireDefault(require("fs"));
12
-
13
9
  var _path = _interopRequireDefault(require("path"));
14
-
15
10
  var _webpack = _interopRequireDefault(require("webpack"));
16
-
17
11
  var _memfs = require("memfs");
18
-
19
12
  var _tmp = _interopRequireDefault(require("tmp"));
20
-
21
13
  var _sourceMapSupport = _interopRequireDefault(require("source-map-support"));
22
-
23
14
  var _unionfs = require("unionfs");
24
-
25
15
  var _webpackDevServer = _interopRequireDefault(require("webpack-dev-server"));
26
-
27
16
  var _runtime = _interopRequireDefault(require("webpack/lib/logging/runtime"));
28
-
29
17
  var _fsRequire = require("fs-require");
30
-
31
18
  require("cross-fetch/polyfill");
32
-
33
19
  // run directly from node
34
20
  if (require.main === module) {
35
21
  const entrypoint = process.argv[2];
36
-
37
22
  if (!entrypoint) {
38
23
  console.log(`Usage: start-anansi <entrypoint-file>`);
39
24
  process.exit(-1);
40
25
  }
41
-
42
26
  startDevServer(entrypoint);
43
27
  }
44
-
45
28
  function startDevServer(entrypoint, env = {}) {
46
29
  var _webpackConfigs$, _webpackConfigs$$devS;
47
-
48
30
  // eslint-disable-next-line @typescript-eslint/no-var-requires
49
- const webpackConfig = require(require.resolve( // TODO: use normal resolution algorithm to find webpack file
31
+ const webpackConfig = require(require.resolve(
32
+ // TODO: use normal resolution algorithm to find webpack file
50
33
  _path.default.join(process.cwd(), 'webpack.config')));
34
+ const log = _runtime.default.getLogger('anansi-devserver');
51
35
 
52
- const log = _runtime.default.getLogger('anansi-devserver'); // Set up in memory filesystem
53
-
54
-
36
+ // Set up in memory filesystem
55
37
  const volume = new _memfs.Volume();
56
38
  const fs = (0, _memfs.createFsFromVolume)(volume);
57
-
58
39
  _unionfs.ufs.use(_fs.default).use(fs);
59
-
60
40
  const fsRequire = (0, _fsRequire.createFsRequire)(_unionfs.ufs);
61
41
  const readFile = (0, _util.promisify)(_unionfs.ufs.readFile);
62
- let server; // Generate a temporary file so we can hot reload from the root of the application
42
+ let server;
63
43
 
44
+ // Generate a temporary file so we can hot reload from the root of the application
64
45
  function hotEntry(entryPath) {
65
46
  // eslint-disable-next-line
66
47
  // @ts-ignore for some reason it's not picking up that other options are optional
67
48
  const generatedEntrypoint = _tmp.default.fileSync({
68
49
  postfix: '.js'
69
50
  });
70
-
71
51
  _fs.default.writeSync(generatedEntrypoint.fd, `
72
52
  import entry from "${_path.default.resolve(process.cwd(), entryPath)}";
73
53
 
@@ -77,39 +57,36 @@ function startDevServer(entrypoint, env = {}) {
77
57
 
78
58
  export default entry;
79
59
  `);
80
-
81
60
  return generatedEntrypoint;
82
61
  }
83
-
84
- const webpackConfigs = [webpackConfig({ ...env,
62
+ const webpackConfigs = [webpackConfig({
63
+ ...env,
85
64
  entrypath: hotEntry(entrypoint).name,
86
65
  name: 'client'
87
66
  }, {
88
67
  mode: 'development'
89
- }), webpackConfig({ ...env,
68
+ }), webpackConfig({
69
+ ...env,
90
70
  entrypath: entrypoint.replace('.tsx', '.server.tsx'),
91
71
  name: 'server',
92
72
  BROWSERSLIST_ENV: 'current node'
93
73
  }, {
94
74
  mode: 'development',
95
75
  target: 'node'
96
- })]; // initialize the webpack compiler
76
+ })];
97
77
 
78
+ // initialize the webpack compiler
98
79
  const compiler = (0, _webpack.default)(webpackConfigs);
99
-
100
80
  _sourceMapSupport.default.install({
101
81
  hookRequire: true
102
82
  });
103
-
104
83
  function getServerBundle(serverStats) {
105
84
  var _serverJson$outputPat;
106
-
107
85
  const serverJson = serverStats.toJson({
108
86
  assets: true
109
87
  });
110
88
  return _path.default.join((_serverJson$outputPat = serverJson.outputPath) != null ? _serverJson$outputPat : '', 'server.js');
111
89
  }
112
-
113
90
  function handleErrors(fn) {
114
91
  return async function (req, res, next) {
115
92
  try {
@@ -119,47 +96,40 @@ function startDevServer(entrypoint, env = {}) {
119
96
  }
120
97
  };
121
98
  }
122
-
123
99
  let initRender = [];
124
-
125
100
  let render = (...args) => new Promise(resolve => {
126
101
  var _initRender;
127
-
128
102
  (_initRender = initRender) == null ? void 0 : _initRender.push({
129
103
  args,
130
104
  resolve
131
105
  });
132
106
  });
133
-
134
107
  function importRender(stats) {
135
108
  var _clientStats$compilat, _clientStats$compilat2, _serverStats$compilat, _serverStats$compilat2;
136
-
137
109
  const [clientStats, serverStats] = stats;
138
-
139
110
  if (clientStats != null && (_clientStats$compilat = clientStats.compilation) != null && (_clientStats$compilat2 = _clientStats$compilat.errors) != null && _clientStats$compilat2.length || serverStats != null && (_serverStats$compilat = serverStats.compilation) != null && (_serverStats$compilat2 = _serverStats$compilat.errors) != null && _serverStats$compilat2.length) {
140
111
  log.error('Errors for client build: ' + clientStats.compilation.errors);
141
- log.error('Errors for server build: ' + serverStats.compilation.errors); // first time, rather than re-render
142
-
112
+ log.error('Errors for server build: ' + serverStats.compilation.errors);
113
+ // first time, rather than re-render
143
114
  if (Array.isArray(initRender)) {
144
115
  process.exit(-1);
145
116
  }
146
-
147
117
  log.error('Above compiler errors blocking reload');
148
118
  return;
149
119
  } else {
150
120
  log.info('Launching SSR');
151
- } // ASSETS
152
-
121
+ }
153
122
 
123
+ // ASSETS
154
124
  const clientManifest = clientStats.toJson();
155
- const serverEntry = getServerBundle(serverStats); // reload modules
156
-
125
+ const serverEntry = getServerBundle(serverStats);
126
+ // reload modules
157
127
  Object.keys(fsRequire.cache).forEach(key => {
158
128
  delete fsRequire.cache[key];
159
- }); // eslint-disable-next-line @typescript-eslint/no-var-requires
160
-
161
- render = fsRequire(serverEntry).default.bind(undefined, clientManifest); // SERVER SIDE ENTRYPOINT
162
-
129
+ });
130
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
131
+ render = fsRequire(serverEntry).default.bind(undefined, clientManifest);
132
+ // SERVER SIDE ENTRYPOINT
163
133
  if (Array.isArray(initRender)) {
164
134
  initRender.forEach(async init => {
165
135
  try {
@@ -174,23 +144,24 @@ function startDevServer(entrypoint, env = {}) {
174
144
  initRender = undefined;
175
145
  }
176
146
  }
177
-
178
- const devServer = new _webpackDevServer.default( // write to memory filesystem so we can import
179
- { ...webpackConfigs[0].devServer,
180
- devMiddleware: { ...((_webpackConfigs$ = webpackConfigs[0]) == null ? void 0 : (_webpackConfigs$$devS = _webpackConfigs$.devServer) == null ? void 0 : _webpackConfigs$$devS.devMiddleware),
181
- outputFileSystem: { ...fs,
147
+ const devServer = new _webpackDevServer.default(
148
+ // write to memory filesystem so we can import
149
+ {
150
+ ...webpackConfigs[0].devServer,
151
+ devMiddleware: {
152
+ ...((_webpackConfigs$ = webpackConfigs[0]) == null ? void 0 : (_webpackConfigs$$devS = _webpackConfigs$.devServer) == null ? void 0 : _webpackConfigs$$devS.devMiddleware),
153
+ outputFileSystem: {
154
+ ...fs,
182
155
  join: _path.default.join
183
156
  }
184
157
  },
185
158
  setupMiddlewares: (middlewares, devServer) => {
186
159
  var _webpackConfigs$0$dev, _webpackConfigs$0$dev2, _devServer$app, _webpackConfigs$0$dev3;
187
-
188
160
  if (!devServer) {
189
161
  throw new Error('webpack-dev-server is not defined');
190
162
  }
191
-
192
- const otherRoutes = [process.env.WEBPACK_PUBLIC_PATH, ...Object.keys((_webpackConfigs$0$dev = (_webpackConfigs$0$dev2 = webpackConfigs[0].devServer) == null ? void 0 : _webpackConfigs$0$dev2.proxy) != null ? _webpackConfigs$0$dev : {})]; // serve SSR for non-WEBPACK_PUBLIC_PATH
193
-
163
+ const otherRoutes = [process.env.WEBPACK_PUBLIC_PATH, ...Object.keys((_webpackConfigs$0$dev = (_webpackConfigs$0$dev2 = webpackConfigs[0].devServer) == null ? void 0 : _webpackConfigs$0$dev2.proxy) != null ? _webpackConfigs$0$dev : {})];
164
+ // serve SSR for non-WEBPACK_PUBLIC_PATH
194
165
  (_devServer$app = devServer.app) == null ? void 0 : _devServer$app.get(new RegExp(`^(?!${otherRoutes.join('|')})`), handleErrors(async function (req, res) {
195
166
  if (req.url.endsWith('favicon.ico')) {
196
167
  res.statusCode = 404;
@@ -198,21 +169,17 @@ function startDevServer(entrypoint, env = {}) {
198
169
  res.send('not found');
199
170
  return;
200
171
  }
201
-
202
172
  res.socket.on('error', error => {
203
173
  console.error('Fatal', error);
204
174
  });
205
175
  await render(req, res);
206
176
  }));
207
-
208
177
  if ((_webpackConfigs$0$dev3 = webpackConfigs[0].devServer) != null && _webpackConfigs$0$dev3.setupMiddlewares) {
209
178
  return webpackConfigs[0].devServer.setupMiddlewares(middlewares, devServer);
210
179
  }
211
-
212
180
  return middlewares;
213
181
  }
214
182
  }, compiler);
215
-
216
183
  const runServer = async () => {
217
184
  await devServer.start();
218
185
  devServer.compiler.hooks.done.tap('Anansi Server', multiStats => {
@@ -220,9 +187,7 @@ function startDevServer(entrypoint, env = {}) {
220
187
  log.error('stats not send');
221
188
  process.exit(-1);
222
189
  }
223
-
224
190
  if (!Object.hasOwn(multiStats, 'stats')) return;
225
-
226
191
  if (multiStats.stats.length > 1) {
227
192
  try {
228
193
  importRender(multiStats.stats);
@@ -235,13 +200,11 @@ function startDevServer(entrypoint, env = {}) {
235
200
  }
236
201
  });
237
202
  };
238
-
239
203
  const stopServer = async () => {
240
204
  log.info('Stopping server...');
241
205
  await devServer.stop();
242
206
  log.info('Server closed');
243
207
  };
244
-
245
208
  process.on('SIGINT', () => {
246
209
  log.warn('Received SIGINT, devserver shutting down');
247
210
  stopServer();
@@ -249,4 +212,4 @@ function startDevServer(entrypoint, env = {}) {
249
212
  });
250
213
  runServer();
251
214
  }
252
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["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","Object","keys","cache","forEach","key","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","hasOwn","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { promisify } from 'util';\nimport diskFs from 'fs';\nimport path from 'path';\nimport webpack, { MultiCompiler } from 'webpack';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport type { NextFunction } from 'express';\nimport tmp from 'tmp';\nimport sourceMapSupport from 'source-map-support';\nimport { ufs } from 'unionfs';\nimport WebpackDevServer from 'webpack-dev-server';\nimport logging from 'webpack/lib/logging/runtime';\nimport { createFsRequire } from 'fs-require';\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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"}
215
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["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","Object","keys","cache","forEach","key","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","hasOwn","stopServer","stop","warn"],"sources":["../../src/scripts/startDevserver.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { promisify } from 'util';\nimport diskFs from 'fs';\nimport path from 'path';\nimport webpack, { MultiCompiler } from 'webpack';\nimport { createFsFromVolume, Volume } from 'memfs';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport type { NextFunction } from 'express';\nimport tmp from 'tmp';\nimport sourceMapSupport from 'source-map-support';\nimport { ufs } from 'unionfs';\nimport WebpackDevServer from 'webpack-dev-server';\nimport logging from 'webpack/lib/logging/runtime';\nimport { createFsRequire } from 'fs-require';\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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"}
@@ -1,18 +1,12 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  exports.__esModule = true;
6
5
  exports.default = Document;
7
-
8
6
  var _jsx2 = _interopRequireDefault(require("@babel/runtime/helpers/jsx"));
9
-
10
7
  var _react = _interopRequireDefault(require("react"));
11
-
12
8
  var _csp = require("./csp");
13
-
14
9
  var _process$env$WEBPACK_;
15
-
16
10
  function Document({
17
11
  assets,
18
12
  head,
@@ -25,13 +19,13 @@ function Document({
25
19
  scripts
26
20
  }) {
27
21
  let cspMeta = null;
28
-
29
22
  if (csPolicy) {
30
23
  // add nonce to policy
31
- const policy = { ...csPolicy
24
+ const policy = {
25
+ ...csPolicy
32
26
  };
33
-
34
- if (nonce && ( // nonces negate 'unsafe-inline' so do not add it if that directive exists
27
+ if (nonce && (
28
+ // nonces negate 'unsafe-inline' so do not add it if that directive exists
35
29
  !policy['script-src'] || !policy['script-src'].includes("'unsafe-inline'"))) {
36
30
  if (typeof policy['script-src'] === 'string') {
37
31
  policy['script-src'] = [policy['script-src'], `'nonce-${nonce}'`];
@@ -39,13 +33,11 @@ function Document({
39
33
  policy['script-src'] = [...policy['script-src'], `'nonce-${nonce}'`];
40
34
  }
41
35
  }
42
-
43
36
  cspMeta = /*#__PURE__*/(0, _jsx2.default)("meta", {
44
37
  httpEquiv: "Content-Security-Policy",
45
38
  content: (0, _csp.buildPolicy)(policy)
46
39
  });
47
40
  }
48
-
49
41
  return /*#__PURE__*/(0, _jsx2.default)("html", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("head", {}, void 0, /*#__PURE__*/(0, _jsx2.default)("meta", {
50
42
  charSet: charSet
51
43
  }), cspMeta, head, assets.map((asset, i) => /*#__PURE__*/_react.default.createElement("link", {
@@ -63,7 +55,6 @@ function Document({
63
55
  async: true
64
56
  }, i))));
65
57
  }
66
-
67
58
  Document.defaultProps = {
68
59
  head: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/(0, _jsx2.default)("meta", {
69
60
  name: "viewport",
@@ -76,4 +67,4 @@ Document.defaultProps = {
76
67
  rootId: 'anansi-root',
77
68
  scripts: null
78
69
  };
79
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEb2N1bWVudCIsImFzc2V0cyIsImhlYWQiLCJjaGlsZHJlbiIsInRpdGxlIiwicm9vdElkIiwiY2hhclNldCIsImNzUG9saWN5Iiwibm9uY2UiLCJzY3JpcHRzIiwiY3NwTWV0YSIsInBvbGljeSIsImluY2x1ZGVzIiwiYnVpbGRQb2xpY3kiLCJtYXAiLCJhc3NldCIsImkiLCJmaWx0ZXIiLCJocmVmIiwiZW5kc1dpdGgiLCJkZWZhdWx0UHJvcHMiLCJwcm9jZXNzIiwiZW52IiwiV0VCUEFDS19QVUJMSUNfUEFUSCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zcG91dHMvRG9jdW1lbnRDb21wb25lbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUG9saWN5IH0gZnJvbSAnLi9jc3AnO1xuaW1wb3J0IHsgYnVpbGRQb2xpY3kgfSBmcm9tICcuL2NzcCc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG4gIGFzc2V0czogeyBocmVmOiBzdHJpbmc7IGFzPzogc3RyaW5nOyByZWw/OiBzdHJpbmcgfVtdO1xuICBoZWFkOiBSZWFjdC5SZWFjdE5vZGU7XG4gIHNjcmlwdHM6IFJlYWN0LlJlYWN0Tm9kZTtcbiAgdGl0bGU6IHN0cmluZztcbiAgcm9vdElkOiBzdHJpbmc7XG4gIGNoYXJTZXQ6IHN0cmluZztcbiAgY3NQb2xpY3k/OiBQb2xpY3k7XG4gIG5vbmNlPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRG9jdW1lbnQoe1xuICBhc3NldHMsXG4gIGhlYWQsXG4gIGNoaWxkcmVuLFxuICB0aXRsZSxcbiAgcm9vdElkLFxuICBjaGFyU2V0LFxuICBjc1BvbGljeSxcbiAgbm9uY2UsXG4gIHNjcmlwdHMsXG59OiBQcm9wcykge1xuICBsZXQgY3NwTWV0YTogbnVsbCB8IFJlYWN0LlJlYWN0Tm9kZSA9IG51bGw7XG4gIGlmIChjc1BvbGljeSkge1xuICAgIC8vIGFkZCBub25jZSB0byBwb2xpY3lcbiAgICBjb25zdCBwb2xpY3kgPSB7XG4gICAgICAuLi5jc1BvbGljeSxcbiAgICB9O1xuICAgIGlmIChcbiAgICAgIG5vbmNlICYmXG4gICAgICAvLyBub25jZXMgbmVnYXRlICd1bnNhZmUtaW5saW5lJyBzbyBkbyBub3QgYWRkIGl0IGlmIHRoYXQgZGlyZWN0aXZlIGV4aXN0c1xuICAgICAgKCFwb2xpY3lbJ3NjcmlwdC1zcmMnXSB8fFxuICAgICAgICAhcG9saWN5WydzY3JpcHQtc3JjJ10uaW5jbHVkZXMoXCIndW5zYWZlLWlubGluZSdcIikpXG4gICAgKSB7XG4gICAgICBpZiAodHlwZW9mIHBvbGljeVsnc2NyaXB0LXNyYyddID09PSAnc3RyaW5nJykge1xuICAgICAgICBwb2xpY3lbJ3NjcmlwdC1zcmMnXSA9IFtwb2xpY3lbJ3NjcmlwdC1zcmMnXSwgYCdub25jZS0ke25vbmNlfSdgXTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHBvbGljeVsnc2NyaXB0LXNyYyddID0gWy4uLnBvbGljeVsnc2NyaXB0LXNyYyddLCBgJ25vbmNlLSR7bm9uY2V9J2BdO1xuICAgICAgfVxuICAgIH1cbiAgICBjc3BNZXRhID0gKFxuICAgICAgPG1ldGEgaHR0cEVxdWl2PVwiQ29udGVudC1TZWN1cml0eS1Qb2xpY3lcIiBjb250ZW50PXtidWlsZFBvbGljeShwb2xpY3kpfSAvPlxuICAgICk7XG4gIH1cbiAgcmV0dXJuIChcbiAgICA8aHRtbD5cbiAgICAgIDxoZWFkPlxuICAgICAgICA8bWV0YSBjaGFyU2V0PXtjaGFyU2V0fSAvPlxuICAgICAgICB7Y3NwTWV0YX1cbiAgICAgICAge2hlYWR9XG4gICAgICAgIHthc3NldHMubWFwKChhc3NldCwgaSkgPT4gKFxuICAgICAgICAgIDxsaW5rIGtleT17aX0gcmVsPVwicHJlbG9hZFwiIHsuLi5hc3NldH0gLz5cbiAgICAgICAgKSl9XG4gICAgICAgIDx0aXRsZT57dGl0bGV9PC90aXRsZT5cbiAgICAgIDwvaGVhZD5cbiAgICAgIDxib2R5PlxuICAgICAgICA8ZGl2IGlkPXtyb290SWR9PntjaGlsZHJlbn08L2Rpdj5cbiAgICAgICAge3NjcmlwdHN9XG4gICAgICAgIHthc3NldHNcbiAgICAgICAgICAuZmlsdGVyKCh7IGhyZWYgfSkgPT4gaHJlZi5lbmRzV2l0aCgnLmpzJykpXG4gICAgICAgICAgLm1hcCgoeyBocmVmIH0sIGkpID0+IChcbiAgICAgICAgICAgIDxzY3JpcHQga2V5PXtpfSBzcmM9e2hyZWZ9IGFzeW5jIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L2JvZHk+XG4gICAgPC9odG1sPlxuICApO1xufVxuRG9jdW1lbnQuZGVmYXVsdFByb3BzID0ge1xuICBoZWFkOiAoXG4gICAgPD5cbiAgICAgIDxtZXRhIG5hbWU9XCJ2aWV3cG9ydFwiIGNvbnRlbnQ9XCJ3aWR0aD1kZXZpY2Utd2lkdGgsIGluaXRpYWwtc2NhbGU9MVwiIC8+XG4gICAgICA8bGlua1xuICAgICAgICByZWw9XCJzaG9ydGN1dCBpY29uXCJcbiAgICAgICAgaHJlZj17YCR7cHJvY2Vzcy5lbnYuV0VCUEFDS19QVUJMSUNfUEFUSCA/PyAnLyd9ZmF2aWNvbi5pY29gfVxuICAgICAgLz5cbiAgICA8Lz5cbiAgKSxcbiAgY2hhclNldDogJ3V0Zi04JyxcbiAgcm9vdElkOiAnYW5hbnNpLXJvb3QnLFxuICBzY3JpcHRzOiBudWxsLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFDQTs7OztBQWNlLFNBQVNBLFFBQVQsQ0FBa0I7RUFDL0JDLE1BRCtCO0VBRS9CQyxJQUYrQjtFQUcvQkMsUUFIK0I7RUFJL0JDLEtBSitCO0VBSy9CQyxNQUwrQjtFQU0vQkMsT0FOK0I7RUFPL0JDLFFBUCtCO0VBUS9CQyxLQVIrQjtFQVMvQkM7QUFUK0IsQ0FBbEIsRUFVTDtFQUNSLElBQUlDLE9BQStCLEdBQUcsSUFBdEM7O0VBQ0EsSUFBSUgsUUFBSixFQUFjO0lBQ1o7SUFDQSxNQUFNSSxNQUFNLEdBQUcsRUFDYixHQUFHSjtJQURVLENBQWY7O0lBR0EsSUFDRUMsS0FBSyxNQUNMO0lBQ0MsQ0FBQ0csTUFBTSxDQUFDLFlBQUQsQ0FBUCxJQUNDLENBQUNBLE1BQU0sQ0FBQyxZQUFELENBQU4sQ0FBcUJDLFFBQXJCLENBQThCLGlCQUE5QixDQUhFLENBRFAsRUFLRTtNQUNBLElBQUksT0FBT0QsTUFBTSxDQUFDLFlBQUQsQ0FBYixLQUFnQyxRQUFwQyxFQUE4QztRQUM1Q0EsTUFBTSxDQUFDLFlBQUQsQ0FBTixHQUF1QixDQUFDQSxNQUFNLENBQUMsWUFBRCxDQUFQLEVBQXdCLFVBQVNILEtBQU0sR0FBdkMsQ0FBdkI7TUFDRCxDQUZELE1BRU87UUFDTEcsTUFBTSxDQUFDLFlBQUQsQ0FBTixHQUF1QixDQUFDLEdBQUdBLE1BQU0sQ0FBQyxZQUFELENBQVYsRUFBMkIsVUFBU0gsS0FBTSxHQUExQyxDQUF2QjtNQUNEO0lBQ0Y7O0lBQ0RFLE9BQU8sZ0JBQ0w7TUFBTSxTQUFTLEVBQUMseUJBQWhCO01BQTBDLE9BQU8sRUFBRSxJQUFBRyxnQkFBQSxFQUFZRixNQUFaO0lBQW5ELEVBREY7RUFHRDs7RUFDRCxvQkFDRSxvREFDRSxvREFDRTtJQUFNLE9BQU8sRUFBRUw7RUFBZixFQURGLEVBRUdJLE9BRkgsRUFHR1IsSUFISCxFQUlHRCxNQUFNLENBQUNhLEdBQVAsQ0FBVyxDQUFDQyxLQUFELEVBQVFDLENBQVIsa0JBQ1Y7SUFBTSxHQUFHLEVBQUVBLENBQVg7SUFBYyxHQUFHLEVBQUMsU0FBbEI7SUFBQSxHQUFnQ0Q7RUFBaEMsRUFERCxDQUpILGVBT0Usd0NBQVFYLEtBQVIsQ0FQRixDQURGLGVBVUUsb0RBQ0U7SUFBSyxFQUFFLEVBQUVDO0VBQVQsV0FBa0JGLFFBQWxCLENBREYsRUFFR00sT0FGSCxFQUdHUixNQUFNLENBQ0pnQixNQURGLENBQ1MsQ0FBQztJQUFFQztFQUFGLENBQUQsS0FBY0EsSUFBSSxDQUFDQyxRQUFMLENBQWMsS0FBZCxDQUR2QixFQUVFTCxHQUZGLENBRU0sQ0FBQztJQUFFSTtFQUFGLENBQUQsRUFBV0YsQ0FBWCxrQkFDSDtJQUFnQixHQUFHLEVBQUVFLElBQXJCO0lBQTJCLEtBQUs7RUFBaEMsR0FBYUYsQ0FBYixDQUhILENBSEgsQ0FWRixDQURGO0FBc0JEOztBQUNEaEIsUUFBUSxDQUFDb0IsWUFBVCxHQUF3QjtFQUN0QmxCLElBQUksZUFDRix5RUFDRTtJQUFNLElBQUksRUFBQyxVQUFYO0lBQXNCLE9BQU8sRUFBQztFQUE5QixFQURGLGVBRUU7SUFDRSxHQUFHLEVBQUMsZUFETjtJQUVFLElBQUksRUFBRyxHQUFELHlCQUFHbUIsT0FBTyxDQUFDQyxHQUFSLENBQVlDLG1CQUFmLG9DQUFzQyxHQUFJO0VBRmxELEVBRkYsQ0FGb0I7RUFVdEJqQixPQUFPLEVBQUUsT0FWYTtFQVd0QkQsTUFBTSxFQUFFLGFBWGM7RUFZdEJJLE9BQU8sRUFBRTtBQVphLENBQXhCIn0=
70
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEb2N1bWVudCIsImFzc2V0cyIsImhlYWQiLCJjaGlsZHJlbiIsInRpdGxlIiwicm9vdElkIiwiY2hhclNldCIsImNzUG9saWN5Iiwibm9uY2UiLCJzY3JpcHRzIiwiY3NwTWV0YSIsInBvbGljeSIsImluY2x1ZGVzIiwiYnVpbGRQb2xpY3kiLCJtYXAiLCJhc3NldCIsImkiLCJmaWx0ZXIiLCJocmVmIiwiZW5kc1dpdGgiLCJkZWZhdWx0UHJvcHMiLCJwcm9jZXNzIiwiZW52IiwiV0VCUEFDS19QVUJMSUNfUEFUSCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zcG91dHMvRG9jdW1lbnRDb21wb25lbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUG9saWN5IH0gZnJvbSAnLi9jc3AnO1xuaW1wb3J0IHsgYnVpbGRQb2xpY3kgfSBmcm9tICcuL2NzcCc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG4gIGFzc2V0czogeyBocmVmOiBzdHJpbmc7IGFzPzogc3RyaW5nOyByZWw/OiBzdHJpbmcgfVtdO1xuICBoZWFkOiBSZWFjdC5SZWFjdE5vZGU7XG4gIHNjcmlwdHM6IFJlYWN0LlJlYWN0Tm9kZTtcbiAgdGl0bGU6IHN0cmluZztcbiAgcm9vdElkOiBzdHJpbmc7XG4gIGNoYXJTZXQ6IHN0cmluZztcbiAgY3NQb2xpY3k/OiBQb2xpY3k7XG4gIG5vbmNlPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRG9jdW1lbnQoe1xuICBhc3NldHMsXG4gIGhlYWQsXG4gIGNoaWxkcmVuLFxuICB0aXRsZSxcbiAgcm9vdElkLFxuICBjaGFyU2V0LFxuICBjc1BvbGljeSxcbiAgbm9uY2UsXG4gIHNjcmlwdHMsXG59OiBQcm9wcykge1xuICBsZXQgY3NwTWV0YTogbnVsbCB8IFJlYWN0LlJlYWN0Tm9kZSA9IG51bGw7XG4gIGlmIChjc1BvbGljeSkge1xuICAgIC8vIGFkZCBub25jZSB0byBwb2xpY3lcbiAgICBjb25zdCBwb2xpY3kgPSB7XG4gICAgICAuLi5jc1BvbGljeSxcbiAgICB9O1xuICAgIGlmIChcbiAgICAgIG5vbmNlICYmXG4gICAgICAvLyBub25jZXMgbmVnYXRlICd1bnNhZmUtaW5saW5lJyBzbyBkbyBub3QgYWRkIGl0IGlmIHRoYXQgZGlyZWN0aXZlIGV4aXN0c1xuICAgICAgKCFwb2xpY3lbJ3NjcmlwdC1zcmMnXSB8fFxuICAgICAgICAhcG9saWN5WydzY3JpcHQtc3JjJ10uaW5jbHVkZXMoXCIndW5zYWZlLWlubGluZSdcIikpXG4gICAgKSB7XG4gICAgICBpZiAodHlwZW9mIHBvbGljeVsnc2NyaXB0LXNyYyddID09PSAnc3RyaW5nJykge1xuICAgICAgICBwb2xpY3lbJ3NjcmlwdC1zcmMnXSA9IFtwb2xpY3lbJ3NjcmlwdC1zcmMnXSwgYCdub25jZS0ke25vbmNlfSdgXTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHBvbGljeVsnc2NyaXB0LXNyYyddID0gWy4uLnBvbGljeVsnc2NyaXB0LXNyYyddLCBgJ25vbmNlLSR7bm9uY2V9J2BdO1xuICAgICAgfVxuICAgIH1cbiAgICBjc3BNZXRhID0gKFxuICAgICAgPG1ldGEgaHR0cEVxdWl2PVwiQ29udGVudC1TZWN1cml0eS1Qb2xpY3lcIiBjb250ZW50PXtidWlsZFBvbGljeShwb2xpY3kpfSAvPlxuICAgICk7XG4gIH1cbiAgcmV0dXJuIChcbiAgICA8aHRtbD5cbiAgICAgIDxoZWFkPlxuICAgICAgICA8bWV0YSBjaGFyU2V0PXtjaGFyU2V0fSAvPlxuICAgICAgICB7Y3NwTWV0YX1cbiAgICAgICAge2hlYWR9XG4gICAgICAgIHthc3NldHMubWFwKChhc3NldCwgaSkgPT4gKFxuICAgICAgICAgIDxsaW5rIGtleT17aX0gcmVsPVwicHJlbG9hZFwiIHsuLi5hc3NldH0gLz5cbiAgICAgICAgKSl9XG4gICAgICAgIDx0aXRsZT57dGl0bGV9PC90aXRsZT5cbiAgICAgIDwvaGVhZD5cbiAgICAgIDxib2R5PlxuICAgICAgICA8ZGl2IGlkPXtyb290SWR9PntjaGlsZHJlbn08L2Rpdj5cbiAgICAgICAge3NjcmlwdHN9XG4gICAgICAgIHthc3NldHNcbiAgICAgICAgICAuZmlsdGVyKCh7IGhyZWYgfSkgPT4gaHJlZi5lbmRzV2l0aCgnLmpzJykpXG4gICAgICAgICAgLm1hcCgoeyBocmVmIH0sIGkpID0+IChcbiAgICAgICAgICAgIDxzY3JpcHQga2V5PXtpfSBzcmM9e2hyZWZ9IGFzeW5jIC8+XG4gICAgICAgICAgKSl9XG4gICAgICA8L2JvZHk+XG4gICAgPC9odG1sPlxuICApO1xufVxuRG9jdW1lbnQuZGVmYXVsdFByb3BzID0ge1xuICBoZWFkOiAoXG4gICAgPD5cbiAgICAgIDxtZXRhIG5hbWU9XCJ2aWV3cG9ydFwiIGNvbnRlbnQ9XCJ3aWR0aD1kZXZpY2Utd2lkdGgsIGluaXRpYWwtc2NhbGU9MVwiIC8+XG4gICAgICA8bGlua1xuICAgICAgICByZWw9XCJzaG9ydGN1dCBpY29uXCJcbiAgICAgICAgaHJlZj17YCR7cHJvY2Vzcy5lbnYuV0VCUEFDS19QVUJMSUNfUEFUSCA/PyAnLyd9ZmF2aWNvbi5pY29gfVxuICAgICAgLz5cbiAgICA8Lz5cbiAgKSxcbiAgY2hhclNldDogJ3V0Zi04JyxcbiAgcm9vdElkOiAnYW5hbnNpLXJvb3QnLFxuICBzY3JpcHRzOiBudWxsLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUNBO0FBQW9DO0FBY3JCLFNBQVNBLFFBQVEsQ0FBQztFQUMvQkMsTUFBTTtFQUNOQyxJQUFJO0VBQ0pDLFFBQVE7RUFDUkMsS0FBSztFQUNMQyxNQUFNO0VBQ05DLE9BQU87RUFDUEMsUUFBUTtFQUNSQyxLQUFLO0VBQ0xDO0FBQ0ssQ0FBQyxFQUFFO0VBQ1IsSUFBSUMsT0FBK0IsR0FBRyxJQUFJO0VBQzFDLElBQUlILFFBQVEsRUFBRTtJQUNaO0lBQ0EsTUFBTUksTUFBTSxHQUFHO01BQ2IsR0FBR0o7SUFDTCxDQUFDO0lBQ0QsSUFDRUMsS0FBSztJQUNMO0lBQ0MsQ0FBQ0csTUFBTSxDQUFDLFlBQVksQ0FBQyxJQUNwQixDQUFDQSxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUNDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLEVBQ3BEO01BQ0EsSUFBSSxPQUFPRCxNQUFNLENBQUMsWUFBWSxDQUFDLEtBQUssUUFBUSxFQUFFO1FBQzVDQSxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQ0EsTUFBTSxDQUFDLFlBQVksQ0FBQyxFQUFHLFVBQVNILEtBQU0sR0FBRSxDQUFDO01BQ25FLENBQUMsTUFBTTtRQUNMRyxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxHQUFHQSxNQUFNLENBQUMsWUFBWSxDQUFDLEVBQUcsVUFBU0gsS0FBTSxHQUFFLENBQUM7TUFDdEU7SUFDRjtJQUNBRSxPQUFPLGdCQUNMO01BQU0sU0FBUyxFQUFDLHlCQUF5QjtNQUFDLE9BQU8sRUFBRSxJQUFBRyxnQkFBVyxFQUFDRixNQUFNO0lBQUUsRUFDeEU7RUFDSDtFQUNBLG9CQUNFLG9EQUNFLG9EQUNFO0lBQU0sT0FBTyxFQUFFTDtFQUFRLEVBQUcsRUFDekJJLE9BQU8sRUFDUFIsSUFBSSxFQUNKRCxNQUFNLENBQUNhLEdBQUcsQ0FBQyxDQUFDQyxLQUFLLEVBQUVDLENBQUMsa0JBQ25CO0lBQU0sR0FBRyxFQUFFQSxDQUFFO0lBQUMsR0FBRyxFQUFDLFNBQVM7SUFBQSxHQUFLRDtFQUFLLEVBQ3RDLENBQUMsZUFDRix3Q0FBUVgsS0FBSyxDQUFTLENBQ2pCLGVBQ1Asb0RBQ0U7SUFBSyxFQUFFLEVBQUVDO0VBQU8sV0FBRUYsUUFBUSxDQUFPLEVBQ2hDTSxPQUFPLEVBQ1BSLE1BQU0sQ0FDSmdCLE1BQU0sQ0FBQyxDQUFDO0lBQUVDO0VBQUssQ0FBQyxLQUFLQSxJQUFJLENBQUNDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUMxQ0wsR0FBRyxDQUFDLENBQUM7SUFBRUk7RUFBSyxDQUFDLEVBQUVGLENBQUMsa0JBQ2Y7SUFBZ0IsR0FBRyxFQUFFRSxJQUFLO0lBQUMsS0FBSztFQUFBLEdBQW5CRixDQUFDLENBQ2YsQ0FBQyxDQUNDLENBQ0Y7QUFFWDtBQUNBaEIsUUFBUSxDQUFDb0IsWUFBWSxHQUFHO0VBQ3RCbEIsSUFBSSxlQUNGLHlFQUNFO0lBQU0sSUFBSSxFQUFDLFVBQVU7SUFBQyxPQUFPLEVBQUM7RUFBcUMsRUFBRyxlQUN0RTtJQUNFLEdBQUcsRUFBQyxlQUFlO0lBQ25CLElBQUksRUFBRyw0QkFBRW1CLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxtQkFBbUIsb0NBQUksR0FBSTtFQUFhLEVBQzdELENBRUw7RUFDRGpCLE9BQU8sRUFBRSxPQUFPO0VBQ2hCRCxNQUFNLEVBQUUsYUFBYTtFQUNyQkksT0FBTyxFQUFFO0FBQ1gsQ0FBQyJ9
package/lib/spouts/app.js CHANGED
@@ -2,11 +2,10 @@
2
2
 
3
3
  exports.__esModule = true;
4
4
  exports.default = void 0;
5
-
6
- const appSpout = app => props => Promise.resolve({ ...props,
5
+ const appSpout = app => props => Promise.resolve({
6
+ ...props,
7
7
  app
8
8
  });
9
-
10
9
  var _default = appSpout;
11
10
  exports.default = _default;
12
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBTcG91dCIsImFwcCIsInByb3BzIiwiUHJvbWlzZSIsInJlc29sdmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2FwcC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgYXBwU3BvdXQgPVxuICAoYXBwOiBKU1guRWxlbWVudCkgPT5cbiAgPFAgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPj4ocHJvcHM6IFApID0+XG4gICAgUHJvbWlzZS5yZXNvbHZlKHsgLi4ucHJvcHMsIGFwcCB9KTtcblxuZXhwb3J0IGRlZmF1bHQgYXBwU3BvdXQ7XG4iXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsTUFBTUEsUUFBUSxHQUNYQyxHQUFELElBQ29DQyxLQUFwQyxJQUNFQyxPQUFPLENBQUNDLE9BQVIsQ0FBZ0IsRUFBRSxHQUFHRixLQUFMO0VBQVlEO0FBQVosQ0FBaEIsQ0FISjs7ZUFLZUQsUSJ9
11
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBTcG91dCIsImFwcCIsInByb3BzIiwiUHJvbWlzZSIsInJlc29sdmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2FwcC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgYXBwU3BvdXQgPVxuICAoYXBwOiBKU1guRWxlbWVudCkgPT5cbiAgPFAgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPj4ocHJvcHM6IFApID0+XG4gICAgUHJvbWlzZS5yZXNvbHZlKHsgLi4ucHJvcHMsIGFwcCB9KTtcblxuZXhwb3J0IGRlZmF1bHQgYXBwU3BvdXQ7XG4iXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxNQUFNQSxRQUFRLEdBQ1hDLEdBQWdCLElBQ21CQyxLQUFRLElBQzFDQyxPQUFPLENBQUNDLE9BQU8sQ0FBQztFQUFFLEdBQUdGLEtBQUs7RUFBRUQ7QUFBSSxDQUFDLENBQUM7QUFBQyxlQUV4QkQsUUFBUTtBQUFBIn0=
@@ -2,11 +2,10 @@
2
2
 
3
3
  exports.__esModule = true;
4
4
  exports.default = void 0;
5
-
6
- const appSpout = app => props => Promise.resolve({ ...props,
5
+ const appSpout = app => props => Promise.resolve({
6
+ ...props,
7
7
  app
8
8
  });
9
-
10
9
  var _default = appSpout;
11
10
  exports.default = _default;
12
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBTcG91dCIsImFwcCIsInByb3BzIiwiUHJvbWlzZSIsInJlc29sdmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2FwcC5zZXJ2ZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlcnZlclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IGFwcFNwb3V0ID1cbiAgKGFwcDogSlNYLkVsZW1lbnQpID0+XG4gIDxQIGV4dGVuZHMgU2VydmVyUHJvcHM+KHByb3BzOiBQKSA9PlxuICAgIFByb21pc2UucmVzb2x2ZSh7IC4uLnByb3BzLCBhcHAgfSk7XG5cbmV4cG9ydCBkZWZhdWx0IGFwcFNwb3V0O1xuIl0sIm1hcHBpbmdzIjoiOzs7OztBQUVBLE1BQU1BLFFBQVEsR0FDWEMsR0FBRCxJQUN3QkMsS0FBeEIsSUFDRUMsT0FBTyxDQUFDQyxPQUFSLENBQWdCLEVBQUUsR0FBR0YsS0FBTDtFQUFZRDtBQUFaLENBQWhCLENBSEo7O2VBS2VELFEifQ==
11
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBTcG91dCIsImFwcCIsInByb3BzIiwiUHJvbWlzZSIsInJlc29sdmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2FwcC5zZXJ2ZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlcnZlclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IGFwcFNwb3V0ID1cbiAgKGFwcDogSlNYLkVsZW1lbnQpID0+XG4gIDxQIGV4dGVuZHMgU2VydmVyUHJvcHM+KHByb3BzOiBQKSA9PlxuICAgIFByb21pc2UucmVzb2x2ZSh7IC4uLnByb3BzLCBhcHAgfSk7XG5cbmV4cG9ydCBkZWZhdWx0IGFwcFNwb3V0O1xuIl0sIm1hcHBpbmdzIjoiOzs7O0FBRUEsTUFBTUEsUUFBUSxHQUNYQyxHQUFnQixJQUNPQyxLQUFRLElBQzlCQyxPQUFPLENBQUNDLE9BQU8sQ0FBQztFQUFFLEdBQUdGLEtBQUs7RUFBRUQ7QUFBSSxDQUFDLENBQUM7QUFBQyxlQUV4QkQsUUFBUTtBQUFBIn0=
package/lib/spouts/csp.js CHANGED
@@ -2,19 +2,18 @@
2
2
 
3
3
  exports.__esModule = true;
4
4
  exports.buildPolicy = buildPolicy;
5
-
6
5
  // TODO: memoize this
7
6
  function buildPolicy(policyObj) {
8
7
  return Object.keys(policyObj).map(key => {
9
- const val = Array.isArray(policyObj[key]) ? [...new Set(policyObj[key]).values()].filter(v => v).join(' ') : policyObj[key]; // move strict dynamic to the end of the policy if it exists to be backwards compatible with csp2
10
- // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/script-src#strict-dynamic
8
+ const val = Array.isArray(policyObj[key]) ? [...new Set(policyObj[key]).values()].filter(v => v).join(' ') : policyObj[key];
11
9
 
10
+ // move strict dynamic to the end of the policy if it exists to be backwards compatible with csp2
11
+ // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/script-src#strict-dynamic
12
12
  if (typeof val === 'string' && val.includes("'strict-dynamic'")) {
13
13
  const newVal = `${val.replace(/\s?'strict-dynamic'\s?/gi, ' ').trim()} 'strict-dynamic'`;
14
14
  return `${key} ${newVal}`;
15
15
  }
16
-
17
16
  return `${key} ${val}`;
18
17
  }).join('; ');
19
18
  }
20
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZFBvbGljeSIsInBvbGljeU9iaiIsIk9iamVjdCIsImtleXMiLCJtYXAiLCJrZXkiLCJ2YWwiLCJBcnJheSIsImlzQXJyYXkiLCJTZXQiLCJ2YWx1ZXMiLCJmaWx0ZXIiLCJ2Iiwiam9pbiIsImluY2x1ZGVzIiwibmV3VmFsIiwicmVwbGFjZSIsInRyaW0iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2NzcC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFBvbGljeSB7XG4gIFtkaXJlY3RpdmU6IHN0cmluZ106IHN0cmluZyB8IHN0cmluZ1tdO1xufVxuXG4vLyBUT0RPOiBtZW1vaXplIHRoaXNcbmV4cG9ydCBmdW5jdGlvbiBidWlsZFBvbGljeShwb2xpY3lPYmo6IFBvbGljeSkge1xuICByZXR1cm4gT2JqZWN0LmtleXMocG9saWN5T2JqKVxuICAgIC5tYXAoa2V5ID0+IHtcbiAgICAgIGNvbnN0IHZhbCA9IEFycmF5LmlzQXJyYXkocG9saWN5T2JqW2tleV0pXG4gICAgICAgID8gWy4uLm5ldyBTZXQocG9saWN5T2JqW2tleV0pLnZhbHVlcygpXS5maWx0ZXIodiA9PiB2KS5qb2luKCcgJylcbiAgICAgICAgOiBwb2xpY3lPYmpba2V5XTtcblxuICAgICAgLy8gbW92ZSBzdHJpY3QgZHluYW1pYyB0byB0aGUgZW5kIG9mIHRoZSBwb2xpY3kgaWYgaXQgZXhpc3RzIHRvIGJlIGJhY2t3YXJkcyBjb21wYXRpYmxlIHdpdGggY3NwMlxuICAgICAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSFRUUC9IZWFkZXJzL0NvbnRlbnQtU2VjdXJpdHktUG9saWN5L3NjcmlwdC1zcmMjc3RyaWN0LWR5bmFtaWNcbiAgICAgIGlmICh0eXBlb2YgdmFsID09PSAnc3RyaW5nJyAmJiB2YWwuaW5jbHVkZXMoXCInc3RyaWN0LWR5bmFtaWMnXCIpKSB7XG4gICAgICAgIGNvbnN0IG5ld1ZhbCA9IGAke3ZhbFxuICAgICAgICAgIC5yZXBsYWNlKC9cXHM/J3N0cmljdC1keW5hbWljJ1xccz8vZ2ksICcgJylcbiAgICAgICAgICAudHJpbSgpfSAnc3RyaWN0LWR5bmFtaWMnYDtcbiAgICAgICAgcmV0dXJuIGAke2tleX0gJHtuZXdWYWx9YDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGAke2tleX0gJHt2YWx9YDtcbiAgICB9KVxuICAgIC5qb2luKCc7ICcpO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7OztBQUlBO0FBQ08sU0FBU0EsV0FBVCxDQUFxQkMsU0FBckIsRUFBd0M7RUFDN0MsT0FBT0MsTUFBTSxDQUFDQyxJQUFQLENBQVlGLFNBQVosRUFDSkcsR0FESSxDQUNBQyxHQUFHLElBQUk7SUFDVixNQUFNQyxHQUFHLEdBQUdDLEtBQUssQ0FBQ0MsT0FBTixDQUFjUCxTQUFTLENBQUNJLEdBQUQsQ0FBdkIsSUFDUixDQUFDLEdBQUcsSUFBSUksR0FBSixDQUFRUixTQUFTLENBQUNJLEdBQUQsQ0FBakIsRUFBd0JLLE1BQXhCLEVBQUosRUFBc0NDLE1BQXRDLENBQTZDQyxDQUFDLElBQUlBLENBQWxELEVBQXFEQyxJQUFyRCxDQUEwRCxHQUExRCxDQURRLEdBRVJaLFNBQVMsQ0FBQ0ksR0FBRCxDQUZiLENBRFUsQ0FLVjtJQUNBOztJQUNBLElBQUksT0FBT0MsR0FBUCxLQUFlLFFBQWYsSUFBMkJBLEdBQUcsQ0FBQ1EsUUFBSixDQUFhLGtCQUFiLENBQS9CLEVBQWlFO01BQy9ELE1BQU1DLE1BQU0sR0FBSSxHQUFFVCxHQUFHLENBQ2xCVSxPQURlLENBQ1AsMEJBRE8sRUFDcUIsR0FEckIsRUFFZkMsSUFGZSxFQUVSLG1CQUZWO01BR0EsT0FBUSxHQUFFWixHQUFJLElBQUdVLE1BQU8sRUFBeEI7SUFDRDs7SUFFRCxPQUFRLEdBQUVWLEdBQUksSUFBR0MsR0FBSSxFQUFyQjtFQUNELENBaEJJLEVBaUJKTyxJQWpCSSxDQWlCQyxJQWpCRCxDQUFQO0FBa0JEIn0=
19
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZFBvbGljeSIsInBvbGljeU9iaiIsIk9iamVjdCIsImtleXMiLCJtYXAiLCJrZXkiLCJ2YWwiLCJBcnJheSIsImlzQXJyYXkiLCJTZXQiLCJ2YWx1ZXMiLCJmaWx0ZXIiLCJ2Iiwiam9pbiIsImluY2x1ZGVzIiwibmV3VmFsIiwicmVwbGFjZSIsInRyaW0iXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BvdXRzL2NzcC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFBvbGljeSB7XG4gIFtkaXJlY3RpdmU6IHN0cmluZ106IHN0cmluZyB8IHN0cmluZ1tdO1xufVxuXG4vLyBUT0RPOiBtZW1vaXplIHRoaXNcbmV4cG9ydCBmdW5jdGlvbiBidWlsZFBvbGljeShwb2xpY3lPYmo6IFBvbGljeSkge1xuICByZXR1cm4gT2JqZWN0LmtleXMocG9saWN5T2JqKVxuICAgIC5tYXAoa2V5ID0+IHtcbiAgICAgIGNvbnN0IHZhbCA9IEFycmF5LmlzQXJyYXkocG9saWN5T2JqW2tleV0pXG4gICAgICAgID8gWy4uLm5ldyBTZXQocG9saWN5T2JqW2tleV0pLnZhbHVlcygpXS5maWx0ZXIodiA9PiB2KS5qb2luKCcgJylcbiAgICAgICAgOiBwb2xpY3lPYmpba2V5XTtcblxuICAgICAgLy8gbW92ZSBzdHJpY3QgZHluYW1pYyB0byB0aGUgZW5kIG9mIHRoZSBwb2xpY3kgaWYgaXQgZXhpc3RzIHRvIGJlIGJhY2t3YXJkcyBjb21wYXRpYmxlIHdpdGggY3NwMlxuICAgICAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSFRUUC9IZWFkZXJzL0NvbnRlbnQtU2VjdXJpdHktUG9saWN5L3NjcmlwdC1zcmMjc3RyaWN0LWR5bmFtaWNcbiAgICAgIGlmICh0eXBlb2YgdmFsID09PSAnc3RyaW5nJyAmJiB2YWwuaW5jbHVkZXMoXCInc3RyaWN0LWR5bmFtaWMnXCIpKSB7XG4gICAgICAgIGNvbnN0IG5ld1ZhbCA9IGAke3ZhbFxuICAgICAgICAgIC5yZXBsYWNlKC9cXHM/J3N0cmljdC1keW5hbWljJ1xccz8vZ2ksICcgJylcbiAgICAgICAgICAudHJpbSgpfSAnc3RyaWN0LWR5bmFtaWMnYDtcbiAgICAgICAgcmV0dXJuIGAke2tleX0gJHtuZXdWYWx9YDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGAke2tleX0gJHt2YWx9YDtcbiAgICB9KVxuICAgIC5qb2luKCc7ICcpO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7O0FBSUE7QUFDTyxTQUFTQSxXQUFXLENBQUNDLFNBQWlCLEVBQUU7RUFDN0MsT0FBT0MsTUFBTSxDQUFDQyxJQUFJLENBQUNGLFNBQVMsQ0FBQyxDQUMxQkcsR0FBRyxDQUFDQyxHQUFHLElBQUk7SUFDVixNQUFNQyxHQUFHLEdBQUdDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDUCxTQUFTLENBQUNJLEdBQUcsQ0FBQyxDQUFDLEdBQ3JDLENBQUMsR0FBRyxJQUFJSSxHQUFHLENBQUNSLFNBQVMsQ0FBQ0ksR0FBRyxDQUFDLENBQUMsQ0FBQ0ssTUFBTSxFQUFFLENBQUMsQ0FBQ0MsTUFBTSxDQUFDQyxDQUFDLElBQUlBLENBQUMsQ0FBQyxDQUFDQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQzlEWixTQUFTLENBQUNJLEdBQUcsQ0FBQzs7SUFFbEI7SUFDQTtJQUNBLElBQUksT0FBT0MsR0FBRyxLQUFLLFFBQVEsSUFBSUEsR0FBRyxDQUFDUSxRQUFRLENBQUMsa0JBQWtCLENBQUMsRUFBRTtNQUMvRCxNQUFNQyxNQUFNLEdBQUksR0FBRVQsR0FBRyxDQUNsQlUsT0FBTyxDQUFDLDBCQUEwQixFQUFFLEdBQUcsQ0FBQyxDQUN4Q0MsSUFBSSxFQUFHLG1CQUFrQjtNQUM1QixPQUFRLEdBQUVaLEdBQUksSUFBR1UsTUFBTyxFQUFDO0lBQzNCO0lBRUEsT0FBUSxHQUFFVixHQUFJLElBQUdDLEdBQUksRUFBQztFQUN4QixDQUFDLENBQUMsQ0FDRE8sSUFBSSxDQUFDLElBQUksQ0FBQztBQUNmIn0=
@@ -2,11 +2,10 @@
2
2
 
3
3
  exports.__esModule = true;
4
4
  exports.default = documentSpout;
5
-
6
5
  function documentSpout(options) {
7
6
  return next => async props => {
8
7
  const nextProps = await next(props);
9
8
  return nextProps;
10
9
  };
11
10
  }
12
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkb2N1bWVudFNwb3V0Iiwib3B0aW9ucyIsIm5leHQiLCJwcm9wcyIsIm5leHRQcm9wcyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zcG91dHMvZG9jdW1lbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IFJvdXRlIH0gZnJvbSAnQGFuYW5zaS9yb3V0ZXInO1xuXG5pbXBvcnQgdHlwZSB7IENsaWVudFNwb3V0IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGRvY3VtZW50U3BvdXQob3B0aW9uczoge1xuICBoZWFkPzogUmVhY3QuUmVhY3ROb2RlO1xuICB0aXRsZTogc3RyaW5nO1xufSk6IENsaWVudFNwb3V0IHtcbiAgcmV0dXJuIG5leHQgPT4gYXN5bmMgcHJvcHMgPT4ge1xuICAgIGNvbnN0IG5leHRQcm9wcyA9IGF3YWl0IG5leHQocHJvcHMpO1xuXG4gICAgcmV0dXJuIG5leHRQcm9wcztcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFLZSxTQUFTQSxhQUFULENBQXVCQyxPQUF2QixFQUdDO0VBQ2QsT0FBT0MsSUFBSSxJQUFJLE1BQU1DLEtBQU4sSUFBZTtJQUM1QixNQUFNQyxTQUFTLEdBQUcsTUFBTUYsSUFBSSxDQUFDQyxLQUFELENBQTVCO0lBRUEsT0FBT0MsU0FBUDtFQUNELENBSkQ7QUFLRCJ9
11
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkb2N1bWVudFNwb3V0Iiwib3B0aW9ucyIsIm5leHQiLCJwcm9wcyIsIm5leHRQcm9wcyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zcG91dHMvZG9jdW1lbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IFJvdXRlIH0gZnJvbSAnQGFuYW5zaS9yb3V0ZXInO1xuXG5pbXBvcnQgdHlwZSB7IENsaWVudFNwb3V0IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGRvY3VtZW50U3BvdXQob3B0aW9uczoge1xuICBoZWFkPzogUmVhY3QuUmVhY3ROb2RlO1xuICB0aXRsZTogc3RyaW5nO1xufSk6IENsaWVudFNwb3V0IHtcbiAgcmV0dXJuIG5leHQgPT4gYXN5bmMgcHJvcHMgPT4ge1xuICAgIGNvbnN0IG5leHRQcm9wcyA9IGF3YWl0IG5leHQocHJvcHMpO1xuXG4gICAgcmV0dXJuIG5leHRQcm9wcztcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7OztBQUtlLFNBQVNBLGFBQWEsQ0FBQ0MsT0FHckMsRUFBZTtFQUNkLE9BQU9DLElBQUksSUFBSSxNQUFNQyxLQUFLLElBQUk7SUFDNUIsTUFBTUMsU0FBUyxHQUFHLE1BQU1GLElBQUksQ0FBQ0MsS0FBSyxDQUFDO0lBRW5DLE9BQU9DLFNBQVM7RUFDbEIsQ0FBQztBQUNIIn0=
@@ -1,42 +1,37 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  exports.__esModule = true;
6
5
  exports.default = DocumentSpout;
7
-
8
6
  var _react = _interopRequireDefault(require("react"));
9
-
10
7
  var _DocumentComponent = _interopRequireDefault(require("./DocumentComponent"));
11
-
12
8
  function DocumentSpout(options) {
13
9
  return next => async props => {
14
10
  var _props$clientManifest, _props$clientManifest2, _props$clientManifest3, _props$clientManifest4, _props$clientManifest5, _nextProps$title;
15
-
16
11
  const nextProps = await next(props);
17
12
  const publicPath = props.clientManifest.publicPath;
18
- if (Object.keys((_props$clientManifest = (_props$clientManifest2 = props.clientManifest) == null ? void 0 : _props$clientManifest2.entrypoints) != null ? _props$clientManifest : {}).length < 1 || publicPath === undefined) throw new Error('Manifest missing entries needed'); // TODO: consider using this package for build stats in future:
19
- // https://github.com/facebook/react/tree/main/packages/react-server-dom-webpack
13
+ if (Object.keys((_props$clientManifest = (_props$clientManifest2 = props.clientManifest) == null ? void 0 : _props$clientManifest2.entrypoints) != null ? _props$clientManifest : {}).length < 1 || publicPath === undefined) throw new Error('Manifest missing entries needed');
20
14
 
15
+ // TODO: consider using this package for build stats in future:
16
+ // https://github.com/facebook/react/tree/main/packages/react-server-dom-webpack
21
17
  const assetMap = assets => assets.map(({
22
18
  name
23
19
  }) => `${publicPath}${name}`);
24
-
25
20
  const assetList = [];
26
21
  Object.values((_props$clientManifest3 = (_props$clientManifest4 = props.clientManifest) == null ? void 0 : _props$clientManifest4.entrypoints) != null ? _props$clientManifest3 : {}).forEach(entrypoint => {
27
22
  var _entrypoint$assets;
28
-
29
23
  assetList.push(...assetMap((_entrypoint$assets = entrypoint.assets) != null ? _entrypoint$assets : []));
30
24
  });
31
25
  new Set(assetMap(Object.values((_props$clientManifest5 = props.clientManifest.namedChunkGroups) != null ? _props$clientManifest5 : {}).filter(({
32
26
  name
33
27
  }) => nextProps.matchedRoutes.some(route => name == null ? void 0 : name.includes(route.name))).flatMap(chunk => {
34
28
  var _chunk$assets;
35
-
36
- return [...((_chunk$assets = chunk.assets) != null ? _chunk$assets : []), // any chunk preloads
29
+ return [...((_chunk$assets = chunk.assets) != null ? _chunk$assets : []),
30
+ // any chunk preloads
37
31
  ...childrenAssets(chunk)];
38
- }))).forEach(asset => assetList.push(asset)); // find additional assets to preload based on matched route
32
+ }))).forEach(asset => assetList.push(asset));
39
33
 
34
+ // find additional assets to preload based on matched route
40
35
  const assets = assetList.filter(asset => !asset.endsWith('.hot-update.js')).map(asset => asset.endsWith('.css') ? {
41
36
  href: asset,
42
37
  rel: 'stylesheet'
@@ -46,8 +41,10 @@ function DocumentSpout(options) {
46
41
  } : {
47
42
  href: asset
48
43
  });
49
- return { ...nextProps,
50
- app: /*#__PURE__*/_react.default.createElement(_DocumentComponent.default, { ...options,
44
+ return {
45
+ ...nextProps,
46
+ app: /*#__PURE__*/_react.default.createElement(_DocumentComponent.default, {
47
+ ...options,
51
48
  title: (_nextProps$title = nextProps.title) != null ? _nextProps$title : options.title,
52
49
  assets: assets,
53
50
  rootId: options.rootId,
@@ -58,12 +55,10 @@ function DocumentSpout(options) {
58
55
  };
59
56
  };
60
57
  }
61
-
62
58
  function childrenAssets(chunk) {
63
59
  return chunk.children ? Object.values(chunk.children).flatMap(preload => preload.flatMap(c => {
64
60
  var _c$assets;
65
-
66
61
  return (_c$assets = c.assets) != null ? _c$assets : [];
67
62
  })) : [];
68
63
  }
69
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEb2N1bWVudFNwb3V0Iiwib3B0aW9ucyIsIm5leHQiLCJwcm9wcyIsIm5leHRQcm9wcyIsInB1YmxpY1BhdGgiLCJjbGllbnRNYW5pZmVzdCIsIk9iamVjdCIsImtleXMiLCJlbnRyeXBvaW50cyIsImxlbmd0aCIsInVuZGVmaW5lZCIsIkVycm9yIiwiYXNzZXRNYXAiLCJhc3NldHMiLCJtYXAiLCJuYW1lIiwiYXNzZXRMaXN0IiwidmFsdWVzIiwiZm9yRWFjaCIsImVudHJ5cG9pbnQiLCJwdXNoIiwiU2V0IiwibmFtZWRDaHVua0dyb3VwcyIsImZpbHRlciIsIm1hdGNoZWRSb3V0ZXMiLCJzb21lIiwicm91dGUiLCJpbmNsdWRlcyIsImZsYXRNYXAiLCJjaHVuayIsImNoaWxkcmVuQXNzZXRzIiwiYXNzZXQiLCJlbmRzV2l0aCIsImhyZWYiLCJyZWwiLCJhcyIsImFwcCIsInRpdGxlIiwicm9vdElkIiwibm9uY2UiLCJjc1BvbGljeSIsInNjcmlwdHMiLCJjaGlsZHJlbiIsInByZWxvYWQiLCJjIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Nwb3V0cy9kb2N1bWVudC5zZXJ2ZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IFJvdXRlIH0gZnJvbSAnQGFuYW5zaS9yb3V0ZXInO1xuaW1wb3J0IHsgU3RhdHNDaHVua0dyb3VwIH0gZnJvbSAnd2VicGFjayc7XG5cbmltcG9ydCB0eXBlIHsgU2VydmVyU3BvdXQgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB0eXBlIHsgUG9saWN5IH0gZnJvbSAnLi9jc3AnO1xuaW1wb3J0IERvY3VtZW50IGZyb20gJy4vRG9jdW1lbnRDb21wb25lbnQnO1xuXG50eXBlIE5lZWRlZE5leHQgPSB7XG4gIG1hdGNoZWRSb3V0ZXM6IFJvdXRlPGFueT5bXTtcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIHNjcmlwdHM/OiBSZWFjdC5SZWFjdE5vZGVbXTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIERvY3VtZW50U3BvdXQob3B0aW9uczoge1xuICBoZWFkPzogUmVhY3QuUmVhY3ROb2RlO1xuICB0aXRsZTogc3RyaW5nO1xuICByb290SWQ/OiBzdHJpbmc7XG4gIGNoYXJTZXQ/OiBzdHJpbmc7XG4gIGNzUG9saWN5PzogUG9saWN5O1xufSk6IFNlcnZlclNwb3V0PFJlY29yZDxzdHJpbmcsIHVua25vd24+LCBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiwgTmVlZGVkTmV4dD4ge1xuICByZXR1cm4gbmV4dCA9PiBhc3luYyBwcm9wcyA9PiB7XG4gICAgY29uc3QgbmV4dFByb3BzID0gYXdhaXQgbmV4dChwcm9wcyk7XG5cbiAgICBjb25zdCBwdWJsaWNQYXRoID0gcHJvcHMuY2xpZW50TWFuaWZlc3QucHVibGljUGF0aDtcblxuICAgIGlmIChcbiAgICAgIE9iamVjdC5rZXlzKHByb3BzLmNsaWVudE1hbmlmZXN0Py5lbnRyeXBvaW50cyA/PyB7fSkubGVuZ3RoIDwgMSB8fFxuICAgICAgcHVibGljUGF0aCA9PT0gdW5kZWZpbmVkXG4gICAgKVxuICAgICAgdGhyb3cgbmV3IEVycm9yKCdNYW5pZmVzdCBtaXNzaW5nIGVudHJpZXMgbmVlZGVkJyk7XG5cbiAgICAvLyBUT0RPOiBjb25zaWRlciB1c2luZyB0aGlzIHBhY2thZ2UgZm9yIGJ1aWxkIHN0YXRzIGluIGZ1dHVyZTpcbiAgICAvLyBodHRwczovL2dpdGh1Yi5jb20vZmFjZWJvb2svcmVhY3QvdHJlZS9tYWluL3BhY2thZ2VzL3JlYWN0LXNlcnZlci1kb20td2VicGFja1xuICAgIGNvbnN0IGFzc2V0TWFwID0gKGFzc2V0czogeyBuYW1lOiBzdHJpbmc7IHNpemU/OiBudW1iZXIgfVtdKSA9PlxuICAgICAgYXNzZXRzLm1hcCgoeyBuYW1lIH0pID0+IGAke3B1YmxpY1BhdGh9JHtuYW1lfWApO1xuXG4gICAgY29uc3QgYXNzZXRMaXN0OiBzdHJpbmdbXSA9IFtdO1xuICAgIE9iamVjdC52YWx1ZXMocHJvcHMuY2xpZW50TWFuaWZlc3Q/LmVudHJ5cG9pbnRzID8/IHt9KS5mb3JFYWNoKFxuICAgICAgZW50cnlwb2ludCA9PiB7XG4gICAgICAgIGFzc2V0TGlzdC5wdXNoKC4uLmFzc2V0TWFwKGVudHJ5cG9pbnQuYXNzZXRzID8/IFtdKSk7XG4gICAgICB9LFxuICAgICk7XG4gICAgbmV3IFNldChcbiAgICAgIGFzc2V0TWFwKFxuICAgICAgICBPYmplY3QudmFsdWVzKHByb3BzLmNsaWVudE1hbmlmZXN0Lm5hbWVkQ2h1bmtHcm91cHMgPz8ge30pXG4gICAgICAgICAgLmZpbHRlcigoeyBuYW1lIH0pID0+XG4gICAgICAgICAgICBuZXh0UHJvcHMubWF0Y2hlZFJvdXRlcy5zb21lKHJvdXRlID0+IG5hbWU/LmluY2x1ZGVzKHJvdXRlLm5hbWUpKSxcbiAgICAgICAgICApXG4gICAgICAgICAgLmZsYXRNYXAoY2h1bmsgPT4gW1xuICAgICAgICAgICAgLi4uKGNodW5rLmFzc2V0cyA/PyBbXSksXG4gICAgICAgICAgICAvLyBhbnkgY2h1bmsgcHJlbG9hZHNcbiAgICAgICAgICAgIC4uLmNoaWxkcmVuQXNzZXRzKGNodW5rKSxcbiAgICAgICAgICBdKSxcbiAgICAgICksXG4gICAgKS5mb3JFYWNoKGFzc2V0ID0+IGFzc2V0TGlzdC5wdXNoKGFzc2V0KSk7XG5cbiAgICAvLyBmaW5kIGFkZGl0aW9uYWwgYXNzZXRzIHRvIHByZWxvYWQgYmFzZWQgb24gbWF0Y2hlZCByb3V0ZVxuICAgIGNvbnN0IGFzc2V0czoge1xuICAgICAgaHJlZjogc3RyaW5nO1xuICAgICAgYXM/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgICByZWw/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgfVtdID0gYXNzZXRMaXN0XG4gICAgICAuZmlsdGVyKGFzc2V0ID0+ICFhc3NldC5lbmRzV2l0aCgnLmhvdC11cGRhdGUuanMnKSlcbiAgICAgIC5tYXAoYXNzZXQgPT5cbiAgICAgICAgYXNzZXQuZW5kc1dpdGgoJy5jc3MnKVxuICAgICAgICAgID8geyBocmVmOiBhc3NldCwgcmVsOiAnc3R5bGVzaGVldCcgfVxuICAgICAgICAgIDogYXNzZXQuZW5kc1dpdGgoJy5qcycpXG4gICAgICAgICAgPyB7IGhyZWY6IGFzc2V0LCBhczogJ3NjcmlwdCcgfVxuICAgICAgICAgIDogeyBocmVmOiBhc3NldCB9LFxuICAgICAgKTtcblxuICAgIHJldHVybiB7XG4gICAgICAuLi5uZXh0UHJvcHMsXG4gICAgICBhcHA6IChcbiAgICAgICAgPERvY3VtZW50XG4gICAgICAgICAgey4uLm9wdGlvbnN9XG4gICAgICAgICAgdGl0bGU9e25leHRQcm9wcy50aXRsZSA/PyBvcHRpb25zLnRpdGxlfVxuICAgICAgICAgIGFzc2V0cz17YXNzZXRzfVxuICAgICAgICAgIHJvb3RJZD17b3B0aW9ucy5yb290SWR9XG4gICAgICAgICAgbm9uY2U9e3Byb3BzLm5vbmNlfVxuICAgICAgICAgIGNzUG9saWN5PXtvcHRpb25zLmNzUG9saWN5fVxuICAgICAgICAgIHNjcmlwdHM9e25leHRQcm9wcy5zY3JpcHRzfVxuICAgICAgICA+XG4gICAgICAgICAge25leHRQcm9wcy5hcHB9XG4gICAgICAgIDwvRG9jdW1lbnQ+XG4gICAgICApLFxuICAgIH07XG4gIH07XG59XG5cbmZ1bmN0aW9uIGNoaWxkcmVuQXNzZXRzKGNodW5rOiBTdGF0c0NodW5rR3JvdXApIHtcbiAgcmV0dXJuIGNodW5rLmNoaWxkcmVuXG4gICAgPyBPYmplY3QudmFsdWVzKGNodW5rLmNoaWxkcmVuKS5mbGF0TWFwKHByZWxvYWQgPT5cbiAgICAgICAgcHJlbG9hZC5mbGF0TWFwKGMgPT4gYy5hc3NldHMgPz8gW10pLFxuICAgICAgKVxuICAgIDogW107XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFNQTs7QUFRZSxTQUFTQSxhQUFULENBQXVCQyxPQUF2QixFQU0rRDtFQUM1RSxPQUFPQyxJQUFJLElBQUksTUFBTUMsS0FBTixJQUFlO0lBQUE7O0lBQzVCLE1B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
64
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEb2N1bWVudFNwb3V0Iiwib3B0aW9ucyIsIm5leHQiLCJwcm9wcyIsIm5leHRQcm9wcyIsInB1YmxpY1BhdGgiLCJjbGllbnRNYW5pZmVzdCIsIk9iamVjdCIsImtleXMiLCJlbnRyeXBvaW50cyIsImxlbmd0aCIsInVuZGVmaW5lZCIsIkVycm9yIiwiYXNzZXRNYXAiLCJhc3NldHMiLCJtYXAiLCJuYW1lIiwiYXNzZXRMaXN0IiwidmFsdWVzIiwiZm9yRWFjaCIsImVudHJ5cG9pbnQiLCJwdXNoIiwiU2V0IiwibmFtZWRDaHVua0dyb3VwcyIsImZpbHRlciIsIm1hdGNoZWRSb3V0ZXMiLCJzb21lIiwicm91dGUiLCJpbmNsdWRlcyIsImZsYXRNYXAiLCJjaHVuayIsImNoaWxkcmVuQXNzZXRzIiwiYXNzZXQiLCJlbmRzV2l0aCIsImhyZWYiLCJyZWwiLCJhcyIsImFwcCIsInRpdGxlIiwicm9vdElkIiwibm9uY2UiLCJjc1BvbGljeSIsInNjcmlwdHMiLCJjaGlsZHJlbiIsInByZWxvYWQiLCJjIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Nwb3V0cy9kb2N1bWVudC5zZXJ2ZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7IFJvdXRlIH0gZnJvbSAnQGFuYW5zaS9yb3V0ZXInO1xuaW1wb3J0IHsgU3RhdHNDaHVua0dyb3VwIH0gZnJvbSAnd2VicGFjayc7XG5cbmltcG9ydCB0eXBlIHsgU2VydmVyU3BvdXQgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB0eXBlIHsgUG9saWN5IH0gZnJvbSAnLi9jc3AnO1xuaW1wb3J0IERvY3VtZW50IGZyb20gJy4vRG9jdW1lbnRDb21wb25lbnQnO1xuXG50eXBlIE5lZWRlZE5leHQgPSB7XG4gIG1hdGNoZWRSb3V0ZXM6IFJvdXRlPGFueT5bXTtcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIHNjcmlwdHM/OiBSZWFjdC5SZWFjdE5vZGVbXTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIERvY3VtZW50U3BvdXQob3B0aW9uczoge1xuICBoZWFkPzogUmVhY3QuUmVhY3ROb2RlO1xuICB0aXRsZTogc3RyaW5nO1xuICByb290SWQ/OiBzdHJpbmc7XG4gIGNoYXJTZXQ/OiBzdHJpbmc7XG4gIGNzUG9saWN5PzogUG9saWN5O1xufSk6IFNlcnZlclNwb3V0PFJlY29yZDxzdHJpbmcsIHVua25vd24+LCBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiwgTmVlZGVkTmV4dD4ge1xuICByZXR1cm4gbmV4dCA9PiBhc3luYyBwcm9wcyA9PiB7XG4gICAgY29uc3QgbmV4dFByb3BzID0gYXdhaXQgbmV4dChwcm9wcyk7XG5cbiAgICBjb25zdCBwdWJsaWNQYXRoID0gcHJvcHMuY2xpZW50TWFuaWZlc3QucHVibGljUGF0aDtcblxuICAgIGlmIChcbiAgICAgIE9iamVjdC5rZXlzKHByb3BzLmNsaWVudE1hbmlmZXN0Py5lbnRyeXBvaW50cyA/PyB7fSkubGVuZ3RoIDwgMSB8fFxuICAgICAgcHVibGljUGF0aCA9PT0gdW5kZWZpbmVkXG4gICAgKVxuICAgICAgdGhyb3cgbmV3IEVycm9yKCdNYW5pZmVzdCBtaXNzaW5nIGVudHJpZXMgbmVlZGVkJyk7XG5cbiAgICAvLyBUT0RPOiBjb25zaWRlciB1c2luZyB0aGlzIHBhY2thZ2UgZm9yIGJ1aWxkIHN0YXRzIGluIGZ1dHVyZTpcbiAgICAvLyBodHRwczovL2dpdGh1Yi5jb20vZmFjZWJvb2svcmVhY3QvdHJlZS9tYWluL3BhY2thZ2VzL3JlYWN0LXNlcnZlci1kb20td2VicGFja1xuICAgIGNvbnN0IGFzc2V0TWFwID0gKGFzc2V0czogeyBuYW1lOiBzdHJpbmc7IHNpemU/OiBudW1iZXIgfVtdKSA9PlxuICAgICAgYXNzZXRzLm1hcCgoeyBuYW1lIH0pID0+IGAke3B1YmxpY1BhdGh9JHtuYW1lfWApO1xuXG4gICAgY29uc3QgYXNzZXRMaXN0OiBzdHJpbmdbXSA9IFtdO1xuICAgIE9iamVjdC52YWx1ZXMocHJvcHMuY2xpZW50TWFuaWZlc3Q/LmVudHJ5cG9pbnRzID8/IHt9KS5mb3JFYWNoKFxuICAgICAgZW50cnlwb2ludCA9PiB7XG4gICAgICAgIGFzc2V0TGlzdC5wdXNoKC4uLmFzc2V0TWFwKGVudHJ5cG9pbnQuYXNzZXRzID8/IFtdKSk7XG4gICAgICB9LFxuICAgICk7XG4gICAgbmV3IFNldChcbiAgICAgIGFzc2V0TWFwKFxuICAgICAgICBPYmplY3QudmFsdWVzKHByb3BzLmNsaWVudE1hbmlmZXN0Lm5hbWVkQ2h1bmtHcm91cHMgPz8ge30pXG4gICAgICAgICAgLmZpbHRlcigoeyBuYW1lIH0pID0+XG4gICAgICAgICAgICBuZXh0UHJvcHMubWF0Y2hlZFJvdXRlcy5zb21lKHJvdXRlID0+IG5hbWU/LmluY2x1ZGVzKHJvdXRlLm5hbWUpKSxcbiAgICAgICAgICApXG4gICAgICAgICAgLmZsYXRNYXAoY2h1bmsgPT4gW1xuICAgICAgICAgICAgLi4uKGNodW5rLmFzc2V0cyA/PyBbXSksXG4gICAgICAgICAgICAvLyBhbnkgY2h1bmsgcHJlbG9hZHNcbiAgICAgICAgICAgIC4uLmNoaWxkcmVuQXNzZXRzKGNodW5rKSxcbiAgICAgICAgICBdKSxcbiAgICAgICksXG4gICAgKS5mb3JFYWNoKGFzc2V0ID0+IGFzc2V0TGlzdC5wdXNoKGFzc2V0KSk7XG5cbiAgICAvLyBmaW5kIGFkZGl0aW9uYWwgYXNzZXRzIHRvIHByZWxvYWQgYmFzZWQgb24gbWF0Y2hlZCByb3V0ZVxuICAgIGNvbnN0IGFzc2V0czoge1xuICAgICAgaHJlZjogc3RyaW5nO1xuICAgICAgYXM/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgICByZWw/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgfVtdID0gYXNzZXRMaXN0XG4gICAgICAuZmlsdGVyKGFzc2V0ID0+ICFhc3NldC5lbmRzV2l0aCgnLmhvdC11cGRhdGUuanMnKSlcbiAgICAgIC5tYXAoYXNzZXQgPT5cbiAgICAgICAgYXNzZXQuZW5kc1dpdGgoJy5jc3MnKVxuICAgICAgICAgID8geyBocmVmOiBhc3NldCwgcmVsOiAnc3R5bGVzaGVldCcgfVxuICAgICAgICAgIDogYXNzZXQuZW5kc1dpdGgoJy5qcycpXG4gICAgICAgICAgPyB7IGhyZWY6IGFzc2V0LCBhczogJ3NjcmlwdCcgfVxuICAgICAgICAgIDogeyBocmVmOiBhc3NldCB9LFxuICAgICAgKTtcblxuICAgIHJldHVybiB7XG4gICAgICAuLi5uZXh0UHJvcHMsXG4gICAgICBhcHA6IChcbiAgICAgICAgPERvY3VtZW50XG4gICAgICAgICAgey4uLm9wdGlvbnN9XG4gICAgICAgICAgdGl0bGU9e25leHRQcm9wcy50aXRsZSA/PyBvcHRpb25zLnRpdGxlfVxuICAgICAgICAgIGFzc2V0cz17YXNzZXRzfVxuICAgICAgICAgIHJvb3RJZD17b3B0aW9ucy5yb290SWR9XG4gICAgICAgICAgbm9uY2U9e3Byb3BzLm5vbmNlfVxuICAgICAgICAgIGNzUG9saWN5PXtvcHRpb25zLmNzUG9saWN5fVxuICAgICAgICAgIHNjcmlwdHM9e25leHRQcm9wcy5zY3JpcHRzfVxuICAgICAgICA+XG4gICAgICAgICAge25leHRQcm9wcy5hcHB9XG4gICAgICAgIDwvRG9jdW1lbnQ+XG4gICAgICApLFxuICAgIH07XG4gIH07XG59XG5cbmZ1bmN0aW9uIGNoaWxkcmVuQXNzZXRzKGNodW5rOiBTdGF0c0NodW5rR3JvdXApIHtcbiAgcmV0dXJuIGNodW5rLmNoaWxkcmVuXG4gICAgPyBPYmplY3QudmFsdWVzKGNodW5rLmNoaWxkcmVuKS5mbGF0TWFwKHByZWxvYWQgPT5cbiAgICAgICAgcHJlbG9hZC5mbGF0TWFwKGMgPT4gYy5hc3NldHMgPz8gW10pLFxuICAgICAgKVxuICAgIDogW107XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7QUFNQTtBQVFlLFNBQVNBLGFBQWEsQ0FBQ0MsT0FNckMsRUFBNkU7RUFDNUUsT0FBT0MsSUFBSSxJQUFJLE1BQU1DLEtBQUssSUFBSTtJQUFBO0lBQzVCLE1BQU1DLFNB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