@tokamohsen/sentry-mcp 0.29.4 → 0.29.6

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 (57) hide show
  1. package/dist/{chunk-C0xms8kb.cjs → chunk-rXqPaSPc.cjs} +26 -0
  2. package/dist/cli/{parse-M8aGwIO5.d.ts → parse-CX7Bcldr.d.ts} +2 -2
  3. package/dist/cli/{parse-M8aGwIO5.d.ts.map → parse-CX7Bcldr.d.ts.map} +1 -1
  4. package/dist/cli/parse.cjs +1 -1
  5. package/dist/cli/{resolve-kNjr_UaF.d.ts → resolve-BVtyZcQM.d.ts} +2 -2
  6. package/dist/cli/resolve-BVtyZcQM.d.ts.map +1 -0
  7. package/dist/cli/resolve.cjs +9 -10
  8. package/dist/cli/resolve.cjs.map +1 -1
  9. package/dist/cli/resolve.js +2 -2
  10. package/dist/cli/{types-B2hDXVnQ.d.ts → types-CnTkIHzd.d.ts} +1 -1
  11. package/dist/cli/{types-B2hDXVnQ.d.ts.map → types-CnTkIHzd.d.ts.map} +1 -1
  12. package/dist/cli/{usage-BMxqEEQ3.d.ts → usage-BhCVaC5j.d.ts} +1 -1
  13. package/dist/cli/usage-BhCVaC5j.d.ts.map +1 -0
  14. package/dist/config-CzqCJmB9.js +613 -0
  15. package/dist/config-CzqCJmB9.js.map +1 -0
  16. package/dist/config-DMt6phB6.cjs +630 -0
  17. package/dist/config-DMt6phB6.cjs.map +1 -0
  18. package/dist/constants-BrEVt86y.js +194 -0
  19. package/dist/constants-BrEVt86y.js.map +1 -0
  20. package/dist/constants-C14tQf_s.cjs +217 -0
  21. package/dist/constants-C14tQf_s.cjs.map +1 -0
  22. package/dist/index.cjs +163 -14
  23. package/dist/index.cjs.map +1 -1
  24. package/dist/index.js +191 -6
  25. package/dist/index.js.map +1 -1
  26. package/dist/server-DduxvXpe.js +32499 -0
  27. package/dist/server-DduxvXpe.js.map +1 -0
  28. package/dist/server-lur5iSHk.cjs +32530 -0
  29. package/dist/server-lur5iSHk.cjs.map +1 -0
  30. package/dist/skills-DOgs9MAy.cjs +96 -0
  31. package/dist/skills-DOgs9MAy.cjs.map +1 -0
  32. package/dist/skills-DfqlqYXj.js +72 -0
  33. package/dist/skills-DfqlqYXj.js.map +1 -0
  34. package/dist/token-CO5Bq1Ct.js +50 -0
  35. package/dist/token-CO5Bq1Ct.js.map +1 -0
  36. package/dist/token-GX19_oyM.cjs +54 -0
  37. package/dist/token-GX19_oyM.cjs.map +1 -0
  38. package/dist/token-util-1O_mwf8r.js +358 -0
  39. package/dist/token-util-1O_mwf8r.js.map +1 -0
  40. package/dist/token-util-Cw83HNFN.cjs +362 -0
  41. package/dist/token-util-Cw83HNFN.cjs.map +1 -0
  42. package/dist/transports/{stdio-DVcJU1wB.d.ts → stdio-DKQR8J7l.d.ts} +1 -1
  43. package/dist/transports/{stdio-DVcJU1wB.d.ts.map → stdio-DKQR8J7l.d.ts.map} +1 -1
  44. package/dist/transports/stdio.cjs +3 -3
  45. package/dist/transports/stdio.js +1 -1
  46. package/dist/url-utils-BHhxlntO.js +119 -0
  47. package/dist/url-utils-BHhxlntO.js.map +1 -0
  48. package/dist/url-utils-N2ExJl9F.cjs +161 -0
  49. package/dist/url-utils-N2ExJl9F.cjs.map +1 -0
  50. package/dist/version-4iOZzjiD.js +7 -0
  51. package/dist/version-4iOZzjiD.js.map +1 -0
  52. package/dist/version-BD4r13ze.cjs +19 -0
  53. package/dist/version-BD4r13ze.cjs.map +1 -0
  54. package/package.json +1 -1
  55. package/dist/cli/resolve-kNjr_UaF.d.ts.map +0 -1
  56. package/dist/cli/usage-BMxqEEQ3.d.ts.map +0 -1
  57. /package/dist/{index-DgNgxUxv.d.ts → index-UKPmYT-S.d.ts} +0 -0
@@ -5,6 +5,20 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
6
  var __getProtoOf = Object.getPrototypeOf;
7
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __commonJSMin = (cb, mod) => () => (mod || cb((mod = { exports: {} }).exports, mod), mod.exports);
9
+ var __exportAll = (all, no_symbols) => {
10
+ let target = {};
11
+ for (var name in all) {
12
+ __defProp(target, name, {
13
+ get: all[name],
14
+ enumerable: true
15
+ });
16
+ }
17
+ if (!no_symbols) {
18
+ __defProp(target, Symbol.toStringTag, { value: "Module" });
19
+ }
20
+ return target;
21
+ };
8
22
  var __copyProps = (to, from, except, desc) => {
9
23
  if (from && typeof from === "object" || typeof from === "function") {
10
24
  for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
@@ -26,6 +40,18 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
26
40
 
27
41
  //#endregion
28
42
 
43
+ Object.defineProperty(exports, '__commonJSMin', {
44
+ enumerable: true,
45
+ get: function () {
46
+ return __commonJSMin;
47
+ }
48
+ });
49
+ Object.defineProperty(exports, '__exportAll', {
50
+ enumerable: true,
51
+ get: function () {
52
+ return __exportAll;
53
+ }
54
+ });
29
55
  Object.defineProperty(exports, '__toESM', {
30
56
  enumerable: true,
31
57
  get: function () {
@@ -1,4 +1,4 @@
1
- import { CliArgs, EnvArgs, MergedArgs } from "./types-B2hDXVnQ.js";
1
+ import { CliArgs, EnvArgs, MergedArgs } from "./types-CnTkIHzd.js";
2
2
 
3
3
  //#region src/cli/parse.d.ts
4
4
  declare function parseArgv(argv: string[]): CliArgs;
@@ -8,4 +8,4 @@ declare function merge(cli: CliArgs, env: EnvArgs): MergedArgs;
8
8
 
9
9
  //#endregion
10
10
  export { merge, parseArgv, parseEnv };
11
- //# sourceMappingURL=parse-M8aGwIO5.d.ts.map
11
+ //# sourceMappingURL=parse-CX7Bcldr.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"parse-M8aGwIO5.d.ts","names":[],"sources":["../../src/cli/parse.ts"],"sourcesContent":[],"mappings":";;;iBAGgB,SAAA,kBAA2B;iBAuE3B,QAAA,MAAc,MAAA,CAAO,aAAa;AAvElC,iBAwFA,KAAA,CAxF2B,GAAA,EAwFhB,OAxFuB,EAAA,GAAA,EAwFT,OAxFS,CAAA,EAwFC,UAxFD;AAuElD"}
1
+ {"version":3,"file":"parse-CX7Bcldr.d.ts","names":[],"sources":["../../src/cli/parse.ts"],"sourcesContent":[],"mappings":";;;iBAGgB,SAAA,kBAA2B;iBAuE3B,QAAA,MAAc,MAAA,CAAO,aAAa;AAvElC,iBAwFA,KAAA,CAxF2B,GAAA,EAwFhB,OAxFuB,EAAA,GAAA,EAwFT,OAxFS,CAAA,EAwFC,UAxFD;AAuElD"}
@@ -1,5 +1,5 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_chunk = require('../chunk-C0xms8kb.cjs');
2
+ const require_chunk = require('../chunk-rXqPaSPc.cjs');
3
3
  let node_util = require("node:util");
4
4
 
5
5
  //#region src/cli/parse.ts
@@ -1,4 +1,4 @@
1
- import { MergedArgs, ResolvedConfig } from "./types-B2hDXVnQ.js";
1
+ import { MergedArgs, ResolvedConfig } from "./types-CnTkIHzd.js";
2
2
 
3
3
  //#region src/cli/resolve.d.ts
4
4
  declare function formatInvalidSkills(invalid: string[], envName?: string): string;
@@ -7,4 +7,4 @@ declare function finalize(input: MergedArgs): ResolvedConfig;
7
7
 
8
8
  //#endregion
9
9
  export { finalize, formatInvalidSkills };
10
- //# sourceMappingURL=resolve-kNjr_UaF.d.ts.map
10
+ //# sourceMappingURL=resolve-BVtyZcQM.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolve-BVtyZcQM.d.ts","names":[],"sources":["../../src/cli/resolve.ts"],"sourcesContent":[],"mappings":";;;iBAQgB,mBAAA;iBASA,QAAA,QAAgB,aAAa;AAT7C"}
@@ -1,34 +1,33 @@
1
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
- const require_chunk = require('../chunk-C0xms8kb.cjs');
3
- let _sentry_mcp_core_skills = require("@sentry/mcp-core/skills");
4
- let _sentry_mcp_core_utils_url_utils = require("@sentry/mcp-core/utils/url-utils");
2
+ const require_skills = require('../skills-DOgs9MAy.cjs');
3
+ const require_url_utils = require('../url-utils-N2ExJl9F.cjs');
5
4
 
6
5
  //#region src/cli/resolve.ts
7
6
  function formatInvalidSkills(invalid, envName) {
8
7
  const where = envName ? `${envName} provided` : "Invalid skills provided";
9
- const allSkills = Object.keys(_sentry_mcp_core_skills.SKILLS).join(", ");
8
+ const allSkills = Object.keys(require_skills.SKILLS).join(", ");
10
9
  return `Error: ${where}: ${invalid.join(", ")}\nAvailable skills: ${allSkills}`;
11
10
  }
12
11
  function finalize(input) {
13
12
  if (!input.accessToken) throw new Error("Error: No access token was provided. Pass one with `--access-token` or via `SENTRY_ACCESS_TOKEN`.");
14
13
  let sentryHost = "sentry.io";
15
- if (input.url) sentryHost = (0, _sentry_mcp_core_utils_url_utils.validateAndParseSentryUrlThrows)(input.url);
14
+ if (input.url) sentryHost = require_url_utils.validateAndParseSentryUrlThrows(input.url);
16
15
  else if (input.host) {
17
- (0, _sentry_mcp_core_utils_url_utils.validateSentryHostThrows)(input.host);
16
+ require_url_utils.validateSentryHostThrows(input.host);
18
17
  sentryHost = input.host;
19
18
  }
20
19
  let finalSkills = void 0;
21
20
  if (input.skills) {
22
- const { valid, invalid } = (0, _sentry_mcp_core_skills.parseSkills)(input.skills);
21
+ const { valid, invalid } = require_skills.parseSkills(input.skills);
23
22
  if (invalid.length > 0) throw new Error(formatInvalidSkills(invalid));
24
23
  if (valid.size === 0) throw new Error("Error: Invalid skills provided. No valid skills found.");
25
24
  finalSkills = valid;
26
25
  } else {
27
- const allSkills = Object.keys(_sentry_mcp_core_skills.SKILLS);
26
+ const allSkills = Object.keys(require_skills.SKILLS);
28
27
  finalSkills = new Set(allSkills);
29
28
  }
30
- const resolvedOpenAiBaseUrl = input.openaiBaseUrl ? (0, _sentry_mcp_core_utils_url_utils.validateOpenAiBaseUrlThrows)(input.openaiBaseUrl) : void 0;
31
- const resolvedAnthropicBaseUrl = input.anthropicBaseUrl ? (0, _sentry_mcp_core_utils_url_utils.validateOpenAiBaseUrlThrows)(input.anthropicBaseUrl) : void 0;
29
+ const resolvedOpenAiBaseUrl = input.openaiBaseUrl ? require_url_utils.validateOpenAiBaseUrlThrows(input.openaiBaseUrl) : void 0;
30
+ const resolvedAnthropicBaseUrl = input.anthropicBaseUrl ? require_url_utils.validateOpenAiBaseUrlThrows(input.anthropicBaseUrl) : void 0;
32
31
  let agentProvider = void 0;
33
32
  if (input.agentProvider) {
34
33
  const provider = input.agentProvider.toLowerCase();
@@ -1 +1 @@
1
- {"version":3,"file":"resolve.cjs","names":["SKILLS"],"sources":["../../src/cli/resolve.ts"],"sourcesContent":["import { parseSkills, SKILLS, type Skill } from \"@sentry/mcp-core/skills\";\nimport {\n validateAndParseSentryUrlThrows,\n validateOpenAiBaseUrlThrows,\n validateSentryHostThrows,\n} from \"@sentry/mcp-core/utils/url-utils\";\nimport type { MergedArgs, ResolvedConfig } from \"./types\";\n\nexport function formatInvalidSkills(\n invalid: string[],\n envName?: string,\n): string {\n const where = envName ? `${envName} provided` : \"Invalid skills provided\";\n const allSkills = Object.keys(SKILLS).join(\", \");\n return `Error: ${where}: ${invalid.join(\", \")}\\nAvailable skills: ${allSkills}`;\n}\n\nexport function finalize(input: MergedArgs): ResolvedConfig {\n // Access token required\n if (!input.accessToken) {\n throw new Error(\n \"Error: No access token was provided. Pass one with `--access-token` or via `SENTRY_ACCESS_TOKEN`.\",\n );\n }\n\n // Determine host from url/host with validation\n let sentryHost = \"sentry.io\";\n if (input.url) {\n sentryHost = validateAndParseSentryUrlThrows(input.url);\n } else if (input.host) {\n validateSentryHostThrows(input.host);\n sentryHost = input.host;\n }\n\n // Skills resolution\n //\n // IMPORTANT: stdio (CLI) intentionally defaults to ALL skills when no --skills flag is provided\n //\n // This differs from the OAuth flow, which requires explicit user selection:\n // - stdio/CLI: Non-interactive, defaults to ALL skills (inspect, docs, seer, triage, project-management)\n // - OAuth: Interactive, requires user to explicitly select skills (with sensible defaults pre-checked)\n //\n // Rationale:\n // We don't want the MCP to break if users don't specify skills. stdio is typically used in\n // local development and CI/CD environments where maximum access by default is expected.\n // OAuth is used in multi-tenant hosted environments where users should consciously grant\n // permissions on a per-app basis.\n //\n // For OAuth validation that enforces minimum 1 skill selection, see:\n // packages/mcp-cloudflare/src/server/oauth/routes/callback.ts (lines 234-248)\n //\n let finalSkills: Set<Skill> | undefined = undefined;\n if (input.skills) {\n // Override: use only the specified skills\n const { valid, invalid } = parseSkills(input.skills);\n if (invalid.length > 0) {\n throw new Error(formatInvalidSkills(invalid));\n }\n if (valid.size === 0) {\n throw new Error(\"Error: Invalid skills provided. No valid skills found.\");\n }\n finalSkills = valid;\n } else {\n // Default: grant ALL skills when no flag is provided (see comment block above for rationale)\n const allSkills = Object.keys(SKILLS) as Skill[];\n finalSkills = new Set<Skill>(allSkills);\n }\n\n const resolvedOpenAiBaseUrl = input.openaiBaseUrl\n ? validateOpenAiBaseUrlThrows(input.openaiBaseUrl)\n : undefined;\n\n // Validate anthropic base URL if provided (same validation as OpenAI)\n const resolvedAnthropicBaseUrl = input.anthropicBaseUrl\n ? validateOpenAiBaseUrlThrows(input.anthropicBaseUrl)\n : undefined;\n\n // Validate agent provider if explicitly set\n let agentProvider: \"openai\" | \"anthropic\" | undefined = undefined;\n if (input.agentProvider) {\n const provider = input.agentProvider.toLowerCase();\n if (provider !== \"openai\" && provider !== \"anthropic\") {\n throw new Error(\n `Error: Invalid agent provider \"${input.agentProvider}\". Must be \"openai\" or \"anthropic\".`,\n );\n }\n agentProvider = provider;\n }\n\n return {\n accessToken: input.accessToken,\n sentryHost,\n mcpUrl: input.mcpUrl,\n sentryDsn: input.sentryDsn,\n openaiBaseUrl: resolvedOpenAiBaseUrl,\n openaiModel: input.openaiModel,\n anthropicBaseUrl: resolvedAnthropicBaseUrl,\n anthropicModel: input.anthropicModel,\n agentProvider,\n finalSkills,\n organizationSlug: input.organizationSlug,\n projectSlug: input.projectSlug,\n };\n}\n"],"mappings":";;;;;;AAQA,SAAgB,oBACd,SACA,SACQ;CACR,MAAM,QAAQ,UAAU,GAAG,QAAQ,aAAa;CAChD,MAAM,YAAY,OAAO,KAAKA,+BAAO,CAAC,KAAK,KAAK;AAChD,QAAO,UAAU,MAAM,IAAI,QAAQ,KAAK,KAAK,CAAC,sBAAsB;;AAGtE,SAAgB,SAAS,OAAmC;AAE1D,KAAI,CAAC,MAAM,YACT,OAAM,IAAI,MACR,oGACD;CAIH,IAAI,aAAa;AACjB,KAAI,MAAM,IACR,oFAA6C,MAAM,IAAI;UAC9C,MAAM,MAAM;AACrB,iEAAyB,MAAM,KAAK;AACpC,eAAa,MAAM;;CAoBrB,IAAI,cAAsC;AAC1C,KAAI,MAAM,QAAQ;EAEhB,MAAM,EAAE,OAAO,qDAAwB,MAAM,OAAO;AACpD,MAAI,QAAQ,SAAS,EACnB,OAAM,IAAI,MAAM,oBAAoB,QAAQ,CAAC;AAE/C,MAAI,MAAM,SAAS,EACjB,OAAM,IAAI,MAAM,yDAAyD;AAE3E,gBAAc;QACT;EAEL,MAAM,YAAY,OAAO,KAAKA,+BAAO;AACrC,gBAAc,IAAI,IAAW,UAAU;;CAGzC,MAAM,wBAAwB,MAAM,kFACJ,MAAM,cAAc,GAChD;CAGJ,MAAM,2BAA2B,MAAM,qFACP,MAAM,iBAAiB,GACnD;CAGJ,IAAI,gBAAoD;AACxD,KAAI,MAAM,eAAe;EACvB,MAAM,WAAW,MAAM,cAAc,aAAa;AAClD,MAAI,aAAa,YAAY,aAAa,YACxC,OAAM,IAAI,MACR,kCAAkC,MAAM,cAAc,qCACvD;AAEH,kBAAgB;;AAGlB,QAAO;EACL,aAAa,MAAM;EACnB;EACA,QAAQ,MAAM;EACd,WAAW,MAAM;EACjB,eAAe;EACf,aAAa,MAAM;EACnB,kBAAkB;EAClB,gBAAgB,MAAM;EACtB;EACA;EACA,kBAAkB,MAAM;EACxB,aAAa,MAAM;EACpB"}
1
+ {"version":3,"file":"resolve.cjs","names":["SKILLS","validateAndParseSentryUrlThrows","parseSkills","validateOpenAiBaseUrlThrows"],"sources":["../../src/cli/resolve.ts"],"sourcesContent":["import { parseSkills, SKILLS, type Skill } from \"@sentry/mcp-core/skills\";\nimport {\n validateAndParseSentryUrlThrows,\n validateOpenAiBaseUrlThrows,\n validateSentryHostThrows,\n} from \"@sentry/mcp-core/utils/url-utils\";\nimport type { MergedArgs, ResolvedConfig } from \"./types\";\n\nexport function formatInvalidSkills(\n invalid: string[],\n envName?: string,\n): string {\n const where = envName ? `${envName} provided` : \"Invalid skills provided\";\n const allSkills = Object.keys(SKILLS).join(\", \");\n return `Error: ${where}: ${invalid.join(\", \")}\\nAvailable skills: ${allSkills}`;\n}\n\nexport function finalize(input: MergedArgs): ResolvedConfig {\n // Access token required\n if (!input.accessToken) {\n throw new Error(\n \"Error: No access token was provided. Pass one with `--access-token` or via `SENTRY_ACCESS_TOKEN`.\",\n );\n }\n\n // Determine host from url/host with validation\n let sentryHost = \"sentry.io\";\n if (input.url) {\n sentryHost = validateAndParseSentryUrlThrows(input.url);\n } else if (input.host) {\n validateSentryHostThrows(input.host);\n sentryHost = input.host;\n }\n\n // Skills resolution\n //\n // IMPORTANT: stdio (CLI) intentionally defaults to ALL skills when no --skills flag is provided\n //\n // This differs from the OAuth flow, which requires explicit user selection:\n // - stdio/CLI: Non-interactive, defaults to ALL skills (inspect, docs, seer, triage, project-management)\n // - OAuth: Interactive, requires user to explicitly select skills (with sensible defaults pre-checked)\n //\n // Rationale:\n // We don't want the MCP to break if users don't specify skills. stdio is typically used in\n // local development and CI/CD environments where maximum access by default is expected.\n // OAuth is used in multi-tenant hosted environments where users should consciously grant\n // permissions on a per-app basis.\n //\n // For OAuth validation that enforces minimum 1 skill selection, see:\n // packages/mcp-cloudflare/src/server/oauth/routes/callback.ts (lines 234-248)\n //\n let finalSkills: Set<Skill> | undefined = undefined;\n if (input.skills) {\n // Override: use only the specified skills\n const { valid, invalid } = parseSkills(input.skills);\n if (invalid.length > 0) {\n throw new Error(formatInvalidSkills(invalid));\n }\n if (valid.size === 0) {\n throw new Error(\"Error: Invalid skills provided. No valid skills found.\");\n }\n finalSkills = valid;\n } else {\n // Default: grant ALL skills when no flag is provided (see comment block above for rationale)\n const allSkills = Object.keys(SKILLS) as Skill[];\n finalSkills = new Set<Skill>(allSkills);\n }\n\n const resolvedOpenAiBaseUrl = input.openaiBaseUrl\n ? validateOpenAiBaseUrlThrows(input.openaiBaseUrl)\n : undefined;\n\n // Validate anthropic base URL if provided (same validation as OpenAI)\n const resolvedAnthropicBaseUrl = input.anthropicBaseUrl\n ? validateOpenAiBaseUrlThrows(input.anthropicBaseUrl)\n : undefined;\n\n // Validate agent provider if explicitly set\n let agentProvider: \"openai\" | \"anthropic\" | undefined = undefined;\n if (input.agentProvider) {\n const provider = input.agentProvider.toLowerCase();\n if (provider !== \"openai\" && provider !== \"anthropic\") {\n throw new Error(\n `Error: Invalid agent provider \"${input.agentProvider}\". Must be \"openai\" or \"anthropic\".`,\n );\n }\n agentProvider = provider;\n }\n\n return {\n accessToken: input.accessToken,\n sentryHost,\n mcpUrl: input.mcpUrl,\n sentryDsn: input.sentryDsn,\n openaiBaseUrl: resolvedOpenAiBaseUrl,\n openaiModel: input.openaiModel,\n anthropicBaseUrl: resolvedAnthropicBaseUrl,\n anthropicModel: input.anthropicModel,\n agentProvider,\n finalSkills,\n organizationSlug: input.organizationSlug,\n projectSlug: input.projectSlug,\n };\n}\n"],"mappings":";;;;;AAQA,SAAgB,oBACd,SACA,SACQ;CACR,MAAM,QAAQ,UAAU,GAAG,QAAQ,aAAa;CAChD,MAAM,YAAY,OAAO,KAAKA,sBAAO,CAAC,KAAK,KAAK;AAChD,QAAO,UAAU,MAAM,IAAI,QAAQ,KAAK,KAAK,CAAC,sBAAsB;;AAGtE,SAAgB,SAAS,OAAmC;AAE1D,KAAI,CAAC,MAAM,YACT,OAAM,IAAI,MACR,oGACD;CAIH,IAAI,aAAa;AACjB,KAAI,MAAM,IACR,cAAaC,kDAAgC,MAAM,IAAI;UAC9C,MAAM,MAAM;AACrB,6CAAyB,MAAM,KAAK;AACpC,eAAa,MAAM;;CAoBrB,IAAI,cAAsC;AAC1C,KAAI,MAAM,QAAQ;EAEhB,MAAM,EAAE,OAAO,YAAYC,2BAAY,MAAM,OAAO;AACpD,MAAI,QAAQ,SAAS,EACnB,OAAM,IAAI,MAAM,oBAAoB,QAAQ,CAAC;AAE/C,MAAI,MAAM,SAAS,EACjB,OAAM,IAAI,MAAM,yDAAyD;AAE3E,gBAAc;QACT;EAEL,MAAM,YAAY,OAAO,KAAKF,sBAAO;AACrC,gBAAc,IAAI,IAAW,UAAU;;CAGzC,MAAM,wBAAwB,MAAM,gBAChCG,8CAA4B,MAAM,cAAc,GAChD;CAGJ,MAAM,2BAA2B,MAAM,mBACnCA,8CAA4B,MAAM,iBAAiB,GACnD;CAGJ,IAAI,gBAAoD;AACxD,KAAI,MAAM,eAAe;EACvB,MAAM,WAAW,MAAM,cAAc,aAAa;AAClD,MAAI,aAAa,YAAY,aAAa,YACxC,OAAM,IAAI,MACR,kCAAkC,MAAM,cAAc,qCACvD;AAEH,kBAAgB;;AAGlB,QAAO;EACL,aAAa,MAAM;EACnB;EACA,QAAQ,MAAM;EACd,WAAW,MAAM;EACjB,eAAe;EACf,aAAa,MAAM;EACnB,kBAAkB;EAClB,gBAAgB,MAAM;EACtB;EACA;EACA,kBAAkB,MAAM;EACxB,aAAa,MAAM;EACpB"}
@@ -1,5 +1,5 @@
1
- import { SKILLS, parseSkills } from "@sentry/mcp-core/skills";
2
- import { validateAndParseSentryUrlThrows, validateOpenAiBaseUrlThrows, validateSentryHostThrows } from "@sentry/mcp-core/utils/url-utils";
1
+ import { i as parseSkills, n as SKILLS } from "../skills-DfqlqYXj.js";
2
+ import { a as validateAndParseSentryUrlThrows, o as validateOpenAiBaseUrlThrows, s as validateSentryHostThrows } from "../url-utils-BHhxlntO.js";
3
3
 
4
4
  //#region src/cli/resolve.ts
5
5
  function formatInvalidSkills(invalid, envName) {
@@ -70,4 +70,4 @@ type ResolvedConfig = {
70
70
  //# sourceMappingURL=types.d.ts.map
71
71
  //#endregion
72
72
  export { CliArgs, EnvArgs, MergedArgs, ResolvedConfig };
73
- //# sourceMappingURL=types-B2hDXVnQ.d.ts.map
73
+ //# sourceMappingURL=types-CnTkIHzd.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types-B2hDXVnQ.d.ts","names":[],"sources":["../../src/cli/types.ts"],"sourcesContent":[],"mappings":";;;KAEY,OAAA;;EAAA,IAAA,CAAA,EAAA,MAAO;EAqBP,GAAA,CAAA,EAAA,MAAO;EAYP,MAAA,CAAA,EAAA,MAAU;EAqBV,SAAA,CAAA,EAAA,MAAc;EAAA,aAAA,CAAA,EAAA,MAAA;aAWN,CAAA,EAAA,MAAA;kBAAJ,CAAA,EAAA,MAAA;EAAG,cAAA,CAAA,EAAA,MAAA;;;;;;;;;;;KA5CP,OAAA;;;;;;;;;;;KAYA,UAAA;;;;;;;;;;;;;;;;;;;;KAqBA,cAAA;;;;;;;;;;;gBAWI,IAAI"}
1
+ {"version":3,"file":"types-CnTkIHzd.d.ts","names":[],"sources":["../../src/cli/types.ts"],"sourcesContent":[],"mappings":";;;KAEY,OAAA;;EAAA,IAAA,CAAA,EAAA,MAAO;EAqBP,GAAA,CAAA,EAAA,MAAO;EAYP,MAAA,CAAA,EAAA,MAAU;EAqBV,SAAA,CAAA,EAAA,MAAc;EAAA,aAAA,CAAA,EAAA,MAAA;aAWN,CAAA,EAAA,MAAA;kBAAJ,CAAA,EAAA,MAAA;EAAG,cAAA,CAAA,EAAA,MAAA;;;;;;;;;;;KA5CP,OAAA;;;;;;;;;;;KAYA,UAAA;;;;;;;;;;;;;;;;;;;;KAqBA,cAAA;;;;;;;;;;;gBAWI,IAAI"}
@@ -6,4 +6,4 @@ declare function buildUsage(packageName: string, allSkills: ReadonlyArray<Skill>
6
6
 
7
7
  //#endregion
8
8
  export { buildUsage };
9
- //# sourceMappingURL=usage-BMxqEEQ3.d.ts.map
9
+ //# sourceMappingURL=usage-BhCVaC5j.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usage-BhCVaC5j.d.ts","names":[],"sources":["../../src/cli/usage.ts"],"sourcesContent":[],"mappings":";;;iBAEgB,UAAA,iCAEH,cAAc"}