@vercel/microfrontends 0.9.0 → 0.10.1

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 (90) hide show
  1. package/README.md +7 -7
  2. package/dist/bin/cli.cjs +1604 -221
  3. package/dist/config/client.d.ts +1 -1
  4. package/dist/config/edge.cjs +47 -47
  5. package/dist/config/edge.cjs.map +1 -1
  6. package/dist/config/edge.d.ts +6 -6
  7. package/dist/config/edge.js +46 -46
  8. package/dist/config/edge.js.map +1 -1
  9. package/dist/config.cjs +67 -66
  10. package/dist/config.cjs.map +1 -1
  11. package/dist/config.d.ts +4 -4
  12. package/dist/config.js +66 -65
  13. package/dist/config.js.map +1 -1
  14. package/dist/{index-eff254d8.d.ts → index-acb44057.d.ts} +12 -23
  15. package/dist/{micro-frontend-config-42886104.d.ts → microfrontend-config-983a5139.d.ts} +13 -13
  16. package/dist/next/client.cjs +1 -1
  17. package/dist/next/client.cjs.map +1 -1
  18. package/dist/next/client.js +1 -1
  19. package/dist/next/client.js.map +1 -1
  20. package/dist/next/config.cjs +86 -87
  21. package/dist/next/config.cjs.map +1 -1
  22. package/dist/next/config.d.ts +3 -3
  23. package/dist/next/config.js +85 -86
  24. package/dist/next/config.js.map +1 -1
  25. package/dist/next/middleware.cjs +60 -62
  26. package/dist/next/middleware.cjs.map +1 -1
  27. package/dist/next/middleware.d.ts +11 -11
  28. package/dist/next/middleware.js +58 -60
  29. package/dist/next/middleware.js.map +1 -1
  30. package/dist/next/testing.cjs +80 -79
  31. package/dist/next/testing.cjs.map +1 -1
  32. package/dist/next/testing.d.ts +10 -10
  33. package/dist/next/testing.js +80 -79
  34. package/dist/next/testing.js.map +1 -1
  35. package/dist/overrides.cjs +9 -9
  36. package/dist/overrides.cjs.map +1 -1
  37. package/dist/overrides.d.ts +2 -2
  38. package/dist/overrides.js +9 -9
  39. package/dist/overrides.js.map +1 -1
  40. package/dist/{schema-83a75e61.d.ts → schema-2922d49e.d.ts} +1 -7
  41. package/dist/{types-4fd1c7c6.d.ts → types-7b1cd9f7.d.ts} +1 -7
  42. package/dist/types-c3d15d04.d.ts +15 -0
  43. package/dist/v2/config.cjs +39 -39
  44. package/dist/v2/config.cjs.map +1 -1
  45. package/dist/v2/config.d.ts +3 -2
  46. package/dist/v2/config.js +38 -38
  47. package/dist/v2/config.js.map +1 -1
  48. package/dist/v2/microfrontends/server.cjs +223 -96
  49. package/dist/v2/microfrontends/server.cjs.map +1 -1
  50. package/dist/v2/microfrontends/server.d.ts +11 -3
  51. package/dist/v2/microfrontends/server.js +223 -96
  52. package/dist/v2/microfrontends/server.js.map +1 -1
  53. package/dist/v2/microfrontends.cjs +44 -44
  54. package/dist/v2/microfrontends.cjs.map +1 -1
  55. package/dist/v2/microfrontends.d.ts +6 -5
  56. package/dist/v2/microfrontends.js +44 -44
  57. package/dist/v2/microfrontends.js.map +1 -1
  58. package/dist/v2/next/client.cjs +1 -1
  59. package/dist/v2/next/client.cjs.map +1 -1
  60. package/dist/v2/next/client.js +1 -1
  61. package/dist/v2/next/client.js.map +1 -1
  62. package/dist/v2/next/config.cjs +247 -122
  63. package/dist/v2/next/config.cjs.map +1 -1
  64. package/dist/v2/next/config.d.ts +4 -4
  65. package/dist/v2/next/config.js +246 -121
  66. package/dist/v2/next/config.js.map +1 -1
  67. package/dist/v2/next/endpoints.cjs +5 -5
  68. package/dist/v2/next/endpoints.cjs.map +1 -1
  69. package/dist/v2/next/endpoints.js +5 -5
  70. package/dist/v2/next/endpoints.js.map +1 -1
  71. package/dist/v2/next/middleware.cjs +55 -55
  72. package/dist/v2/next/middleware.cjs.map +1 -1
  73. package/dist/v2/next/middleware.d.ts +8 -8
  74. package/dist/v2/next/middleware.js +53 -53
  75. package/dist/v2/next/middleware.js.map +1 -1
  76. package/dist/v2/overrides.cjs +75 -0
  77. package/dist/v2/overrides.cjs.map +1 -0
  78. package/dist/v2/overrides.d.ts +24 -0
  79. package/dist/v2/overrides.js +45 -0
  80. package/dist/v2/overrides.js.map +1 -0
  81. package/dist/v2/schema.cjs.map +1 -1
  82. package/dist/v2/schema.d.ts +1 -1
  83. package/dist/validation.cjs +20 -28
  84. package/dist/validation.cjs.map +1 -1
  85. package/dist/validation.d.ts +2 -8
  86. package/dist/validation.js +20 -28
  87. package/dist/validation.js.map +1 -1
  88. package/package.json +15 -7
  89. package/schema/schema-v2.json +0 -4
  90. package/schema/schema.json +0 -4
@@ -1,4 +1,4 @@
1
- import { A as ApplicationConfig, C as Config } from '../schema-83a75e61.js';
1
+ import { A as ApplicationConfig, C as Config } from '../schema-2922d49e.js';
2
2
 
3
3
  type ClientApplicationConfig = Pick<ApplicationConfig, 'default' | 'routing'>;
4
4
  interface ClientConfig {
@@ -20,22 +20,22 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
20
20
  // src/config/edge/index.ts
21
21
  var edge_exports = {};
22
22
  __export(edge_exports, {
23
- MicroFrontendConfigEdge: () => MicroFrontendConfigEdge
23
+ MicrofrontendConfigEdge: () => MicrofrontendConfigEdge
24
24
  });
25
25
  module.exports = __toCommonJS(edge_exports);
26
26
 
27
- // src/config/edge/micro-frontend-config.ts
27
+ // src/config/edge/microfrontend-config.ts
28
28
  var import_jsonc_parser = require("jsonc-parser");
29
29
 
30
30
  // src/config/errors.ts
31
- var MicroFrontendError = class extends Error {
31
+ var MicrofrontendError = class extends Error {
32
32
  constructor(message, opts) {
33
33
  super(message);
34
- this.name = "MicroFrontendsError";
35
- this.source = (opts == null ? void 0 : opts.source) ?? "@vercel/micro-frontends";
34
+ this.name = "MicrofrontendsError";
35
+ this.source = (opts == null ? void 0 : opts.source) ?? "@vercel/microfrontends";
36
36
  this.type = (opts == null ? void 0 : opts.type) ?? "unknown";
37
37
  this.subtype = opts == null ? void 0 : opts.subtype;
38
- Error.captureStackTrace(this, MicroFrontendError);
38
+ Error.captureStackTrace(this, MicrofrontendError);
39
39
  }
40
40
  isKnown() {
41
41
  return this.type !== "unknown";
@@ -44,13 +44,13 @@ var MicroFrontendError = class extends Error {
44
44
  return !this.isKnown();
45
45
  }
46
46
  /**
47
- * Converts an error to a MicroFrontendsError.
47
+ * Converts an error to a MicrofrontendsError.
48
48
  * @param original - The original error to convert.
49
- * @returns The converted MicroFrontendsError.
49
+ * @returns The converted MicrofrontendsError.
50
50
  */
51
51
  static convert(original, opts) {
52
52
  if (opts == null ? void 0 : opts.fileName) {
53
- const err = MicroFrontendError.convertFSError(original, opts.fileName);
53
+ const err = MicrofrontendError.convertFSError(original, opts.fileName);
54
54
  if (err) {
55
55
  return err;
56
56
  }
@@ -58,25 +58,25 @@ var MicroFrontendError = class extends Error {
58
58
  if (original.message.includes(
59
59
  "Code generation from strings disallowed for this context"
60
60
  )) {
61
- return new MicroFrontendError(original.message, {
61
+ return new MicrofrontendError(original.message, {
62
62
  type: "config",
63
63
  subtype: "unsupported_validation_env",
64
64
  source: "ajv"
65
65
  });
66
66
  }
67
- return new MicroFrontendError(original.message);
67
+ return new MicrofrontendError(original.message);
68
68
  }
69
69
  static convertFSError(original, fileName) {
70
70
  if (original instanceof Error && "code" in original) {
71
71
  if (original.code === "ENOENT") {
72
- return new MicroFrontendError(`Could not find "${fileName}"`, {
72
+ return new MicrofrontendError(`Could not find "${fileName}"`, {
73
73
  type: "config",
74
74
  subtype: "unable_to_read_file",
75
75
  source: "fs"
76
76
  });
77
77
  }
78
78
  if (original.code === "EACCES") {
79
- return new MicroFrontendError(
79
+ return new MicrofrontendError(
80
80
  `Permission denied while accessing "${fileName}"`,
81
81
  {
82
82
  type: "config",
@@ -87,7 +87,7 @@ var MicroFrontendError = class extends Error {
87
87
  }
88
88
  }
89
89
  if (original instanceof SyntaxError) {
90
- return new MicroFrontendError(
90
+ return new MicrofrontendError(
91
91
  `Failed to parse "${fileName}": Invalid JSON format.`,
92
92
  {
93
93
  type: "config",
@@ -99,23 +99,23 @@ var MicroFrontendError = class extends Error {
99
99
  return null;
100
100
  }
101
101
  /**
102
- * Handles an unknown error and returns a MicroFrontendsError instance.
102
+ * Handles an unknown error and returns a MicrofrontendsError instance.
103
103
  * @param err - The error to handle.
104
- * @returns A MicroFrontendsError instance.
104
+ * @returns A MicrofrontendsError instance.
105
105
  */
106
106
  static handle(err, opts) {
107
- if (err instanceof MicroFrontendError) {
107
+ if (err instanceof MicrofrontendError) {
108
108
  return err;
109
109
  }
110
110
  if (err instanceof Error) {
111
- return MicroFrontendError.convert(err, opts);
111
+ return MicrofrontendError.convert(err, opts);
112
112
  }
113
113
  if (typeof err === "object" && err !== null) {
114
114
  if ("message" in err && typeof err.message === "string") {
115
- return MicroFrontendError.convert(new Error(err.message), opts);
115
+ return MicrofrontendError.convert(new Error(err.message), opts);
116
116
  }
117
117
  }
118
- return new MicroFrontendError("An unknown error occurred");
118
+ return new MicrofrontendError("An unknown error occurred");
119
119
  }
120
120
  };
121
121
 
@@ -198,27 +198,27 @@ var _Overrides = class {
198
198
  });
199
199
  return overridesConfig;
200
200
  }
201
- static validOverrideDomainsForZone(microFrontendConfig, zone) {
201
+ static validOverrideDomainsForZone(microfrontendConfig, zone) {
202
202
  var _a, _b, _c, _d, _e;
203
- const projectName = (_a = microFrontendConfig.getZone(zone).vercel) == null ? void 0 : _a.projectName;
203
+ const projectName = (_a = microfrontendConfig.getZone(zone).vercel) == null ? void 0 : _a.projectName;
204
204
  if (!projectName) {
205
- return [microFrontendConfig.getZone(zone).production.host];
205
+ return [microfrontendConfig.getZone(zone).production.host];
206
206
  }
207
207
  const parsedProjectName = makeUrlSafe(projectName);
208
- const previewDeploymentSuffix = (_c = (_b = microFrontendConfig.options) == null ? void 0 : _b.vercel) == null ? void 0 : _c.previewDeploymentSuffix;
209
- const teamSlug = (_e = (_d = microFrontendConfig.options) == null ? void 0 : _d.vercel) == null ? void 0 : _e.teamSlug;
208
+ const previewDeploymentSuffix = (_c = (_b = microfrontendConfig.options) == null ? void 0 : _b.vercel) == null ? void 0 : _c.previewDeploymentSuffix;
209
+ const teamSlug = (_e = (_d = microfrontendConfig.options) == null ? void 0 : _d.vercel) == null ? void 0 : _e.teamSlug;
210
210
  if (!teamSlug && !previewDeploymentSuffix) {
211
- return [microFrontendConfig.getZone(zone).production.host];
211
+ return [microfrontendConfig.getZone(zone).production.host];
212
212
  }
213
213
  const suffix = previewDeploymentSuffix ? `.${previewDeploymentSuffix}` : `-${teamSlug}.vercel.app`;
214
214
  return [
215
215
  `${parsedProjectName}-git-([a-zA-Z0-9-]+)${suffix}`,
216
- microFrontendConfig.getZone(zone).production.host
216
+ microfrontendConfig.getZone(zone).production.host
217
217
  ];
218
218
  }
219
- static validateOverrideDomain(microFrontendConfig, zone, domain) {
219
+ static validateOverrideDomain(microfrontendConfig, zone, domain) {
220
220
  return new RegExp(
221
- `^${_Overrides.validOverrideDomainsForZone(microFrontendConfig, zone).join(
221
+ `^${_Overrides.validOverrideDomainsForZone(microfrontendConfig, zone).join(
222
222
  "|"
223
223
  )}$`
224
224
  ).test(domain);
@@ -300,7 +300,7 @@ var Application = class {
300
300
  static validate(name, app) {
301
301
  var _a, _b, _c, _d, _e;
302
302
  if (((_b = (_a = app.routing) == null ? void 0 : _a.assetPrefix) == null ? void 0 : _b.startsWith("/")) || ((_d = (_c = app.routing) == null ? void 0 : _c.assetPrefix) == null ? void 0 : _d.endsWith("/"))) {
303
- throw new MicroFrontendError(
303
+ throw new MicrofrontendError(
304
304
  `Invalid assetPrefix for application "${name}". Must not start or end with a slash.`,
305
305
  { type: "zone", subtype: "invalid_asset_prefix" }
306
306
  );
@@ -311,13 +311,13 @@ var Application = class {
311
311
  continue;
312
312
  }
313
313
  if (p.endsWith("/")) {
314
- throw new MicroFrontendError(
314
+ throw new MicrofrontendError(
315
315
  `Invalid path for application "${name}". ${p} must not end with a slash.`,
316
316
  { type: "zone", subtype: "invalid_path" }
317
317
  );
318
318
  }
319
319
  if (!p.startsWith("/")) {
320
- throw new MicroFrontendError(
320
+ throw new MicrofrontendError(
321
321
  `Invalid path for application "${name}". ${p} must start with a slash.`,
322
322
  { type: "zone", subtype: "invalid_path" }
323
323
  );
@@ -351,10 +351,10 @@ var Application = class {
351
351
  }
352
352
  };
353
353
 
354
- // src/config/common/micro-frontend-config.ts
354
+ // src/config/common/microfrontend-config.ts
355
355
  var SUPPORTED_VERSIONS = ["1"];
356
356
  var DEFAULT_LOCAL_PROXY_PORT = 3024;
357
- var MicroFrontendConfigCommon = class {
357
+ var MicrofrontendConfigCommon = class {
358
358
  constructor({
359
359
  config,
360
360
  overrides
@@ -362,7 +362,7 @@ var MicroFrontendConfigCommon = class {
362
362
  this.zones = {};
363
363
  var _a, _b, _c;
364
364
  if (!SUPPORTED_VERSIONS.includes(config.version)) {
365
- throw new MicroFrontendError(
365
+ throw new MicrofrontendError(
366
366
  `Unsupported version: ${config.version}. Supported versions are: ${SUPPORTED_VERSIONS.join(
367
367
  ", "
368
368
  )}`,
@@ -390,7 +390,7 @@ var MicroFrontendConfigCommon = class {
390
390
  static getConfigFromEnv() {
391
391
  const config = process.env.MFE_CONFIG;
392
392
  if (!config) {
393
- throw new MicroFrontendError(`Missing "MFE_CONFIG" in environment.`, {
393
+ throw new MicrofrontendError(`Missing "MFE_CONFIG" in environment.`, {
394
394
  type: "config",
395
395
  subtype: "not_found_in_env"
396
396
  });
@@ -409,8 +409,8 @@ var MicroFrontendConfigCommon = class {
409
409
  getZone(name) {
410
410
  const zone = this.zones[name];
411
411
  if (!zone) {
412
- throw new MicroFrontendError(
413
- `Could not find micro-frontends configuration for application "${name}"`,
412
+ throw new MicrofrontendError(
413
+ `Could not find microfrontends configuration for application "${name}"`,
414
414
  {
415
415
  type: "zone",
416
416
  subtype: "not_found"
@@ -430,8 +430,8 @@ var MicroFrontendConfigCommon = class {
430
430
  getDefaultZone() {
431
431
  const zone = Object.values(this.zones).find((z) => z.default);
432
432
  if (!zone) {
433
- throw new MicroFrontendError(
434
- `Could not find default zone in micro-frontends configuration`,
433
+ throw new MicrofrontendError(
434
+ `Could not find default zone in microfrontends configuration`,
435
435
  {
436
436
  type: "zone",
437
437
  subtype: "not_found"
@@ -483,26 +483,26 @@ var MicroFrontendConfigCommon = class {
483
483
  };
484
484
  }
485
485
  write(_) {
486
- throw new MicroFrontendError(
487
- `Writing to file to disk requires using an instance of "MicroFrontendConfig".`,
486
+ throw new MicrofrontendError(
487
+ `Writing to file to disk requires using an instance of "MicrofrontendConfig".`,
488
488
  { type: "config", subtype: "unsupported_operation" }
489
489
  );
490
490
  }
491
491
  };
492
492
 
493
- // src/config/edge/micro-frontend-config.ts
494
- var MicroFrontendConfigEdge = class extends MicroFrontendConfigCommon {
493
+ // src/config/edge/microfrontend-config.ts
494
+ var MicrofrontendConfigEdge = class extends MicrofrontendConfigCommon {
495
495
  static fromEnv({
496
496
  cookies
497
497
  }) {
498
- return new MicroFrontendConfigCommon({
499
- config: (0, import_jsonc_parser.parse)(MicroFrontendConfigCommon.getConfigFromEnv()),
498
+ return new MicrofrontendConfigCommon({
499
+ config: (0, import_jsonc_parser.parse)(MicrofrontendConfigCommon.getConfigFromEnv()),
500
500
  overrides: Overrides.parseOverrides(cookies)
501
501
  });
502
502
  }
503
503
  };
504
504
  // Annotate the CommonJS export names for ESM import in node:
505
505
  0 && (module.exports = {
506
- MicroFrontendConfigEdge
506
+ MicrofrontendConfigEdge
507
507
  });
508
508
  //# sourceMappingURL=edge.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/config/edge/index.ts","../../src/config/edge/micro-frontend-config.ts","../../src/config/errors.ts","../../src/routing/url.ts","../../src/config/overrides/config.ts","../../src/config/common/host.ts","../../src/config/common/application.ts","../../src/config/common/micro-frontend-config.ts"],"sourcesContent":["export { Config as MicroFrontendSchema } from '../schema';\nexport { MicroFrontendConfigEdge } from './micro-frontend-config';\n","/// <reference types=\"@edge-runtime/types\" />\n\nimport { parse } from 'jsonc-parser';\nimport { MicroFrontendConfigCommon } from '../common/micro-frontend-config';\nimport type { Config } from '../schema';\nimport { Overrides } from '../overrides';\n\n/**\n * Edge Runtime does not support ajv validation, or fs access.\n * This version of the MicroFrontendConfig does not validate the config shape,\n * and requires the config to be set on the environment.\n *\n * It should be used for Next.js middleware which runs in the Edge Runtime.\n */\nexport class MicroFrontendConfigEdge extends MicroFrontendConfigCommon {\n static fromEnv({\n cookies,\n }: {\n cookies: { name: string; value: string }[];\n }): MicroFrontendConfigEdge {\n return new MicroFrontendConfigCommon({\n config: parse(MicroFrontendConfigCommon.getConfigFromEnv()) as Config,\n overrides: Overrides.parseOverrides(cookies),\n });\n }\n}\n","export type MicroFrontendErrorType =\n | 'config'\n | 'packageJson'\n | 'vercelJson'\n | 'zone'\n | 'unknown';\n\nexport type MicroFrontendErrorSubtype =\n | 'not_found'\n | 'not_found_in_env'\n | 'invalid_asset_prefix'\n | 'invalid_main_path'\n | 'does_not_match_schema'\n | 'unable_to_read_file'\n | 'unsupported_validation_env'\n | 'unsupported_version'\n | 'invalid_path'\n | 'invalid_permissions'\n | 'invalid_syntax'\n | 'missing_microFrontend_config_path'\n | 'unsupported_operation';\n\n// A mapping of error types to their subtypes.\ninterface TypeToSubtype {\n zone:\n | 'invalid_asset_prefix'\n | 'invalid_path'\n | 'multiple_package_managers'\n | 'not_found';\n config:\n | 'conflicting_paths'\n | 'does_not_match_schema'\n | 'invalid_main_path'\n | 'invalid_preview_deployment_suffix'\n | 'multiple_default_applications'\n | 'no_default_application'\n | 'not_found_in_env'\n | 'not_found'\n | 'unable_to_read_file'\n | 'invalid_syntax'\n | 'invalid_permissions'\n | 'unsupported_operation'\n | 'unsupported_validation_env'\n | 'unsupported_version';\n packageJson:\n | 'missing_field_name'\n | 'unable_to_read_file'\n | 'invalid_permissions'\n | 'invalid_syntax';\n vercelJson:\n | 'missing_field_microFrontend_config_path'\n | 'unable_to_read_file'\n | 'invalid_permissions'\n | 'invalid_syntax';\n unknown: never;\n}\n\nexport type MicroFrontendErrorSource =\n | '@vercel/micro-frontends'\n | '@vercel/micro-frontends/next'\n | 'fs'\n | 'ajv';\n\nexport interface MicroFrontendErrorOptions<T extends MicroFrontendErrorType> {\n source?: MicroFrontendErrorSource;\n type?: T;\n subtype?: TypeToSubtype[T];\n}\n\ninterface HandleOptions {\n fileName?: string;\n}\n\nexport class MicroFrontendError<\n T extends MicroFrontendErrorType = 'unknown',\n> extends Error {\n public source: MicroFrontendErrorSource;\n public type: T;\n public subtype?: TypeToSubtype[T];\n\n constructor(message: string, opts?: MicroFrontendErrorOptions<T>) {\n super(message);\n this.name = 'MicroFrontendsError';\n this.source = opts?.source ?? '@vercel/micro-frontends';\n this.type = opts?.type ?? ('unknown' as T);\n this.subtype = opts?.subtype;\n Error.captureStackTrace(this, MicroFrontendError);\n }\n\n isKnown(): boolean {\n return this.type !== 'unknown';\n }\n\n isUnknown(): boolean {\n return !this.isKnown();\n }\n\n /**\n * Converts an error to a MicroFrontendsError.\n * @param original - The original error to convert.\n * @returns The converted MicroFrontendsError.\n */\n static convert(\n original: Error,\n opts?: HandleOptions,\n ): MicroFrontendError<MicroFrontendErrorType> {\n if (opts?.fileName) {\n const err = MicroFrontendError.convertFSError(original, opts.fileName);\n if (err) {\n return err;\n }\n }\n\n if (\n original.message.includes(\n 'Code generation from strings disallowed for this context',\n )\n ) {\n return new MicroFrontendError(original.message, {\n type: 'config',\n subtype: 'unsupported_validation_env',\n source: 'ajv',\n });\n }\n\n // unknown catch-all\n return new MicroFrontendError(original.message);\n }\n\n static convertFSError(\n original: Error,\n fileName: string,\n ): MicroFrontendError<MicroFrontendErrorType> | null {\n if (original instanceof Error && 'code' in original) {\n if (original.code === 'ENOENT') {\n return new MicroFrontendError(`Could not find \"${fileName}\"`, {\n type: 'config',\n subtype: 'unable_to_read_file',\n source: 'fs',\n });\n }\n if (original.code === 'EACCES') {\n return new MicroFrontendError(\n `Permission denied while accessing \"${fileName}\"`,\n {\n type: 'config',\n subtype: 'invalid_permissions',\n source: 'fs',\n },\n );\n }\n }\n\n if (original instanceof SyntaxError) {\n return new MicroFrontendError(\n `Failed to parse \"${fileName}\": Invalid JSON format.`,\n {\n type: 'config',\n subtype: 'invalid_syntax',\n source: 'fs',\n },\n );\n }\n\n return null;\n }\n\n /**\n * Handles an unknown error and returns a MicroFrontendsError instance.\n * @param err - The error to handle.\n * @returns A MicroFrontendsError instance.\n */\n static handle(\n err: unknown,\n opts?: HandleOptions,\n ): MicroFrontendError<MicroFrontendErrorType> {\n if (err instanceof MicroFrontendError) {\n return err as MicroFrontendError<MicroFrontendErrorType>;\n }\n\n // handle Error instances\n if (err instanceof Error) {\n return MicroFrontendError.convert(err, opts);\n }\n\n // handle object errors\n if (typeof err === 'object' && err !== null) {\n if ('message' in err && typeof err.message === 'string') {\n return MicroFrontendError.convert(new Error(err.message), opts);\n }\n }\n\n return new MicroFrontendError('An unknown error occurred');\n }\n}\n","// NOTE: This is copied from https://github.com/vercel/api/blob/main/packages/util-func/src/url-safe-string.ts.\n// See https://linear.app/vercel/issue/FDRTN-199/spike-move-preview-domain-generation-logic-into-build-and-deploy\n// for cleaning this up before release.\n\ninterface Options {\n joinString?: string;\n lowercaseOnly?: boolean;\n maxLen?: number;\n regexRemovePattern?: RegExp;\n trimWhitespace?: boolean;\n}\n\n/**\n * This function allows to convert single string to URL-safe tags to use for routing,\n * SEO purposes, etc. It is taken from https://www.npmjs.com/package/url-safe-string\n * and implemented here to be typed and skip the dependency.\n */\nfunction buildUrlSafeString(givenOpts: Options = {}): {\n generate: (...args: string[]) => string;\n} {\n const options = {\n joinString: '-',\n lowercaseOnly: true,\n maxLen: 100,\n regexRemovePattern: /(?:(?!(?:[a-z0-9])).)/gi,\n trimWhitespace: true,\n ...givenOpts,\n };\n\n return {\n generate: (...args: string[]) => {\n const reJoinString = new RegExp(`${options.joinString}+`, 'g');\n\n // biome-ignore lint/suspicious/noImplicitAnyLet: Ignored using `--suppress`\n let tag;\n\n if (args.length === 0) {\n throw new Error('generate method must be passed at least one argument');\n }\n\n // Validate, trim all arguments:\n for (let i = 0; i < args.length; i++) {\n const arg = args[i];\n if (typeof arg !== 'string')\n throw new Error('all supplied arguments must be Strings');\n\n if (options.trimWhitespace) {\n args[i] = arg.trim();\n }\n }\n\n // Join strings and convert whitespace between words to join string\n tag = args.join(options.joinString);\n tag = tag.replace(/\\s/g, options.joinString);\n if (options.lowercaseOnly) tag = tag.toLowerCase();\n // Regex away anything \"unsafe\", but ignore the join string!\n tag = tag.replace(options.regexRemovePattern, (match) => {\n if (match === options.joinString) return match;\n\n return '';\n });\n\n // Truncate in excess of maxLen\n if (tag.length > options.maxLen) tag = tag.substring(0, options.maxLen);\n\n // Remove any duplicates of the join string using this pattern: /<join string>+/g\n tag = tag.replace(reJoinString, options.joinString);\n\n return tag;\n },\n };\n}\n\n/**\n * Export a preconfigured version for convenience.\n */\nexport const urlSafeString = buildUrlSafeString().generate;\n\nexport function makeUrlSafe(name: string): string {\n return urlSafeString(name.replace(/\\//g, '-'))\n .replace(/^-*/g, '')\n .replace(/-*$/g, '');\n}\n","import { makeUrlSafe } from '../../routing/url';\nimport type { MicroFrontendConfig } from '../micro-frontend-config';\nimport type { OverridesConfig } from './types';\n\nexport const OVERRIDES_COOKIE_PREFIX = 'vercel-micro-frontends-override';\n\nexport class Overrides {\n config: OverridesConfig;\n\n constructor(config: OverridesConfig) {\n this.config = config;\n }\n\n static overrideEnvCookiePrefix = `${OVERRIDES_COOKIE_PREFIX}:env:`;\n\n static getAppEnvOverrideCookieName(zone: string): string {\n return `${Overrides.overrideEnvCookiePrefix}${zone}`;\n }\n\n static isOverrideCookie(cookie: { name?: string }): boolean {\n return Boolean(cookie.name?.startsWith(OVERRIDES_COOKIE_PREFIX));\n }\n\n static getOverrideFromCookie(cookie: {\n name: string;\n value?: string | null;\n }): { zone: string; host: string } | undefined {\n if (!Overrides.isOverrideCookie(cookie) || !cookie.value) return;\n return {\n zone: cookie.name.replace(Overrides.overrideEnvCookiePrefix, ''),\n host: cookie.value,\n };\n }\n\n static parseOverrides(\n cookies: { name: string; value?: string | null }[],\n ): OverridesConfig {\n const overridesConfig: OverridesConfig = { applications: {} };\n\n cookies.forEach((cookie) => {\n const override = Overrides.getOverrideFromCookie(cookie);\n if (!override) return;\n overridesConfig.applications[override.zone] = {\n environment: { host: override.host },\n };\n });\n\n return overridesConfig;\n }\n\n static validOverrideDomainsForZone(\n microFrontendConfig: MicroFrontendConfig,\n zone: string,\n ): string[] {\n const projectName = microFrontendConfig.getZone(zone).vercel?.projectName;\n if (!projectName) {\n return [microFrontendConfig.getZone(zone).production.host];\n }\n const parsedProjectName = makeUrlSafe(projectName);\n const previewDeploymentSuffix =\n microFrontendConfig.options?.vercel?.previewDeploymentSuffix;\n const teamSlug = microFrontendConfig.options?.vercel?.teamSlug;\n if (!teamSlug && !previewDeploymentSuffix) {\n return [microFrontendConfig.getZone(zone).production.host];\n }\n\n const suffix = previewDeploymentSuffix\n ? `.${previewDeploymentSuffix}`\n : `-${teamSlug}.vercel.app`;\n\n // <project-name>-git-<branch-name>-<scope-slug>.vercel.app\n // <project-name>-git-<branch-name>.<custom-suffix>\n return [\n `${parsedProjectName}-git-([a-zA-Z0-9-]+)${suffix}`,\n microFrontendConfig.getZone(zone).production.host,\n ];\n }\n\n static validateOverrideDomain(\n microFrontendConfig: MicroFrontendConfig,\n zone: string,\n domain: string,\n ): boolean {\n return new RegExp(\n `^${Overrides.validOverrideDomainsForZone(microFrontendConfig, zone).join(\n '|',\n )}$`,\n ).test(domain);\n }\n\n serialize(): OverridesConfig {\n return this.config;\n }\n}\n","import type { HostConfig } from '../schema';\n\ninterface HostDisplayOptions {\n includeDefaultPort?: boolean;\n}\n\nexport class Host {\n protocol: 'http' | 'https';\n host: HostConfig['host'];\n port: number;\n serialized: HostConfig;\n\n constructor({ protocol, host, port }: HostConfig) {\n this.protocol = protocol || 'https';\n this.host = host;\n this.port = Host.getPort({ port, protocol: this.protocol });\n this.serialized = {\n protocol,\n host,\n ...(port ? { port } : undefined),\n };\n }\n\n isLocal(): boolean {\n return this.host === 'localhost' || this.host === '127.0.0.1';\n }\n\n static getPort({\n protocol,\n port,\n }: { protocol: HostConfig['protocol']; port?: HostConfig['port'] }): number {\n if (!port) {\n if (protocol === 'http') {\n return 80;\n }\n return 443;\n }\n\n return port;\n }\n\n isDefaultPort(): boolean {\n return this.port === Host.getPort({ protocol: this.protocol });\n }\n\n toString(opts: HostDisplayOptions = {}): string {\n const url = this.toUrl(opts);\n // strip the trailing slash\n return url.toString().replace(/\\/$/, '');\n }\n\n toUrl(opts: HostDisplayOptions = {}): URL {\n const { includeDefaultPort } = opts;\n const url = `${this.protocol}://${this.host}${this.isDefaultPort() && !includeDefaultPort ? '' : `:${this.port}`}`;\n\n return new URL(url);\n }\n\n serialize(): HostConfig {\n return this.serialized;\n }\n}\n","import type { ApplicationConfig, Routing, Vercel } from '../schema';\nimport type { ApplicationOverrideConfig } from '../overrides';\nimport { MicroFrontendError } from '../errors';\nimport { Host } from './host';\n\nexport class Application {\n default: boolean;\n routing?: Routing;\n name: string;\n development: {\n local: Host;\n fallback?: Host;\n };\n production: Host;\n vercel?: Vercel;\n overrides?: {\n environment?: Host;\n };\n\n constructor(\n name: string,\n {\n app,\n overrides,\n }: { app: ApplicationConfig; overrides?: ApplicationOverrideConfig },\n ) {\n // validate\n Application.validate(name, app);\n\n this.name = name;\n this.default = app.default;\n this.routing = app.routing;\n this.development = {\n local: new Host(app.development.local),\n fallback: app.development.fallback\n ? new Host(app.development.fallback)\n : undefined,\n };\n this.production = new Host(app.production);\n this.vercel = app.vercel;\n this.overrides = overrides?.environment\n ? {\n environment: new Host(overrides.environment),\n }\n : undefined;\n }\n\n isDefault(): boolean {\n return this.default;\n }\n\n static validate(name: string, app: ApplicationConfig): void {\n // validate assetPrefix\n if (\n app.routing?.assetPrefix?.startsWith('/') ||\n app.routing?.assetPrefix?.endsWith('/')\n ) {\n throw new MicroFrontendError(\n `Invalid assetPrefix for application \"${name}\". Must not start or end with a slash.`,\n { type: 'zone', subtype: 'invalid_asset_prefix' },\n );\n }\n\n // validate routes\n for (const group of app.routing?.matches ?? []) {\n for (const p of group.paths) {\n if (p === '/') {\n continue;\n }\n if (p.endsWith('/')) {\n throw new MicroFrontendError(\n `Invalid path for application \"${name}\". ${p} must not end with a slash.`,\n { type: 'zone', subtype: 'invalid_path' },\n );\n }\n\n if (!p.startsWith('/')) {\n throw new MicroFrontendError(\n `Invalid path for application \"${name}\". ${p} must start with a slash.`,\n { type: 'zone', subtype: 'invalid_path' },\n );\n }\n }\n }\n }\n\n serialize(): ApplicationConfig {\n if (this.routing === undefined || this.default) {\n return {\n default: true,\n development: {\n local: this.development.local.serialize(),\n fallback: this.development.fallback?.serialize(),\n },\n production: this.production.serialize(),\n vercel: this.vercel,\n };\n }\n\n return {\n default: false,\n routing: this.routing,\n development: {\n local: this.development.local.serialize(),\n fallback: this.development.fallback?.serialize(),\n },\n production: this.production.serialize(),\n vercel: this.vercel,\n };\n }\n}\n","import type { ApplicationConfig, Config, Options } from '../schema';\nimport { MicroFrontendError } from '../errors';\nimport type { OverridesConfig } from '../overrides';\nimport { Overrides } from '../overrides/config';\nimport { Application } from './application';\n\nconst SUPPORTED_VERSIONS = ['1'];\nconst DEFAULT_LOCAL_PROXY_PORT = 3024;\n\n/**\n * A class to manage the micro-frontends configuration.\n *\n * This class should not be used directly. Instead, use the `MicroFrontendConfig` or `MicroFrontendConfigEdgeRuntime` classes.\n */\nexport class MicroFrontendConfigCommon {\n config: Config;\n name?: string;\n zones: Record<string, Application> = {};\n version: string;\n overrides?: Overrides;\n options?: Options;\n $schema: string | undefined;\n\n constructor({\n config,\n overrides,\n }: { config: Config; overrides?: OverridesConfig }) {\n if (!SUPPORTED_VERSIONS.includes(config.version)) {\n throw new MicroFrontendError(\n `Unsupported version: ${config.version}. Supported versions are: ${SUPPORTED_VERSIONS.join(\n ', ',\n )}`,\n { type: 'config', subtype: 'unsupported_version' },\n );\n }\n const disableOverrides = config.options?.vercel?.disableOverrides ?? false;\n\n this.overrides =\n overrides && !disableOverrides ? new Overrides(overrides) : undefined;\n\n // create zones\n for (const [zoneName, zoneConfig] of Object.entries(config.applications)) {\n this.zones[zoneName] = new Application(zoneName, {\n app: zoneConfig,\n overrides: !disableOverrides\n ? this.overrides?.config.applications[zoneName]\n : undefined,\n });\n }\n\n this.config = config;\n this.name = config.name;\n this.version = config.version;\n this.options = config.options;\n this.$schema = config.$schema;\n }\n\n isOverridesDisabled(): boolean {\n return this.options?.vercel?.disableOverrides ?? false;\n }\n\n protected static getConfigFromEnv(): string {\n const config = process.env.MFE_CONFIG;\n if (!config) {\n throw new MicroFrontendError(`Missing \"MFE_CONFIG\" in environment.`, {\n type: 'config',\n subtype: 'not_found_in_env',\n });\n }\n return config;\n }\n\n static fromEnv(_: {\n cookies: { name: string; value: string }[];\n }): MicroFrontendConfigCommon | Promise<MicroFrontendConfigCommon> {\n throw new Error('Not implemented');\n }\n\n getConfig(): Config {\n return this.config;\n }\n\n getAllApplications(): Application[] {\n return Object.values(this.zones);\n }\n\n getZone(name: string): Application {\n const zone = this.zones[name];\n if (!zone) {\n throw new MicroFrontendError(\n `Could not find micro-frontends configuration for application \"${name}\"`,\n {\n type: 'zone',\n subtype: 'not_found',\n },\n );\n }\n\n return zone;\n }\n\n getApplicationByProjectId(projectId: string): Application | undefined {\n return Object.values(this.zones).find(\n (zone) => zone.vercel?.projectId === projectId,\n );\n }\n\n getDefaultZone(): Application {\n const zone = Object.values(this.zones).find((z) => z.default);\n if (!zone) {\n throw new MicroFrontendError(\n `Could not find default zone in micro-frontends configuration`,\n {\n type: 'zone',\n subtype: 'not_found',\n },\n );\n }\n\n return zone;\n }\n\n /**\n * Returns the configured port for the local proxy\n */\n getLocalProxyPort(): number {\n return this.config.options?.localProxy?.port ?? DEFAULT_LOCAL_PROXY_PORT;\n }\n\n /**\n * Serializes the class back to the Schema type.\n *\n * NOTE: This is used when writing the config to disk and must always match the input Schema\n */\n toSchemaJson(): Config {\n const applications: Record<string, ApplicationConfig> = {};\n for (const [name, zone] of Object.entries(this.zones)) {\n applications[name] = zone.serialize();\n }\n\n return {\n $schema: this.$schema,\n name: this.name,\n version: this.version,\n options: this.options,\n applications,\n };\n }\n\n serialize(): { config: Config; overrides?: OverridesConfig } {\n const applications: Record<string, ApplicationConfig> = {};\n for (const [name, zone] of Object.entries(this.zones)) {\n applications[name] = zone.serialize();\n }\n\n return {\n config: {\n name: this.name,\n version: this.version,\n applications,\n options: this.options,\n $schema: this.$schema,\n },\n overrides: this.overrides?.serialize(),\n };\n }\n\n write(_: string): void {\n throw new MicroFrontendError(\n `Writing to file to disk requires using an instance of \"MicroFrontendConfig\".`,\n { type: 'config', subtype: 'unsupported_operation' },\n );\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../src/config/edge/index.ts","../../src/config/edge/microfrontend-config.ts","../../src/config/errors.ts","../../src/routing/url.ts","../../src/config/overrides/config.ts","../../src/config/common/host.ts","../../src/config/common/application.ts","../../src/config/common/microfrontend-config.ts"],"sourcesContent":["export { Config as MicrofrontendSchema } from '../schema';\nexport { MicrofrontendConfigEdge } from './microfrontend-config';\n","/// <reference types=\"@edge-runtime/types\" />\n\nimport { parse } from 'jsonc-parser';\nimport { MicrofrontendConfigCommon } from '../common/microfrontend-config';\nimport type { Config } from '../schema';\nimport { Overrides } from '../overrides';\n\n/**\n * Edge Runtime does not support ajv validation, or fs access.\n * This version of the MicrofrontendConfig does not validate the config shape,\n * and requires the config to be set on the environment.\n *\n * It should be used for Next.js middleware which runs in the Edge Runtime.\n */\nexport class MicrofrontendConfigEdge extends MicrofrontendConfigCommon {\n static fromEnv({\n cookies,\n }: {\n cookies: { name: string; value: string }[];\n }): MicrofrontendConfigEdge {\n return new MicrofrontendConfigCommon({\n config: parse(MicrofrontendConfigCommon.getConfigFromEnv()) as Config,\n overrides: Overrides.parseOverrides(cookies),\n });\n }\n}\n","export type MicrofrontendErrorType =\n | 'config'\n | 'packageJson'\n | 'vercelJson'\n | 'zone'\n | 'unknown';\n\nexport type MicrofrontendErrorSubtype =\n | 'not_found'\n | 'not_found_in_env'\n | 'invalid_asset_prefix'\n | 'invalid_main_path'\n | 'does_not_match_schema'\n | 'unable_to_read_file'\n | 'unsupported_validation_env'\n | 'unsupported_version'\n | 'invalid_path'\n | 'invalid_permissions'\n | 'invalid_syntax'\n | 'missing_microfrontend_config_path'\n | 'unsupported_operation';\n\n// A mapping of error types to their subtypes.\ninterface TypeToSubtype {\n zone:\n | 'invalid_asset_prefix'\n | 'invalid_path'\n | 'multiple_package_managers'\n | 'not_found';\n config:\n | 'conflicting_paths'\n | 'does_not_match_schema'\n | 'invalid_main_path'\n | 'invalid_preview_deployment_suffix'\n | 'multiple_default_applications'\n | 'no_default_application'\n | 'not_found_in_env'\n | 'not_found'\n | 'unable_to_read_file'\n | 'invalid_syntax'\n | 'invalid_permissions'\n | 'unsupported_operation'\n | 'unsupported_validation_env'\n | 'unsupported_version';\n packageJson:\n | 'missing_field_name'\n | 'unable_to_read_file'\n | 'invalid_permissions'\n | 'invalid_syntax';\n vercelJson:\n | 'missing_field_microFrontend_config_path'\n | 'unable_to_read_file'\n | 'invalid_permissions'\n | 'invalid_syntax';\n unknown: never;\n}\n\nexport type MicrofrontendErrorSource =\n | '@vercel/microfrontends'\n | '@vercel/microfrontends/next'\n | 'fs'\n | 'ajv';\n\nexport interface MicrofrontendErrorOptions<T extends MicrofrontendErrorType> {\n source?: MicrofrontendErrorSource;\n type?: T;\n subtype?: TypeToSubtype[T];\n}\n\ninterface HandleOptions {\n fileName?: string;\n}\n\nexport class MicrofrontendError<\n T extends MicrofrontendErrorType = 'unknown',\n> extends Error {\n public source: MicrofrontendErrorSource;\n public type: T;\n public subtype?: TypeToSubtype[T];\n\n constructor(message: string, opts?: MicrofrontendErrorOptions<T>) {\n super(message);\n this.name = 'MicrofrontendsError';\n this.source = opts?.source ?? '@vercel/microfrontends';\n this.type = opts?.type ?? ('unknown' as T);\n this.subtype = opts?.subtype;\n Error.captureStackTrace(this, MicrofrontendError);\n }\n\n isKnown(): boolean {\n return this.type !== 'unknown';\n }\n\n isUnknown(): boolean {\n return !this.isKnown();\n }\n\n /**\n * Converts an error to a MicrofrontendsError.\n * @param original - The original error to convert.\n * @returns The converted MicrofrontendsError.\n */\n static convert(\n original: Error,\n opts?: HandleOptions,\n ): MicrofrontendError<MicrofrontendErrorType> {\n if (opts?.fileName) {\n const err = MicrofrontendError.convertFSError(original, opts.fileName);\n if (err) {\n return err;\n }\n }\n\n if (\n original.message.includes(\n 'Code generation from strings disallowed for this context',\n )\n ) {\n return new MicrofrontendError(original.message, {\n type: 'config',\n subtype: 'unsupported_validation_env',\n source: 'ajv',\n });\n }\n\n // unknown catch-all\n return new MicrofrontendError(original.message);\n }\n\n static convertFSError(\n original: Error,\n fileName: string,\n ): MicrofrontendError<MicrofrontendErrorType> | null {\n if (original instanceof Error && 'code' in original) {\n if (original.code === 'ENOENT') {\n return new MicrofrontendError(`Could not find \"${fileName}\"`, {\n type: 'config',\n subtype: 'unable_to_read_file',\n source: 'fs',\n });\n }\n if (original.code === 'EACCES') {\n return new MicrofrontendError(\n `Permission denied while accessing \"${fileName}\"`,\n {\n type: 'config',\n subtype: 'invalid_permissions',\n source: 'fs',\n },\n );\n }\n }\n\n if (original instanceof SyntaxError) {\n return new MicrofrontendError(\n `Failed to parse \"${fileName}\": Invalid JSON format.`,\n {\n type: 'config',\n subtype: 'invalid_syntax',\n source: 'fs',\n },\n );\n }\n\n return null;\n }\n\n /**\n * Handles an unknown error and returns a MicrofrontendsError instance.\n * @param err - The error to handle.\n * @returns A MicrofrontendsError instance.\n */\n static handle(\n err: unknown,\n opts?: HandleOptions,\n ): MicrofrontendError<MicrofrontendErrorType> {\n if (err instanceof MicrofrontendError) {\n return err as MicrofrontendError<MicrofrontendErrorType>;\n }\n\n // handle Error instances\n if (err instanceof Error) {\n return MicrofrontendError.convert(err, opts);\n }\n\n // handle object errors\n if (typeof err === 'object' && err !== null) {\n if ('message' in err && typeof err.message === 'string') {\n return MicrofrontendError.convert(new Error(err.message), opts);\n }\n }\n\n return new MicrofrontendError('An unknown error occurred');\n }\n}\n","// NOTE: This is copied from https://github.com/vercel/api/blob/main/packages/util-func/src/url-safe-string.ts.\n// See https://linear.app/vercel/issue/FDRTN-199/spike-move-preview-domain-generation-logic-into-build-and-deploy\n// for cleaning this up before release.\n\ninterface Options {\n joinString?: string;\n lowercaseOnly?: boolean;\n maxLen?: number;\n regexRemovePattern?: RegExp;\n trimWhitespace?: boolean;\n}\n\n/**\n * This function allows to convert single string to URL-safe tags to use for routing,\n * SEO purposes, etc. It is taken from https://www.npmjs.com/package/url-safe-string\n * and implemented here to be typed and skip the dependency.\n */\nfunction buildUrlSafeString(givenOpts: Options = {}): {\n generate: (...args: string[]) => string;\n} {\n const options = {\n joinString: '-',\n lowercaseOnly: true,\n maxLen: 100,\n regexRemovePattern: /(?:(?!(?:[a-z0-9])).)/gi,\n trimWhitespace: true,\n ...givenOpts,\n };\n\n return {\n generate: (...args: string[]) => {\n const reJoinString = new RegExp(`${options.joinString}+`, 'g');\n\n // biome-ignore lint/suspicious/noImplicitAnyLet: Ignored using `--suppress`\n let tag;\n\n if (args.length === 0) {\n throw new Error('generate method must be passed at least one argument');\n }\n\n // Validate, trim all arguments:\n for (let i = 0; i < args.length; i++) {\n const arg = args[i];\n if (typeof arg !== 'string')\n throw new Error('all supplied arguments must be Strings');\n\n if (options.trimWhitespace) {\n args[i] = arg.trim();\n }\n }\n\n // Join strings and convert whitespace between words to join string\n tag = args.join(options.joinString);\n tag = tag.replace(/\\s/g, options.joinString);\n if (options.lowercaseOnly) tag = tag.toLowerCase();\n // Regex away anything \"unsafe\", but ignore the join string!\n tag = tag.replace(options.regexRemovePattern, (match) => {\n if (match === options.joinString) return match;\n\n return '';\n });\n\n // Truncate in excess of maxLen\n if (tag.length > options.maxLen) tag = tag.substring(0, options.maxLen);\n\n // Remove any duplicates of the join string using this pattern: /<join string>+/g\n tag = tag.replace(reJoinString, options.joinString);\n\n return tag;\n },\n };\n}\n\n/**\n * Export a preconfigured version for convenience.\n */\nexport const urlSafeString = buildUrlSafeString().generate;\n\nexport function makeUrlSafe(name: string): string {\n return urlSafeString(name.replace(/\\//g, '-'))\n .replace(/^-*/g, '')\n .replace(/-*$/g, '');\n}\n","import { makeUrlSafe } from '../../routing/url';\nimport type { MicrofrontendConfig } from '../microfrontend-config';\nimport type { OverridesConfig } from './types';\n\nexport const OVERRIDES_COOKIE_PREFIX = 'vercel-micro-frontends-override';\n\nexport class Overrides {\n config: OverridesConfig;\n\n constructor(config: OverridesConfig) {\n this.config = config;\n }\n\n static overrideEnvCookiePrefix = `${OVERRIDES_COOKIE_PREFIX}:env:`;\n\n static getAppEnvOverrideCookieName(zone: string): string {\n return `${Overrides.overrideEnvCookiePrefix}${zone}`;\n }\n\n static isOverrideCookie(cookie: { name?: string }): boolean {\n return Boolean(cookie.name?.startsWith(OVERRIDES_COOKIE_PREFIX));\n }\n\n static getOverrideFromCookie(cookie: {\n name: string;\n value?: string | null;\n }): { zone: string; host: string } | undefined {\n if (!Overrides.isOverrideCookie(cookie) || !cookie.value) return;\n return {\n zone: cookie.name.replace(Overrides.overrideEnvCookiePrefix, ''),\n host: cookie.value,\n };\n }\n\n static parseOverrides(\n cookies: { name: string; value?: string | null }[],\n ): OverridesConfig {\n const overridesConfig: OverridesConfig = { applications: {} };\n\n cookies.forEach((cookie) => {\n const override = Overrides.getOverrideFromCookie(cookie);\n if (!override) return;\n overridesConfig.applications[override.zone] = {\n environment: { host: override.host },\n };\n });\n\n return overridesConfig;\n }\n\n static validOverrideDomainsForZone(\n microfrontendConfig: MicrofrontendConfig,\n zone: string,\n ): string[] {\n const projectName = microfrontendConfig.getZone(zone).vercel?.projectName;\n if (!projectName) {\n return [microfrontendConfig.getZone(zone).production.host];\n }\n const parsedProjectName = makeUrlSafe(projectName);\n const previewDeploymentSuffix =\n microfrontendConfig.options?.vercel?.previewDeploymentSuffix;\n const teamSlug = microfrontendConfig.options?.vercel?.teamSlug;\n if (!teamSlug && !previewDeploymentSuffix) {\n return [microfrontendConfig.getZone(zone).production.host];\n }\n\n const suffix = previewDeploymentSuffix\n ? `.${previewDeploymentSuffix}`\n : `-${teamSlug}.vercel.app`;\n\n // <project-name>-git-<branch-name>-<scope-slug>.vercel.app\n // <project-name>-git-<branch-name>.<custom-suffix>\n return [\n `${parsedProjectName}-git-([a-zA-Z0-9-]+)${suffix}`,\n microfrontendConfig.getZone(zone).production.host,\n ];\n }\n\n static validateOverrideDomain(\n microfrontendConfig: MicrofrontendConfig,\n zone: string,\n domain: string,\n ): boolean {\n return new RegExp(\n `^${Overrides.validOverrideDomainsForZone(microfrontendConfig, zone).join(\n '|',\n )}$`,\n ).test(domain);\n }\n\n serialize(): OverridesConfig {\n return this.config;\n }\n}\n","import type { HostConfig } from '../schema';\n\ninterface HostDisplayOptions {\n includeDefaultPort?: boolean;\n}\n\nexport class Host {\n protocol: 'http' | 'https';\n host: HostConfig['host'];\n port: number;\n serialized: HostConfig;\n\n constructor({ protocol, host, port }: HostConfig) {\n this.protocol = protocol || 'https';\n this.host = host;\n this.port = Host.getPort({ port, protocol: this.protocol });\n this.serialized = {\n protocol,\n host,\n ...(port ? { port } : undefined),\n };\n }\n\n isLocal(): boolean {\n return this.host === 'localhost' || this.host === '127.0.0.1';\n }\n\n static getPort({\n protocol,\n port,\n }: { protocol: HostConfig['protocol']; port?: HostConfig['port'] }): number {\n if (!port) {\n if (protocol === 'http') {\n return 80;\n }\n return 443;\n }\n\n return port;\n }\n\n isDefaultPort(): boolean {\n return this.port === Host.getPort({ protocol: this.protocol });\n }\n\n toString(opts: HostDisplayOptions = {}): string {\n const url = this.toUrl(opts);\n // strip the trailing slash\n return url.toString().replace(/\\/$/, '');\n }\n\n toUrl(opts: HostDisplayOptions = {}): URL {\n const { includeDefaultPort } = opts;\n const url = `${this.protocol}://${this.host}${this.isDefaultPort() && !includeDefaultPort ? '' : `:${this.port}`}`;\n\n return new URL(url);\n }\n\n serialize(): HostConfig {\n return this.serialized;\n }\n}\n","import type { ApplicationConfig, Routing, Vercel } from '../schema';\nimport type { ApplicationOverrideConfig } from '../overrides';\nimport { MicrofrontendError } from '../errors';\nimport { Host } from './host';\n\nexport class Application {\n default: boolean;\n routing?: Routing;\n name: string;\n development: {\n local: Host;\n fallback?: Host;\n };\n production: Host;\n vercel?: Vercel;\n overrides?: {\n environment?: Host;\n };\n\n constructor(\n name: string,\n {\n app,\n overrides,\n }: { app: ApplicationConfig; overrides?: ApplicationOverrideConfig },\n ) {\n // validate\n Application.validate(name, app);\n\n this.name = name;\n this.default = app.default;\n this.routing = app.routing;\n this.development = {\n local: new Host(app.development.local),\n fallback: app.development.fallback\n ? new Host(app.development.fallback)\n : undefined,\n };\n this.production = new Host(app.production);\n this.vercel = app.vercel;\n this.overrides = overrides?.environment\n ? {\n environment: new Host(overrides.environment),\n }\n : undefined;\n }\n\n isDefault(): boolean {\n return this.default;\n }\n\n static validate(name: string, app: ApplicationConfig): void {\n // validate assetPrefix\n if (\n app.routing?.assetPrefix?.startsWith('/') ||\n app.routing?.assetPrefix?.endsWith('/')\n ) {\n throw new MicrofrontendError(\n `Invalid assetPrefix for application \"${name}\". Must not start or end with a slash.`,\n { type: 'zone', subtype: 'invalid_asset_prefix' },\n );\n }\n\n // validate routes\n for (const group of app.routing?.matches ?? []) {\n for (const p of group.paths) {\n if (p === '/') {\n continue;\n }\n if (p.endsWith('/')) {\n throw new MicrofrontendError(\n `Invalid path for application \"${name}\". ${p} must not end with a slash.`,\n { type: 'zone', subtype: 'invalid_path' },\n );\n }\n\n if (!p.startsWith('/')) {\n throw new MicrofrontendError(\n `Invalid path for application \"${name}\". ${p} must start with a slash.`,\n { type: 'zone', subtype: 'invalid_path' },\n );\n }\n }\n }\n }\n\n serialize(): ApplicationConfig {\n if (this.routing === undefined || this.default) {\n return {\n default: true,\n development: {\n local: this.development.local.serialize(),\n fallback: this.development.fallback?.serialize(),\n },\n production: this.production.serialize(),\n vercel: this.vercel,\n };\n }\n\n return {\n default: false,\n routing: this.routing,\n development: {\n local: this.development.local.serialize(),\n fallback: this.development.fallback?.serialize(),\n },\n production: this.production.serialize(),\n vercel: this.vercel,\n };\n }\n}\n","import type { ApplicationConfig, Config, Options } from '../schema';\nimport { MicrofrontendError } from '../errors';\nimport type { OverridesConfig } from '../overrides';\nimport { Overrides } from '../overrides/config';\nimport { Application } from './application';\n\nconst SUPPORTED_VERSIONS = ['1'];\nconst DEFAULT_LOCAL_PROXY_PORT = 3024;\n\n/**\n * A class to manage the microfrontends configuration.\n *\n * This class should not be used directly. Instead, use the `MicrofrontendConfig` or `MicrofrontendConfigEdgeRuntime` classes.\n */\nexport class MicrofrontendConfigCommon {\n config: Config;\n name?: string;\n zones: Record<string, Application> = {};\n version: string;\n overrides?: Overrides;\n options?: Options;\n $schema: string | undefined;\n\n constructor({\n config,\n overrides,\n }: { config: Config; overrides?: OverridesConfig }) {\n if (!SUPPORTED_VERSIONS.includes(config.version)) {\n throw new MicrofrontendError(\n `Unsupported version: ${config.version}. Supported versions are: ${SUPPORTED_VERSIONS.join(\n ', ',\n )}`,\n { type: 'config', subtype: 'unsupported_version' },\n );\n }\n const disableOverrides = config.options?.vercel?.disableOverrides ?? false;\n\n this.overrides =\n overrides && !disableOverrides ? new Overrides(overrides) : undefined;\n\n // create zones\n for (const [zoneName, zoneConfig] of Object.entries(config.applications)) {\n this.zones[zoneName] = new Application(zoneName, {\n app: zoneConfig,\n overrides: !disableOverrides\n ? this.overrides?.config.applications[zoneName]\n : undefined,\n });\n }\n\n this.config = config;\n this.name = config.name;\n this.version = config.version;\n this.options = config.options;\n this.$schema = config.$schema;\n }\n\n isOverridesDisabled(): boolean {\n return this.options?.vercel?.disableOverrides ?? false;\n }\n\n protected static getConfigFromEnv(): string {\n const config = process.env.MFE_CONFIG;\n if (!config) {\n throw new MicrofrontendError(`Missing \"MFE_CONFIG\" in environment.`, {\n type: 'config',\n subtype: 'not_found_in_env',\n });\n }\n return config;\n }\n\n static fromEnv(_: {\n cookies: { name: string; value: string }[];\n }): MicrofrontendConfigCommon | Promise<MicrofrontendConfigCommon> {\n throw new Error('Not implemented');\n }\n\n getConfig(): Config {\n return this.config;\n }\n\n getAllApplications(): Application[] {\n return Object.values(this.zones);\n }\n\n getZone(name: string): Application {\n const zone = this.zones[name];\n if (!zone) {\n throw new MicrofrontendError(\n `Could not find microfrontends configuration for application \"${name}\"`,\n {\n type: 'zone',\n subtype: 'not_found',\n },\n );\n }\n\n return zone;\n }\n\n getApplicationByProjectId(projectId: string): Application | undefined {\n return Object.values(this.zones).find(\n (zone) => zone.vercel?.projectId === projectId,\n );\n }\n\n getDefaultZone(): Application {\n const zone = Object.values(this.zones).find((z) => z.default);\n if (!zone) {\n throw new MicrofrontendError(\n `Could not find default zone in microfrontends configuration`,\n {\n type: 'zone',\n subtype: 'not_found',\n },\n );\n }\n\n return zone;\n }\n\n /**\n * Returns the configured port for the local proxy\n */\n getLocalProxyPort(): number {\n return this.config.options?.localProxy?.port ?? DEFAULT_LOCAL_PROXY_PORT;\n }\n\n /**\n * Serializes the class back to the Schema type.\n *\n * NOTE: This is used when writing the config to disk and must always match the input Schema\n */\n toSchemaJson(): Config {\n const applications: Record<string, ApplicationConfig> = {};\n for (const [name, zone] of Object.entries(this.zones)) {\n applications[name] = zone.serialize();\n }\n\n return {\n $schema: this.$schema,\n name: this.name,\n version: this.version,\n options: this.options,\n applications,\n };\n }\n\n serialize(): { config: Config; overrides?: OverridesConfig } {\n const applications: Record<string, ApplicationConfig> = {};\n for (const [name, zone] of Object.entries(this.zones)) {\n applications[name] = zone.serialize();\n }\n\n return {\n config: {\n name: this.name,\n version: this.version,\n applications,\n options: this.options,\n $schema: this.$schema,\n },\n overrides: this.overrides?.serialize(),\n };\n }\n\n write(_: string): void {\n throw new MicrofrontendError(\n `Writing to file to disk requires using an instance of \"MicrofrontendConfig\".`,\n { type: 'config', subtype: 'unsupported_operation' },\n );\n }\n}\n"],"mappings":"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","names":[]}
@@ -1,20 +1,20 @@
1
- export { C as MicroFrontendSchema } from '../schema-83a75e61.js';
2
- import { a as MicroFrontendConfigCommon } from '../micro-frontend-config-42886104.js';
1
+ export { C as MicrofrontendSchema } from '../schema-2922d49e.js';
2
+ import { a as MicrofrontendConfigCommon } from '../microfrontend-config-983a5139.js';
3
3
 
4
4
  /**
5
5
  * Edge Runtime does not support ajv validation, or fs access.
6
- * This version of the MicroFrontendConfig does not validate the config shape,
6
+ * This version of the MicrofrontendConfig does not validate the config shape,
7
7
  * and requires the config to be set on the environment.
8
8
  *
9
9
  * It should be used for Next.js middleware which runs in the Edge Runtime.
10
10
  */
11
- declare class MicroFrontendConfigEdge extends MicroFrontendConfigCommon {
11
+ declare class MicrofrontendConfigEdge extends MicrofrontendConfigCommon {
12
12
  static fromEnv({ cookies, }: {
13
13
  cookies: {
14
14
  name: string;
15
15
  value: string;
16
16
  }[];
17
- }): MicroFrontendConfigEdge;
17
+ }): MicrofrontendConfigEdge;
18
18
  }
19
19
 
20
- export { MicroFrontendConfigEdge };
20
+ export { MicrofrontendConfigEdge };