@modern-js/server 2.6.1-alpha.0 → 2.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/CHANGELOG.md +45 -0
  2. package/README.md +2 -2
  3. package/dist/cjs/server/devServer.js +1 -1
  4. package/dist/esm/server/devServer.js +1 -1
  5. package/dist/esm-node/server/devServer.js +1 -1
  6. package/package.json +12 -12
  7. package/dist/js/modern/constants.js +0 -19
  8. package/dist/js/modern/dev-tools/dev-middleware/hmr-client/createSocketUrl.js +0 -41
  9. package/dist/js/modern/dev-tools/dev-middleware/hmr-client/index.js +0 -146
  10. package/dist/js/modern/dev-tools/dev-middleware/index.js +0 -94
  11. package/dist/js/modern/dev-tools/dev-middleware/socket-server.js +0 -132
  12. package/dist/js/modern/dev-tools/https/index.js +0 -49
  13. package/dist/js/modern/dev-tools/mock/getMockData.js +0 -105
  14. package/dist/js/modern/dev-tools/mock/index.js +0 -70
  15. package/dist/js/modern/dev-tools/register/index.js +0 -112
  16. package/dist/js/modern/dev-tools/watcher/dependency-tree.js +0 -59
  17. package/dist/js/modern/dev-tools/watcher/index.js +0 -106
  18. package/dist/js/modern/dev-tools/watcher/stats-cache.js +0 -58
  19. package/dist/js/modern/index.js +0 -12
  20. package/dist/js/modern/server/dev-server.js +0 -294
  21. package/dist/js/modern/server/index.js +0 -16
  22. package/dist/js/modern/types.js +0 -0
  23. package/dist/js/node/constants.js +0 -42
  24. package/dist/js/node/dev-tools/dev-middleware/hmr-client/createSocketUrl.js +0 -65
  25. package/dist/js/node/dev-tools/dev-middleware/hmr-client/index.js +0 -155
  26. package/dist/js/node/dev-tools/dev-middleware/index.js +0 -119
  27. package/dist/js/node/dev-tools/dev-middleware/socket-server.js +0 -159
  28. package/dist/js/node/dev-tools/https/index.js +0 -72
  29. package/dist/js/node/dev-tools/mock/getMockData.js +0 -126
  30. package/dist/js/node/dev-tools/mock/index.js +0 -99
  31. package/dist/js/node/dev-tools/register/index.js +0 -139
  32. package/dist/js/node/dev-tools/watcher/dependency-tree.js +0 -89
  33. package/dist/js/node/dev-tools/watcher/index.js +0 -135
  34. package/dist/js/node/dev-tools/watcher/stats-cache.js +0 -87
  35. package/dist/js/node/index.js +0 -35
  36. package/dist/js/node/server/dev-server.js +0 -311
  37. package/dist/js/node/server/index.js +0 -39
  38. package/dist/js/node/types.js +0 -15
  39. package/dist/js/treeshaking/constants.js +0 -21
  40. package/dist/js/treeshaking/dev-tools/dev-middleware/hmr-client/createSocketUrl.js +0 -51
  41. package/dist/js/treeshaking/dev-tools/dev-middleware/hmr-client/index.js +0 -162
  42. package/dist/js/treeshaking/dev-tools/dev-middleware/index.js +0 -322
  43. package/dist/js/treeshaking/dev-tools/dev-middleware/socket-server.js +0 -209
  44. package/dist/js/treeshaking/dev-tools/https/index.js +0 -193
  45. package/dist/js/treeshaking/dev-tools/mock/getMockData.js +0 -318
  46. package/dist/js/treeshaking/dev-tools/mock/index.js +0 -207
  47. package/dist/js/treeshaking/dev-tools/register/index.js +0 -154
  48. package/dist/js/treeshaking/dev-tools/watcher/dependency-tree.js +0 -150
  49. package/dist/js/treeshaking/dev-tools/watcher/index.js +0 -200
  50. package/dist/js/treeshaking/dev-tools/watcher/stats-cache.js +0 -128
  51. package/dist/js/treeshaking/index.js +0 -9
  52. package/dist/js/treeshaking/server/dev-server.js +0 -800
  53. package/dist/js/treeshaking/server/index.js +0 -92
  54. package/dist/js/treeshaking/types.js +0 -1
@@ -1,105 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __async = (__this, __arguments, generator) => {
21
- return new Promise((resolve, reject) => {
22
- var fulfilled = (value) => {
23
- try {
24
- step(generator.next(value));
25
- } catch (e) {
26
- reject(e);
27
- }
28
- };
29
- var rejected = (value) => {
30
- try {
31
- step(generator.throw(value));
32
- } catch (e) {
33
- reject(e);
34
- }
35
- };
36
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
37
- step((generator = generator.apply(__this, __arguments)).next());
38
- });
39
- };
40
- import { match } from "path-to-regexp";
41
- const VALID_METHODS = ["get", "post", "put", "delete", "patch"];
42
- const BODY_PARSED_METHODS = ["post", "put", "delete", "patch"];
43
- const createFunctionDataHandler = (method, handler) => (context, next) => __async(void 0, null, function* () {
44
- const { req, res } = context;
45
- return handler(req, res, next);
46
- });
47
- const createStaticDataHandler = (method, handler) => (context) => {
48
- const { res } = context;
49
- res.setHeader("Content-Type", "application/json");
50
- res.end(JSON.stringify(handler));
51
- };
52
- const allowTypes = ["object", "function"];
53
- var getMockData_default = (mockConfig) => Object.keys(mockConfig).reduce((acc, key) => {
54
- const handler = mockConfig[key];
55
- const type = typeof handler;
56
- if (!allowTypes.includes(type)) {
57
- throw new Error(
58
- `mock value of ${key} should be object or function, but got ${type}`
59
- );
60
- }
61
- const meta = parseKey(key);
62
- if (type === "object") {
63
- acc.push(__spreadProps(__spreadValues({}, meta), {
64
- handler: createStaticDataHandler(meta.method, handler)
65
- }));
66
- } else {
67
- acc.push(__spreadProps(__spreadValues({}, meta), {
68
- handler: createFunctionDataHandler(meta.method, handler)
69
- }));
70
- }
71
- return acc;
72
- }, []);
73
- const _blank = " ";
74
- const parseKey = (key) => {
75
- const splitted = key.split(_blank).filter(Boolean);
76
- if (splitted.length > 1) {
77
- const [method, pathname] = splitted;
78
- return {
79
- method: method.toLowerCase(),
80
- path: pathname
81
- };
82
- }
83
- return {
84
- method: "get",
85
- path: key
86
- };
87
- };
88
- const getMatched = (context, mockApiList) => {
89
- const { path: targetPathname, method: targetMethod } = context;
90
- const matched = mockApiList.find((mockApi) => {
91
- const { method, path: pathname } = mockApi;
92
- if (method.toLowerCase() === targetMethod.toLowerCase()) {
93
- return match(pathname, {
94
- encode: encodeURI,
95
- decode: decodeURIComponent
96
- })(targetPathname);
97
- }
98
- return false;
99
- });
100
- return matched;
101
- };
102
- export {
103
- getMockData_default as default,
104
- getMatched
105
- };
@@ -1,70 +0,0 @@
1
- var __async = (__this, __arguments, generator) => {
2
- return new Promise((resolve, reject) => {
3
- var fulfilled = (value) => {
4
- try {
5
- step(generator.next(value));
6
- } catch (e) {
7
- reject(e);
8
- }
9
- };
10
- var rejected = (value) => {
11
- try {
12
- step(generator.throw(value));
13
- } catch (e) {
14
- reject(e);
15
- }
16
- };
17
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
18
- step((generator = generator.apply(__this, __arguments)).next());
19
- });
20
- };
21
- import path from "path";
22
- import { compatRequire, fs } from "@modern-js/utils";
23
- import { AGGRED_DIR } from "@modern-js/prod-server";
24
- import getMockData, { getMatched } from "./getMockData";
25
- const createMockHandler = ({ pwd }) => {
26
- const exts = [".ts", ".js"];
27
- let filepath = "";
28
- for (const ext of exts) {
29
- const maybeMatch = path.join(pwd, `${AGGRED_DIR.mock}/index${ext}`);
30
- if (fs.existsSync(maybeMatch)) {
31
- filepath = maybeMatch;
32
- break;
33
- }
34
- }
35
- if (!filepath) {
36
- return null;
37
- }
38
- const {
39
- default: mockModule,
40
- config
41
- } = compatRequire(filepath, false);
42
- if ((config == null ? void 0 : config.enable) === false) {
43
- return null;
44
- }
45
- if (!mockModule) {
46
- throw new Error(`Mock file ${filepath} parsed failed!`);
47
- }
48
- const apiList = getMockData(mockModule);
49
- if (!apiList || apiList.length === 0) {
50
- return null;
51
- }
52
- return (context, next) => __async(void 0, null, function* () {
53
- if (typeof (config == null ? void 0 : config.enable) === "function") {
54
- const enableMock = config.enable(context.req, context.res);
55
- if (!enableMock) {
56
- return next();
57
- }
58
- }
59
- const { res } = context;
60
- const matched = getMatched(context, apiList);
61
- if (!matched) {
62
- return next();
63
- }
64
- res.setHeader("Access-Control-Allow-Origin", "*");
65
- return matched.handler(context, next);
66
- });
67
- };
68
- export {
69
- createMockHandler
70
- };
@@ -1,112 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- import path from "path";
21
- import { resolveBabelConfig } from "@modern-js/server-utils";
22
- import { fs, getAliasConfig, createDebugger } from "@modern-js/utils";
23
- const debug = createDebugger("server");
24
- const checkDep = (depName, paths) => {
25
- let packagePath = "";
26
- try {
27
- packagePath = require.resolve(depName, {
28
- paths
29
- });
30
- } catch (error) {
31
- }
32
- return Boolean(packagePath);
33
- };
34
- const enableRegister = (projectRoot, config) => {
35
- var _a, _b, _c;
36
- const registerDirs = ["./api", "./server", "./config/mock", "./shared"];
37
- const TS_CONFIG_FILENAME = `tsconfig.json`;
38
- const tsconfigPath = path.resolve(projectRoot, TS_CONFIG_FILENAME);
39
- const isTsProject = fs.existsSync(tsconfigPath);
40
- const existTsNode = checkDep("ts-node", [projectRoot]);
41
- const existTsConfigPaths = checkDep("tsconfig-paths", [projectRoot]);
42
- if (isTsProject && existTsNode && existTsConfigPaths) {
43
- debug("use ts-node");
44
- const distPath = ((_a = config.output.distPath) == null ? void 0 : _a.root) || "dist";
45
- const tsNode = require("ts-node");
46
- const tsConfigPaths = require("tsconfig-paths");
47
- const { alias } = config.source;
48
- const aliasConfig = getAliasConfig(alias, {
49
- appDirectory: projectRoot,
50
- tsconfigPath
51
- });
52
- const { paths = {}, absoluteBaseUrl = "./" } = aliasConfig;
53
- const tsPaths = Object.keys(paths).reduce((o, key) => {
54
- let tsPath = paths[key];
55
- if (typeof tsPath === "string" && path.isAbsolute(tsPath)) {
56
- tsPath = path.relative(absoluteBaseUrl, tsPath);
57
- }
58
- if (typeof tsPath === "string") {
59
- tsPath = [tsPath];
60
- }
61
- return __spreadProps(__spreadValues({}, o), {
62
- [`${key}`]: tsPath
63
- });
64
- }, {});
65
- tsConfigPaths.register({
66
- baseUrl: absoluteBaseUrl || "./",
67
- paths: tsPaths
68
- });
69
- tsNode.register({
70
- project: tsconfigPath,
71
- scope: true,
72
- files: true,
73
- transpileOnly: true,
74
- ignore: ["(?:^|/)node_modules/", `(?:^|/)${distPath}/`]
75
- });
76
- } else {
77
- debug("use @babel/register");
78
- const babelConfig = resolveBabelConfig(
79
- projectRoot,
80
- __spreadProps(__spreadValues({}, config.source), {
81
- babelConfig: (_b = config.tools) == null ? void 0 : _b.babel,
82
- server: {
83
- compiler: (_c = config.server) == null ? void 0 : _c.compiler
84
- }
85
- }),
86
- {
87
- tsconfigPath,
88
- syntax: "es6+",
89
- type: "commonjs"
90
- }
91
- );
92
- return require("@babel/register")(__spreadProps(__spreadValues({}, babelConfig), {
93
- only: [
94
- function(filePath) {
95
- if (filePath.includes(`node_modules${path.sep}.modern-js`)) {
96
- return true;
97
- }
98
- return registerDirs.some(
99
- (registerDir) => filePath.startsWith(path.join(projectRoot, registerDir))
100
- );
101
- }
102
- ],
103
- extensions: [".js", ".ts"],
104
- babelrc: false,
105
- configFile: false,
106
- root: projectRoot
107
- }));
108
- }
109
- };
110
- export {
111
- enableRegister
112
- };
@@ -1,59 +0,0 @@
1
- import minimatch from "minimatch";
2
- const defaultIgnores = [
3
- "**/bower_components/**",
4
- "**/coverage/**",
5
- "**/node_modules/**",
6
- "**/.*/**",
7
- "**/*.d.ts",
8
- "**/*.log"
9
- ];
10
- class DependencyTree {
11
- constructor() {
12
- this.tree = /* @__PURE__ */ new Map();
13
- this.ignore = [...defaultIgnores];
14
- }
15
- getNode(path) {
16
- return this.tree.get(path);
17
- }
18
- update(cache) {
19
- this.tree.clear();
20
- Object.keys(cache).forEach((path) => {
21
- if (!this.shouldIgnore(path)) {
22
- const module = cache[path];
23
- this.tree.set(module.filename, {
24
- module,
25
- parent: /* @__PURE__ */ new Set(),
26
- children: /* @__PURE__ */ new Set()
27
- });
28
- }
29
- });
30
- for (const treeNode of this.tree.values()) {
31
- const { parent } = treeNode.module;
32
- const { children } = treeNode.module;
33
- if (parent && !this.shouldIgnore(parent.filename)) {
34
- const parentTreeNode = this.tree.get(parent.filename);
35
- if (parentTreeNode) {
36
- treeNode.parent.add(parentTreeNode);
37
- }
38
- }
39
- children.forEach((child) => {
40
- if (!this.shouldIgnore(child.filename)) {
41
- const childTreeNode = this.tree.get(child.filename);
42
- if (childTreeNode) {
43
- treeNode.children.add(childTreeNode);
44
- childTreeNode.parent.add(treeNode);
45
- }
46
- }
47
- });
48
- }
49
- }
50
- shouldIgnore(path) {
51
- return !path || Boolean(
52
- this.ignore.find((rule) => minimatch.match([path], rule).length > 0)
53
- );
54
- }
55
- }
56
- export {
57
- DependencyTree,
58
- defaultIgnores
59
- };
@@ -1,106 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
3
- var __hasOwnProp = Object.prototype.hasOwnProperty;
4
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
5
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
- var __spreadValues = (a, b) => {
7
- for (var prop in b || (b = {}))
8
- if (__hasOwnProp.call(b, prop))
9
- __defNormalProp(a, prop, b[prop]);
10
- if (__getOwnPropSymbols)
11
- for (var prop of __getOwnPropSymbols(b)) {
12
- if (__propIsEnum.call(b, prop))
13
- __defNormalProp(a, prop, b[prop]);
14
- }
15
- return a;
16
- };
17
- import path from "path";
18
- import { fs, chokidar } from "@modern-js/utils";
19
- import { DependencyTree } from "./dependency-tree";
20
- import { StatsCache } from "./stats-cache";
21
- const defaultWatchOptions = {
22
- ignoreInitial: true,
23
- ignored: /api\/typings\/.*/
24
- };
25
- const getWatchedFiles = (watcher) => {
26
- const watched = watcher.getWatched();
27
- const files = [];
28
- Object.keys(watched).forEach((dir) => {
29
- watched[dir].forEach((fileName) => {
30
- files.push(path.join(dir, fileName));
31
- });
32
- });
33
- return files;
34
- };
35
- const mergeWatchOptions = (options) => {
36
- const watchOptions = __spreadValues({}, options);
37
- if (watchOptions) {
38
- const { ignored } = watchOptions;
39
- const finalIgnored = ignored ? [
40
- defaultWatchOptions.ignored,
41
- ...Array.isArray(ignored) ? ignored : [ignored]
42
- ] : ignored;
43
- if (finalIgnored) {
44
- watchOptions.ignored = finalIgnored;
45
- }
46
- }
47
- const finalWatchOptions = __spreadValues(__spreadValues({}, defaultWatchOptions), watchOptions);
48
- return finalWatchOptions;
49
- };
50
- class Watcher {
51
- constructor() {
52
- this.dependencyTree = null;
53
- }
54
- listen(files, options, callback) {
55
- const watched = files.filter(Boolean);
56
- const filenames = watched.map((filename) => filename.replace(/\\/g, "/"));
57
- const cache = new StatsCache();
58
- const watcher = chokidar.watch(filenames, options);
59
- watcher.on("ready", () => {
60
- cache.add(getWatchedFiles(watcher));
61
- });
62
- watcher.on("change", (changed) => {
63
- if (!fs.existsSync(changed) || cache.isDiff(changed)) {
64
- cache.refresh(changed);
65
- callback(changed, "change");
66
- }
67
- });
68
- watcher.on("add", (changed) => {
69
- if (!cache.has(changed)) {
70
- cache.add([changed]);
71
- callback(changed, "add");
72
- }
73
- });
74
- watcher.on("unlink", (changed) => {
75
- cache.del(changed);
76
- callback(changed, "unlink");
77
- });
78
- this.watcher = watcher;
79
- }
80
- createDepTree() {
81
- this.dependencyTree = new DependencyTree();
82
- }
83
- updateDepTree() {
84
- var _a;
85
- (_a = this.dependencyTree) == null ? void 0 : _a.update(require.cache);
86
- }
87
- cleanDepCache(filepath) {
88
- var _a;
89
- const node = (_a = this.dependencyTree) == null ? void 0 : _a.getNode(filepath);
90
- if (node && require.cache[filepath]) {
91
- delete require.cache[filepath];
92
- for (const parentNode of node.parent.values()) {
93
- this.cleanDepCache(parentNode.module.filename);
94
- }
95
- }
96
- }
97
- close() {
98
- return this.watcher.close();
99
- }
100
- }
101
- export {
102
- Watcher as default,
103
- defaultWatchOptions,
104
- getWatchedFiles,
105
- mergeWatchOptions
106
- };
@@ -1,58 +0,0 @@
1
- import fs from "fs";
2
- import crypto from "crypto";
3
- class StatsCache {
4
- constructor() {
5
- this.cachedHash = {};
6
- this.cachedSize = {};
7
- }
8
- add(files) {
9
- const { cachedHash, cachedSize } = this;
10
- for (const filename of files) {
11
- if (fs.existsSync(filename)) {
12
- const stats = fs.statSync(filename);
13
- if (stats.isFile() && !cachedHash[filename]) {
14
- cachedHash[filename] = this.hash(stats, filename);
15
- cachedSize[filename] = stats.size;
16
- }
17
- }
18
- }
19
- }
20
- refresh(filename) {
21
- const { cachedHash, cachedSize } = this;
22
- if (fs.existsSync(filename)) {
23
- const stats = fs.statSync(filename);
24
- if (stats.isFile()) {
25
- cachedHash[filename] = this.hash(stats, filename);
26
- cachedSize[filename] = stats.size;
27
- }
28
- }
29
- }
30
- del(filename) {
31
- if (this.cachedHash[filename]) {
32
- delete this.cachedHash[filename];
33
- delete this.cachedSize[filename];
34
- }
35
- }
36
- isDiff(filename) {
37
- const { cachedHash, cachedSize } = this;
38
- const stats = fs.statSync(filename);
39
- const hash = cachedHash[filename];
40
- const size = cachedSize[filename];
41
- if (stats.size !== size) {
42
- return true;
43
- }
44
- if (this.hash(stats, filename) !== hash) {
45
- return true;
46
- }
47
- return false;
48
- }
49
- has(filename) {
50
- return Boolean(this.cachedHash[filename]);
51
- }
52
- hash(stats, filename) {
53
- return crypto.createHash("md5").update(fs.readFileSync(filename)).digest("hex");
54
- }
55
- }
56
- export {
57
- StatsCache
58
- };
@@ -1,12 +0,0 @@
1
- import { DevServer as Server } from "./server";
2
- var src_default = (options) => {
3
- if (options == null) {
4
- throw new Error("can not start server without options");
5
- }
6
- const server = new Server(options);
7
- return server.init();
8
- };
9
- export {
10
- Server,
11
- src_default as default
12
- };