@eventcatalog/sdk 2.2.9 → 2.3.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 (47) hide show
  1. package/dist/channels.js +32 -5
  2. package/dist/channels.js.map +1 -1
  3. package/dist/channels.mjs +34 -7
  4. package/dist/channels.mjs.map +1 -1
  5. package/dist/commands.js +20 -4
  6. package/dist/commands.js.map +1 -1
  7. package/dist/commands.mjs +21 -5
  8. package/dist/commands.mjs.map +1 -1
  9. package/dist/custom-docs.js +20 -4
  10. package/dist/custom-docs.js.map +1 -1
  11. package/dist/custom-docs.mjs +21 -5
  12. package/dist/custom-docs.mjs.map +1 -1
  13. package/dist/domains.js +32 -5
  14. package/dist/domains.js.map +1 -1
  15. package/dist/domains.mjs +33 -6
  16. package/dist/domains.mjs.map +1 -1
  17. package/dist/eventcatalog.js +29 -7
  18. package/dist/eventcatalog.js.map +1 -1
  19. package/dist/eventcatalog.mjs +32 -10
  20. package/dist/eventcatalog.mjs.map +1 -1
  21. package/dist/events.js +20 -4
  22. package/dist/events.js.map +1 -1
  23. package/dist/events.mjs +21 -5
  24. package/dist/events.mjs.map +1 -1
  25. package/dist/index.d.mts +6 -1
  26. package/dist/index.d.ts +6 -1
  27. package/dist/index.js +29 -7
  28. package/dist/index.js.map +1 -1
  29. package/dist/index.mjs +32 -10
  30. package/dist/index.mjs.map +1 -1
  31. package/dist/queries.js +20 -4
  32. package/dist/queries.js.map +1 -1
  33. package/dist/queries.mjs +21 -5
  34. package/dist/queries.mjs.map +1 -1
  35. package/dist/services.js +32 -5
  36. package/dist/services.js.map +1 -1
  37. package/dist/services.mjs +34 -7
  38. package/dist/services.mjs.map +1 -1
  39. package/dist/teams.js +20 -4
  40. package/dist/teams.js.map +1 -1
  41. package/dist/teams.mjs +21 -5
  42. package/dist/teams.mjs.map +1 -1
  43. package/dist/users.js +20 -4
  44. package/dist/users.js.map +1 -1
  45. package/dist/users.mjs +21 -5
  46. package/dist/users.mjs.map +1 -1
  47. package/package.json +1 -1
package/dist/index.mjs CHANGED
@@ -9,7 +9,7 @@ import { join as join3 } from "node:path";
9
9
  import { globSync } from "glob";
10
10
  import fsSync from "node:fs";
11
11
  import { copy } from "fs-extra";
12
- import { join, dirname } from "node:path";
12
+ import { join, dirname, normalize, resolve, relative } from "node:path";
13
13
  import matter from "gray-matter";
14
14
  import { satisfies, validRange, valid } from "semver";
15
15
  var versionExists = async (catalogDir, id, version) => {
@@ -43,12 +43,28 @@ var findFileById = async (catalogDir, id, version) => {
43
43
  };
44
44
  var getFiles = async (pattern, ignore = "") => {
45
45
  try {
46
+ const normalizedInputPattern = normalize(pattern);
47
+ const absoluteBaseDir = resolve(
48
+ normalizedInputPattern.includes("**") ? normalizedInputPattern.split("**")[0] : dirname(normalizedInputPattern)
49
+ );
50
+ let relativePattern = relative(absoluteBaseDir, normalizedInputPattern);
51
+ relativePattern = relativePattern.replace(/\\/g, "/");
46
52
  const ignoreList = Array.isArray(ignore) ? ignore : [ignore];
47
- const baseDir = pattern.includes("**") ? pattern.split("**")[0] : dirname(pattern);
48
- const files = globSync(pattern, { cwd: baseDir, ignore: ["node_modules/**", ...ignoreList] });
49
- return files;
53
+ const files = globSync(relativePattern, {
54
+ cwd: absoluteBaseDir,
55
+ ignore: ["node_modules/**", ...ignoreList],
56
+ absolute: true,
57
+ nodir: true
58
+ });
59
+ return files.map(normalize);
50
60
  } catch (error) {
51
- throw new Error(`Error finding files: ${error}`);
61
+ const absoluteBaseDirForError = resolve(
62
+ normalize(pattern).includes("**") ? normalize(pattern).split("**")[0] : dirname(normalize(pattern))
63
+ );
64
+ const relativePatternForError = relative(absoluteBaseDirForError, normalize(pattern)).replace(/\\/g, "/");
65
+ throw new Error(
66
+ `Error finding files for pattern "${pattern}" (using cwd: "${absoluteBaseDirForError}", globPattern: "${relativePatternForError}"): ${error.message}`
67
+ );
52
68
  }
53
69
  };
54
70
  var readMdxFile = async (path4) => {
@@ -348,7 +364,7 @@ var queryHasVersion = (directory) => async (id, version) => {
348
364
 
349
365
  // src/services.ts
350
366
  import fs5 from "node:fs/promises";
351
- import { join as join6, dirname as dirname4 } from "node:path";
367
+ import { join as join6, dirname as dirname4, extname } from "node:path";
352
368
  var getService = (directory) => async (id, version) => getResource(directory, id, version, { type: "service" });
353
369
  var getServices = (directory) => async (options) => getResources(directory, {
354
370
  type: "services",
@@ -407,6 +423,8 @@ var getSpecificationFilesForService = (directory) => async (id, version) => {
407
423
  };
408
424
  var addMessageToService = (directory) => async (id, direction, event, version) => {
409
425
  let service = await getService(directory)(id, version);
426
+ const servicePath = await getResourcePath(directory, id, version);
427
+ const extension = extname(servicePath?.fullPath || "");
410
428
  if (direction === "sends") {
411
429
  if (service.sends === void 0) {
412
430
  service.sends = [];
@@ -437,7 +455,7 @@ var addMessageToService = (directory) => async (id, direction, event, version) =
437
455
  const path4 = existingResource.split("/services")[0];
438
456
  const pathToResource = join6(path4, "services");
439
457
  await rmServiceById(directory)(id, version);
440
- await writeService(pathToResource)(service);
458
+ await writeService(pathToResource)(service, { format: extension === ".md" ? "md" : "mdx" });
441
459
  };
442
460
  var serviceHasVersion = (directory) => async (id, version) => {
443
461
  const file = await findFileById(directory, id, version);
@@ -495,6 +513,8 @@ var domainHasVersion = (directory) => async (id, version) => {
495
513
  };
496
514
  var addServiceToDomain = (directory) => async (id, service, version) => {
497
515
  let domain = await getDomain(directory)(id, version);
516
+ const domainPath = await getResourcePath(directory, id, version);
517
+ const extension = path.extname(domainPath?.fullPath || "");
498
518
  if (domain.services === void 0) {
499
519
  domain.services = [];
500
520
  }
@@ -504,12 +524,12 @@ var addServiceToDomain = (directory) => async (id, service, version) => {
504
524
  }
505
525
  domain.services.push(service);
506
526
  await rmDomainById(directory)(id, version, true);
507
- await writeDomain(directory)(domain);
527
+ await writeDomain(directory)(domain, { format: extension === ".md" ? "md" : "mdx" });
508
528
  };
509
529
 
510
530
  // src/channels.ts
511
531
  import fs7 from "node:fs/promises";
512
- import { join as join8 } from "node:path";
532
+ import { join as join8, extname as extname2 } from "node:path";
513
533
  var getChannel = (directory) => async (id, version) => getResource(directory, id, version, { type: "channel" });
514
534
  var getChannels = (directory) => async (options) => getResources(directory, { type: "channels", ...options });
515
535
  var writeChannel = (directory) => async (channel, options = { path: "" }) => writeResource(directory, { ...channel }, { ...options, type: "channel" });
@@ -543,6 +563,8 @@ var addMessageToChannel = (directory, collection) => async (id, _message, versio
543
563
  };
544
564
  const { getMessage, rmMessageById, writeMessage } = functions[collection];
545
565
  const message = await getMessage(directory)(_message.id, _message.version);
566
+ const messagePath = await getResourcePath(directory, _message.id, _message.version);
567
+ const extension = extname2(messagePath?.fullPath || "");
546
568
  if (!message) throw new Error(`Message ${_message.id} with version ${_message.version} not found`);
547
569
  if (message.channels === void 0) {
548
570
  message.channels = [];
@@ -556,7 +578,7 @@ var addMessageToChannel = (directory, collection) => async (id, _message, versio
556
578
  const path4 = existingResource.split(`/${collection}`)[0];
557
579
  const pathToResource = join8(path4, collection);
558
580
  await rmMessageById(directory)(_message.id, _message.version, true);
559
- await writeMessage(pathToResource)(message);
581
+ await writeMessage(pathToResource)(message, { format: extension === ".md" ? "md" : "mdx" });
560
582
  };
561
583
 
562
584
  // src/eventcatalog.ts