@neurosec/sentry 1.0.20 → 1.1.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 (176) hide show
  1. package/README.md +4 -0
  2. package/dist/api-auth.d.ts +31 -0
  3. package/dist/api-auth.d.ts.map +1 -0
  4. package/dist/api-auth.js +105 -0
  5. package/dist/api-auth.js.map +1 -0
  6. package/dist/api-auth.test.d.ts +2 -0
  7. package/dist/api-auth.test.d.ts.map +1 -0
  8. package/dist/api-auth.test.js +89 -0
  9. package/dist/api-auth.test.js.map +1 -0
  10. package/dist/api.d.ts +8 -7
  11. package/dist/api.d.ts.map +1 -1
  12. package/dist/api.js +141 -134
  13. package/dist/api.js.map +1 -1
  14. package/dist/cli.d.ts +1 -1
  15. package/dist/cli.d.ts.map +1 -1
  16. package/dist/cli.js +107 -14
  17. package/dist/cli.js.map +1 -1
  18. package/dist/cli.test.d.ts +2 -0
  19. package/dist/cli.test.d.ts.map +1 -0
  20. package/dist/cli.test.js +68 -0
  21. package/dist/cli.test.js.map +1 -0
  22. package/dist/config.d.ts +30 -0
  23. package/dist/config.d.ts.map +1 -1
  24. package/dist/config.js +50 -1
  25. package/dist/config.js.map +1 -1
  26. package/dist/discovery-win.d.ts +4 -0
  27. package/dist/discovery-win.d.ts.map +1 -0
  28. package/dist/discovery-win.js +153 -0
  29. package/dist/discovery-win.js.map +1 -0
  30. package/dist/discovery.d.ts.map +1 -1
  31. package/dist/discovery.js +23 -97
  32. package/dist/discovery.js.map +1 -1
  33. package/dist/discovery.test.js +18 -109
  34. package/dist/discovery.test.js.map +1 -1
  35. package/dist/enforcement/file-monitor.d.ts +9 -0
  36. package/dist/enforcement/file-monitor.d.ts.map +1 -1
  37. package/dist/enforcement/file-monitor.js +9 -2
  38. package/dist/enforcement/file-monitor.js.map +1 -1
  39. package/dist/enforcement/network-monitor.d.ts.map +1 -1
  40. package/dist/enforcement/network-monitor.js +350 -9
  41. package/dist/enforcement/network-monitor.js.map +1 -1
  42. package/dist/enforcement/network-monitor.test.d.ts +2 -0
  43. package/dist/enforcement/network-monitor.test.d.ts.map +1 -0
  44. package/dist/enforcement/network-monitor.test.js +52 -0
  45. package/dist/enforcement/network-monitor.test.js.map +1 -0
  46. package/dist/enforcement/policy-executor.d.ts +24 -1
  47. package/dist/enforcement/policy-executor.d.ts.map +1 -1
  48. package/dist/enforcement/policy-executor.js +213 -69
  49. package/dist/enforcement/policy-executor.js.map +1 -1
  50. package/dist/enforcement/policy-executor.test.d.ts +2 -0
  51. package/dist/enforcement/policy-executor.test.d.ts.map +1 -0
  52. package/dist/enforcement/policy-executor.test.js +46 -0
  53. package/dist/enforcement/policy-executor.test.js.map +1 -0
  54. package/dist/enforcement/target-validator.d.ts +37 -0
  55. package/dist/enforcement/target-validator.d.ts.map +1 -0
  56. package/dist/enforcement/target-validator.js +0 -0
  57. package/dist/enforcement/target-validator.js.map +1 -0
  58. package/dist/enforcement/target-validator.test.d.ts +2 -0
  59. package/dist/enforcement/target-validator.test.d.ts.map +1 -0
  60. package/dist/enforcement/target-validator.test.js +103 -0
  61. package/dist/enforcement/target-validator.test.js.map +1 -0
  62. package/dist/http-client.d.ts +35 -0
  63. package/dist/http-client.d.ts.map +1 -0
  64. package/dist/http-client.js +168 -0
  65. package/dist/http-client.js.map +1 -0
  66. package/dist/http-client.test.d.ts +2 -0
  67. package/dist/http-client.test.d.ts.map +1 -0
  68. package/dist/http-client.test.js +172 -0
  69. package/dist/http-client.test.js.map +1 -0
  70. package/dist/index.js +190 -114
  71. package/dist/index.js.map +1 -1
  72. package/dist/launcher.d.ts +33 -0
  73. package/dist/launcher.d.ts.map +1 -0
  74. package/dist/launcher.js +425 -0
  75. package/dist/launcher.js.map +1 -0
  76. package/dist/launcher.test.d.ts +2 -0
  77. package/dist/launcher.test.d.ts.map +1 -0
  78. package/dist/launcher.test.js +109 -0
  79. package/dist/launcher.test.js.map +1 -0
  80. package/dist/proxy/cert-manager.d.ts +24 -0
  81. package/dist/proxy/cert-manager.d.ts.map +1 -0
  82. package/dist/proxy/cert-manager.js +117 -0
  83. package/dist/proxy/cert-manager.js.map +1 -0
  84. package/dist/proxy/cert-manager.test.d.ts +2 -0
  85. package/dist/proxy/cert-manager.test.d.ts.map +1 -0
  86. package/dist/proxy/cert-manager.test.js +70 -0
  87. package/dist/proxy/cert-manager.test.js.map +1 -0
  88. package/dist/proxy/index.d.ts +61 -0
  89. package/dist/proxy/index.d.ts.map +1 -0
  90. package/dist/proxy/index.js +74 -0
  91. package/dist/proxy/index.js.map +1 -0
  92. package/dist/proxy/policy-enforcer.d.ts +30 -0
  93. package/dist/proxy/policy-enforcer.d.ts.map +1 -0
  94. package/dist/proxy/policy-enforcer.js +143 -0
  95. package/dist/proxy/policy-enforcer.js.map +1 -0
  96. package/dist/proxy/proxy-server.d.ts +42 -0
  97. package/dist/proxy/proxy-server.d.ts.map +1 -0
  98. package/dist/proxy/proxy-server.js +652 -0
  99. package/dist/proxy/proxy-server.js.map +1 -0
  100. package/dist/proxy/redaction-engine.d.ts +4 -0
  101. package/dist/proxy/redaction-engine.d.ts.map +1 -0
  102. package/dist/proxy/redaction-engine.js +50 -0
  103. package/dist/proxy/redaction-engine.js.map +1 -0
  104. package/dist/proxy/response-redaction.test.d.ts +2 -0
  105. package/dist/proxy/response-redaction.test.d.ts.map +1 -0
  106. package/dist/proxy/response-redaction.test.js +125 -0
  107. package/dist/proxy/response-redaction.test.js.map +1 -0
  108. package/dist/proxy/threat-engine.d.ts +22 -0
  109. package/dist/proxy/threat-engine.d.ts.map +1 -0
  110. package/dist/proxy/threat-engine.js +291 -0
  111. package/dist/proxy/threat-engine.js.map +1 -0
  112. package/dist/proxy/threat-engine.test.d.ts +2 -0
  113. package/dist/proxy/threat-engine.test.d.ts.map +1 -0
  114. package/dist/proxy/threat-engine.test.js +27 -0
  115. package/dist/proxy/threat-engine.test.js.map +1 -0
  116. package/dist/redirect/env-injector.d.ts +72 -0
  117. package/dist/redirect/env-injector.d.ts.map +1 -0
  118. package/dist/redirect/env-injector.js +177 -0
  119. package/dist/redirect/env-injector.js.map +1 -0
  120. package/dist/redirect/env-injector.test.d.ts +2 -0
  121. package/dist/redirect/env-injector.test.d.ts.map +1 -0
  122. package/dist/redirect/env-injector.test.js +91 -0
  123. package/dist/redirect/env-injector.test.js.map +1 -0
  124. package/dist/redirect/index.d.ts +3 -0
  125. package/dist/redirect/index.d.ts.map +1 -0
  126. package/dist/redirect/index.js +8 -0
  127. package/dist/redirect/index.js.map +1 -0
  128. package/dist/redirect/platform-redirect.d.ts +42 -0
  129. package/dist/redirect/platform-redirect.d.ts.map +1 -0
  130. package/dist/redirect/platform-redirect.js +229 -0
  131. package/dist/redirect/platform-redirect.js.map +1 -0
  132. package/dist/redirect/platform-redirect.test.d.ts +2 -0
  133. package/dist/redirect/platform-redirect.test.d.ts.map +1 -0
  134. package/dist/redirect/platform-redirect.test.js +76 -0
  135. package/dist/redirect/platform-redirect.test.js.map +1 -0
  136. package/dist/sandbox/index.d.ts +23 -2
  137. package/dist/sandbox/index.d.ts.map +1 -1
  138. package/dist/sandbox/index.js +24 -7
  139. package/dist/sandbox/index.js.map +1 -1
  140. package/dist/sandbox/linux-sandbox.d.ts +13 -2
  141. package/dist/sandbox/linux-sandbox.d.ts.map +1 -1
  142. package/dist/sandbox/linux-sandbox.js +61 -27
  143. package/dist/sandbox/linux-sandbox.js.map +1 -1
  144. package/dist/sandbox/macos-sandbox.d.ts +15 -4
  145. package/dist/sandbox/macos-sandbox.d.ts.map +1 -1
  146. package/dist/sandbox/macos-sandbox.js +36 -18
  147. package/dist/sandbox/macos-sandbox.js.map +1 -1
  148. package/dist/sandbox/sandbox-result.test.d.ts +2 -0
  149. package/dist/sandbox/sandbox-result.test.d.ts.map +1 -0
  150. package/dist/sandbox/sandbox-result.test.js +87 -0
  151. package/dist/sandbox/sandbox-result.test.js.map +1 -0
  152. package/dist/sandbox/windows-sandbox.d.ts +34 -0
  153. package/dist/sandbox/windows-sandbox.d.ts.map +1 -0
  154. package/dist/sandbox/windows-sandbox.js +161 -0
  155. package/dist/sandbox/windows-sandbox.js.map +1 -0
  156. package/dist/setup.d.ts.map +1 -1
  157. package/dist/setup.js +33 -43
  158. package/dist/setup.js.map +1 -1
  159. package/dist/skill-authz/skill-evaluator.d.ts +30 -0
  160. package/dist/skill-authz/skill-evaluator.d.ts.map +1 -1
  161. package/dist/skill-authz/skill-evaluator.js +161 -30
  162. package/dist/skill-authz/skill-evaluator.js.map +1 -1
  163. package/dist/skill-authz/skill-evaluator.test.d.ts +2 -0
  164. package/dist/skill-authz/skill-evaluator.test.d.ts.map +1 -0
  165. package/dist/skill-authz/skill-evaluator.test.js +127 -0
  166. package/dist/skill-authz/skill-evaluator.test.js.map +1 -0
  167. package/dist/telemetry.d.ts +2 -8
  168. package/dist/telemetry.d.ts.map +1 -1
  169. package/dist/telemetry.js +17 -147
  170. package/dist/telemetry.js.map +1 -1
  171. package/dist/types.d.ts +48 -105
  172. package/dist/types.d.ts.map +1 -1
  173. package/dist/types.js +34 -1
  174. package/dist/types.js.map +1 -1
  175. package/package.json +7 -3
  176. package/scripts/install-sentry-windows.ps1 +217 -0
@@ -0,0 +1,425 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.detectLauncherCapabilities = detectLauncherCapabilities;
7
+ exports.resolveLaunchProfile = resolveLaunchProfile;
8
+ exports.buildLaunchPlan = buildLaunchPlan;
9
+ exports.launchWithSentry = launchWithSentry;
10
+ exports.renderLaunchPlan = renderLaunchPlan;
11
+ const fs_1 = __importDefault(require("fs"));
12
+ const path_1 = __importDefault(require("path"));
13
+ const os_1 = __importDefault(require("os"));
14
+ const child_process_1 = require("child_process");
15
+ const sandbox_1 = require("./sandbox");
16
+ const cert_manager_1 = require("./proxy/cert-manager");
17
+ const types_1 = require("./types");
18
+ function detectLauncherCapabilities(platform = os_1.default.platform()) {
19
+ return {
20
+ systemdRun: platform === 'linux' && commandExists('systemd-run'),
21
+ sandboxExec: platform === 'darwin' && commandExists('sandbox-exec'),
22
+ powershell: platform === 'win32' && (commandExists('powershell.exe') || commandExists('powershell')),
23
+ };
24
+ }
25
+ function resolveLaunchProfile(request) {
26
+ if (request.profileName) {
27
+ const byName = (0, sandbox_1.getProfileForFramework)('')?.name === request.profileName
28
+ ? (0, sandbox_1.getProfileForFramework)('')
29
+ : null;
30
+ if (byName)
31
+ return byName;
32
+ }
33
+ if (request.profileName) {
34
+ const explicit = require('./types').AGENT_SANDBOX_PROFILES.find((p) => p.name === request.profileName);
35
+ if (explicit)
36
+ return explicit;
37
+ }
38
+ return (0, sandbox_1.getProfileForFramework)(request.frameworkId ?? '') ?? require('./types').AGENT_SANDBOX_PROFILES.find((p) => p.name === 'default-restrictive');
39
+ }
40
+ function buildLaunchPlan(config, request, platform = os_1.default.platform(), capabilities = detectLauncherCapabilities(platform)) {
41
+ if (!request.command.length) {
42
+ throw new Error('launch requires a command after --');
43
+ }
44
+ const profile = resolveLaunchProfile(request);
45
+ if (!profile) {
46
+ throw new Error('no sandbox profile available');
47
+ }
48
+ const generatedFiles = [];
49
+ const notes = [];
50
+ const env = buildLaunchEnvironment(config, request.extraEnv ?? {}, !!request.dryRun);
51
+ const cwd = request.cwd;
52
+ if (platform === 'linux' && capabilities.systemdRun) {
53
+ return {
54
+ platform,
55
+ executable: 'systemd-run',
56
+ args: buildLinuxArgs(config, profile, request, env),
57
+ env,
58
+ cwd,
59
+ notes,
60
+ profile,
61
+ generatedFiles,
62
+ };
63
+ }
64
+ if (platform === 'darwin' && capabilities.sandboxExec) {
65
+ const profilePath = request.dryRun
66
+ ? path_1.default.join(config.sentry.stateDir, 'launcher', 'launch-dry-run.sb')
67
+ : writeMacLauncherProfile(config, profile);
68
+ generatedFiles.push(profilePath);
69
+ return {
70
+ platform,
71
+ executable: 'sandbox-exec',
72
+ args: ['-f', profilePath, ...request.command],
73
+ env,
74
+ cwd,
75
+ notes,
76
+ profile,
77
+ generatedFiles,
78
+ };
79
+ }
80
+ if (platform === 'win32' && capabilities.powershell) {
81
+ const scriptPath = request.dryRun
82
+ ? path_1.default.join(config.sentry.stateDir, 'launcher', 'launch-dry-run.ps1')
83
+ : writeWindowsLauncherScript(config, profile, request, env);
84
+ generatedFiles.push(scriptPath);
85
+ return {
86
+ platform,
87
+ executable: commandExists('powershell.exe') ? 'powershell.exe' : 'powershell',
88
+ args: ['-NoProfile', '-NonInteractive', '-ExecutionPolicy', 'Bypass', '-File', scriptPath],
89
+ env,
90
+ cwd,
91
+ notes,
92
+ profile,
93
+ generatedFiles,
94
+ };
95
+ }
96
+ notes.push('Platform launcher unavailable; falling back to plain spawn with proxy env only');
97
+ return {
98
+ platform,
99
+ executable: request.command[0],
100
+ args: request.command.slice(1),
101
+ env,
102
+ cwd,
103
+ notes,
104
+ profile,
105
+ generatedFiles,
106
+ };
107
+ }
108
+ async function launchWithSentry(config, request, platform = os_1.default.platform(), capabilities = detectLauncherCapabilities(platform)) {
109
+ const plan = buildLaunchPlan(config, request, platform, capabilities);
110
+ if (request.dryRun) {
111
+ process.stdout.write(renderLaunchPlan(plan) + '\n');
112
+ return 0;
113
+ }
114
+ return new Promise((resolve, reject) => {
115
+ const child = (0, child_process_1.spawn)(plan.executable, plan.args, {
116
+ cwd: plan.cwd,
117
+ env: plan.env,
118
+ stdio: 'inherit',
119
+ });
120
+ child.once('error', reject);
121
+ child.once('exit', (code, signal) => {
122
+ if (signal) {
123
+ resolve(1);
124
+ return;
125
+ }
126
+ resolve(code ?? 0);
127
+ });
128
+ });
129
+ }
130
+ function renderLaunchPlan(plan) {
131
+ return [
132
+ `Platform: ${plan.platform}`,
133
+ `Profile: ${plan.profile.name}`,
134
+ `Executable: ${plan.executable}`,
135
+ `Args: ${plan.args.map(shellQuote).join(' ')}`,
136
+ `Env additions: ${Object.keys(plan.env).length}`,
137
+ ...(plan.generatedFiles.length > 0 ? [`Generated: ${plan.generatedFiles.join(', ')}`] : []),
138
+ ...(plan.notes.length > 0 ? [`Notes: ${plan.notes.join(' | ')}`] : []),
139
+ ].join('\n');
140
+ }
141
+ function buildLaunchEnvironment(config, extraEnv, dryRun) {
142
+ const env = { ...process.env };
143
+ const proxyPort = config.proxy.interceptHttps ? config.proxy.port + 1 : config.proxy.port;
144
+ const proxyScheme = config.proxy.interceptHttps ? 'https' : 'http';
145
+ const proxyUrl = `${proxyScheme}://127.0.0.1:${proxyPort}`;
146
+ if (config.proxy.enabled) {
147
+ const providerEnvKeys = {
148
+ openai: ['OPENAI_BASE_URL', 'OPENAI_API_BASE'],
149
+ anthropic: ['ANTHROPIC_BASE_URL'],
150
+ 'google-gemini': ['GOOGLE_GEMINI_BASE_URL'],
151
+ together: ['TOGETHER_BASE_URL'],
152
+ deepseek: ['DEEPSEEK_BASE_URL'],
153
+ groq: ['GROQ_BASE_URL'],
154
+ mistral: ['MISTRAL_BASE_URL'],
155
+ cohere: ['COHERE_BASE_URL'],
156
+ openrouter: ['OPENROUTER_BASE_URL'],
157
+ replicate: ['REPLICATE_BASE_URL'],
158
+ };
159
+ for (const id of Object.keys(types_1.KNOWN_PROVIDERS)) {
160
+ const vars = providerEnvKeys[id] ?? [`${id.toUpperCase().replace(/-/g, '_')}_BASE_URL`];
161
+ for (const variable of vars)
162
+ env[variable] = proxyUrl;
163
+ }
164
+ env.LANGCHAIN_ENDPOINT = proxyUrl;
165
+ env.LITELLM_BASE_URL = proxyUrl;
166
+ env.AZURE_OPENAI_ENDPOINT = proxyUrl;
167
+ if (config.proxy.interceptHttps) {
168
+ if (dryRun) {
169
+ env.NODE_EXTRA_CA_CERTS = config.proxy.certPath;
170
+ }
171
+ else {
172
+ const certInfo = (0, cert_manager_1.ensureProxyCertificate)({ certPath: config.proxy.certPath, keyPath: config.proxy.keyPath });
173
+ env.NODE_EXTRA_CA_CERTS = certInfo.certPath;
174
+ }
175
+ }
176
+ }
177
+ for (const [key, value] of Object.entries(extraEnv))
178
+ env[key] = value;
179
+ return env;
180
+ }
181
+ function buildLinuxArgs(config, profile, request, env) {
182
+ const args = ['--scope', '--quiet'];
183
+ if (request.cwd)
184
+ args.push(`--working-directory=${request.cwd}`);
185
+ const properties = [
186
+ `Description=NeuroShield Sentry launch (${profile.name})`,
187
+ `MemoryMax=${parseMemoryBytes(profile.memoryMax || config.sandboxDefaults.memoryMax)}`,
188
+ `TasksMax=${profile.pidMax || config.sandboxDefaults.pidMax}`,
189
+ `CPUQuota=${cpuQuotaPercent(profile.cpuMax || config.sandboxDefaults.cpuMax)}`,
190
+ 'NoNewPrivileges=yes',
191
+ 'PrivateTmp=yes',
192
+ 'PrivateDevices=yes',
193
+ 'ProtectKernelTunables=yes',
194
+ 'ProtectKernelModules=yes',
195
+ 'ProtectControlGroups=yes',
196
+ 'ProtectProc=invisible',
197
+ 'RestrictSUIDSGID=yes',
198
+ 'LockPersonality=yes',
199
+ 'RestrictNamespaces=yes',
200
+ 'SystemCallArchitectures=native',
201
+ 'SystemCallErrorNumber=EPERM',
202
+ ];
203
+ if (profile.allowedSyscalls.length > 0) {
204
+ properties.push(`SystemCallFilter=${profile.allowedSyscalls.join(' ')}`);
205
+ }
206
+ if (profile.blockedCapabilities.length > 0) {
207
+ properties.push(`CapabilityBoundingSet=~${Array.from(new Set(profile.blockedCapabilities)).join(' ')}`);
208
+ }
209
+ const fsRules = normalizeFsRules(profile.fsRules, request.cwd);
210
+ for (const p of fsRules.readWrite)
211
+ properties.push(`ReadWritePaths=${p}`);
212
+ for (const p of fsRules.readOnly)
213
+ properties.push(`ReadOnlyPaths=${p}`);
214
+ for (const p of fsRules.inaccessible)
215
+ properties.push(`InaccessiblePaths=${p}`);
216
+ if (config.proxy.enabled) {
217
+ properties.push('IPAddressDeny=any');
218
+ properties.push('IPAddressAllow=127.0.0.1/32');
219
+ properties.push('IPAddressAllow=::1/128');
220
+ }
221
+ for (const property of properties)
222
+ args.push('--property', property);
223
+ for (const [key, value] of Object.entries(diffEnv(env))) {
224
+ args.push(`--setenv=${key}=${value}`);
225
+ }
226
+ args.push(...request.command);
227
+ return args;
228
+ }
229
+ function writeMacLauncherProfile(config, profile) {
230
+ const dir = path_1.default.join(config.sentry.stateDir, 'launcher');
231
+ fs_1.default.mkdirSync(dir, { recursive: true });
232
+ const profilePath = path_1.default.join(dir, `launch-${Date.now()}.sb`);
233
+ const lines = [
234
+ '(version 1)',
235
+ '(deny default)',
236
+ '(allow process*)',
237
+ '(allow sysctl-read)',
238
+ '(allow ipc-posix-sem* ipc-posix-shm*)',
239
+ ];
240
+ for (const rule of profile.fsRules) {
241
+ const root = sanitizeFsRoot(rule.path);
242
+ switch (rule.permissions) {
243
+ case 'rw':
244
+ case 'w':
245
+ lines.push(`(allow file-read* file-write* (subpath "${root}"))`);
246
+ break;
247
+ case 'rwx':
248
+ lines.push(`(allow file-read* file-write* file-exec* (subpath "${root}"))`);
249
+ break;
250
+ case 'rx':
251
+ lines.push(`(allow file-read* file-exec* (subpath "${root}"))`);
252
+ break;
253
+ case 'r':
254
+ lines.push(`(allow file-read* (subpath "${root}"))`);
255
+ break;
256
+ case 'none':
257
+ lines.push(`(deny file-read* file-write* file-exec* (subpath "${root}"))`);
258
+ break;
259
+ }
260
+ }
261
+ for (const rule of profile.networkRules) {
262
+ if (rule.action === 'allow') {
263
+ if (rule.host)
264
+ lines.push(`(allow network* (remote ip "${rule.host}"))`);
265
+ else
266
+ lines.push('(allow network*)');
267
+ }
268
+ }
269
+ fs_1.default.writeFileSync(profilePath, lines.join('\n') + '\n', 'utf8');
270
+ return profilePath;
271
+ }
272
+ function writeWindowsLauncherScript(config, profile, request, env) {
273
+ const dir = path_1.default.join(config.sentry.stateDir, 'launcher');
274
+ fs_1.default.mkdirSync(dir, { recursive: true });
275
+ const scriptPath = path_1.default.join(dir, `launch-${Date.now()}.ps1`);
276
+ const command = psQuote(request.command[0]);
277
+ const argList = request.command.slice(1).map(psQuote).join(', ');
278
+ const jobName = `NeuroShield_Sentry_Launch_${Date.now()}`;
279
+ const sandboxProfileRoot = path_1.default.join(dir, `profile-${Date.now()}`);
280
+ const sandboxHome = path_1.default.join(sandboxProfileRoot, 'home');
281
+ const sandboxAppData = path_1.default.join(sandboxProfileRoot, 'AppData', 'Roaming');
282
+ const sandboxLocalAppData = path_1.default.join(sandboxProfileRoot, 'AppData', 'Local');
283
+ fs_1.default.mkdirSync(path_1.default.join(sandboxHome, '.ssh'), { recursive: true });
284
+ fs_1.default.mkdirSync(path_1.default.join(sandboxHome, '.aws'), { recursive: true });
285
+ fs_1.default.mkdirSync(path_1.default.join(sandboxHome, '.config'), { recursive: true });
286
+ fs_1.default.mkdirSync(sandboxAppData, { recursive: true });
287
+ fs_1.default.mkdirSync(sandboxLocalAppData, { recursive: true });
288
+ const isolatedEnv = {
289
+ ...diffEnv(env),
290
+ HOME: sandboxHome,
291
+ USERPROFILE: sandboxHome,
292
+ HOMEDRIVE: path_1.default.parse(sandboxHome).root.replace(/\\$/, ''),
293
+ HOMEPATH: sandboxHome.slice(path_1.default.parse(sandboxHome).root.length - 1),
294
+ APPDATA: sandboxAppData,
295
+ LOCALAPPDATA: sandboxLocalAppData,
296
+ };
297
+ const envLines = Object.entries(isolatedEnv).map(([key, value]) => `$env:${key} = ${psQuote(value)}`).join('\n');
298
+ const cwdLine = request.cwd ? `Set-Location -LiteralPath ${psQuote(request.cwd)}` : '';
299
+ const script = `
300
+ $ErrorActionPreference = 'Stop'
301
+ ${envLines}
302
+ ${cwdLine}
303
+ Add-Type -Namespace NeuroShield -Name JobObj -MemberDefinition @'
304
+ [DllImport("kernel32.dll", CharSet=CharSet.Unicode, SetLastError=true)]
305
+ public static extern IntPtr CreateJobObject(IntPtr a, string lpName);
306
+ [DllImport("kernel32.dll", SetLastError=true)]
307
+ public static extern bool AssignProcessToJobObject(IntPtr job, IntPtr proc);
308
+ [DllImport("kernel32.dll", SetLastError=true)]
309
+ public static extern bool SetInformationJobObject(IntPtr hJob, int infoClass, IntPtr lpJobObjectInfo, uint cbJobObjectInfoLength);
310
+ [DllImport("kernel32.dll", SetLastError=true)]
311
+ public static extern IntPtr OpenProcess(uint dwDesiredAccess, bool bInheritHandle, uint dwProcessId);
312
+ '@
313
+
314
+ $proc = Start-Process -FilePath ${command} -ArgumentList @(${argList}) -PassThru -NoNewWindow
315
+ $allowRuleName = "NeuroShield Allow Loopback $($proc.Id)"
316
+ $blockRuleName = "NeuroShield Block Remote $($proc.Id)"
317
+ $procPath = $proc.Path
318
+ if (-not $procPath) { throw "Could not resolve launched process path" }
319
+ New-NetFirewallRule -DisplayName $allowRuleName -Direction Outbound -Program $procPath -Action Allow -RemoteAddress 127.0.0.1,::1 | Out-Null
320
+ New-NetFirewallRule -DisplayName $blockRuleName -Direction Outbound -Program $procPath -Action Block -RemoteAddress Any | Out-Null
321
+ $job = [NeuroShield.JobObj]::CreateJobObject([IntPtr]::Zero, ${psQuote(jobName)})
322
+ if ($job -eq [IntPtr]::Zero) { throw "CreateJobObject failed" }
323
+ $size = 144
324
+ $ptr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($size)
325
+ [System.Runtime.InteropServices.Marshal]::WriteInt32($ptr, 0x18, [int](0x2000 -bor 0x8 -bor 0x200))
326
+ [System.Runtime.InteropServices.Marshal]::WriteInt32($ptr, 0x40, ${profile.pidMax || config.sandboxDefaults.pidMax})
327
+ [System.Runtime.InteropServices.Marshal]::WriteInt64($ptr, 0x60, [int64]${parseMemoryBytes(profile.memoryMax || config.sandboxDefaults.memoryMax)})
328
+ $ok = [NeuroShield.JobObj]::SetInformationJobObject($job, 9, $ptr, [uint32]$size)
329
+ [System.Runtime.InteropServices.Marshal]::FreeHGlobal($ptr)
330
+ if (-not $ok) { throw "SetInformationJobObject failed" }
331
+ $ph = [NeuroShield.JobObj]::OpenProcess(0x101, $false, [uint32]$proc.Id)
332
+ if ($ph -eq [IntPtr]::Zero) { throw "OpenProcess failed" }
333
+ $assigned = [NeuroShield.JobObj]::AssignProcessToJobObject($job, $ph)
334
+ if (-not $assigned) { throw "AssignProcessToJobObject failed" }
335
+ $exitCode = 1
336
+ try {
337
+ $proc.WaitForExit()
338
+ $exitCode = $proc.ExitCode
339
+ } finally {
340
+ Get-NetFirewallRule -DisplayName $allowRuleName -ErrorAction SilentlyContinue | Remove-NetFirewallRule -ErrorAction SilentlyContinue
341
+ Get-NetFirewallRule -DisplayName $blockRuleName -ErrorAction SilentlyContinue | Remove-NetFirewallRule -ErrorAction SilentlyContinue
342
+ }
343
+ exit $exitCode
344
+ `.trim();
345
+ fs_1.default.writeFileSync(scriptPath, script, 'utf8');
346
+ return scriptPath;
347
+ }
348
+ function normalizeFsRules(rules, cwd) {
349
+ const readWrite = new Set();
350
+ const readOnly = new Set();
351
+ const inaccessible = new Set();
352
+ for (const rule of rules) {
353
+ const root = sanitizeFsRoot(rule.path);
354
+ if (!root)
355
+ continue;
356
+ if (rule.permissions === 'none')
357
+ inaccessible.add(root);
358
+ else if (rule.permissions.includes('w'))
359
+ readWrite.add(root);
360
+ else
361
+ readOnly.add(root);
362
+ }
363
+ if (cwd)
364
+ readWrite.add(cwd);
365
+ return {
366
+ readWrite: Array.from(readWrite),
367
+ readOnly: Array.from(readOnly),
368
+ inaccessible: Array.from(inaccessible),
369
+ };
370
+ }
371
+ function sanitizeFsRoot(input) {
372
+ return input.replace(/\*\*.*$/, '').replace(/\/$/, '') || '/';
373
+ }
374
+ function parseMemoryBytes(value) {
375
+ const match = value.match(/^(\d+)(GB|MB|KB|B)?$/i);
376
+ if (!match)
377
+ return 512 * 1024 * 1024;
378
+ const amount = parseInt(match[1], 10);
379
+ switch ((match[2] || 'B').toUpperCase()) {
380
+ case 'GB': return amount * 1024 * 1024 * 1024;
381
+ case 'MB': return amount * 1024 * 1024;
382
+ case 'KB': return amount * 1024;
383
+ default: return amount;
384
+ }
385
+ }
386
+ function cpuQuotaPercent(value) {
387
+ const numeric = Number.parseFloat(value);
388
+ if (!Number.isFinite(numeric) || numeric <= 0)
389
+ return '50%';
390
+ return `${Math.max(1, Math.round(numeric * 100))}%`;
391
+ }
392
+ function commandExists(name) {
393
+ const suffixes = process.platform === 'win32' && !name.endsWith('.exe') ? [name, `${name}.exe`] : [name];
394
+ for (const candidate of suffixes) {
395
+ const pathEnv = process.env.PATH ?? '';
396
+ for (const dir of pathEnv.split(path_1.default.delimiter)) {
397
+ if (!dir)
398
+ continue;
399
+ const target = path_1.default.join(dir, candidate);
400
+ try {
401
+ fs_1.default.accessSync(target, fs_1.default.constants.X_OK);
402
+ return true;
403
+ }
404
+ catch {
405
+ continue;
406
+ }
407
+ }
408
+ }
409
+ return false;
410
+ }
411
+ function diffEnv(env) {
412
+ const diff = {};
413
+ for (const [key, value] of Object.entries(env)) {
414
+ if (process.env[key] !== value)
415
+ diff[key] = value;
416
+ }
417
+ return diff;
418
+ }
419
+ function shellQuote(value) {
420
+ return value.includes(' ') ? JSON.stringify(value) : value;
421
+ }
422
+ function psQuote(value) {
423
+ return `'${value.replace(/'/g, "''")}'`;
424
+ }
425
+ //# sourceMappingURL=launcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"launcher.js","sourceRoot":"","sources":["../src/launcher.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=launcher.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"launcher.test.d.ts","sourceRoot":"","sources":["../src/launcher.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const fs_1 = __importDefault(require("fs"));
7
+ const os_1 = __importDefault(require("os"));
8
+ const path_1 = __importDefault(require("path"));
9
+ const vitest_1 = require("vitest");
10
+ vitest_1.vi.mock('./proxy/cert-manager', () => ({
11
+ ensureProxyCertificate: vitest_1.vi.fn(() => ({
12
+ certPath: '/tmp/neuroshield-test-cert.pem',
13
+ keyPath: '/tmp/neuroshield-test-key.pem',
14
+ generated: false,
15
+ fingerprintSha256: 'ABCDEF',
16
+ notAfter: 'tomorrow',
17
+ })),
18
+ }));
19
+ const launcher_1 = require("./launcher");
20
+ function makeConfig() {
21
+ const stateDir = fs_1.default.mkdtempSync(path_1.default.join(os_1.default.tmpdir(), 'sentry-launch-'));
22
+ return {
23
+ sentry: {
24
+ hostId: 'host-1',
25
+ version: '1.0.0',
26
+ healthPort: 9190,
27
+ apiPort: 9191,
28
+ stateDir,
29
+ pidFilePath: path_1.default.join(stateDir, 'sentry.pid'),
30
+ },
31
+ neurosec: {
32
+ endpoint: 'https://sentry.neurosec.ai',
33
+ orgId: 'org-1',
34
+ tokenPath: path_1.default.join(stateDir, 'token'),
35
+ tlsCert: '',
36
+ tlsKey: '',
37
+ caBundlePath: '',
38
+ pinnedFingerprintSha256: '',
39
+ allowInsecureTls: false,
40
+ syncIntervalMs: 30000,
41
+ heartbeatIntervalMs: 300000,
42
+ },
43
+ enforcement: {
44
+ mode: 'enforce',
45
+ sandboxEnabled: true,
46
+ syscallFilterEnabled: true,
47
+ networkFilterEnabled: true,
48
+ filesystemFilterEnabled: true,
49
+ },
50
+ sandboxDefaults: { cpuMax: '0.5', memoryMax: '512MB', pidMax: 100 },
51
+ network: { allowHosts: ['api.openai.com:443'], blockHosts: [], allowPrivate: false, dnsMonitorEnabled: true },
52
+ skillAuthz: { enabled: true, allowUnknown: false, requireApproval: [] },
53
+ audit: { logPath: path_1.default.join(stateDir, 'audit.log'), retentionDays: 90, maxSizeMb: 500 },
54
+ discovery: { intervalMs: 30000, sourcePaths: ['/workspace'] },
55
+ proxy: {
56
+ enabled: true,
57
+ port: 9081,
58
+ bindAddress: '127.0.0.1',
59
+ upstreamTimeoutMs: 120000,
60
+ maxBufferSizeMb: 10,
61
+ interceptHttps: true,
62
+ certPath: path_1.default.join(stateDir, 'proxy-cert.pem'),
63
+ keyPath: path_1.default.join(stateDir, 'proxy-key.pem'),
64
+ allowedProviders: ['*'],
65
+ blockLocalModels: false,
66
+ },
67
+ redirect: { enabled: true, strategy: 'both', preserveOriginalKey: true, injectOnDiscover: true },
68
+ };
69
+ }
70
+ (0, vitest_1.describe)('Sentry launcher', () => {
71
+ let config;
72
+ (0, vitest_1.beforeEach)(() => {
73
+ config = makeConfig();
74
+ });
75
+ (0, vitest_1.it)('builds a Linux systemd-run plan with seccomp/resource properties and proxy env', () => {
76
+ const plan = (0, launcher_1.buildLaunchPlan)(config, { frameworkId: 'codex', command: ['node', 'agent.js'], cwd: '/workspace' }, 'linux', { systemdRun: true, sandboxExec: false, powershell: false });
77
+ (0, vitest_1.expect)(plan.executable).toBe('systemd-run');
78
+ (0, vitest_1.expect)(plan.args).toContain('--property');
79
+ (0, vitest_1.expect)(plan.args.join(' ')).toContain('SystemCallFilter=');
80
+ (0, vitest_1.expect)(plan.args.join(' ')).toContain('IPAddressDeny=any');
81
+ (0, vitest_1.expect)(plan.args.join(' ')).toContain('--setenv=OPENAI_BASE_URL=https://127.0.0.1:9082');
82
+ (0, vitest_1.expect)(plan.args.join(' ')).toContain('--setenv=NODE_EXTRA_CA_CERTS=/tmp/neuroshield-test-cert.pem');
83
+ });
84
+ (0, vitest_1.it)('builds a macOS sandbox-exec plan and writes a profile', () => {
85
+ const plan = (0, launcher_1.buildLaunchPlan)(config, { frameworkId: 'claude-code', command: ['node', 'agent.js'] }, 'darwin', { systemdRun: false, sandboxExec: true, powershell: false });
86
+ (0, vitest_1.expect)(plan.executable).toBe('sandbox-exec');
87
+ (0, vitest_1.expect)(plan.args[0]).toBe('-f');
88
+ (0, vitest_1.expect)(plan.generatedFiles).toHaveLength(1);
89
+ (0, vitest_1.expect)(fs_1.default.existsSync(plan.generatedFiles[0])).toBe(true);
90
+ });
91
+ (0, vitest_1.it)('falls back to direct spawn when no platform launcher exists', () => {
92
+ const plan = (0, launcher_1.buildLaunchPlan)(config, { frameworkId: 'unknown-agent', command: ['node', 'agent.js'] }, 'linux', { systemdRun: false, sandboxExec: false, powershell: false });
93
+ (0, vitest_1.expect)(plan.executable).toBe('node');
94
+ (0, vitest_1.expect)(plan.notes[0]).toMatch(/falling back/i);
95
+ (0, vitest_1.expect)(plan.env.OPENAI_BASE_URL).toBe('https://127.0.0.1:9082');
96
+ });
97
+ (0, vitest_1.it)('builds a Windows launcher script with loopback-only egress and isolated profile env', () => {
98
+ const plan = (0, launcher_1.buildLaunchPlan)(config, { frameworkId: 'claude-code', command: ['node', 'agent.js'] }, 'win32', { systemdRun: false, sandboxExec: false, powershell: true });
99
+ (0, vitest_1.expect)(plan.executable).toMatch(/^powershell(?:\.exe)?$/);
100
+ (0, vitest_1.expect)(plan.generatedFiles).toHaveLength(1);
101
+ const script = fs_1.default.readFileSync(plan.generatedFiles[0], 'utf8');
102
+ (0, vitest_1.expect)(script).toContain('New-NetFirewallRule -DisplayName $allowRuleName');
103
+ (0, vitest_1.expect)(script).toContain('New-NetFirewallRule -DisplayName $blockRuleName');
104
+ (0, vitest_1.expect)(script).toContain('$env:USERPROFILE = ');
105
+ (0, vitest_1.expect)(script).toContain('$env:APPDATA = ');
106
+ (0, vitest_1.expect)(script).toContain('$env:HOME = ');
107
+ });
108
+ });
109
+ //# sourceMappingURL=launcher.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"launcher.test.js","sourceRoot":"","sources":["../src/launcher.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ export interface CertProvisionResult {
2
+ certPath: string;
3
+ keyPath: string;
4
+ generated: boolean;
5
+ fingerprintSha256: string;
6
+ notAfter: string;
7
+ }
8
+ export interface CertProvisionOptions {
9
+ certPath: string;
10
+ keyPath: string;
11
+ /** Extra Subject Alternative Names to add (DNS:* form is auto-applied). */
12
+ extraSans?: string[];
13
+ /** Days the generated cert is valid. */
14
+ validityDays?: number;
15
+ }
16
+ /**
17
+ * Ensure a usable cert/key pair exists. Returns the paths plus a SHA-256
18
+ * fingerprint suitable for client-side pinning.
19
+ *
20
+ * Idempotent: if files already exist AND parse as a valid cert, leaves them
21
+ * alone. Otherwise generates a new self-signed cert via openssl.
22
+ */
23
+ export declare function ensureProxyCertificate(opts: CertProvisionOptions): CertProvisionResult;
24
+ //# sourceMappingURL=cert-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cert-manager.d.ts","sourceRoot":"","sources":["../../src/proxy/cert-manager.ts"],"names":[],"mappings":"AAoCA,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,OAAO,CAAC;IACnB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,2EAA2E;IAC3E,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,wCAAwC;IACxC,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,oBAAoB,GAAG,mBAAmB,CAkDtF"}