hackmyagent 0.16.5 → 0.17.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.
- package/dist/.integrity-manifest.json +1 -1
- package/dist/arp/crypto/hybrid-signing.d.ts +107 -0
- package/dist/arp/crypto/hybrid-signing.d.ts.map +1 -0
- package/dist/arp/crypto/hybrid-signing.js +321 -0
- package/dist/arp/crypto/hybrid-signing.js.map +1 -0
- package/dist/arp/crypto/index.d.ts +13 -0
- package/dist/arp/crypto/index.d.ts.map +1 -0
- package/dist/arp/crypto/index.js +33 -0
- package/dist/arp/crypto/index.js.map +1 -0
- package/dist/arp/crypto/manifest-loader.d.ts +117 -0
- package/dist/arp/crypto/manifest-loader.d.ts.map +1 -0
- package/dist/arp/crypto/manifest-loader.js +361 -0
- package/dist/arp/crypto/manifest-loader.js.map +1 -0
- package/dist/arp/crypto/types.d.ts +69 -0
- package/dist/arp/crypto/types.d.ts.map +1 -0
- package/dist/arp/crypto/types.js +11 -0
- package/dist/arp/crypto/types.js.map +1 -0
- package/dist/arp/index.d.ts +28 -1
- package/dist/arp/index.d.ts.map +1 -1
- package/dist/arp/index.js +97 -4
- package/dist/arp/index.js.map +1 -1
- package/dist/arp/intelligence/behavioral-risk-server.d.ts +82 -0
- package/dist/arp/intelligence/behavioral-risk-server.d.ts.map +1 -0
- package/dist/arp/intelligence/behavioral-risk-server.js +258 -0
- package/dist/arp/intelligence/behavioral-risk-server.js.map +1 -0
- package/dist/arp/intelligence/behavioral-risk.d.ts +217 -0
- package/dist/arp/intelligence/behavioral-risk.d.ts.map +1 -0
- package/dist/arp/intelligence/behavioral-risk.js +429 -0
- package/dist/arp/intelligence/behavioral-risk.js.map +1 -0
- package/dist/arp/intelligence/coordinator.d.ts +93 -2
- package/dist/arp/intelligence/coordinator.d.ts.map +1 -1
- package/dist/arp/intelligence/coordinator.js +281 -1
- package/dist/arp/intelligence/coordinator.js.map +1 -1
- package/dist/arp/intelligence/guard-anomaly.d.ts +349 -0
- package/dist/arp/intelligence/guard-anomaly.d.ts.map +1 -0
- package/dist/arp/intelligence/guard-anomaly.js +399 -0
- package/dist/arp/intelligence/guard-anomaly.js.map +1 -0
- package/dist/arp/intelligence/nanomind-l1.d.ts +37 -0
- package/dist/arp/intelligence/nanomind-l1.d.ts.map +1 -1
- package/dist/arp/intelligence/nanomind-l1.js +78 -0
- package/dist/arp/intelligence/nanomind-l1.js.map +1 -1
- package/dist/arp/intelligence/runtime-twin.d.ts +157 -0
- package/dist/arp/intelligence/runtime-twin.d.ts.map +1 -0
- package/dist/arp/intelligence/runtime-twin.js +479 -0
- package/dist/arp/intelligence/runtime-twin.js.map +1 -0
- package/dist/arp/intelligence/verify-classification.d.ts +124 -0
- package/dist/arp/intelligence/verify-classification.d.ts.map +1 -0
- package/dist/arp/intelligence/verify-classification.js +329 -0
- package/dist/arp/intelligence/verify-classification.js.map +1 -0
- package/dist/arp/proxy/server.d.ts +38 -8
- package/dist/arp/proxy/server.d.ts.map +1 -1
- package/dist/arp/proxy/server.js +89 -0
- package/dist/arp/proxy/server.js.map +1 -1
- package/dist/arp/types.d.ts +229 -1
- package/dist/arp/types.d.ts.map +1 -1
- package/dist/cli.js +691 -154
- package/dist/cli.js.map +1 -1
- package/dist/hardening/scanner.d.ts.map +1 -1
- package/dist/hardening/scanner.js +11 -1
- package/dist/hardening/scanner.js.map +1 -1
- package/dist/nanomind-core/compiler/semantic-compiler.d.ts.map +1 -1
- package/dist/nanomind-core/compiler/semantic-compiler.js +170 -10
- package/dist/nanomind-core/compiler/semantic-compiler.js.map +1 -1
- package/dist/nanomind-core/compiler/source-code-preprocessor.d.ts +64 -0
- package/dist/nanomind-core/compiler/source-code-preprocessor.d.ts.map +1 -0
- package/dist/nanomind-core/compiler/source-code-preprocessor.js +656 -0
- package/dist/nanomind-core/compiler/source-code-preprocessor.js.map +1 -0
- package/dist/nanomind-core/ingestion/artifact-parser.d.ts.map +1 -1
- package/dist/nanomind-core/ingestion/artifact-parser.js +15 -6
- package/dist/nanomind-core/ingestion/artifact-parser.js.map +1 -1
- package/package.json +3 -1
package/dist/arp/index.js
CHANGED
|
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.AgentRuntimeProtection = exports.mapEventType = exports.isAnomalousEvent = exports.submitGTINEvent = exports.buildGTINPayload = exports.generateSensorToken = exports.GTINForwarder = exports.PREMIUM_FEATURES = exports.registerLicenseValidator = exports.hasFeature = exports.checkLicense = exports.ARPProxy = exports.ALL_PATTERNS = exports.PATTERN_SETS = exports.scanText = exports.defaultConfig = exports.loadConfig = exports.LocalLogger = exports.EnforcementEngine = exports.A2AProtocolInterceptor = exports.MCPProtocolInterceptor = exports.PromptInterceptor = exports.FilesystemInterceptor = exports.NetworkInterceptor = exports.ProcessInterceptor = exports.parseDeclaredCapabilities = exports.createCapabilityMonitor = exports.SkillCapabilityMonitor = exports.FilesystemMonitor = exports.NetworkMonitor = exports.ProcessMonitor = exports.autoDetectAdapter = exports.createAdapter = exports.OllamaAdapter = exports.OpenAIAdapter = exports.AnthropicAdapter = exports.
|
|
36
|
+
exports.AgentRuntimeProtection = exports.mapEventType = exports.isAnomalousEvent = exports.submitGTINEvent = exports.buildGTINPayload = exports.generateSensorToken = exports.GTINForwarder = exports.PREMIUM_FEATURES = exports.registerLicenseValidator = exports.hasFeature = exports.checkLicense = exports.ARPProxy = exports.ALL_PATTERNS = exports.PATTERN_SETS = exports.scanText = exports.defaultConfig = exports.loadConfig = exports.LocalLogger = exports.EnforcementEngine = exports.A2AProtocolInterceptor = exports.MCPProtocolInterceptor = exports.PromptInterceptor = exports.FilesystemInterceptor = exports.NetworkInterceptor = exports.ProcessInterceptor = exports.parseDeclaredCapabilities = exports.createCapabilityMonitor = exports.SkillCapabilityMonitor = exports.FilesystemMonitor = exports.NetworkMonitor = exports.ProcessMonitor = exports.autoDetectAdapter = exports.createAdapter = exports.OllamaAdapter = exports.OpenAIAdapter = exports.AnthropicAdapter = exports.RuntimeTwin = exports.AnomalyDetector = exports.BudgetController = exports.IntelligenceCoordinator = exports.CorrelationEngine = exports.EventEngine = exports.VERSION = void 0;
|
|
37
37
|
exports.VERSION = '0.2.0';
|
|
38
38
|
// Re-export components
|
|
39
39
|
var event_engine_1 = require("./engine/event-engine");
|
|
@@ -46,8 +46,8 @@ var budget_1 = require("./intelligence/budget");
|
|
|
46
46
|
Object.defineProperty(exports, "BudgetController", { enumerable: true, get: function () { return budget_1.BudgetController; } });
|
|
47
47
|
var anomaly_1 = require("./intelligence/anomaly");
|
|
48
48
|
Object.defineProperty(exports, "AnomalyDetector", { enumerable: true, get: function () { return anomaly_1.AnomalyDetector; } });
|
|
49
|
-
var
|
|
50
|
-
Object.defineProperty(exports, "
|
|
49
|
+
var runtime_twin_1 = require("./intelligence/runtime-twin");
|
|
50
|
+
Object.defineProperty(exports, "RuntimeTwin", { enumerable: true, get: function () { return runtime_twin_1.RuntimeTwin; } });
|
|
51
51
|
var adapters_1 = require("./intelligence/adapters");
|
|
52
52
|
Object.defineProperty(exports, "AnthropicAdapter", { enumerable: true, get: function () { return adapters_1.AnthropicAdapter; } });
|
|
53
53
|
Object.defineProperty(exports, "OpenAIAdapter", { enumerable: true, get: function () { return adapters_1.OpenAIAdapter; } });
|
|
@@ -105,6 +105,9 @@ Object.defineProperty(exports, "mapEventType", { enumerable: true, get: function
|
|
|
105
105
|
const path = __importStar(require("path"));
|
|
106
106
|
const event_engine_2 = require("./engine/event-engine");
|
|
107
107
|
const coordinator_2 = require("./intelligence/coordinator");
|
|
108
|
+
const runtime_twin_2 = require("./intelligence/runtime-twin");
|
|
109
|
+
const behavioral_risk_1 = require("./intelligence/behavioral-risk");
|
|
110
|
+
const guard_anomaly_1 = require("./intelligence/guard-anomaly");
|
|
108
111
|
const kill_switch_2 = require("./enforcement/kill-switch");
|
|
109
112
|
const local_log_2 = require("./reporting/local-log");
|
|
110
113
|
const process_3 = require("./monitors/process");
|
|
@@ -146,7 +149,24 @@ class AgentRuntimeProtection {
|
|
|
146
149
|
}
|
|
147
150
|
const dataDir = this.config.dataDir ?? path.join(process.cwd(), '.opena2a', 'arp');
|
|
148
151
|
this.engine = new event_engine_2.EventEngine(this.config);
|
|
149
|
-
|
|
152
|
+
// Build the runtime twin and behavioral risk source. Runtime twin is
|
|
153
|
+
// on by default when intelligence is enabled; opt out via
|
|
154
|
+
// `intelligence.runtimeTwin.enabled = false`. We do NOT attach the
|
|
155
|
+
// twin to the event engine here; start() does that so a user who
|
|
156
|
+
// constructs an ARP without calling start() does not get surprise
|
|
157
|
+
// event handlers.
|
|
158
|
+
this.runtimeTwin = buildRuntimeTwin(this.config);
|
|
159
|
+
this.behavioralRiskSource = this.runtimeTwin
|
|
160
|
+
? new behavioral_risk_1.InProcessBehavioralRiskSource(this.runtimeTwin, 'runtime-twin-inproc')
|
|
161
|
+
: null;
|
|
162
|
+
// Build the guard anomaly detector. Only constructed when the caller
|
|
163
|
+
// injected a baseline; otherwise drift detection is inert.
|
|
164
|
+
this.guardAnomaly = buildGuardAnomaly(this.config);
|
|
165
|
+
// Wire both sources into the coordinator. The third argument
|
|
166
|
+
// (manifest) stays null here; capability manifests are loaded by
|
|
167
|
+
// ARPProxy.start for HTTP proxy deployments and are not part of the
|
|
168
|
+
// AgentRuntimeProtection constructor surface today.
|
|
169
|
+
this.intelligence = new coordinator_2.IntelligenceCoordinator(this.config, dataDir, null, this.behavioralRiskSource, this.guardAnomaly);
|
|
150
170
|
this.enforcement = new kill_switch_2.EnforcementEngine();
|
|
151
171
|
this.logger = new local_log_2.LocalLogger(dataDir);
|
|
152
172
|
// Wire up: events → intelligence → logger
|
|
@@ -211,6 +231,13 @@ class AgentRuntimeProtection {
|
|
|
211
231
|
async start() {
|
|
212
232
|
if (this.running)
|
|
213
233
|
return;
|
|
234
|
+
// Attach the runtime twin to the event engine BEFORE monitors start
|
|
235
|
+
// so the twin observes every event from the first tick. The twin
|
|
236
|
+
// trains its own baseline over the first 100 events and does not
|
|
237
|
+
// mutate the event or block the L0 decision.
|
|
238
|
+
if (this.runtimeTwin) {
|
|
239
|
+
this.runtimeTwin.attach(this.engine);
|
|
240
|
+
}
|
|
214
241
|
for (const monitor of this.monitors) {
|
|
215
242
|
await monitor.start();
|
|
216
243
|
}
|
|
@@ -275,6 +302,72 @@ class AgentRuntimeProtection {
|
|
|
275
302
|
getEnforcement() {
|
|
276
303
|
return this.enforcement;
|
|
277
304
|
}
|
|
305
|
+
/**
|
|
306
|
+
* Get the intelligence coordinator. Exposed so tests can assert the
|
|
307
|
+
* coordinator was constructed with the expected behavioral risk and
|
|
308
|
+
* guard anomaly sources, and so advanced integrations can swap
|
|
309
|
+
* sources at runtime via `setBehavioralRiskSource` / `setGuardAnomaly`.
|
|
310
|
+
*/
|
|
311
|
+
getIntelligence() {
|
|
312
|
+
return this.intelligence;
|
|
313
|
+
}
|
|
314
|
+
/** The runtime twin instance, or null when disabled. */
|
|
315
|
+
getRuntimeTwin() {
|
|
316
|
+
return this.runtimeTwin;
|
|
317
|
+
}
|
|
278
318
|
}
|
|
279
319
|
exports.AgentRuntimeProtection = AgentRuntimeProtection;
|
|
320
|
+
/**
|
|
321
|
+
* Construct an in-process `RuntimeTwin` from the ARP config, or return
|
|
322
|
+
* null when the caller disabled intelligence or the runtime twin
|
|
323
|
+
* explicitly. Kept as a free function so the constructor stays short
|
|
324
|
+
* and the default policy is visible in one place.
|
|
325
|
+
*
|
|
326
|
+
* Default policy:
|
|
327
|
+
* - When `intelligence.enabled === false`: no twin (L2 disabled implies
|
|
328
|
+
* the behavioral layer is also unwanted).
|
|
329
|
+
* - When `intelligence.runtimeTwin.enabled === false`: no twin.
|
|
330
|
+
* - Otherwise: construct a twin seeded from `config.agentName`, with
|
|
331
|
+
* fleet federation opt-in from the config (default off).
|
|
332
|
+
*/
|
|
333
|
+
function buildRuntimeTwin(config) {
|
|
334
|
+
const ic = config.intelligence;
|
|
335
|
+
if (ic?.enabled === false)
|
|
336
|
+
return null;
|
|
337
|
+
const twinCfg = ic?.runtimeTwin;
|
|
338
|
+
if (twinCfg?.enabled === false)
|
|
339
|
+
return null;
|
|
340
|
+
return new runtime_twin_2.RuntimeTwin(config.agentName, {
|
|
341
|
+
enabled: true,
|
|
342
|
+
fleetEnabled: twinCfg?.fleetEnabled ?? false,
|
|
343
|
+
agentCategory: twinCfg?.agentCategory ?? 'general',
|
|
344
|
+
});
|
|
345
|
+
}
|
|
346
|
+
/**
|
|
347
|
+
* Construct a `GuardAnomalyDetector` from the ARP config, or return
|
|
348
|
+
* null when no baseline was provided or the caller explicitly disabled
|
|
349
|
+
* guard anomaly detection. A baseline is required: drift detection
|
|
350
|
+
* without a reference distribution is nonsense, so we refuse to
|
|
351
|
+
* auto-bootstrap one from observations. The caller supplies a
|
|
352
|
+
* Registry-exported training distribution in production, or a
|
|
353
|
+
* snapshotted JSON file pre-Registry.
|
|
354
|
+
*/
|
|
355
|
+
function buildGuardAnomaly(config) {
|
|
356
|
+
const gaCfg = config.intelligence?.guardAnomaly;
|
|
357
|
+
if (!gaCfg)
|
|
358
|
+
return null;
|
|
359
|
+
if (gaCfg.enabled === false)
|
|
360
|
+
return null;
|
|
361
|
+
const baseline = gaCfg.baseline;
|
|
362
|
+
if (!baseline || Object.keys(baseline).length === 0)
|
|
363
|
+
return null;
|
|
364
|
+
return new guard_anomaly_1.GuardAnomalyDetector({
|
|
365
|
+
baseline,
|
|
366
|
+
windowSize: gaCfg.windowSize,
|
|
367
|
+
alarmThreshold: gaCfg.alarmThreshold,
|
|
368
|
+
smoothing: gaCfg.smoothing,
|
|
369
|
+
minObservations: gaCfg.minObservations,
|
|
370
|
+
sourceName: gaCfg.sourceName,
|
|
371
|
+
});
|
|
372
|
+
}
|
|
280
373
|
//# sourceMappingURL=index.js.map
|
package/dist/arp/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/arp/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAa,QAAA,OAAO,GAAG,OAAO,CAAC;AA4B/B,uBAAuB;AACvB,sDAAoD;AAA3C,2GAAA,WAAW,OAAA;AACpB,oDAAyD;AAAhD,gHAAA,iBAAiB,OAAA;AAC1B,0DAAqE;AAA5D,sHAAA,uBAAuB,OAAA;AAChC,gDAAyD;AAAhD,0GAAA,gBAAgB,OAAA;AACzB,kDAAyD;AAAhD,0GAAA,eAAe,OAAA;AACxB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/arp/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAa,QAAA,OAAO,GAAG,OAAO,CAAC;AA4B/B,uBAAuB;AACvB,sDAAoD;AAA3C,2GAAA,WAAW,OAAA;AACpB,oDAAyD;AAAhD,gHAAA,iBAAiB,OAAA;AAC1B,0DAAqE;AAA5D,sHAAA,uBAAuB,OAAA;AAChC,gDAAyD;AAAhD,0GAAA,gBAAgB,OAAA;AACzB,kDAAyD;AAAhD,0GAAA,eAAe,OAAA;AACxB,4DAA0D;AAAjD,2GAAA,WAAW,OAAA;AACpB,oDAA2H;AAAlH,4GAAA,gBAAgB,OAAA;AAAE,yGAAA,aAAa,OAAA;AAAE,yGAAA,aAAa,OAAA;AAAE,yGAAA,aAAa,OAAA;AAAE,6GAAA,iBAAiB,OAAA;AACzF,8CAAoD;AAA3C,yGAAA,cAAc,OAAA;AACvB,8CAAoD;AAA3C,yGAAA,cAAc,OAAA;AACvB,oDAA0D;AAAjD,+GAAA,iBAAiB,OAAA;AAC1B,gFAAiI;AAAxH,kIAAA,sBAAsB,OAAA;AAAE,mIAAA,uBAAuB,OAAA;AAAE,qIAAA,yBAAyB,OAAA;AAEnF,kDAA4D;AAAnD,6GAAA,kBAAkB,OAAA;AAC3B,kDAA4D;AAAnD,6GAAA,kBAAkB,OAAA;AAC3B,wDAAkE;AAAzD,mHAAA,qBAAqB,OAAA;AAC9B,gDAA0D;AAAjD,2GAAA,iBAAiB,OAAA;AAC1B,4DAAqE;AAA5D,sHAAA,sBAAsB,OAAA;AAC/B,4DAAqE;AAA5D,sHAAA,sBAAsB,OAAA;AAC/B,yDAAkF;AAAzE,gHAAA,iBAAiB,OAAA;AAC1B,mDAAoD;AAA3C,wGAAA,WAAW,OAAA;AACpB,0CAA4D;AAAnD,oGAAA,UAAU,OAAA;AAAE,uGAAA,aAAa,OAAA;AAClC,oDAAkH;AAAzG,sGAAA,QAAQ,OAAA;AAAE,0GAAA,YAAY,OAAA;AAAE,0GAAA,YAAY,OAAA;AAC7C,yCAA6D;AAApD,kGAAA,QAAQ,OAAA;AACjB,qCAOmB;AANjB,uGAAA,YAAY,OAAA;AACZ,qGAAA,UAAU,OAAA;AACV,mHAAA,wBAAwB,OAAA;AACxB,2GAAA,gBAAgB,OAAA;AAKlB,sBAAsB;AACtB,yCAYqB;AAXnB,0GAAA,aAAa,OAAA;AACb,gHAAA,mBAAmB,OAAA;AACnB,6GAAA,gBAAgB,OAAA;AAChB,4GAAA,eAAe,OAAA;AACf,6GAAA,gBAAgB,OAAA;AAChB,yGAAA,YAAY,OAAA;AAQd,2CAA6B;AAE7B,wDAAoD;AACpD,4DAAqE;AACrE,8DAA0D;AAC1D,oEAGwC;AACxC,gEAGsC;AACtC,2DAAkF;AAClF,qDAAoD;AACpD,gDAAoD;AACpD,gDAAoD;AACpD,sDAA0D;AAC1D,oDAA4D;AAC5D,oDAA4D;AAC5D,0DAAkE;AAClE,kDAA0D;AAC1D,8DAAqE;AACrE,8DAAqE;AACrE,4CAA6C;AAC7C,qDAAsD;AACtD,2CAAuD;AAEvD;;;;;;;;;;;;;GAaG;AACH,MAAa,sBAAsB;IA2BjC,YAAY,YAAiC;QArB5B,aAAQ,GAAc,EAAE,CAAC;QAClC,kBAAa,GAAyB,IAAI,CAAC;QAC3C,YAAO,GAAG,KAAK,CAAC;QAoBtB,IAAI,OAAO,YAAY,KAAK,QAAQ,EAAE,CAAC;YACrC,IAAI,CAAC,MAAM,GAAG,IAAA,mBAAU,EAAC,YAAY,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,YAAY,IAAI,IAAA,mBAAU,GAAE,CAAC;QAC7C,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;QAEnF,IAAI,CAAC,MAAM,GAAG,IAAI,0BAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE3C,qEAAqE;QACrE,0DAA0D;QAC1D,mEAAmE;QACnE,iEAAiE;QACjE,kEAAkE;QAClE,kBAAkB;QAClB,IAAI,CAAC,WAAW,GAAG,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,WAAW;YAC1C,CAAC,CAAC,IAAI,+CAA6B,CAAC,IAAI,CAAC,WAAW,EAAE,qBAAqB,CAAC;YAC5E,CAAC,CAAC,IAAI,CAAC;QAET,qEAAqE;QACrE,2DAA2D;QAC3D,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEnD,6DAA6D;QAC7D,iEAAiE;QACjE,oEAAoE;QACpE,oDAAoD;QACpD,IAAI,CAAC,YAAY,GAAG,IAAI,qCAAuB,CAC7C,IAAI,CAAC,MAAM,EACX,OAAO,EACP,IAAI,EACJ,IAAI,CAAC,oBAAoB,EACzB,IAAI,CAAC,YAAY,CAClB,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,IAAI,+BAAiB,EAAE,CAAC;QAC3C,IAAI,CAAC,MAAM,GAAG,IAAI,uBAAW,CAAC,OAAO,CAAC,CAAC;QAEvC,0CAA0C;QAC1C,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YAClC,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;YACzC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;YAC7E,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,kCAAkC;QAClC,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,EAAE,EAAE,OAAO,EAAE,OAAO,KAAK,KAAK,EAAE,CAAC;YACnC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,wBAAc,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC;QAC/E,CAAC;QACD,IAAI,EAAE,EAAE,OAAO,EAAE,OAAO,KAAK,KAAK,EAAE,CAAC;YACnC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,wBAAc,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;QAC1G,CAAC;QACD,IAAI,EAAE,EAAE,UAAU,EAAE,OAAO,KAAK,KAAK,EAAE,CAAC;YACtC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,8BAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,EAAE,EAAE,UAAU,EAAE,YAAY,CAAC,CAAC,CAAC;QACnH,CAAC;QAED,8EAA8E;QAC9E,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC;QACpC,IAAI,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;YACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,4BAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QAC1D,CAAC;QACD,IAAI,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;YACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,4BAAkB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;QACnF,CAAC;QACD,IAAI,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;YAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,kCAAqB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACpG,CAAC;QAED,+BAA+B;QAC/B,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;QAC/B,IAAI,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,0BAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QACzD,CAAC;QACD,IAAI,EAAE,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;YACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,qCAAsB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC;QACnF,CAAC;QACD,IAAI,EAAE,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC;YACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,qCAAsB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC;QACpF,CAAC;QAED,oCAAoC;QACpC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,CAAC;YAC9B,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,IAAI,IAAA,0BAAmB,GAAE,CAAC;YAC1E,IAAI,CAAC,aAAa,GAAG,IAAI,yBAAa,CAAC;gBACrC,OAAO,EAAE,IAAI;gBACb,WAAW;gBACX,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW;gBACzC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS;aACnC,CAAC,CAAC;YAEH,4DAA4D;YAC5D,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC5B,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;YACrC,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,yBAAyB;IACzB,KAAK,CAAC,KAAK;QACT,IAAI,IAAI,CAAC,OAAO;YAAE,OAAO;QAEzB,oEAAoE;QACpE,iEAAiE;QACjE,iEAAiE;QACjE,6CAA6C;QAC7C,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvC,CAAC;QAED,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;QACxB,CAAC;QAED,qCAAqC;QACrC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,uCAAuC;IACvC,KAAK,CAAC,IAAI;QACR,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QAE1B,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;QACvB,CAAC;QAED,oCAAoC;QACpC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,MAAM,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QACtC,CAAC;QAED,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAC/B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,8BAA8B;IAC9B,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,yBAAyB;IACzB,SAAS;QAMP,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAC9E,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE;YAC3C,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;SAC7C,CAAC;IACJ,CAAC;IAED,wBAAwB;IACxB,SAAS,CAAC,KAAc;QACtB,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,8BAA8B;IAC9B,MAAM,CAAC,GAAW;QAChB,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACtC,CAAC;IAED,oFAAoF;IACpF,OAAO,CAAC,OAAkD;QACxD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED,2CAA2C;IAC3C,aAAa,CAAC,OAA8E;QAC1F,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,wDAAwD;IACxD,gBAAgB,CAAC,QAAuB;QACtC,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;IAC9C,CAAC;IAED,qDAAqD;IACrD,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,sDAAsD;IACtD,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;;;OAKG;IACH,eAAe;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,wDAAwD;IACxD,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;CACF;AAlPD,wDAkPC;AAED;;;;;;;;;;;;GAYG;AACH,SAAS,gBAAgB,CAAC,MAAiB;IACzC,MAAM,EAAE,GAAG,MAAM,CAAC,YAAY,CAAC;IAC/B,IAAI,EAAE,EAAE,OAAO,KAAK,KAAK;QAAE,OAAO,IAAI,CAAC;IACvC,MAAM,OAAO,GAAG,EAAE,EAAE,WAAW,CAAC;IAChC,IAAI,OAAO,EAAE,OAAO,KAAK,KAAK;QAAE,OAAO,IAAI,CAAC;IAC5C,OAAO,IAAI,0BAAW,CAAC,MAAM,CAAC,SAAS,EAAE;QACvC,OAAO,EAAE,IAAI;QACb,YAAY,EAAE,OAAO,EAAE,YAAY,IAAI,KAAK;QAC5C,aAAa,EAAE,OAAO,EAAE,aAAa,IAAI,SAAS;KACnD,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;GAQG;AACH,SAAS,iBAAiB,CAAC,MAAiB;IAC1C,MAAM,KAAK,GAAG,MAAM,CAAC,YAAY,EAAE,YAAY,CAAC;IAChD,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IACxB,IAAI,KAAK,CAAC,OAAO,KAAK,KAAK;QAAE,OAAO,IAAI,CAAC;IACzC,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;IAChC,IAAI,CAAC,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IACjE,OAAO,IAAI,oCAAoB,CAAC;QAC9B,QAAQ;QACR,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,UAAU,EAAE,KAAK,CAAC,UAAU;KAC7B,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Behavioral risk IPC server (AIComply P1, producer side).
|
|
3
|
+
*
|
|
4
|
+
* Partner to `behavioral-risk.ts`. Listens on a unix domain socket (or
|
|
5
|
+
* Windows named pipe) and answers risk signal requests by delegating to a
|
|
6
|
+
* caller-supplied `BehavioralRiskScoreable`, which in production is a
|
|
7
|
+
* `RuntimeTwin` instance running in the twin's own process.
|
|
8
|
+
*
|
|
9
|
+
* The server is deliberately narrow: one request per connection, no
|
|
10
|
+
* session state, no authentication beyond filesystem permissions on the
|
|
11
|
+
* socket path. The threat model assumes the socket is owned by the same
|
|
12
|
+
* local user and is reachable only from processes with appropriate
|
|
13
|
+
* filesystem access; cross-host or cross-user use is out of scope.
|
|
14
|
+
*
|
|
15
|
+
* Wire format (both directions, newline-delimited JSON):
|
|
16
|
+
*
|
|
17
|
+
* request {"kind":"risk_signal_request","version":1,"event":<ARPEvent>}
|
|
18
|
+
* response {"kind":"risk_signal_response","version":1,"score":...,
|
|
19
|
+
* "action":"allow|alert|throttle|suspend|kill","reason":"...",
|
|
20
|
+
* "source":"...","computedAtMs":...}
|
|
21
|
+
* error {"kind":"risk_signal_error","version":1,"code":<code>,
|
|
22
|
+
* "reason":"..."}
|
|
23
|
+
*
|
|
24
|
+
* Any parse failure, unknown kind, or thrown exception inside the scorer
|
|
25
|
+
* is converted to a structured `risk_signal_error` message. The server
|
|
26
|
+
* never crashes on a malformed request; per-request isolation keeps a
|
|
27
|
+
* bad client from affecting others.
|
|
28
|
+
*/
|
|
29
|
+
import { type BehavioralRiskScoreable, type BehavioralRiskUnavailableCode } from './behavioral-risk';
|
|
30
|
+
/**
|
|
31
|
+
* Options accepted by `startBehavioralRiskServer`. Only `twin` is
|
|
32
|
+
* required; everything else has a defensible default.
|
|
33
|
+
*/
|
|
34
|
+
export interface BehavioralRiskServerOptions {
|
|
35
|
+
/**
|
|
36
|
+
* Handle that knows how to score an ARP event. In production this is a
|
|
37
|
+
* RuntimeTwin instance. In tests it can be any stub that returns a
|
|
38
|
+
* deterministic risk score.
|
|
39
|
+
*/
|
|
40
|
+
twin: BehavioralRiskScoreable;
|
|
41
|
+
/**
|
|
42
|
+
* Filesystem path where the server listens. On POSIX systems, a unix
|
|
43
|
+
* domain socket; on Windows, a named pipe path. Any existing socket
|
|
44
|
+
* file at this path is removed before binding (POSIX only).
|
|
45
|
+
*/
|
|
46
|
+
socketPath: string;
|
|
47
|
+
/**
|
|
48
|
+
* Identifier written back into the `source` field of every response.
|
|
49
|
+
* Helps the coordinator's audit log distinguish between multiple risk
|
|
50
|
+
* sources during A/B rollout.
|
|
51
|
+
*/
|
|
52
|
+
sourceName?: string;
|
|
53
|
+
/**
|
|
54
|
+
* Invoked whenever the server rejects a request with an error response.
|
|
55
|
+
* Gets the code and reason. Useful for routing to a SIEM or surfacing
|
|
56
|
+
* in an operator dashboard. Optional; defaults to a no-op.
|
|
57
|
+
*/
|
|
58
|
+
onError?: (code: BehavioralRiskUnavailableCode, reason: string) => void;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Handle returned by `startBehavioralRiskServer`. Callers hold this for
|
|
62
|
+
* the lifetime of the coordinator and invoke `close()` on shutdown.
|
|
63
|
+
*/
|
|
64
|
+
export interface BehavioralRiskServerHandle {
|
|
65
|
+
/** The listening socket path. */
|
|
66
|
+
readonly socketPath: string;
|
|
67
|
+
/**
|
|
68
|
+
* Stop accepting new connections, tear down the listening socket, and
|
|
69
|
+
* clean up the socket file on POSIX. Safe to call more than once.
|
|
70
|
+
*/
|
|
71
|
+
close(): Promise<void>;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Start the behavioral risk IPC server. Resolves once the server is
|
|
75
|
+
* actively listening on the socket path so the caller can hand the path
|
|
76
|
+
* to clients without a race against a half-open listener.
|
|
77
|
+
*
|
|
78
|
+
* Throws on bind failure (unrecoverable; the caller should decide
|
|
79
|
+
* whether to degrade to an in-process source or fail the startup).
|
|
80
|
+
*/
|
|
81
|
+
export declare function startBehavioralRiskServer(options: BehavioralRiskServerOptions): Promise<BehavioralRiskServerHandle>;
|
|
82
|
+
//# sourceMappingURL=behavioral-risk-server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"behavioral-risk-server.d.ts","sourceRoot":"","sources":["../../../src/arp/intelligence/behavioral-risk-server.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AAMH,OAAO,EAEL,KAAK,uBAAuB,EAC5B,KAAK,6BAA6B,EACnC,MAAM,mBAAmB,CAAC;AAE3B;;;GAGG;AACH,MAAM,WAAW,2BAA2B;IAC1C;;;;OAIG;IACH,IAAI,EAAE,uBAAuB,CAAC;IAC9B;;;;OAIG;IACH,UAAU,EAAE,MAAM,CAAC;IACnB;;;;OAIG;IACH,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB;;;;OAIG;IACH,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,6BAA6B,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;CACzE;AAED;;;GAGG;AACH,MAAM,WAAW,0BAA0B;IACzC,iCAAiC;IACjC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B;;;OAGG;IACH,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CACxB;AAED;;;;;;;GAOG;AACH,wBAAsB,yBAAyB,CAC7C,OAAO,EAAE,2BAA2B,GACnC,OAAO,CAAC,0BAA0B,CAAC,CAkGrC"}
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Behavioral risk IPC server (AIComply P1, producer side).
|
|
4
|
+
*
|
|
5
|
+
* Partner to `behavioral-risk.ts`. Listens on a unix domain socket (or
|
|
6
|
+
* Windows named pipe) and answers risk signal requests by delegating to a
|
|
7
|
+
* caller-supplied `BehavioralRiskScoreable`, which in production is a
|
|
8
|
+
* `RuntimeTwin` instance running in the twin's own process.
|
|
9
|
+
*
|
|
10
|
+
* The server is deliberately narrow: one request per connection, no
|
|
11
|
+
* session state, no authentication beyond filesystem permissions on the
|
|
12
|
+
* socket path. The threat model assumes the socket is owned by the same
|
|
13
|
+
* local user and is reachable only from processes with appropriate
|
|
14
|
+
* filesystem access; cross-host or cross-user use is out of scope.
|
|
15
|
+
*
|
|
16
|
+
* Wire format (both directions, newline-delimited JSON):
|
|
17
|
+
*
|
|
18
|
+
* request {"kind":"risk_signal_request","version":1,"event":<ARPEvent>}
|
|
19
|
+
* response {"kind":"risk_signal_response","version":1,"score":...,
|
|
20
|
+
* "action":"allow|alert|throttle|suspend|kill","reason":"...",
|
|
21
|
+
* "source":"...","computedAtMs":...}
|
|
22
|
+
* error {"kind":"risk_signal_error","version":1,"code":<code>,
|
|
23
|
+
* "reason":"..."}
|
|
24
|
+
*
|
|
25
|
+
* Any parse failure, unknown kind, or thrown exception inside the scorer
|
|
26
|
+
* is converted to a structured `risk_signal_error` message. The server
|
|
27
|
+
* never crashes on a malformed request; per-request isolation keeps a
|
|
28
|
+
* bad client from affecting others.
|
|
29
|
+
*/
|
|
30
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
31
|
+
if (k2 === undefined) k2 = k;
|
|
32
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
33
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
34
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
35
|
+
}
|
|
36
|
+
Object.defineProperty(o, k2, desc);
|
|
37
|
+
}) : (function(o, m, k, k2) {
|
|
38
|
+
if (k2 === undefined) k2 = k;
|
|
39
|
+
o[k2] = m[k];
|
|
40
|
+
}));
|
|
41
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
42
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
43
|
+
}) : function(o, v) {
|
|
44
|
+
o["default"] = v;
|
|
45
|
+
});
|
|
46
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
47
|
+
var ownKeys = function(o) {
|
|
48
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
49
|
+
var ar = [];
|
|
50
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
51
|
+
return ar;
|
|
52
|
+
};
|
|
53
|
+
return ownKeys(o);
|
|
54
|
+
};
|
|
55
|
+
return function (mod) {
|
|
56
|
+
if (mod && mod.__esModule) return mod;
|
|
57
|
+
var result = {};
|
|
58
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
59
|
+
__setModuleDefault(result, mod);
|
|
60
|
+
return result;
|
|
61
|
+
};
|
|
62
|
+
})();
|
|
63
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
64
|
+
exports.startBehavioralRiskServer = startBehavioralRiskServer;
|
|
65
|
+
const net = __importStar(require("net"));
|
|
66
|
+
const fs = __importStar(require("fs"));
|
|
67
|
+
const path = __importStar(require("path"));
|
|
68
|
+
const behavioral_risk_1 = require("./behavioral-risk");
|
|
69
|
+
/**
|
|
70
|
+
* Start the behavioral risk IPC server. Resolves once the server is
|
|
71
|
+
* actively listening on the socket path so the caller can hand the path
|
|
72
|
+
* to clients without a race against a half-open listener.
|
|
73
|
+
*
|
|
74
|
+
* Throws on bind failure (unrecoverable; the caller should decide
|
|
75
|
+
* whether to degrade to an in-process source or fail the startup).
|
|
76
|
+
*/
|
|
77
|
+
async function startBehavioralRiskServer(options) {
|
|
78
|
+
const { twin, socketPath, sourceName = 'nanomind-l1-ipc', onError } = options;
|
|
79
|
+
// On POSIX, a stale socket file from a crashed previous run blocks
|
|
80
|
+
// bind. We remove it defensively. On Windows named pipes, the path is
|
|
81
|
+
// in its own namespace and this step is a no-op.
|
|
82
|
+
if (process.platform !== 'win32') {
|
|
83
|
+
try {
|
|
84
|
+
const dir = path.dirname(socketPath);
|
|
85
|
+
if (!fs.existsSync(dir))
|
|
86
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
87
|
+
if (fs.existsSync(socketPath))
|
|
88
|
+
fs.unlinkSync(socketPath);
|
|
89
|
+
}
|
|
90
|
+
catch {
|
|
91
|
+
// If we cannot clean up the stale file, let listen() surface the
|
|
92
|
+
// real error below.
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
const server = net.createServer((socket) => {
|
|
96
|
+
let buffer = '';
|
|
97
|
+
let handled = false;
|
|
98
|
+
const sendAndClose = (payload) => {
|
|
99
|
+
if (handled)
|
|
100
|
+
return;
|
|
101
|
+
handled = true;
|
|
102
|
+
try {
|
|
103
|
+
socket.write(JSON.stringify(payload) + '\n');
|
|
104
|
+
}
|
|
105
|
+
catch {
|
|
106
|
+
// If the client already hung up, there is nothing useful to do.
|
|
107
|
+
}
|
|
108
|
+
socket.end();
|
|
109
|
+
};
|
|
110
|
+
const sendError = (code, reason) => {
|
|
111
|
+
onError?.(code, reason);
|
|
112
|
+
sendAndClose({
|
|
113
|
+
kind: 'risk_signal_error',
|
|
114
|
+
version: behavioral_risk_1.BEHAVIORAL_RISK_WIRE_VERSION,
|
|
115
|
+
code,
|
|
116
|
+
reason,
|
|
117
|
+
});
|
|
118
|
+
};
|
|
119
|
+
socket.on('data', (chunk) => {
|
|
120
|
+
if (handled)
|
|
121
|
+
return;
|
|
122
|
+
buffer += chunk.toString('utf8');
|
|
123
|
+
const nl = buffer.indexOf('\n');
|
|
124
|
+
if (nl < 0) {
|
|
125
|
+
// Cap unparsed buffer to keep a misbehaving client from
|
|
126
|
+
// exhausting server memory. One request per connection means a
|
|
127
|
+
// single line; anything beyond a reasonable ceiling is hostile.
|
|
128
|
+
if (buffer.length > 64 * 1024) {
|
|
129
|
+
sendError('PARSE_ERROR', 'request exceeded maximum size');
|
|
130
|
+
}
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
const line = buffer.slice(0, nl);
|
|
134
|
+
handleRequest(line, twin, sourceName, sendAndClose, sendError);
|
|
135
|
+
});
|
|
136
|
+
socket.on('error', () => {
|
|
137
|
+
// Drop per-connection errors; nothing to log that the client will
|
|
138
|
+
// see. A wedged client eventually times out.
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
server.on('error', (err) => {
|
|
142
|
+
// Per-connection errors bubble up here after a catastrophic failure.
|
|
143
|
+
// We defer to the caller's onError hook so operators can spot
|
|
144
|
+
// repeating listen-level failures.
|
|
145
|
+
onError?.('TRANSPORT_ERROR', `server error: ${err.message}`);
|
|
146
|
+
});
|
|
147
|
+
await new Promise((resolve, reject) => {
|
|
148
|
+
server.once('error', reject);
|
|
149
|
+
server.listen(socketPath, () => {
|
|
150
|
+
server.removeListener('error', reject);
|
|
151
|
+
resolve();
|
|
152
|
+
});
|
|
153
|
+
});
|
|
154
|
+
let closed = false;
|
|
155
|
+
return {
|
|
156
|
+
socketPath,
|
|
157
|
+
close: async () => {
|
|
158
|
+
if (closed)
|
|
159
|
+
return;
|
|
160
|
+
closed = true;
|
|
161
|
+
await new Promise((resolve) => {
|
|
162
|
+
server.close(() => resolve());
|
|
163
|
+
});
|
|
164
|
+
if (process.platform !== 'win32') {
|
|
165
|
+
try {
|
|
166
|
+
if (fs.existsSync(socketPath))
|
|
167
|
+
fs.unlinkSync(socketPath);
|
|
168
|
+
}
|
|
169
|
+
catch {
|
|
170
|
+
// Nothing actionable; the socket file may already be gone.
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
},
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Parse and dispatch a single request line. Extracted so the connection
|
|
178
|
+
* handler stays readable and so the request path can be unit tested in
|
|
179
|
+
* isolation later if needed. Every failure path resolves to a
|
|
180
|
+
* `risk_signal_error` rather than propagating an exception: the server
|
|
181
|
+
* must never crash on a malformed request.
|
|
182
|
+
*/
|
|
183
|
+
function handleRequest(line, twin, sourceName, sendAndClose, sendError) {
|
|
184
|
+
let msg;
|
|
185
|
+
try {
|
|
186
|
+
msg = JSON.parse(line);
|
|
187
|
+
}
|
|
188
|
+
catch (err) {
|
|
189
|
+
sendError('PARSE_ERROR', `invalid json: ${err.message}`);
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
if (msg === null || typeof msg !== 'object') {
|
|
193
|
+
sendError('PARSE_ERROR', 'request is not a json object');
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
const obj = msg;
|
|
197
|
+
if (obj.version !== behavioral_risk_1.BEHAVIORAL_RISK_WIRE_VERSION) {
|
|
198
|
+
sendError('PARSE_ERROR', `unsupported wire version: ${JSON.stringify(obj.version)}`);
|
|
199
|
+
return;
|
|
200
|
+
}
|
|
201
|
+
if (obj.kind !== 'risk_signal_request') {
|
|
202
|
+
sendError('PARSE_ERROR', `unexpected kind: ${JSON.stringify(obj.kind)}`);
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
const event = obj.event;
|
|
206
|
+
if (!isArpEventLike(event)) {
|
|
207
|
+
sendError('PARSE_ERROR', 'event field is missing required ARPEvent shape');
|
|
208
|
+
return;
|
|
209
|
+
}
|
|
210
|
+
let result;
|
|
211
|
+
try {
|
|
212
|
+
result = twin.scoreARPEvent(event);
|
|
213
|
+
}
|
|
214
|
+
catch (err) {
|
|
215
|
+
sendError('INTERNAL_ERROR', `twin threw: ${err.message ?? String(err)}`);
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
if (result === null) {
|
|
219
|
+
sendError('NOT_READY', 'twin baseline not yet trained');
|
|
220
|
+
return;
|
|
221
|
+
}
|
|
222
|
+
sendAndClose({
|
|
223
|
+
kind: 'risk_signal_response',
|
|
224
|
+
version: behavioral_risk_1.BEHAVIORAL_RISK_WIRE_VERSION,
|
|
225
|
+
score: result.score,
|
|
226
|
+
action: result.action,
|
|
227
|
+
reason: result.reason,
|
|
228
|
+
source: sourceName,
|
|
229
|
+
computedAtMs: Date.now(),
|
|
230
|
+
});
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* Narrow runtime check for an ARPEvent-shaped request payload. Only
|
|
234
|
+
* validates the fields the twin's scoreARPEvent path actually reads,
|
|
235
|
+
* which is by design: stricter validation would reject valid events
|
|
236
|
+
* whose extra fields the server does not care about.
|
|
237
|
+
*/
|
|
238
|
+
function isArpEventLike(v) {
|
|
239
|
+
if (v === null || typeof v !== 'object')
|
|
240
|
+
return false;
|
|
241
|
+
const e = v;
|
|
242
|
+
if (typeof e.id !== 'string')
|
|
243
|
+
return false;
|
|
244
|
+
if (typeof e.timestamp !== 'string')
|
|
245
|
+
return false;
|
|
246
|
+
if (typeof e.source !== 'string')
|
|
247
|
+
return false;
|
|
248
|
+
if (typeof e.category !== 'string')
|
|
249
|
+
return false;
|
|
250
|
+
if (typeof e.severity !== 'string')
|
|
251
|
+
return false;
|
|
252
|
+
if (typeof e.description !== 'string')
|
|
253
|
+
return false;
|
|
254
|
+
if (e.data === null || typeof e.data !== 'object')
|
|
255
|
+
return false;
|
|
256
|
+
return true;
|
|
257
|
+
}
|
|
258
|
+
//# sourceMappingURL=behavioral-risk-server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"behavioral-risk-server.js","sourceRoot":"","sources":["../../../src/arp/intelligence/behavioral-risk-server.ts"],"names":[],"mappings":"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"}
|