@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.
@@ -1,35 +1,20 @@
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.routerSpout = exports.restHooksSpout = exports.prefetchSpout = exports.laySpouts = exports.documentSpout = exports.appSpout = exports.JSONSpout = void 0;
7
-
8
6
  var _laySpouts = _interopRequireDefault(require("./laySpouts"));
9
-
10
7
  exports.laySpouts = _laySpouts.default;
11
-
12
8
  var _document = _interopRequireDefault(require("./spouts/document.server"));
13
-
14
9
  exports.documentSpout = _document.default;
15
-
16
10
  var _restHooks = _interopRequireDefault(require("./spouts/restHooks.server"));
17
-
18
11
  exports.restHooksSpout = _restHooks.default;
19
-
20
12
  var _router = _interopRequireDefault(require("./spouts/router.server"));
21
-
22
13
  exports.routerSpout = _router.default;
23
-
24
14
  var _prefetch = _interopRequireDefault(require("./spouts/prefetch.server"));
25
-
26
15
  exports.prefetchSpout = _prefetch.default;
27
-
28
16
  var _json = _interopRequireDefault(require("./spouts/json.server"));
29
-
30
17
  exports.JSONSpout = _json.default;
31
-
32
18
  var _app = _interopRequireDefault(require("./spouts/app.server"));
33
-
34
19
  exports.appSpout = _app.default;
35
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2luZGV4LnNlcnZlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBkZWZhdWx0IGFzIGxheVNwb3V0cyB9IGZyb20gJy4vbGF5U3BvdXRzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgZG9jdW1lbnRTcG91dCB9IGZyb20gJy4vc3BvdXRzL2RvY3VtZW50LnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHJlc3RIb29rc1Nwb3V0IH0gZnJvbSAnLi9zcG91dHMvcmVzdEhvb2tzLnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHJvdXRlclNwb3V0IH0gZnJvbSAnLi9zcG91dHMvcm91dGVyLnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHByZWZldGNoU3BvdXQgfSBmcm9tICcuL3Nwb3V0cy9wcmVmZXRjaC5zZXJ2ZXInO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBKU09OU3BvdXQgfSBmcm9tICcuL3Nwb3V0cy9qc29uLnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIGFwcFNwb3V0IH0gZnJvbSAnLi9zcG91dHMvYXBwLnNlcnZlcic7XG5leHBvcnQgdHlwZSB7IFNlcnZlclByb3BzIH0gZnJvbSAnLi9zcG91dHMvdHlwZXMnO1xuZXhwb3J0IHR5cGUgeyBTZXJ2ZXJTcG91dCBhcyBTcG91dCB9IGZyb20gJy4vc3BvdXRzL3R5cGVzJztcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBIn0=
20
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2luZGV4LnNlcnZlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBkZWZhdWx0IGFzIGxheVNwb3V0cyB9IGZyb20gJy4vbGF5U3BvdXRzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgZG9jdW1lbnRTcG91dCB9IGZyb20gJy4vc3BvdXRzL2RvY3VtZW50LnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHJlc3RIb29rc1Nwb3V0IH0gZnJvbSAnLi9zcG91dHMvcmVzdEhvb2tzLnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHJvdXRlclNwb3V0IH0gZnJvbSAnLi9zcG91dHMvcm91dGVyLnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHByZWZldGNoU3BvdXQgfSBmcm9tICcuL3Nwb3V0cy9wcmVmZXRjaC5zZXJ2ZXInO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBKU09OU3BvdXQgfSBmcm9tICcuL3Nwb3V0cy9qc29uLnNlcnZlcic7XG5leHBvcnQgeyBkZWZhdWx0IGFzIGFwcFNwb3V0IH0gZnJvbSAnLi9zcG91dHMvYXBwLnNlcnZlcic7XG5leHBvcnQgdHlwZSB7IFNlcnZlclByb3BzIH0gZnJvbSAnLi9zcG91dHMvdHlwZXMnO1xuZXhwb3J0IHR5cGUgeyBTZXJ2ZXJTcG91dCBhcyBTcG91dCB9IGZyb20gJy4vc3BvdXRzL3R5cGVzJztcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTtBQUFtRDtBQUNuRDtBQUFvRTtBQUNwRTtBQUFzRTtBQUN0RTtBQUFnRTtBQUNoRTtBQUFvRTtBQUNwRTtBQUE0RDtBQUM1RDtBQUEwRCJ9
package/lib/laySpouts.js CHANGED
@@ -1,21 +1,16 @@
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 = laySpouts;
7
-
8
6
  var _server = require("react-dom/server");
9
-
10
7
  var _crypto = _interopRequireDefault(require("crypto"));
11
-
12
8
  function laySpouts(spouts, {
13
9
  timeoutMS = 200,
14
10
  onError
15
11
  } = {}) {
16
12
  const render = async (clientManifest, req, res) => {
17
13
  const nonce = _crypto.default.randomBytes(16).toString('base64');
18
-
19
14
  try {
20
15
  const {
21
16
  app
@@ -31,7 +26,6 @@ function laySpouts(spouts, {
31
26
  abort
32
27
  } = (0, _server.renderToPipeableStream)(app, {
33
28
  nonce,
34
-
35
29
  //bootstrapScripts: assets.filter(asset => asset.endsWith('.js')),
36
30
  onShellReady() {
37
31
  //managers.forEach(manager => manager.cleanup());
@@ -40,31 +34,27 @@ function laySpouts(spouts, {
40
34
  res.setHeader('Content-type', 'text/html');
41
35
  pipe(res);
42
36
  },
43
-
44
37
  onShellError() {
45
38
  didError = true;
46
39
  res.statusCode = 500;
47
40
  pipe(res);
48
41
  },
49
-
50
42
  onError(e) {
51
43
  didError = true;
52
44
  console.error(e);
53
- res.statusCode = 500; //pipe(res); Removing this avoids, "React currently only supports piping to one writable stream."
54
-
45
+ res.statusCode = 500;
46
+ //pipe(res); Removing this avoids, "React currently only supports piping to one writable stream."
55
47
  if (onError) onError(e);
56
48
  }
57
-
58
- }); // Abandon and switch to client rendering if enough time passes.
49
+ });
50
+ // Abandon and switch to client rendering if enough time passes.
59
51
  // Try lowering this to see the client recover.
60
-
61
52
  setTimeout(() => abort(`Timeout of ${timeoutMS}ms exceeded`), timeoutMS);
62
53
  } catch (e) {
63
54
  if (onError) onError(e);
64
55
  throw e;
65
56
  }
66
57
  };
67
-
68
58
  return render;
69
59
  }
70
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJsYXlTcG91dHMiLCJzcG91dHMiLCJ0aW1lb3V0TVMiLCJvbkVycm9yIiwicmVuZGVyIiwiY2xpZW50TWFuaWZlc3QiLCJyZXEiLCJyZXMiLCJub25jZSIsImNyeXB0byIsInJhbmRvbUJ5dGVzIiwidG9TdHJpbmciLCJhcHAiLCJkaWRFcnJvciIsInBpcGUiLCJhYm9ydCIsInJlYWN0UmVuZGVyIiwib25TaGVsbFJlYWR5Iiwic3RhdHVzQ29kZSIsInNldEhlYWRlciIsIm9uU2hlbGxFcnJvciIsImUiLCJjb25zb2xlIiwiZXJyb3IiLCJzZXRUaW1lb3V0Il0sInNvdXJjZXMiOlsiLi4vc3JjL2xheVNwb3V0cy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVuZGVyVG9QaXBlYWJsZVN0cmVhbSBhcyByZWFjdFJlbmRlciB9IGZyb20gJ3JlYWN0LWRvbS9zZXJ2ZXInO1xuaW1wb3J0IGNyeXB0byBmcm9tICdjcnlwdG8nO1xuXG5pbXBvcnQgeyBSZW5kZXIgfSBmcm9tICcuL3NjcmlwdHMvdHlwZXMnO1xuaW1wb3J0IHsgU2VydmVyUHJvcHMgfSBmcm9tICcuL3Nwb3V0cy90eXBlcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGxheVNwb3V0cyhcbiAgc3BvdXRzOiAocHJvcHM6IFNlcnZlclByb3BzKSA9PiBQcm9taXNlPHtcbiAgICBhcHA6IEpTWC5FbGVtZW50O1xuICB9PixcbiAge1xuICAgIHRpbWVvdXRNUyA9IDIwMCxcbiAgICBvbkVycm9yLFxuICB9OiB7IHRpbWVvdXRNUz86IG51bWJlcjsgb25FcnJvcj86IChlcnJvcjogdW5rbm93bikgPT4gdm9pZCB9ID0ge30sXG4pIHtcbiAgY29uc3QgcmVuZGVyOiBSZW5kZXIgPSBhc3luYyAoY2xpZW50TWFuaWZlc3QsIHJlcSwgcmVzKSA9PiB7XG4gICAgY29uc3Qgbm9uY2UgPSBjcnlwdG8ucmFuZG9tQnl0ZXMoMTYpLnRvU3RyaW5nKCdiYXNlNjQnKTtcblxuICAgIHRyeSB7XG4gICAgICBjb25zdCB7IGFwcCB9ID0gYXdhaXQgc3BvdXRzKHsgY2xpZW50TWFuaWZlc3QsIHJlcSwgcmVzLCBub25jZSB9KTtcblxuICAgICAgbGV0IGRpZEVycm9yID0gZmFsc2U7XG4gICAgICBjb25zdCB7IHBpcGUsIGFib3J0IH0gPSByZWFjdFJlbmRlcihhcHAsIHtcbiAgICAgICAgbm9uY2UsXG4gICAgICAgIC8vYm9vdHN0cmFwU2NyaXB0czogYXNzZXRzLmZpbHRlcihhc3NldCA9PiBhc3NldC5lbmRzV2l0aCgnLmpzJykpLFxuICAgICAgICBvblNoZWxsUmVhZHkoKSB7XG4gICAgICAgICAgLy9tYW5hZ2Vycy5mb3JFYWNoKG1hbmFnZXIgPT4gbWFuYWdlci5jbGVhbnVwKCkpO1xuICAgICAgICAgIC8vIElmIHNvbWV0aGluZyBlcnJvcmVkIGJlZm9yZSB3ZSBzdGFydGVkIHN0cmVhbWluZywgd2Ugc2V0IHRoZSBlcnJvciBjb2RlIGFwcHJvcHJpYXRlbHkuXG4gICAgICAgICAgcmVzLnN0YXR1c0NvZGUgPSBkaWRFcnJvciA/IDUwMCA6IDIwMDtcbiAgICAgICAgICByZXMuc2V0SGVhZGVyKCdDb250ZW50LXR5cGUnLCAndGV4dC9odG1sJyk7XG4gICAgICAgICAgcGlwZShyZXMpO1xuICAgICAgICB9LFxuICAgICAgICBvblNoZWxsRXJyb3IoKSB7XG4gICAgICAgICAgZGlkRXJyb3IgPSB0cnVlO1xuICAgICAgICAgIHJlcy5zdGF0dXNDb2RlID0gNTAwO1xuICAgICAgICAgIHBpcGUocmVzKTtcbiAgICAgICAgfSxcbiAgICAgICAgb25FcnJvcihlOiBhbnkpIHtcbiAgICAgICAgICBkaWRFcnJvciA9IHRydWU7XG4gICAgICAgICAgY29uc29sZS5lcnJvcihlKTtcbiAgICAgICAgICByZXMuc3RhdHVzQ29kZSA9IDUwMDtcbiAgICAgICAgICAvL3BpcGUocmVzKTsgUmVtb3ZpbmcgdGhpcyBhdm9pZHMsIFwiUmVhY3QgY3VycmVudGx5IG9ubHkgc3VwcG9ydHMgcGlwaW5nIHRvIG9uZSB3cml0YWJsZSBzdHJlYW0uXCJcbiAgICAgICAgICBpZiAob25FcnJvcikgb25FcnJvcihlKTtcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICAgICAgLy8gQWJhbmRvbiBhbmQgc3dpdGNoIHRvIGNsaWVudCByZW5kZXJpbmcgaWYgZW5vdWdoIHRpbWUgcGFzc2VzLlxuICAgICAgLy8gVHJ5IGxvd2VyaW5nIHRoaXMgdG8gc2VlIHRoZSBjbGllbnQgcmVjb3Zlci5cbiAgICAgIHNldFRpbWVvdXQoXG4gICAgICAgICgpID0+IChhYm9ydCBhcyBhbnkpKGBUaW1lb3V0IG9mICR7dGltZW91dE1TfW1zIGV4Y2VlZGVkYCksXG4gICAgICAgIHRpbWVvdXRNUyxcbiAgICAgICk7XG4gICAgfSBjYXRjaCAoZTogdW5rbm93bikge1xuICAgICAgaWYgKG9uRXJyb3IpIG9uRXJyb3IoZSk7XG4gICAgICB0aHJvdyBlO1xuICAgIH1cbiAgfTtcbiAgcmV0dXJuIHJlbmRlcjtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUtlLFNBQVNBLFNBQVQsQ0FDYkMsTUFEYSxFQUliO0VBQ0VDLFNBQVMsR0FBRyxHQURkO0VBRUVDO0FBRkYsSUFHZ0UsRUFQbkQsRUFRYjtFQUNBLE1BQU1DLE1BQWMsR0FBRyxPQUFPQyxjQUFQLEVBQXVCQyxHQUF2QixFQUE0QkMsR0FBNUIsS0FBb0M7SUFDekQsTUFBTUMsS0FBSyxHQUFHQyxlQUFBLENBQU9DLFdBQVAsQ0FBbUIsRUFBbkIsRUFBdUJDLFFBQXZCLENBQWdDLFFBQWhDLENBQWQ7O0lBRUEsSUFBSTtNQUNGLE1BQU07UUFBRUM7TUFBRixJQUFVLE1BQU1YLE1BQU0sQ0FBQztRQUFFSSxjQUFGO1FBQWtCQyxHQUFsQjtRQUF1QkMsR0FBdkI7UUFBNEJDO01BQTVCLENBQUQsQ0FBNUI7TUFFQSxJQUFJSyxRQUFRLEdBQUcsS0FBZjtNQUNBLE1BQU07UUFBRUMsSUFBRjtRQUFRQztNQUFSLElBQWtCLElBQUFDLDhCQUFBLEVBQVlKLEdBQVosRUFBaUI7UUFDdkNKLEtBRHVDOztRQUV2QztRQUNBUyxZQUFZLEdBQUc7VUFDYjtVQUNBO1VBQ0FWLEdBQUcsQ0FBQ1csVUFBSixHQUFpQkwsUUFBUSxHQUFHLEdBQUgsR0FBUyxHQUFsQztVQUNBTixHQUFHLENBQUNZLFNBQUosQ0FBYyxjQUFkLEVBQThCLFdBQTlCO1VBQ0FMLElBQUksQ0FBQ1AsR0FBRCxDQUFKO1FBQ0QsQ0FUc0M7O1FBVXZDYSxZQUFZLEdBQUc7VUFDYlAsUUFBUSxHQUFHLElBQVg7VUFDQU4sR0FBRyxDQUFDVyxVQUFKLEdBQWlCLEdBQWpCO1VBQ0FKLElBQUksQ0FBQ1AsR0FBRCxDQUFKO1FBQ0QsQ0Fkc0M7O1FBZXZDSixPQUFPLENBQUNrQixDQUFELEVBQVM7VUFDZFIsUUFBUSxHQUFHLElBQVg7VUFDQVMsT0FBTyxDQUFDQyxLQUFSLENBQWNGLENBQWQ7VUFDQWQsR0FBRyxDQUFDVyxVQUFKLEdBQWlCLEdBQWpCLENBSGMsQ0FJZDs7VUFDQSxJQUFJZixPQUFKLEVBQWFBLE9BQU8sQ0FBQ2tCLENBQUQsQ0FBUDtRQUNkOztNQXJCc0MsQ0FBakIsQ0FBeEIsQ0FKRSxDQTJCRjtNQUNBOztNQUNBRyxVQUFVLENBQ1IsTUFBT1QsS0FBRCxDQUFnQixjQUFhYixTQUFVLGFBQXZDLENBREUsRUFFUkEsU0FGUSxDQUFWO0lBSUQsQ0FqQ0QsQ0FpQ0UsT0FBT21CLENBQVAsRUFBbUI7TUFDbkIsSUFBSWxCLE9BQUosRUFBYUEsT0FBTyxDQUFDa0IsQ0FBRCxDQUFQO01BQ2IsTUFBTUEsQ0FBTjtJQUNEO0VBQ0YsQ0F4Q0Q7O0VBeUNBLE9BQU9qQixNQUFQO0FBQ0QifQ==
60
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJsYXlTcG91dHMiLCJzcG91dHMiLCJ0aW1lb3V0TVMiLCJvbkVycm9yIiwicmVuZGVyIiwiY2xpZW50TWFuaWZlc3QiLCJyZXEiLCJyZXMiLCJub25jZSIsImNyeXB0byIsInJhbmRvbUJ5dGVzIiwidG9TdHJpbmciLCJhcHAiLCJkaWRFcnJvciIsInBpcGUiLCJhYm9ydCIsInJlYWN0UmVuZGVyIiwib25TaGVsbFJlYWR5Iiwic3RhdHVzQ29kZSIsInNldEhlYWRlciIsIm9uU2hlbGxFcnJvciIsImUiLCJjb25zb2xlIiwiZXJyb3IiLCJzZXRUaW1lb3V0Il0sInNvdXJjZXMiOlsiLi4vc3JjL2xheVNwb3V0cy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVuZGVyVG9QaXBlYWJsZVN0cmVhbSBhcyByZWFjdFJlbmRlciB9IGZyb20gJ3JlYWN0LWRvbS9zZXJ2ZXInO1xuaW1wb3J0IGNyeXB0byBmcm9tICdjcnlwdG8nO1xuXG5pbXBvcnQgeyBSZW5kZXIgfSBmcm9tICcuL3NjcmlwdHMvdHlwZXMnO1xuaW1wb3J0IHsgU2VydmVyUHJvcHMgfSBmcm9tICcuL3Nwb3V0cy90eXBlcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGxheVNwb3V0cyhcbiAgc3BvdXRzOiAocHJvcHM6IFNlcnZlclByb3BzKSA9PiBQcm9taXNlPHtcbiAgICBhcHA6IEpTWC5FbGVtZW50O1xuICB9PixcbiAge1xuICAgIHRpbWVvdXRNUyA9IDIwMCxcbiAgICBvbkVycm9yLFxuICB9OiB7IHRpbWVvdXRNUz86IG51bWJlcjsgb25FcnJvcj86IChlcnJvcjogdW5rbm93bikgPT4gdm9pZCB9ID0ge30sXG4pIHtcbiAgY29uc3QgcmVuZGVyOiBSZW5kZXIgPSBhc3luYyAoY2xpZW50TWFuaWZlc3QsIHJlcSwgcmVzKSA9PiB7XG4gICAgY29uc3Qgbm9uY2UgPSBjcnlwdG8ucmFuZG9tQnl0ZXMoMTYpLnRvU3RyaW5nKCdiYXNlNjQnKTtcblxuICAgIHRyeSB7XG4gICAgICBjb25zdCB7IGFwcCB9ID0gYXdhaXQgc3BvdXRzKHsgY2xpZW50TWFuaWZlc3QsIHJlcSwgcmVzLCBub25jZSB9KTtcblxuICAgICAgbGV0IGRpZEVycm9yID0gZmFsc2U7XG4gICAgICBjb25zdCB7IHBpcGUsIGFib3J0IH0gPSByZWFjdFJlbmRlcihhcHAsIHtcbiAgICAgICAgbm9uY2UsXG4gICAgICAgIC8vYm9vdHN0cmFwU2NyaXB0czogYXNzZXRzLmZpbHRlcihhc3NldCA9PiBhc3NldC5lbmRzV2l0aCgnLmpzJykpLFxuICAgICAgICBvblNoZWxsUmVhZHkoKSB7XG4gICAgICAgICAgLy9tYW5hZ2Vycy5mb3JFYWNoKG1hbmFnZXIgPT4gbWFuYWdlci5jbGVhbnVwKCkpO1xuICAgICAgICAgIC8vIElmIHNvbWV0aGluZyBlcnJvcmVkIGJlZm9yZSB3ZSBzdGFydGVkIHN0cmVhbWluZywgd2Ugc2V0IHRoZSBlcnJvciBjb2RlIGFwcHJvcHJpYXRlbHkuXG4gICAgICAgICAgcmVzLnN0YXR1c0NvZGUgPSBkaWRFcnJvciA/IDUwMCA6IDIwMDtcbiAgICAgICAgICByZXMuc2V0SGVhZGVyKCdDb250ZW50LXR5cGUnLCAndGV4dC9odG1sJyk7XG4gICAgICAgICAgcGlwZShyZXMpO1xuICAgICAgICB9LFxuICAgICAgICBvblNoZWxsRXJyb3IoKSB7XG4gICAgICAgICAgZGlkRXJyb3IgPSB0cnVlO1xuICAgICAgICAgIHJlcy5zdGF0dXNDb2RlID0gNTAwO1xuICAgICAgICAgIHBpcGUocmVzKTtcbiAgICAgICAgfSxcbiAgICAgICAgb25FcnJvcihlOiBhbnkpIHtcbiAgICAgICAgICBkaWRFcnJvciA9IHRydWU7XG4gICAgICAgICAgY29uc29sZS5lcnJvcihlKTtcbiAgICAgICAgICByZXMuc3RhdHVzQ29kZSA9IDUwMDtcbiAgICAgICAgICAvL3BpcGUocmVzKTsgUmVtb3ZpbmcgdGhpcyBhdm9pZHMsIFwiUmVhY3QgY3VycmVudGx5IG9ubHkgc3VwcG9ydHMgcGlwaW5nIHRvIG9uZSB3cml0YWJsZSBzdHJlYW0uXCJcbiAgICAgICAgICBpZiAob25FcnJvcikgb25FcnJvcihlKTtcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICAgICAgLy8gQWJhbmRvbiBhbmQgc3dpdGNoIHRvIGNsaWVudCByZW5kZXJpbmcgaWYgZW5vdWdoIHRpbWUgcGFzc2VzLlxuICAgICAgLy8gVHJ5IGxvd2VyaW5nIHRoaXMgdG8gc2VlIHRoZSBjbGllbnQgcmVjb3Zlci5cbiAgICAgIHNldFRpbWVvdXQoXG4gICAgICAgICgpID0+IChhYm9ydCBhcyBhbnkpKGBUaW1lb3V0IG9mICR7dGltZW91dE1TfW1zIGV4Y2VlZGVkYCksXG4gICAgICAgIHRpbWVvdXRNUyxcbiAgICAgICk7XG4gICAgfSBjYXRjaCAoZTogdW5rbm93bikge1xuICAgICAgaWYgKG9uRXJyb3IpIG9uRXJyb3IoZSk7XG4gICAgICB0aHJvdyBlO1xuICAgIH1cbiAgfTtcbiAgcmV0dXJuIHJlbmRlcjtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQTtBQUNBO0FBS2UsU0FBU0EsU0FBUyxDQUMvQkMsTUFFRSxFQUNGO0VBQ0VDLFNBQVMsR0FBRyxHQUFHO0VBQ2ZDO0FBQzBELENBQUMsR0FBRyxDQUFDLENBQUMsRUFDbEU7RUFDQSxNQUFNQyxNQUFjLEdBQUcsT0FBT0MsY0FBYyxFQUFFQyxHQUFHLEVBQUVDLEdBQUcsS0FBSztJQUN6RCxNQUFNQyxLQUFLLEdBQUdDLGVBQU0sQ0FBQ0MsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDQyxRQUFRLENBQUMsUUFBUSxDQUFDO0lBRXZELElBQUk7TUFDRixNQUFNO1FBQUVDO01BQUksQ0FBQyxHQUFHLE1BQU1YLE1BQU0sQ0FBQztRQUFFSSxjQUFjO1FBQUVDLEdBQUc7UUFBRUMsR0FBRztRQUFFQztNQUFNLENBQUMsQ0FBQztNQUVqRSxJQUFJSyxRQUFRLEdBQUcsS0FBSztNQUNwQixNQUFNO1FBQUVDLElBQUk7UUFBRUM7TUFBTSxDQUFDLEdBQUcsSUFBQUMsOEJBQVcsRUFBQ0osR0FBRyxFQUFFO1FBQ3ZDSixLQUFLO1FBQ0w7UUFDQVMsWUFBWSxHQUFHO1VBQ2I7VUFDQTtVQUNBVixHQUFHLENBQUNXLFVBQVUsR0FBR0wsUUFBUSxHQUFHLEdBQUcsR0FBRyxHQUFHO1VBQ3JDTixHQUFHLENBQUNZLFNBQVMsQ0FBQyxjQUFjLEVBQUUsV0FBVyxDQUFDO1VBQzFDTCxJQUFJLENBQUNQLEdBQUcsQ0FBQztRQUNYLENBQUM7UUFDRGEsWUFBWSxHQUFHO1VBQ2JQLFFBQVEsR0FBRyxJQUFJO1VBQ2ZOLEdBQUcsQ0FBQ1csVUFBVSxHQUFHLEdBQUc7VUFDcEJKLElBQUksQ0FBQ1AsR0FBRyxDQUFDO1FBQ1gsQ0FBQztRQUNESixPQUFPLENBQUNrQixDQUFNLEVBQUU7VUFDZFIsUUFBUSxHQUFHLElBQUk7VUFDZlMsT0FBTyxDQUFDQyxLQUFLLENBQUNGLENBQUMsQ0FBQztVQUNoQmQsR0FBRyxDQUFDVyxVQUFVLEdBQUcsR0FBRztVQUNwQjtVQUNBLElBQUlmLE9BQU8sRUFBRUEsT0FBTyxDQUFDa0IsQ0FBQyxDQUFDO1FBQ3pCO01BQ0YsQ0FBQyxDQUFDO01BQ0Y7TUFDQTtNQUNBRyxVQUFVLENBQ1IsTUFBT1QsS0FBSyxDQUFVLGNBQWFiLFNBQVUsYUFBWSxDQUFDLEVBQzFEQSxTQUFTLENBQ1Y7SUFDSCxDQUFDLENBQUMsT0FBT21CLENBQVUsRUFBRTtNQUNuQixJQUFJbEIsT0FBTyxFQUFFQSxPQUFPLENBQUNrQixDQUFDLENBQUM7TUFDdkIsTUFBTUEsQ0FBQztJQUNUO0VBQ0YsQ0FBQztFQUNELE9BQU9qQixNQUFNO0FBQ2YifQ==
@@ -2,34 +2,29 @@
2
2
 
3
3
  exports.__esModule = true;
4
4
  exports.default = getProxyMiddlewares;
5
-
6
5
  // Essentially taken from https://github.com/webpack/webpack-dev-server/blob/b5e5b67398f97c7a2934e12ebe34fb03cc06c473/lib/Server.js#L2123
7
6
  function getProxyMiddlewares(proxyConfig) {
8
- const middlewares = []; // eslint-disable-next-line @typescript-eslint/no-var-requires
9
-
7
+ const middlewares = [];
8
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
10
9
  const {
11
10
  createProxyMiddleware
12
11
  } = require('http-proxy-middleware');
13
-
14
12
  const proxy = !Array.isArray(proxyConfig) && typeof proxyConfig === 'object' ? Object.keys(proxyConfig).length && Object.keys(proxyConfig)[0].startsWith('/') ? Object.entries(proxyConfig).map(([path, v]) => ({
15
13
  path,
16
14
  ...v
17
15
  })) : [proxyConfig] : proxyConfig;
18
-
19
16
  const getProxyMiddleware = proxyConfig => {
20
17
  // It is possible to use the `bypass` method without a `target` or `router`.
21
18
  // However, the proxy middleware has no use in this case, and will fail to instantiate.
22
19
  if (proxyConfig.target) {
23
20
  const context = proxyConfig.context || proxyConfig.path;
24
- return createProxyMiddleware(
25
- /** @type {string} */
26
- context, proxyConfig);
21
+ return createProxyMiddleware( /** @type {string} */context, proxyConfig);
27
22
  }
28
-
29
23
  if (proxyConfig.router) {
30
24
  return createProxyMiddleware(proxyConfig);
31
25
  }
32
26
  };
27
+
33
28
  /**
34
29
  * Assume a proxy configuration specified as:
35
30
  * proxy: [
@@ -46,12 +41,11 @@ function getProxyMiddlewares(proxyConfig) {
46
41
  * }
47
42
  * ]
48
43
  */
49
-
50
-
51
44
  proxy.forEach(proxyConfigOrCallback => {
52
45
  let proxyMiddleware;
53
46
  let proxyConfig = typeof proxyConfigOrCallback === 'function' ? proxyConfigOrCallback() : proxyConfigOrCallback;
54
47
  proxyMiddleware = getProxyMiddleware(proxyConfig);
48
+
55
49
  /* TODO: figure out how to make this work
56
50
  if (proxyConfig.ws) {
57
51
  this.webSocketProxies.push(proxyMiddleware);
@@ -61,19 +55,17 @@ function getProxyMiddlewares(proxyConfig) {
61
55
  const handler = async (req, res, next) => {
62
56
  if (typeof proxyConfigOrCallback === 'function') {
63
57
  const newProxyConfig = proxyConfigOrCallback(req, res, next);
64
-
65
58
  if (newProxyConfig !== proxyConfig) {
66
59
  proxyConfig = newProxyConfig;
67
60
  proxyMiddleware = getProxyMiddleware(proxyConfig);
68
61
  }
69
- } // - Check if we have a bypass function defined
62
+ }
63
+
64
+ // - Check if we have a bypass function defined
70
65
  // - In case the bypass function is defined we'll retrieve the
71
66
  // bypassUrl from it otherwise bypassUrl would be null
72
67
  // TODO remove in the next major in favor `context` and `router` options
73
-
74
-
75
68
  const bypassUrl = typeof proxyConfig.bypass === 'function' ? await proxyConfig.bypass(req, res, proxyConfig) : null;
76
-
77
69
  if (typeof bypassUrl === 'boolean') {
78
70
  // skip the proxy
79
71
  // eslint-disable-next-line @typescript-eslint/ban-ts-comment
@@ -90,12 +82,11 @@ function getProxyMiddlewares(proxyConfig) {
90
82
  next();
91
83
  }
92
84
  };
93
-
94
85
  middlewares.push({
95
86
  name: 'http-proxy-middleware',
96
87
  middleware: handler
97
- }); // Also forward error requests to the proxy so it can handle them.
98
-
88
+ });
89
+ // Also forward error requests to the proxy so it can handle them.
99
90
  middlewares.push({
100
91
  name: 'http-proxy-middleware-error-handler',
101
92
  middleware: (error, req, res, next) => handler(req, res, next)
@@ -103,4 +94,4 @@ function getProxyMiddlewares(proxyConfig) {
103
94
  });
104
95
  return middlewares;
105
96
  }
106
- //# 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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"}
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":"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"}
@@ -1,15 +1,10 @@
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.serve = exports.devServe = void 0;
7
-
8
6
  var _serve = _interopRequireDefault(require("./serve"));
9
-
10
7
  exports.serve = _serve.default;
11
-
12
8
  var _startDevserver = _interopRequireDefault(require("./startDevserver"));
13
-
14
9
  exports.devServe = _startDevserver.default;
15
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmlwdHMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgZGVmYXVsdCBhcyBzZXJ2ZSB9IGZyb20gJy4vc2VydmUnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBkZXZTZXJ2ZSB9IGZyb20gJy4vc3RhcnREZXZzZXJ2ZXInO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7QUFDQSJ9
10
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmlwdHMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgZGVmYXVsdCBhcyBzZXJ2ZSB9IGZyb20gJy4vc2VydmUnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBkZXZTZXJ2ZSB9IGZyb20gJy4vc3RhcnREZXZzZXJ2ZXInO1xuIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBO0FBQTJDO0FBQzNDO0FBQXVEIn0=
@@ -2,51 +2,36 @@
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 = serve;
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 _express = _interopRequireDefault(require("express"));
16
-
17
11
  var _ora = _interopRequireDefault(require("ora"));
18
-
19
12
  var _compression = _interopRequireDefault(require("compression"));
20
-
21
13
  require("cross-fetch/polyfill");
22
-
23
14
  var _getProxyMiddlewares = _interopRequireDefault(require("./getProxyMiddlewares"));
24
-
25
15
  // run directly from node
26
16
  if (require.main === module) {
27
17
  const entrypoint = process.argv[2];
28
-
29
18
  if (!entrypoint) {
30
19
  console.log(`Usage: ${process.argv[0]} <server-entrypoint>`);
31
20
  process.exit(-1);
32
21
  }
33
-
34
22
  serve(entrypoint);
35
23
  }
36
-
37
24
  function serve(entrypoint, options = {}) {
38
25
  const PORT = process.env.PORT || 8080;
39
26
  const loader = (0, _ora.default)('Initializing').start();
40
-
41
- const webpackConfig = require(require.resolve( // TODO: use normal resolution algorithm to find webpack file
27
+ const webpackConfig = require(require.resolve(
28
+ // TODO: use normal resolution algorithm to find webpack file
42
29
  _path.default.join(process.cwd(), 'webpack.config')));
43
-
44
30
  const manifestPath = getManifestPathFromWebpackconfig(webpackConfig({}, {
45
31
  mode: 'production'
46
32
  }));
47
33
  const readFile = (0, _util.promisify)(_fs.default.readFile);
48
34
  let server;
49
-
50
35
  function handleErrors(fn) {
51
36
  return async function (req, res, next) {
52
37
  try {
@@ -55,31 +40,27 @@ function serve(entrypoint, options = {}) {
55
40
  next(x);
56
41
  }
57
42
  };
58
- } // Start the express server after the first compilation
59
-
43
+ }
60
44
 
45
+ // Start the express server after the first compilation
61
46
  function initializeApp(clientManifest) {
62
47
  loader.info('Launching server');
63
-
64
48
  if (!clientManifest) {
65
- loader.fail('Manifest not found'); // TODO: handle more gracefully
66
-
49
+ loader.fail('Manifest not found');
50
+ // TODO: handle more gracefully
67
51
  process.exit(-1);
68
52
  }
69
-
70
- const wrappingApp = (0, _express.default)(); // eslint-disable-next-line
53
+ const wrappingApp = (0, _express.default)();
54
+ // eslint-disable-next-line
71
55
  //@ts-ignore
56
+ wrappingApp.use((0, _compression.default)());
72
57
 
73
- wrappingApp.use((0, _compression.default)()); // ASSETS
74
-
58
+ // ASSETS
75
59
  if (options.serveAssets) {
76
60
  wrappingApp.use(async (req, res, next) => {
77
61
  var _req$url$substr, _req$url, _clientManifest$outpu;
78
-
79
62
  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 : '';
80
-
81
63
  const assetPath = _path.default.join((_clientManifest$outpu = clientManifest.outputPath) != null ? _clientManifest$outpu : '', filename);
82
-
83
64
  if (_fs.default.existsSync(assetPath) && !_fs.default.lstatSync(assetPath).isDirectory()) {
84
65
  try {
85
66
  const fileContent = (await readFile(assetPath)).toString();
@@ -92,33 +73,28 @@ function serve(entrypoint, options = {}) {
92
73
  next();
93
74
  }
94
75
  });
95
- } // PROXIES
96
-
76
+ }
97
77
 
78
+ // PROXIES
98
79
  if (options.serveProxy) {
99
80
  var _devConfig$devServer;
100
-
101
81
  const devConfig = webpackConfig({}, {
102
82
  mode: 'development'
103
83
  });
104
-
105
84
  if ((_devConfig$devServer = devConfig.devServer) != null && _devConfig$devServer.proxy) {
106
85
  var _devConfig$devServer2;
107
-
108
86
  const middlewares = (0, _getProxyMiddlewares.default)((_devConfig$devServer2 = devConfig.devServer) == null ? void 0 : _devConfig$devServer2.proxy);
109
-
110
87
  if (middlewares) {
111
88
  wrappingApp.use(...middlewares.map(({
112
89
  middleware
113
90
  }) => middleware));
114
91
  }
115
92
  }
116
- } // SERVER SIDE RENDERING
117
- // eslint-disable-next-line @typescript-eslint/no-var-requires
118
-
93
+ }
119
94
 
95
+ // SERVER SIDE RENDERING
96
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
120
97
  const render = require(_path.default.join(process.cwd(), entrypoint)).default;
121
-
122
98
  wrappingApp.get('/*', handleErrors(async function (req, res) {
123
99
  if (req.url.endsWith('favicon.ico')) {
124
100
  res.statusCode = 404;
@@ -126,7 +102,6 @@ function serve(entrypoint, options = {}) {
126
102
  res.send('not found');
127
103
  return;
128
104
  }
129
-
130
105
  res.socket.on('error', error => {
131
106
  console.error('Fatal', error);
132
107
  });
@@ -138,33 +113,27 @@ function serve(entrypoint, options = {}) {
138
113
  if (error.syscall !== 'listen') {
139
114
  throw error;
140
115
  }
141
-
142
116
  const isPipe = portOrPipe => Number.isNaN(portOrPipe);
143
-
144
117
  const bind = isPipe(PORT) ? 'Pipe ' + PORT : 'Port ' + PORT;
145
-
146
118
  switch (error.code) {
147
119
  case 'EACCES':
148
120
  loader.fail(bind + ' requires elevated privileges');
149
121
  process.exit(1);
150
122
  // eslint-disable-next-line no-fallthrough
151
-
152
123
  case 'EADDRINUSE':
153
124
  loader.fail(bind + ' is already in use');
154
125
  process.exit(1);
155
126
  // eslint-disable-next-line no-fallthrough
156
-
157
127
  default:
158
128
  throw error;
159
129
  }
160
130
  });
161
- } // eslint-disable-next-line @typescript-eslint/no-var-requires
162
-
131
+ }
163
132
 
133
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
164
134
  initializeApp(require(manifestPath));
165
135
  process.on('SIGINT', () => {
166
136
  var _server;
167
-
168
137
  loader.warn('Received SIGINT, devserver shutting down');
169
138
  if (server) console.log('Closing server');
170
139
  (_server = server) == null ? void 0 : _server.close(() => {
@@ -173,16 +142,12 @@ function serve(entrypoint, options = {}) {
173
142
  process.exit(-1);
174
143
  });
175
144
  }
176
-
177
145
  function getManifestPathFromWebpackconfig(webpackConfig) {
178
146
  var _opts$filename, _webpackConfig$plugin, _webpackConfig$plugin2, _webpackConfig$plugin3, _webpackConfig$output, _webpackConfig$output2;
179
-
180
147
  const manifestFilename = (_opts$filename = webpackConfig == null ? void 0 : (_webpackConfig$plugin = webpackConfig.plugins) == null ? void 0 : (_webpackConfig$plugin2 = _webpackConfig$plugin.find(plugin => {
181
148
  return plugin.constructor.name === 'StatsWriterPlugin';
182
149
  })) == null ? void 0 : (_webpackConfig$plugin3 = _webpackConfig$plugin2.opts) == null ? void 0 : _webpackConfig$plugin3.filename) != null ? _opts$filename : 'manifest.json';
183
-
184
150
  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);
185
-
186
151
  return manifestPath;
187
152
  }
188
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["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\n\nimport { promisify } from 'util';\nimport diskFs from 'fs';\nimport path from 'path';\nimport webpack, { web } from 'webpack';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport express, { NextFunction } from 'express';\nimport ora from 'ora';\nimport compress from 'compression';\n\nimport 'cross-fetch/polyfill';\nimport { Render } from './types';\nimport getProxyMiddlewares from './getProxyMiddlewares';\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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"}
153
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["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\n\nimport { promisify } from 'util';\nimport diskFs from 'fs';\nimport path from 'path';\nimport webpack, { web } from 'webpack';\nimport { Server, IncomingMessage, ServerResponse } from 'http';\nimport express, { NextFunction } from 'express';\nimport ora from 'ora';\nimport compress from 'compression';\n\nimport 'cross-fetch/polyfill';\nimport { Render } from './types';\nimport getProxyMiddlewares from './getProxyMiddlewares';\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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"}