@bookedsolid/reagent 0.3.0 → 0.5.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 (196) hide show
  1. package/README.md +552 -118
  2. package/agents/ai-platforms/ai-anthropic-specialist.md +1 -1
  3. package/agents/ai-platforms/ai-fine-tuning-specialist.md +1 -1
  4. package/agents/ai-platforms/ai-gemini-specialist.md +1 -1
  5. package/agents/ai-platforms/ai-mcp-developer.md +1 -1
  6. package/agents/ai-platforms/ai-multi-modal-specialist.md +1 -1
  7. package/agents/ai-platforms/ai-open-source-models-specialist.md +1 -1
  8. package/agents/ai-platforms/ai-openai-specialist.md +1 -1
  9. package/agents/ai-platforms/ai-platform-strategist.md +1 -1
  10. package/agents/ai-platforms/ai-prompt-engineer.md +1 -1
  11. package/agents/ai-platforms/ai-rag-architect.md +1 -1
  12. package/agents/ai-platforms/ai-rea.md +2 -2
  13. package/agents/ai-platforms/ai-safety-reviewer.md +1 -1
  14. package/agents/engineering/accessibility-engineer.md +1 -1
  15. package/agents/engineering/aws-architect.md +1 -1
  16. package/agents/engineering/backend-engineer-payments.md +1 -1
  17. package/agents/engineering/backend-engineering-manager.md +1 -1
  18. package/agents/engineering/code-reviewer.md +1 -1
  19. package/agents/engineering/css3-animation-purist.md +1 -1
  20. package/agents/engineering/data-engineer.md +1 -1
  21. package/agents/engineering/database-architect.md +1 -1
  22. package/agents/engineering/design-system-developer.md +1 -1
  23. package/agents/engineering/design-systems-animator.md +1 -1
  24. package/agents/engineering/devops-engineer.md +1 -1
  25. package/agents/engineering/drupal-integration-specialist.md +1 -1
  26. package/agents/engineering/drupal-specialist.md +1 -1
  27. package/agents/engineering/engineering-manager-frontend.md +1 -1
  28. package/agents/engineering/frontend-specialist.md +1 -1
  29. package/agents/engineering/infrastructure-engineer.md +1 -1
  30. package/agents/engineering/lit-specialist.md +1 -1
  31. package/agents/engineering/migration-specialist.md +1 -1
  32. package/agents/engineering/ml-engineer.md +1 -1
  33. package/agents/engineering/mobile-engineer.md +1 -1
  34. package/agents/engineering/motion-designer-interactive.md +1 -1
  35. package/agents/engineering/nextjs-specialist.md +1 -1
  36. package/agents/engineering/open-source-specialist.md +1 -1
  37. package/agents/engineering/performance-engineer.md +1 -1
  38. package/agents/engineering/performance-qa-engineer.md +1 -1
  39. package/agents/engineering/pr-maintainer.md +1 -1
  40. package/agents/engineering/principal-engineer.md +1 -1
  41. package/agents/engineering/privacy-engineer.md +1 -1
  42. package/agents/engineering/qa-engineer.md +1 -1
  43. package/agents/engineering/security-engineer.md +1 -1
  44. package/agents/engineering/security-qa-engineer.md +1 -1
  45. package/agents/engineering/senior-backend-engineer.md +1 -1
  46. package/agents/engineering/senior-database-engineer.md +1 -1
  47. package/agents/engineering/senior-frontend-engineer.md +1 -1
  48. package/agents/engineering/senior-product-manager-platform.md +1 -1
  49. package/agents/engineering/senior-technical-project-manager.md +1 -1
  50. package/agents/engineering/site-reliability-engineer-2.md +1 -1
  51. package/agents/engineering/solutions-architect.md +1 -1
  52. package/agents/engineering/sre-lead.md +1 -1
  53. package/agents/engineering/staff-engineer-platform.md +1 -1
  54. package/agents/engineering/staff-software-engineer.md +1 -1
  55. package/agents/engineering/storybook-specialist.md +1 -1
  56. package/agents/engineering/supabase-specialist.md +1 -1
  57. package/agents/engineering/technical-project-manager.md +1 -1
  58. package/agents/engineering/technical-writer.md +1 -1
  59. package/agents/engineering/test-architect.md +1 -1
  60. package/agents/engineering/typescript-specialist.md +1 -1
  61. package/agents/engineering/ux-researcher.md +1 -1
  62. package/agents/engineering/vp-engineering.md +1 -1
  63. package/agents/product-owner.md +44 -0
  64. package/commands/plan-work.md +19 -0
  65. package/commands/tasks.md +26 -0
  66. package/dist/cli/commands/cache.d.ts +2 -0
  67. package/dist/cli/commands/cache.d.ts.map +1 -0
  68. package/dist/cli/commands/cache.js +114 -0
  69. package/dist/cli/commands/cache.js.map +1 -0
  70. package/dist/cli/commands/init/agents.d.ts +3 -0
  71. package/dist/cli/commands/init/agents.d.ts.map +1 -0
  72. package/dist/cli/commands/init/agents.js +47 -0
  73. package/dist/cli/commands/init/agents.js.map +1 -0
  74. package/dist/cli/commands/init/claude-hooks.d.ts +3 -0
  75. package/dist/cli/commands/init/claude-hooks.d.ts.map +1 -0
  76. package/dist/cli/commands/init/claude-hooks.js +134 -0
  77. package/dist/cli/commands/init/claude-hooks.js.map +1 -0
  78. package/dist/cli/commands/init/claude-md.d.ts +3 -0
  79. package/dist/cli/commands/init/claude-md.d.ts.map +1 -0
  80. package/dist/cli/commands/init/claude-md.js +52 -0
  81. package/dist/cli/commands/init/claude-md.js.map +1 -0
  82. package/dist/cli/commands/init/commands.d.ts +3 -0
  83. package/dist/cli/commands/init/commands.d.ts.map +1 -0
  84. package/dist/cli/commands/init/commands.js +31 -0
  85. package/dist/cli/commands/init/commands.js.map +1 -0
  86. package/dist/cli/commands/init/cursor-rules.d.ts +3 -0
  87. package/dist/cli/commands/init/cursor-rules.d.ts.map +1 -0
  88. package/dist/cli/commands/init/cursor-rules.js +30 -0
  89. package/dist/cli/commands/init/cursor-rules.js.map +1 -0
  90. package/dist/cli/commands/init/gateway-config.d.ts +3 -0
  91. package/dist/cli/commands/init/gateway-config.d.ts.map +1 -0
  92. package/dist/cli/commands/init/gateway-config.js +51 -0
  93. package/dist/cli/commands/init/gateway-config.js.map +1 -0
  94. package/dist/cli/commands/init/gitignore.d.ts +3 -0
  95. package/dist/cli/commands/init/gitignore.d.ts.map +1 -0
  96. package/dist/cli/commands/init/gitignore.js +20 -0
  97. package/dist/cli/commands/init/gitignore.js.map +1 -0
  98. package/dist/cli/commands/init/husky-hooks.d.ts +3 -0
  99. package/dist/cli/commands/init/husky-hooks.d.ts.map +1 -0
  100. package/dist/cli/commands/init/husky-hooks.js +73 -0
  101. package/dist/cli/commands/init/husky-hooks.js.map +1 -0
  102. package/dist/cli/commands/{init.d.ts → init/index.d.ts} +1 -1
  103. package/dist/cli/commands/init/index.d.ts.map +1 -0
  104. package/dist/cli/commands/init/index.js +121 -0
  105. package/dist/cli/commands/init/index.js.map +1 -0
  106. package/dist/cli/commands/init/pm.d.ts +9 -0
  107. package/dist/cli/commands/init/pm.d.ts.map +1 -0
  108. package/dist/cli/commands/init/pm.js +40 -0
  109. package/dist/cli/commands/init/pm.js.map +1 -0
  110. package/dist/cli/commands/init/policy.d.ts +3 -0
  111. package/dist/cli/commands/init/policy.d.ts.map +1 -0
  112. package/dist/cli/commands/init/policy.js +61 -0
  113. package/dist/cli/commands/init/policy.js.map +1 -0
  114. package/dist/cli/commands/init/types.d.ts +29 -0
  115. package/dist/cli/commands/init/types.d.ts.map +1 -0
  116. package/dist/cli/commands/init/types.js +2 -0
  117. package/dist/cli/commands/init/types.js.map +1 -0
  118. package/dist/cli/index.js +6 -1
  119. package/dist/cli/index.js.map +1 -1
  120. package/dist/config/gateway-config.d.ts.map +1 -1
  121. package/dist/config/gateway-config.js +5 -1
  122. package/dist/config/gateway-config.js.map +1 -1
  123. package/dist/config/policy-loader.d.ts.map +1 -1
  124. package/dist/config/policy-loader.js +15 -1
  125. package/dist/config/policy-loader.js.map +1 -1
  126. package/dist/config/tier-map.d.ts +1 -1
  127. package/dist/config/tier-map.d.ts.map +1 -1
  128. package/dist/config/tier-map.js +38 -5
  129. package/dist/config/tier-map.js.map +1 -1
  130. package/dist/gateway/client-manager.d.ts.map +1 -1
  131. package/dist/gateway/client-manager.js +9 -3
  132. package/dist/gateway/client-manager.js.map +1 -1
  133. package/dist/gateway/middleware/audit.d.ts +2 -1
  134. package/dist/gateway/middleware/audit.d.ts.map +1 -1
  135. package/dist/gateway/middleware/audit.js +57 -46
  136. package/dist/gateway/middleware/audit.js.map +1 -1
  137. package/dist/gateway/middleware/blocked-paths.d.ts +13 -0
  138. package/dist/gateway/middleware/blocked-paths.d.ts.map +1 -0
  139. package/dist/gateway/middleware/blocked-paths.js +118 -0
  140. package/dist/gateway/middleware/blocked-paths.js.map +1 -0
  141. package/dist/gateway/middleware/policy.d.ts +3 -1
  142. package/dist/gateway/middleware/policy.d.ts.map +1 -1
  143. package/dist/gateway/middleware/policy.js +22 -3
  144. package/dist/gateway/middleware/policy.js.map +1 -1
  145. package/dist/gateway/middleware/redact.d.ts.map +1 -1
  146. package/dist/gateway/middleware/redact.js +18 -5
  147. package/dist/gateway/middleware/redact.js.map +1 -1
  148. package/dist/gateway/native-tools.d.ts +8 -0
  149. package/dist/gateway/native-tools.d.ts.map +1 -0
  150. package/dist/gateway/native-tools.js +190 -0
  151. package/dist/gateway/native-tools.js.map +1 -0
  152. package/dist/gateway/server.d.ts.map +1 -1
  153. package/dist/gateway/server.js +14 -7
  154. package/dist/gateway/server.js.map +1 -1
  155. package/dist/gateway/tool-proxy.d.ts.map +1 -1
  156. package/dist/gateway/tool-proxy.js +18 -6
  157. package/dist/gateway/tool-proxy.js.map +1 -1
  158. package/dist/pm/github-bridge.d.ts +36 -0
  159. package/dist/pm/github-bridge.d.ts.map +1 -0
  160. package/dist/pm/github-bridge.js +138 -0
  161. package/dist/pm/github-bridge.js.map +1 -0
  162. package/dist/pm/task-store.d.ts +39 -0
  163. package/dist/pm/task-store.d.ts.map +1 -0
  164. package/dist/pm/task-store.js +189 -0
  165. package/dist/pm/task-store.js.map +1 -0
  166. package/dist/pm/types.d.ts +70 -0
  167. package/dist/pm/types.d.ts.map +1 -0
  168. package/dist/pm/types.js +22 -0
  169. package/dist/pm/types.js.map +1 -0
  170. package/dist/types/enums.d.ts +0 -4
  171. package/dist/types/enums.d.ts.map +1 -1
  172. package/dist/types/enums.js +0 -5
  173. package/dist/types/enums.js.map +1 -1
  174. package/dist/types/index.d.ts +1 -1
  175. package/dist/types/index.d.ts.map +1 -1
  176. package/dist/types/index.js +1 -1
  177. package/dist/types/index.js.map +1 -1
  178. package/hooks/_lib/common.sh +87 -0
  179. package/hooks/architecture-review-gate.sh +84 -0
  180. package/hooks/attribution-advisory.sh +1 -1
  181. package/hooks/blocked-paths-enforcer.sh +169 -0
  182. package/hooks/commit-review-gate.sh +131 -0
  183. package/hooks/dangerous-bash-interceptor.sh +33 -1
  184. package/hooks/dependency-audit-gate.sh +118 -0
  185. package/hooks/env-file-protection.sh +1 -1
  186. package/hooks/push-review-gate.sh +105 -0
  187. package/hooks/secret-scanner.sh +1 -1
  188. package/hooks/settings-protection.sh +145 -0
  189. package/hooks/task-link-gate.sh +70 -0
  190. package/package.json +16 -1
  191. package/profiles/bst-internal.json +21 -4
  192. package/profiles/client-engagement.json +20 -3
  193. package/templates/CLAUDE.md +14 -1
  194. package/dist/cli/commands/init.d.ts.map +0 -1
  195. package/dist/cli/commands/init.js +0 -511
  196. package/dist/cli/commands/init.js.map +0 -1
@@ -53,6 +53,14 @@ export function redactSecrets(input) {
53
53
  * could corrupt the result if a replacement changes JSON structure.
54
54
  */
55
55
  export const redactMiddleware = async (ctx, next) => {
56
+ // SECURITY: Pre-execution — scan arguments for secrets before they reach the downstream tool.
57
+ if (ctx.arguments) {
58
+ const argRedacted = [];
59
+ redactDeep(ctx.arguments, argRedacted);
60
+ if (argRedacted.length > 0) {
61
+ ctx.redacted_fields = [...new Set(argRedacted)];
62
+ }
63
+ }
56
64
  await next();
57
65
  if (ctx.result == null)
58
66
  return;
@@ -60,7 +68,7 @@ export const redactMiddleware = async (ctx, next) => {
60
68
  const { output, redacted } = redactSecrets(ctx.result);
61
69
  if (redacted.length > 0) {
62
70
  ctx.result = output;
63
- ctx.redacted_fields = redacted;
71
+ ctx.redacted_fields = [...new Set([...(ctx.redacted_fields ?? []), ...redacted])];
64
72
  }
65
73
  return;
66
74
  }
@@ -68,15 +76,20 @@ export const redactMiddleware = async (ctx, next) => {
68
76
  const allRedacted = [];
69
77
  redactDeep(ctx.result, allRedacted);
70
78
  if (allRedacted.length > 0) {
71
- ctx.redacted_fields = [...new Set(allRedacted)];
79
+ ctx.redacted_fields = [...new Set([...(ctx.redacted_fields ?? []), ...allRedacted])];
72
80
  }
73
81
  };
74
82
  /**
75
83
  * Recursively walk an object/array and redact string values in-place.
84
+ * Uses a WeakSet to guard against circular references.
76
85
  */
77
- function redactDeep(obj, redacted) {
86
+ function redactDeep(obj, redacted, seen = new WeakSet()) {
78
87
  if (obj == null || typeof obj !== 'object')
79
88
  return;
89
+ // Guard against circular references
90
+ if (seen.has(obj))
91
+ return;
92
+ seen.add(obj);
80
93
  if (Array.isArray(obj)) {
81
94
  for (let i = 0; i < obj.length; i++) {
82
95
  if (typeof obj[i] === 'string') {
@@ -87,7 +100,7 @@ function redactDeep(obj, redacted) {
87
100
  }
88
101
  }
89
102
  else {
90
- redactDeep(obj[i], redacted);
103
+ redactDeep(obj[i], redacted, seen);
91
104
  }
92
105
  }
93
106
  return;
@@ -102,7 +115,7 @@ function redactDeep(obj, redacted) {
102
115
  }
103
116
  }
104
117
  else {
105
- redactDeep(record[key], redacted);
118
+ redactDeep(record[key], redacted, seen);
106
119
  }
107
120
  }
108
121
  }
@@ -1 +1 @@
1
- {"version":3,"file":"redact.js","sourceRoot":"","sources":["../../../src/gateway/middleware/redact.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"redact.js","sourceRoot":"","sources":["../../../src/gateway/middleware/redact.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
2
+ import type { Middleware } from './middleware/chain.js';
3
+ /**
4
+ * Register first-party MCP tools (task management) on the gateway.
5
+ * These go through the same middleware chain as proxied tools.
6
+ */
7
+ export declare function registerNativeTools(gateway: McpServer, baseDir: string, middlewares: Middleware[]): number;
8
+ //# sourceMappingURL=native-tools.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"native-tools.d.ts","sourceRoot":"","sources":["../../src/gateway/native-tools.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAIzE,OAAO,KAAK,EAAE,UAAU,EAAqB,MAAM,uBAAuB,CAAC;AAI3E;;;GAGG;AACH,wBAAgB,mBAAmB,CACjC,OAAO,EAAE,SAAS,EAClB,OAAO,EAAE,MAAM,EACf,WAAW,EAAE,UAAU,EAAE,GACxB,MAAM,CAmOR"}
@@ -0,0 +1,190 @@
1
+ import { z } from 'zod';
2
+ import { TaskStore } from '../pm/task-store.js';
3
+ import { GitHubBridge } from '../pm/github-bridge.js';
4
+ import { executeChain } from './middleware/chain.js';
5
+ import { InvocationStatus } from '../types/index.js';
6
+ /**
7
+ * Register first-party MCP tools (task management) on the gateway.
8
+ * These go through the same middleware chain as proxied tools.
9
+ */
10
+ export function registerNativeTools(gateway, baseDir, middlewares) {
11
+ const store = new TaskStore(baseDir);
12
+ const bridge = new GitHubBridge({ baseDir });
13
+ let count = 0;
14
+ function wrapHandler(toolName, handler) {
15
+ return async (params) => {
16
+ const ctx = {
17
+ tool_name: toolName,
18
+ server_name: 'reagent',
19
+ arguments: params,
20
+ session_id: '',
21
+ status: InvocationStatus.Allowed,
22
+ start_time: Date.now(),
23
+ metadata: {},
24
+ };
25
+ const fullChain = [
26
+ ...middlewares,
27
+ async (innerCtx) => {
28
+ if (innerCtx.status !== InvocationStatus.Allowed)
29
+ return;
30
+ try {
31
+ innerCtx.result = handler(innerCtx.arguments);
32
+ innerCtx.status = InvocationStatus.Allowed;
33
+ }
34
+ catch (err) {
35
+ innerCtx.status = InvocationStatus.Error;
36
+ innerCtx.error = err instanceof Error ? err.message : String(err);
37
+ }
38
+ },
39
+ ];
40
+ await executeChain(fullChain, ctx);
41
+ if (ctx.status === InvocationStatus.Denied) {
42
+ return {
43
+ content: [{ type: 'text', text: `[DENIED] ${ctx.error}` }],
44
+ isError: true,
45
+ };
46
+ }
47
+ if (ctx.status === InvocationStatus.Error) {
48
+ return {
49
+ content: [{ type: 'text', text: `[ERROR] ${ctx.error}` }],
50
+ isError: true,
51
+ };
52
+ }
53
+ return {
54
+ content: [{ type: 'text', text: JSON.stringify(ctx.result, null, 2) }],
55
+ };
56
+ };
57
+ }
58
+ // ── task_create ──────────────────────────────────────────────────────
59
+ gateway.tool('task_create', 'Create a new task in the local task store', {
60
+ title: z.string().describe('Task title'),
61
+ description: z.string().optional().describe('Task description'),
62
+ urgency: z.enum(['critical', 'normal', 'low']).optional().describe('Task urgency'),
63
+ phase: z.string().optional().describe('Project phase'),
64
+ milestone: z.string().optional().describe('Milestone'),
65
+ assignee: z.string().optional().describe('Assignee'),
66
+ parent_id: z.string().optional().describe('Parent task ID (T-NNN format)'),
67
+ }, wrapHandler('task_create', (args) => {
68
+ const id = store.nextId();
69
+ store.appendEvent({
70
+ id,
71
+ type: 'created',
72
+ title: args.title,
73
+ description: args.description,
74
+ urgency: args.urgency || 'normal',
75
+ phase: args.phase,
76
+ milestone: args.milestone,
77
+ assignee: args.assignee,
78
+ parent_id: args.parent_id,
79
+ timestamp: new Date().toISOString(),
80
+ });
81
+ return { id, status: 'created' };
82
+ }));
83
+ count++;
84
+ // ── task_update ──────────────────────────────────────────────────────
85
+ gateway.tool('task_update', 'Update a task status or fields', {
86
+ id: z.string().describe('Task ID (T-NNN format)'),
87
+ type: z.enum(['started', 'completed', 'blocked', 'cancelled']).describe('New status'),
88
+ title: z.string().optional().describe('Updated title'),
89
+ description: z.string().optional().describe('Updated description'),
90
+ urgency: z.enum(['critical', 'normal', 'low']).optional(),
91
+ assignee: z.string().optional(),
92
+ blocked_by: z.string().optional(),
93
+ commit_refs: z.array(z.string()).optional(),
94
+ pr_ref: z.string().optional(),
95
+ }, wrapHandler('task_update', (args) => {
96
+ const existing = store.getTask(args.id);
97
+ if (!existing) {
98
+ throw new Error(`Task ${args.id} not found`);
99
+ }
100
+ store.appendEvent({
101
+ id: args.id,
102
+ type: args.type,
103
+ title: args.title || existing.title,
104
+ description: args.description,
105
+ urgency: args.urgency || existing.urgency,
106
+ assignee: args.assignee,
107
+ blocked_by: args.blocked_by,
108
+ commit_refs: args.commit_refs,
109
+ pr_ref: args.pr_ref,
110
+ timestamp: new Date().toISOString(),
111
+ });
112
+ // Close GitHub issue if completed
113
+ if (args.type === 'completed' && existing.github_issue) {
114
+ bridge.closeGitHubIssue(existing.github_issue);
115
+ }
116
+ return { id: args.id, status: args.type };
117
+ }));
118
+ count++;
119
+ // ── task_list ────────────────────────────────────────────────────────
120
+ gateway.tool('task_list', 'List tasks with optional filters', {
121
+ status: z.string().optional().describe('Filter by status'),
122
+ urgency: z.string().optional().describe('Filter by urgency'),
123
+ phase: z.string().optional().describe('Filter by phase'),
124
+ }, wrapHandler('task_list', (args) => {
125
+ return store.listTasks({
126
+ status: args.status,
127
+ urgency: args.urgency,
128
+ phase: args.phase,
129
+ });
130
+ }));
131
+ count++;
132
+ // ── task_get ─────────────────────────────────────────────────────────
133
+ gateway.tool('task_get', 'Get a single task by ID', {
134
+ id: z.string().describe('Task ID (T-NNN format)'),
135
+ }, wrapHandler('task_get', (args) => {
136
+ const task = store.getTask(args.id);
137
+ if (!task) {
138
+ throw new Error(`Task ${args.id} not found`);
139
+ }
140
+ return task;
141
+ }));
142
+ count++;
143
+ // ── task_delete ──────────────────────────────────────────────────────
144
+ gateway.tool('task_delete', 'Cancel a task (soft delete via cancelled event)', {
145
+ id: z.string().describe('Task ID (T-NNN format)'),
146
+ }, wrapHandler('task_delete', (args) => {
147
+ const existing = store.getTask(args.id);
148
+ if (!existing) {
149
+ throw new Error(`Task ${args.id} not found`);
150
+ }
151
+ store.appendEvent({
152
+ id: args.id,
153
+ type: 'cancelled',
154
+ title: existing.title,
155
+ timestamp: new Date().toISOString(),
156
+ });
157
+ return { id: args.id, status: 'cancelled' };
158
+ }));
159
+ count++;
160
+ // ── task_sync_github ────────────────────────────────────────────────
161
+ gateway.tool('task_sync_github', 'Sync local tasks to GitHub issues (requires gh CLI)', {}, wrapHandler('task_sync_github', () => {
162
+ // Note: This is sync because the bridge uses execFileSync
163
+ const mode = bridge.getMode();
164
+ if (mode === 'local-only') {
165
+ return { error: 'GitHub CLI not available. Install gh and run: gh auth login' };
166
+ }
167
+ // Can't await in sync context, so we trigger directly
168
+ let created = 0;
169
+ let skipped = 0;
170
+ const tasks = store.listTasks();
171
+ for (const task of tasks) {
172
+ if (task.github_issue || task.status === 'completed' || task.status === 'cancelled') {
173
+ skipped++;
174
+ }
175
+ else {
176
+ created++;
177
+ }
178
+ }
179
+ return {
180
+ mode,
181
+ tasks_eligible: created,
182
+ tasks_skipped: skipped,
183
+ note: 'Use the async sync endpoint for full GitHub sync',
184
+ };
185
+ }));
186
+ count++;
187
+ console.error(`[reagent] Registered ${count} native tools`);
188
+ return count;
189
+ }
190
+ //# sourceMappingURL=native-tools.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"native-tools.js","sourceRoot":"","sources":["../../src/gateway/native-tools.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/gateway/server.ts"],"names":[],"mappings":"AAeA,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;;GAQG;AACH,wBAAsB,YAAY,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CA0EvE"}
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/gateway/server.ts"],"names":[],"mappings":"AAiBA,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;;GAQG;AACH,wBAAsB,YAAY,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAkFvE"}
@@ -11,6 +11,8 @@ import { createTierMiddleware } from './middleware/tier.js';
11
11
  import { createPolicyMiddleware } from './middleware/policy.js';
12
12
  import { redactMiddleware } from './middleware/redact.js';
13
13
  import { createAuditMiddleware } from './middleware/audit.js';
14
+ import { createBlockedPathsMiddleware } from './middleware/blocked-paths.js';
15
+ import { registerNativeTools } from './native-tools.js';
14
16
  /**
15
17
  * Starts the MCP gateway server.
16
18
  *
@@ -30,13 +32,15 @@ export async function startGateway(options) {
30
32
  console.error(`[reagent] Gateway: ${Object.keys(gatewayConfig.servers).length} downstream server(s)`);
31
33
  // Build middleware chain
32
34
  // SECURITY: Audit is outermost so it records ALL invocations, including kill-switch denials.
33
- // Order (onion): audit session kill-switch tier policy redact → [execute]
35
+ // SECURITY: blocked-paths runs before tool execution to prevent writes to protected paths.
36
+ // Order (onion): audit → session → kill-switch → tier → policy → blocked-paths → redact → [execute]
34
37
  const middlewares = [
35
- createAuditMiddleware(baseDir),
38
+ createAuditMiddleware(baseDir, policy),
36
39
  createSessionMiddleware(),
37
40
  createKillSwitchMiddleware(baseDir),
38
41
  createTierMiddleware(gatewayConfig),
39
- createPolicyMiddleware(policy, gatewayConfig),
42
+ createPolicyMiddleware(policy, gatewayConfig, baseDir),
43
+ createBlockedPathsMiddleware(policy, baseDir),
40
44
  redactMiddleware,
41
45
  ];
42
46
  // Create gateway MCP server
@@ -44,10 +48,13 @@ export async function startGateway(options) {
44
48
  // Connect to downstream servers
45
49
  const clientManager = new ClientManager();
46
50
  await clientManager.connectAll(gatewayConfig);
47
- // Discover and register tools
51
+ // Register native (first-party) tools
52
+ const nativeCount = registerNativeTools(gateway, baseDir, middlewares);
53
+ // Discover and register proxied tools
48
54
  const toolProxy = new ToolProxy();
49
- const toolCount = await toolProxy.discoverAndRegister(gateway, clientManager, middlewares);
50
- console.error(`[reagent] Gateway ready: ${toolCount} tools registered`);
55
+ const proxyCount = await toolProxy.discoverAndRegister(gateway, clientManager, middlewares);
56
+ const toolCount = nativeCount + proxyCount;
57
+ console.error(`[reagent] Gateway ready: ${toolCount} tools registered (${nativeCount} native, ${proxyCount} proxied)`);
51
58
  // Listen on stdio
52
59
  const transport = new StdioServerTransport();
53
60
  await gateway.connect(transport);
@@ -71,7 +78,7 @@ export async function startGateway(options) {
71
78
  catch (err) {
72
79
  console.error('[reagent] Error during gateway close:', err instanceof Error ? err.message : err);
73
80
  }
74
- process.exit(0);
81
+ process.exitCode = 0;
75
82
  };
76
83
  process.on('SIGINT', shutdown);
77
84
  process.on('SIGTERM', shutdown);
@@ -1 +1 @@
1
- {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/gateway/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAO9D;;;;;;;;GAQG;AACH,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAAqB;IACtD,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAE5B,qBAAqB;IACrB,OAAO,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC;IACpD,MAAM,MAAM,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;IACnC,MAAM,aAAa,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAEjD,OAAO,CAAC,KAAK,CAAC,8BAA8B,MAAM,CAAC,cAAc,aAAa,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;IAChG,OAAO,CAAC,KAAK,CACX,sBAAsB,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,MAAM,uBAAuB,CACvF,CAAC;IAEF,yBAAyB;IACzB,6FAA6F;IAC7F,oFAAoF;IACpF,MAAM,WAAW,GAAiB;QAChC,qBAAqB,CAAC,OAAO,CAAC;QAC9B,uBAAuB,EAAE;QACzB,0BAA0B,CAAC,OAAO,CAAC;QACnC,oBAAoB,CAAC,aAAa,CAAC;QACnC,sBAAsB,CAAC,MAAM,EAAE,aAAa,CAAC;QAC7C,gBAAgB;KACjB,CAAC;IAEF,4BAA4B;IAC5B,MAAM,OAAO,GAAG,IAAI,SAAS,CAC3B,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,aAAa,EAAE,EAAE,EAC7C,EAAE,YAAY,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAChC,CAAC;IAEF,gCAAgC;IAChC,MAAM,aAAa,GAAG,IAAI,aAAa,EAAE,CAAC;IAC1C,MAAM,aAAa,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAE9C,8BAA8B;IAC9B,MAAM,SAAS,GAAG,IAAI,SAAS,EAAE,CAAC;IAClC,MAAM,SAAS,GAAG,MAAM,SAAS,CAAC,mBAAmB,CAAC,OAAO,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;IAE3F,OAAO,CAAC,KAAK,CAAC,4BAA4B,SAAS,mBAAmB,CAAC,CAAC;IAExE,kBAAkB;IAClB,MAAM,SAAS,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAC7C,MAAM,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAEjC,OAAO,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAC;IAEjD,sDAAsD;IACtD,IAAI,YAAY,GAAG,KAAK,CAAC;IACzB,MAAM,QAAQ,GAAG,KAAK,IAAI,EAAE;QAC1B,IAAI,YAAY;YAAE,OAAO;QACzB,YAAY,GAAG,IAAI,CAAC;QACpB,OAAO,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAC5C,IAAI,CAAC;YACH,MAAM,aAAa,CAAC,aAAa,EAAE,CAAC;QACtC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CACX,2CAA2C,EAC3C,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CACzC,CAAC;QACJ,CAAC;QACD,IAAI,CAAC;YACH,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;QACxB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CACX,uCAAuC,EACvC,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CACzC,CAAC;QACJ,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC;IAEF,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAC/B,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;AAClC,CAAC"}
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/gateway/server.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"tool-proxy.d.ts","sourceRoot":"","sources":["../../src/gateway/tool-proxy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAEzE,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,KAAK,EAAE,UAAU,EAAqB,MAAM,uBAAuB,CAAC;AAI3E,UAAU,cAAc;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACrC,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,aAAa,CAAC;CACvB;AA0BD;;;GAGG;AACH,qBAAa,SAAS;IACpB,OAAO,CAAC,KAAK,CAAwB;IAE/B,mBAAmB,CACvB,OAAO,EAAE,SAAS,EAClB,aAAa,EAAE,aAAa,EAC5B,WAAW,EAAE,UAAU,EAAE,GACxB,OAAO,CAAC,MAAM,CAAC;IAoHlB,QAAQ,IAAI,cAAc,EAAE;CAG7B"}
1
+ {"version":3,"file":"tool-proxy.d.ts","sourceRoot":"","sources":["../../src/gateway/tool-proxy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAEzE,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,KAAK,EAAE,UAAU,EAAqB,MAAM,uBAAuB,CAAC;AAI3E,UAAU,cAAc;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACrC,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,aAAa,CAAC;CACvB;AA0BD;;;GAGG;AACH,qBAAa,SAAS;IACpB,OAAO,CAAC,KAAK,CAAwB;IAE/B,mBAAmB,CACvB,OAAO,EAAE,SAAS,EAClB,aAAa,EAAE,aAAa,EAC5B,WAAW,EAAE,UAAU,EAAE,GACxB,OAAO,CAAC,MAAM,CAAC;IAoIlB,QAAQ,IAAI,cAAc,EAAE;CAG7B"}
@@ -2,7 +2,7 @@ import { z } from 'zod';
2
2
  import { executeChain } from './middleware/chain.js';
3
3
  import { InvocationStatus } from '../types/index.js';
4
4
  /**
5
- * Convert a JSON Schema properties object to a Zod record of `z.any().optional()`.
5
+ * Convert a JSON Schema properties object to a Zod record of `z.unknown().optional()`.
6
6
  * This preserves the downstream tool's top-level parameter names so the MCP caller
7
7
  * sends them directly (not wrapped in `{ args: ... }`).
8
8
  */
@@ -12,12 +12,12 @@ function jsonSchemaToZodParams(inputSchema) {
12
12
  const required = inputSchema.required ?? [];
13
13
  if (properties) {
14
14
  for (const key of Object.keys(properties)) {
15
- zodParams[key] = required.includes(key) ? z.any() : z.any().optional();
15
+ zodParams[key] = required.includes(key) ? z.unknown() : z.unknown().optional();
16
16
  }
17
17
  }
18
18
  // If no properties defined, accept arbitrary keys
19
19
  if (Object.keys(zodParams).length === 0) {
20
- return { _passthrough: z.any().optional() };
20
+ return { _passthrough: z.unknown().optional() };
21
21
  }
22
22
  return zodParams;
23
23
  }
@@ -67,12 +67,24 @@ export class ToolProxy {
67
67
  return; // Short-circuited by a prior middleware
68
68
  }
69
69
  try {
70
- const callResult = await managed.client.callTool({
70
+ const callPromise = managed.client.callTool({
71
71
  name: tool.name,
72
72
  arguments: innerCtx.arguments,
73
73
  });
74
- innerCtx.result = callResult;
75
- innerCtx.status = InvocationStatus.Allowed;
74
+ // Per-tool timeout — prevents hung downstream from blocking the gateway.
75
+ const timeoutMs = 30_000;
76
+ let timer;
77
+ const timeoutPromise = new Promise((_, reject) => {
78
+ timer = setTimeout(() => reject(new Error(`Tool "${tool.name}" timed out after ${timeoutMs}ms`)), timeoutMs);
79
+ });
80
+ try {
81
+ const callResult = await Promise.race([callPromise, timeoutPromise]);
82
+ innerCtx.result = callResult;
83
+ innerCtx.status = InvocationStatus.Allowed;
84
+ }
85
+ finally {
86
+ clearTimeout(timer);
87
+ }
76
88
  }
77
89
  catch (err) {
78
90
  innerCtx.status = InvocationStatus.Error;
@@ -1 +1 @@
1
- {"version":3,"file":"tool-proxy.js","sourceRoot":"","sources":["../../src/gateway/tool-proxy.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"tool-proxy.js","sourceRoot":"","sources":["../../src/gateway/tool-proxy.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ export type GitHubMode = 'gh-cli' | 'local-only';
2
+ export interface GitHubBridgeOptions {
3
+ baseDir: string;
4
+ label?: string;
5
+ syncCooldownSeconds?: number;
6
+ }
7
+ export declare class GitHubBridge {
8
+ private readonly store;
9
+ private readonly label;
10
+ private readonly syncCooldown;
11
+ private mode;
12
+ private lastSyncTime;
13
+ constructor(options: GitHubBridgeOptions);
14
+ /**
15
+ * Detect which GitHub integration mode is available.
16
+ */
17
+ private detectMode;
18
+ getMode(): GitHubMode;
19
+ /**
20
+ * Sync local tasks to GitHub issues (creates issues for tasks without github_issue).
21
+ * Only syncs tasks that have the reagent label scope.
22
+ */
23
+ syncToGitHub(): Promise<{
24
+ created: number;
25
+ skipped: number;
26
+ }>;
27
+ /**
28
+ * Create a GitHub issue for a task.
29
+ */
30
+ private createGitHubIssue;
31
+ /**
32
+ * Close a GitHub issue when a task is completed.
33
+ */
34
+ closeGitHubIssue(issueNumber: number): boolean;
35
+ }
36
+ //# sourceMappingURL=github-bridge.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"github-bridge.d.ts","sourceRoot":"","sources":["../../src/pm/github-bridge.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,UAAU,GAAG,QAAQ,GAAG,YAAY,CAAC;AAEjD,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAY;IAClC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAS;IAC/B,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,IAAI,CAAa;IACzB,OAAO,CAAC,YAAY,CAAK;gBAEb,OAAO,EAAE,mBAAmB;IAOxC;;OAEG;IACH,OAAO,CAAC,UAAU;IAalB,OAAO,IAAI,UAAU;IAIrB;;;OAGG;IACG,YAAY,IAAI,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAoDnE;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAwCzB;;OAEG;IACH,gBAAgB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;CAc/C"}
@@ -0,0 +1,138 @@
1
+ import { execFileSync } from 'node:child_process';
2
+ import { TaskStore } from './task-store.js';
3
+ export class GitHubBridge {
4
+ store;
5
+ label;
6
+ syncCooldown;
7
+ mode;
8
+ lastSyncTime = 0;
9
+ constructor(options) {
10
+ this.store = new TaskStore(options.baseDir);
11
+ this.label = options.label || 'reagent';
12
+ this.syncCooldown = (options.syncCooldownSeconds || 300) * 1000;
13
+ this.mode = this.detectMode();
14
+ }
15
+ /**
16
+ * Detect which GitHub integration mode is available.
17
+ */
18
+ detectMode() {
19
+ try {
20
+ execFileSync('gh', ['auth', 'status'], {
21
+ encoding: 'utf8',
22
+ timeout: 5000,
23
+ stdio: 'pipe',
24
+ });
25
+ return 'gh-cli';
26
+ }
27
+ catch {
28
+ return 'local-only';
29
+ }
30
+ }
31
+ getMode() {
32
+ return this.mode;
33
+ }
34
+ /**
35
+ * Sync local tasks to GitHub issues (creates issues for tasks without github_issue).
36
+ * Only syncs tasks that have the reagent label scope.
37
+ */
38
+ async syncToGitHub() {
39
+ if (this.mode !== 'gh-cli') {
40
+ return { created: 0, skipped: 0 };
41
+ }
42
+ // Rate limit guard
43
+ const now = Date.now();
44
+ if (now - this.lastSyncTime < this.syncCooldown) {
45
+ return { created: 0, skipped: 0 };
46
+ }
47
+ this.lastSyncTime = now;
48
+ const tasks = this.store.listTasks();
49
+ let created = 0;
50
+ let skipped = 0;
51
+ for (const task of tasks) {
52
+ if (task.github_issue) {
53
+ skipped++;
54
+ continue;
55
+ }
56
+ // Terminal tasks don't need issues
57
+ if (task.status === 'completed' || task.status === 'cancelled') {
58
+ skipped++;
59
+ continue;
60
+ }
61
+ try {
62
+ const issueNumber = this.createGitHubIssue(task);
63
+ if (issueNumber) {
64
+ // Update local task with issue number
65
+ this.store.appendEvent({
66
+ id: task.id,
67
+ type: task.status === 'created' ? 'created' : task.status,
68
+ title: task.title,
69
+ github_issue: issueNumber,
70
+ timestamp: new Date().toISOString(),
71
+ });
72
+ created++;
73
+ }
74
+ }
75
+ catch (err) {
76
+ console.error(`[github-bridge] Failed to create issue for ${task.id}: ${err instanceof Error ? err.message : err}`);
77
+ skipped++;
78
+ }
79
+ }
80
+ return { created, skipped };
81
+ }
82
+ /**
83
+ * Create a GitHub issue for a task.
84
+ */
85
+ createGitHubIssue(task) {
86
+ try {
87
+ const body = [
88
+ task.description || '',
89
+ '',
90
+ `**Task ID:** ${task.id}`,
91
+ task.phase ? `**Phase:** ${task.phase}` : '',
92
+ task.urgency !== 'normal' ? `**Urgency:** ${task.urgency}` : '',
93
+ task.parent_id ? `**Parent:** ${task.parent_id}` : '',
94
+ ]
95
+ .filter(Boolean)
96
+ .join('\n');
97
+ const result = execFileSync('gh', [
98
+ 'issue',
99
+ 'create',
100
+ '--title',
101
+ `[${task.id}] ${task.title}`,
102
+ '--body',
103
+ body,
104
+ '--label',
105
+ this.label,
106
+ ], {
107
+ encoding: 'utf8',
108
+ timeout: 10000,
109
+ stdio: 'pipe',
110
+ });
111
+ // Extract issue number from URL
112
+ const match = result.trim().match(/\/issues\/(\d+)$/);
113
+ return match ? parseInt(match[1], 10) : null;
114
+ }
115
+ catch {
116
+ return null;
117
+ }
118
+ }
119
+ /**
120
+ * Close a GitHub issue when a task is completed.
121
+ */
122
+ closeGitHubIssue(issueNumber) {
123
+ if (this.mode !== 'gh-cli')
124
+ return false;
125
+ try {
126
+ execFileSync('gh', ['issue', 'close', String(issueNumber)], {
127
+ encoding: 'utf8',
128
+ timeout: 10000,
129
+ stdio: 'pipe',
130
+ });
131
+ return true;
132
+ }
133
+ catch {
134
+ return false;
135
+ }
136
+ }
137
+ }
138
+ //# sourceMappingURL=github-bridge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"github-bridge.js","sourceRoot":"","sources":["../../src/pm/github-bridge.ts"],"names":[],"mappings":"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"}