vaspera 2.11.0 → 2.13.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/CHANGELOG.md +46 -0
- package/dist/__tests__/audit-trail.test.d.ts +7 -0
- package/dist/__tests__/audit-trail.test.d.ts.map +1 -0
- package/dist/__tests__/audit-trail.test.js +336 -0
- package/dist/__tests__/audit-trail.test.js.map +1 -0
- package/dist/__tests__/property-test-helpers.d.ts +1 -1
- package/dist/__tests__/siem-integration.test.d.ts +7 -0
- package/dist/__tests__/siem-integration.test.d.ts.map +1 -0
- package/dist/__tests__/siem-integration.test.js +285 -0
- package/dist/__tests__/siem-integration.test.js.map +1 -0
- package/dist/action/pr-comment.test.js +1 -0
- package/dist/action/pr-comment.test.js.map +1 -1
- package/dist/action/sarif-upload.test.js +1 -0
- package/dist/action/sarif-upload.test.js.map +1 -1
- package/dist/autofix/ast/__tests__/typescript.test.d.ts +5 -0
- package/dist/autofix/ast/__tests__/typescript.test.d.ts.map +1 -0
- package/dist/autofix/ast/__tests__/typescript.test.js +210 -0
- package/dist/autofix/ast/__tests__/typescript.test.js.map +1 -0
- package/dist/autofix/ast/index.d.ts +11 -0
- package/dist/autofix/ast/index.d.ts.map +1 -0
- package/dist/autofix/ast/index.js +11 -0
- package/dist/autofix/ast/index.js.map +1 -0
- package/dist/autofix/ast/types.d.ts +77 -0
- package/dist/autofix/ast/types.d.ts.map +1 -0
- package/dist/autofix/ast/types.js +9 -0
- package/dist/autofix/ast/types.js.map +1 -0
- package/dist/autofix/ast/typescript.d.ts +17 -0
- package/dist/autofix/ast/typescript.d.ts.map +1 -0
- package/dist/autofix/ast/typescript.js +427 -0
- package/dist/autofix/ast/typescript.js.map +1 -0
- package/dist/autofix/constitution.schema.d.ts +21 -21
- package/dist/autofix/index.d.ts +1 -0
- package/dist/autofix/index.d.ts.map +1 -1
- package/dist/autofix/index.js +2 -0
- package/dist/autofix/index.js.map +1 -1
- package/dist/config/flags.d.ts +6 -6
- package/dist/history/store.d.ts +55 -1
- package/dist/history/store.d.ts.map +1 -1
- package/dist/history/store.js +152 -4
- package/dist/history/store.js.map +1 -1
- package/dist/history/types.d.ts +9 -5
- package/dist/history/types.d.ts.map +1 -1
- package/dist/history/verify.d.ts.map +1 -1
- package/dist/history/verify.js +5 -3
- package/dist/history/verify.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +923 -16
- package/dist/index.js.map +1 -1
- package/dist/integrations/siem/datadog.d.ts +44 -0
- package/dist/integrations/siem/datadog.d.ts.map +1 -0
- package/dist/integrations/siem/datadog.js +211 -0
- package/dist/integrations/siem/datadog.js.map +1 -0
- package/dist/integrations/siem/format.d.ts +59 -0
- package/dist/integrations/siem/format.d.ts.map +1 -0
- package/dist/integrations/siem/format.js +360 -0
- package/dist/integrations/siem/format.js.map +1 -0
- package/dist/integrations/siem/index.d.ts +56 -0
- package/dist/integrations/siem/index.d.ts.map +1 -0
- package/dist/integrations/siem/index.js +117 -0
- package/dist/integrations/siem/index.js.map +1 -0
- package/dist/integrations/siem/sentinel.d.ts +53 -0
- package/dist/integrations/siem/sentinel.d.ts.map +1 -0
- package/dist/integrations/siem/sentinel.js +231 -0
- package/dist/integrations/siem/sentinel.js.map +1 -0
- package/dist/integrations/siem/splunk.d.ts +46 -0
- package/dist/integrations/siem/splunk.d.ts.map +1 -0
- package/dist/integrations/siem/splunk.js +210 -0
- package/dist/integrations/siem/splunk.js.map +1 -0
- package/dist/integrations/siem/types.d.ts +210 -0
- package/dist/integrations/siem/types.d.ts.map +1 -0
- package/dist/integrations/siem/types.js +9 -0
- package/dist/integrations/siem/types.js.map +1 -0
- package/dist/persistence/__tests__/json-fallback.test.d.ts +5 -0
- package/dist/persistence/__tests__/json-fallback.test.d.ts.map +1 -0
- package/dist/persistence/__tests__/json-fallback.test.js +249 -0
- package/dist/persistence/__tests__/json-fallback.test.js.map +1 -0
- package/dist/persistence/__tests__/persistence.test.d.ts +5 -0
- package/dist/persistence/__tests__/persistence.test.d.ts.map +1 -0
- package/dist/persistence/__tests__/persistence.test.js +369 -0
- package/dist/persistence/__tests__/persistence.test.js.map +1 -0
- package/dist/persistence/db.d.ts +30 -0
- package/dist/persistence/db.d.ts.map +1 -0
- package/dist/persistence/db.js +128 -0
- package/dist/persistence/db.js.map +1 -0
- package/dist/persistence/index.d.ts +75 -0
- package/dist/persistence/index.d.ts.map +1 -0
- package/dist/persistence/index.js +268 -0
- package/dist/persistence/index.js.map +1 -0
- package/dist/persistence/json-fallback.d.ts +52 -0
- package/dist/persistence/json-fallback.d.ts.map +1 -0
- package/dist/persistence/json-fallback.js +283 -0
- package/dist/persistence/json-fallback.js.map +1 -0
- package/dist/persistence/migrations/index.d.ts +10 -0
- package/dist/persistence/migrations/index.d.ts.map +1 -0
- package/dist/persistence/migrations/index.js +125 -0
- package/dist/persistence/migrations/index.js.map +1 -0
- package/dist/persistence/repositories/findings.d.ts +41 -0
- package/dist/persistence/repositories/findings.d.ts.map +1 -0
- package/dist/persistence/repositories/findings.js +238 -0
- package/dist/persistence/repositories/findings.js.map +1 -0
- package/dist/persistence/repositories/projects.d.ts +22 -0
- package/dist/persistence/repositories/projects.d.ts.map +1 -0
- package/dist/persistence/repositories/projects.js +71 -0
- package/dist/persistence/repositories/projects.js.map +1 -0
- package/dist/persistence/repositories/scans.d.ts +30 -0
- package/dist/persistence/repositories/scans.d.ts.map +1 -0
- package/dist/persistence/repositories/scans.js +107 -0
- package/dist/persistence/repositories/scans.js.map +1 -0
- package/dist/persistence/repositories/trends.d.ts +42 -0
- package/dist/persistence/repositories/trends.d.ts.map +1 -0
- package/dist/persistence/repositories/trends.js +178 -0
- package/dist/persistence/repositories/trends.js.map +1 -0
- package/dist/persistence/types.d.ts +105 -0
- package/dist/persistence/types.d.ts.map +1 -0
- package/dist/persistence/types.js +13 -0
- package/dist/persistence/types.js.map +1 -0
- package/dist/plugins/types.d.ts +2 -2
- package/dist/scanners/ai-code/index.d.ts.map +1 -1
- package/dist/scanners/ai-code/index.js +90 -2
- package/dist/scanners/ai-code/index.js.map +1 -1
- package/dist/scanners/ai-code/types.d.ts +24 -12
- package/dist/scanners/ai-code/types.d.ts.map +1 -1
- package/dist/scanners/cache.d.ts.map +1 -1
- package/dist/scanners/cache.js +1 -0
- package/dist/scanners/cache.js.map +1 -1
- package/dist/scanners/deploy/types.d.ts +13 -13
- package/dist/scanners/detection/__tests__/detection.test.d.ts +5 -0
- package/dist/scanners/detection/__tests__/detection.test.d.ts.map +1 -0
- package/dist/scanners/detection/__tests__/detection.test.js +265 -0
- package/dist/scanners/detection/__tests__/detection.test.js.map +1 -0
- package/dist/scanners/detection/engines/ast-query.d.ts +23 -0
- package/dist/scanners/detection/engines/ast-query.d.ts.map +1 -0
- package/dist/scanners/detection/engines/ast-query.js +232 -0
- package/dist/scanners/detection/engines/ast-query.js.map +1 -0
- package/dist/scanners/detection/engines/data-flow.d.ts +12 -0
- package/dist/scanners/detection/engines/data-flow.d.ts.map +1 -0
- package/dist/scanners/detection/engines/data-flow.js +269 -0
- package/dist/scanners/detection/engines/data-flow.js.map +1 -0
- package/dist/scanners/detection/index.d.ts +29 -0
- package/dist/scanners/detection/index.d.ts.map +1 -0
- package/dist/scanners/detection/index.js +140 -0
- package/dist/scanners/detection/index.js.map +1 -0
- package/dist/scanners/detection/rules/builtin.d.ts +14 -0
- package/dist/scanners/detection/rules/builtin.d.ts.map +1 -0
- package/dist/scanners/detection/rules/builtin.js +307 -0
- package/dist/scanners/detection/rules/builtin.js.map +1 -0
- package/dist/scanners/detection/rules/loader.d.ts +19 -0
- package/dist/scanners/detection/rules/loader.d.ts.map +1 -0
- package/dist/scanners/detection/rules/loader.js +111 -0
- package/dist/scanners/detection/rules/loader.js.map +1 -0
- package/dist/scanners/detection/types.d.ts +171 -0
- package/dist/scanners/detection/types.d.ts.map +1 -0
- package/dist/scanners/detection/types.js +36 -0
- package/dist/scanners/detection/types.js.map +1 -0
- package/dist/scanners/eslint.d.ts.map +1 -1
- package/dist/scanners/eslint.js +45 -3
- package/dist/scanners/eslint.js.map +1 -1
- package/dist/scanners/index.d.ts +9 -1
- package/dist/scanners/index.d.ts.map +1 -1
- package/dist/scanners/index.js +64 -0
- package/dist/scanners/index.js.map +1 -1
- package/dist/scanners/index.test.js +6 -6
- package/dist/scanners/index.test.js.map +1 -1
- package/dist/scanners/scale/bottleneck-detector.d.ts +13 -2
- package/dist/scanners/scale/bottleneck-detector.d.ts.map +1 -1
- package/dist/scanners/scale/bottleneck-detector.js +199 -72
- package/dist/scanners/scale/bottleneck-detector.js.map +1 -1
- package/dist/scanners/scale/types.d.ts +3 -3
- package/dist/scanners/types.d.ts +19 -2
- package/dist/scanners/types.d.ts.map +1 -1
- package/dist/scanners/types.js +1 -0
- package/dist/scanners/types.js.map +1 -1
- package/dist/scanners/typescript.d.ts.map +1 -1
- package/dist/scanners/typescript.js +36 -4
- package/dist/scanners/typescript.js.map +1 -1
- package/package.json +5 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"format.js","sourceRoot":"","sources":["../../../src/integrations/siem/format.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SIEM Integration
|
|
3
|
+
*
|
|
4
|
+
* Export findings and events to enterprise SIEM platforms.
|
|
5
|
+
* Supports Splunk, Microsoft Sentinel, and Datadog.
|
|
6
|
+
*
|
|
7
|
+
* @module integrations/siem
|
|
8
|
+
*/
|
|
9
|
+
export * from "./types.js";
|
|
10
|
+
export * from "./format.js";
|
|
11
|
+
export { SplunkClient, createSplunkClient } from "./splunk.js";
|
|
12
|
+
export { SentinelClient, createSentinelClient } from "./sentinel.js";
|
|
13
|
+
export { DatadogClient, createDatadogClient } from "./datadog.js";
|
|
14
|
+
import type { SIEMClient, SIEMProvider, SIEMConfig } from "./types.js";
|
|
15
|
+
/**
|
|
16
|
+
* Create a SIEM client from configuration
|
|
17
|
+
*/
|
|
18
|
+
export declare function createSIEMClient(config: SIEMConfig): SIEMClient;
|
|
19
|
+
/**
|
|
20
|
+
* SIEM client registry for managing multiple connections
|
|
21
|
+
*/
|
|
22
|
+
export declare class SIEMRegistry {
|
|
23
|
+
private clients;
|
|
24
|
+
/**
|
|
25
|
+
* Register a SIEM client
|
|
26
|
+
*/
|
|
27
|
+
register(name: string, client: SIEMClient): void;
|
|
28
|
+
/**
|
|
29
|
+
* Get a registered client
|
|
30
|
+
*/
|
|
31
|
+
get(name: string): SIEMClient | undefined;
|
|
32
|
+
/**
|
|
33
|
+
* List all registered clients
|
|
34
|
+
*/
|
|
35
|
+
list(): Array<{
|
|
36
|
+
name: string;
|
|
37
|
+
provider: SIEMProvider;
|
|
38
|
+
}>;
|
|
39
|
+
/**
|
|
40
|
+
* Unregister and close a client
|
|
41
|
+
*/
|
|
42
|
+
unregister(name: string): Promise<void>;
|
|
43
|
+
/**
|
|
44
|
+
* Close all clients
|
|
45
|
+
*/
|
|
46
|
+
closeAll(): Promise<void>;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Get the global SIEM registry
|
|
50
|
+
*/
|
|
51
|
+
export declare function getSIEMRegistry(): SIEMRegistry;
|
|
52
|
+
/**
|
|
53
|
+
* Close the global SIEM registry
|
|
54
|
+
*/
|
|
55
|
+
export declare function closeSIEMRegistry(): Promise<void>;
|
|
56
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/integrations/siem/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAE5B,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAKlE,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAEvE;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,UAAU,GAAG,UAAU,CAiC/D;AAED;;GAEG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,OAAO,CAAsC;IAErD;;OAEG;IACH,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,GAAG,IAAI;IAIhD;;OAEG;IACH,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,SAAS;IAIzC;;OAEG;IACH,IAAI,IAAI,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,YAAY,CAAA;KAAE,CAAC;IAOvD;;OAEG;IACG,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7C;;OAEG;IACG,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAMhC;AAKD;;GAEG;AACH,wBAAgB,eAAe,IAAI,YAAY,CAK9C;AAED;;GAEG;AACH,wBAAsB,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,CAKvD"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SIEM Integration
|
|
3
|
+
*
|
|
4
|
+
* Export findings and events to enterprise SIEM platforms.
|
|
5
|
+
* Supports Splunk, Microsoft Sentinel, and Datadog.
|
|
6
|
+
*
|
|
7
|
+
* @module integrations/siem
|
|
8
|
+
*/
|
|
9
|
+
export * from "./types.js";
|
|
10
|
+
export * from "./format.js";
|
|
11
|
+
export { SplunkClient, createSplunkClient } from "./splunk.js";
|
|
12
|
+
export { SentinelClient, createSentinelClient } from "./sentinel.js";
|
|
13
|
+
export { DatadogClient, createDatadogClient } from "./datadog.js";
|
|
14
|
+
import { createSplunkClient } from "./splunk.js";
|
|
15
|
+
import { createSentinelClient } from "./sentinel.js";
|
|
16
|
+
import { createDatadogClient } from "./datadog.js";
|
|
17
|
+
/**
|
|
18
|
+
* Create a SIEM client from configuration
|
|
19
|
+
*/
|
|
20
|
+
export function createSIEMClient(config) {
|
|
21
|
+
switch (config.provider) {
|
|
22
|
+
case "splunk":
|
|
23
|
+
return createSplunkClient({
|
|
24
|
+
endpoint: config.endpoint,
|
|
25
|
+
token: config.token,
|
|
26
|
+
index: config.options?.index,
|
|
27
|
+
sourceType: config.options?.sourceType,
|
|
28
|
+
source: config.options?.source,
|
|
29
|
+
host: config.options?.host,
|
|
30
|
+
verifySsl: config.options?.verifySsl,
|
|
31
|
+
});
|
|
32
|
+
case "sentinel":
|
|
33
|
+
return createSentinelClient({
|
|
34
|
+
workspaceId: config.options?.workspaceId || "",
|
|
35
|
+
sharedKey: config.token,
|
|
36
|
+
logType: config.options?.logType,
|
|
37
|
+
timeGeneratedField: config.options?.timeGeneratedField,
|
|
38
|
+
});
|
|
39
|
+
case "datadog":
|
|
40
|
+
return createDatadogClient({
|
|
41
|
+
apiKey: config.token,
|
|
42
|
+
site: config.options?.site,
|
|
43
|
+
service: config.options?.service,
|
|
44
|
+
env: config.options?.env,
|
|
45
|
+
tags: config.options?.tags,
|
|
46
|
+
});
|
|
47
|
+
default:
|
|
48
|
+
throw new Error(`Unknown SIEM provider: ${config.provider}`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* SIEM client registry for managing multiple connections
|
|
53
|
+
*/
|
|
54
|
+
export class SIEMRegistry {
|
|
55
|
+
clients = new Map();
|
|
56
|
+
/**
|
|
57
|
+
* Register a SIEM client
|
|
58
|
+
*/
|
|
59
|
+
register(name, client) {
|
|
60
|
+
this.clients.set(name, client);
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Get a registered client
|
|
64
|
+
*/
|
|
65
|
+
get(name) {
|
|
66
|
+
return this.clients.get(name);
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* List all registered clients
|
|
70
|
+
*/
|
|
71
|
+
list() {
|
|
72
|
+
return Array.from(this.clients.entries()).map(([name, client]) => ({
|
|
73
|
+
name,
|
|
74
|
+
provider: client.provider,
|
|
75
|
+
}));
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Unregister and close a client
|
|
79
|
+
*/
|
|
80
|
+
async unregister(name) {
|
|
81
|
+
const client = this.clients.get(name);
|
|
82
|
+
if (client) {
|
|
83
|
+
await client.close();
|
|
84
|
+
this.clients.delete(name);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Close all clients
|
|
89
|
+
*/
|
|
90
|
+
async closeAll() {
|
|
91
|
+
for (const client of this.clients.values()) {
|
|
92
|
+
await client.close();
|
|
93
|
+
}
|
|
94
|
+
this.clients.clear();
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
// Global registry instance
|
|
98
|
+
let globalRegistry = null;
|
|
99
|
+
/**
|
|
100
|
+
* Get the global SIEM registry
|
|
101
|
+
*/
|
|
102
|
+
export function getSIEMRegistry() {
|
|
103
|
+
if (!globalRegistry) {
|
|
104
|
+
globalRegistry = new SIEMRegistry();
|
|
105
|
+
}
|
|
106
|
+
return globalRegistry;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Close the global SIEM registry
|
|
110
|
+
*/
|
|
111
|
+
export async function closeSIEMRegistry() {
|
|
112
|
+
if (globalRegistry) {
|
|
113
|
+
await globalRegistry.closeAll();
|
|
114
|
+
globalRegistry = null;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/integrations/siem/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Microsoft Sentinel Client
|
|
3
|
+
*
|
|
4
|
+
* Log Analytics Data Collector API client for Microsoft Sentinel integration.
|
|
5
|
+
*
|
|
6
|
+
* @module integrations/siem/sentinel
|
|
7
|
+
*/
|
|
8
|
+
import type { SIEMClient, SIEMEvent, SIEMTestResult, SIEMSendResult, SIEMBatchResult, SentinelConfig } from "./types.js";
|
|
9
|
+
/**
|
|
10
|
+
* Microsoft Sentinel (Log Analytics) client
|
|
11
|
+
*/
|
|
12
|
+
export declare class SentinelClient implements SIEMClient {
|
|
13
|
+
readonly provider: "sentinel";
|
|
14
|
+
private config;
|
|
15
|
+
private workspaceId;
|
|
16
|
+
private sharedKey;
|
|
17
|
+
private logType;
|
|
18
|
+
constructor(config: SentinelConfig);
|
|
19
|
+
/**
|
|
20
|
+
* Build authorization signature for Log Analytics API
|
|
21
|
+
*/
|
|
22
|
+
private buildSignature;
|
|
23
|
+
/**
|
|
24
|
+
* Get RFC1123 formatted date
|
|
25
|
+
*/
|
|
26
|
+
private getRfc1123Date;
|
|
27
|
+
/**
|
|
28
|
+
* Test connection to Sentinel
|
|
29
|
+
*/
|
|
30
|
+
testConnection(): Promise<SIEMTestResult>;
|
|
31
|
+
/**
|
|
32
|
+
* Send a single event to Sentinel
|
|
33
|
+
*/
|
|
34
|
+
sendEvent(event: SIEMEvent): Promise<SIEMSendResult>;
|
|
35
|
+
/**
|
|
36
|
+
* Send multiple events in batch
|
|
37
|
+
*/
|
|
38
|
+
sendEvents(events: SIEMEvent[]): Promise<SIEMBatchResult>;
|
|
39
|
+
/**
|
|
40
|
+
* Close connection
|
|
41
|
+
*/
|
|
42
|
+
close(): Promise<void>;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Create a Sentinel client from configuration
|
|
46
|
+
*/
|
|
47
|
+
export declare function createSentinelClient(config: {
|
|
48
|
+
workspaceId: string;
|
|
49
|
+
sharedKey: string;
|
|
50
|
+
logType?: string;
|
|
51
|
+
timeGeneratedField?: string;
|
|
52
|
+
}): SentinelClient;
|
|
53
|
+
//# sourceMappingURL=sentinel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentinel.d.ts","sourceRoot":"","sources":["../../../src/integrations/siem/sentinel.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAKH,OAAO,KAAK,EACV,UAAU,EACV,SAAS,EACT,cAAc,EACd,cAAc,EACd,eAAe,EACf,cAAc,EACf,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,qBAAa,cAAe,YAAW,UAAU;IAC/C,QAAQ,CAAC,QAAQ,EAAG,UAAU,CAAU;IACxC,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,WAAW,CAAS;IAC5B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,EAAE,cAAc;IAOlC;;OAEG;IACH,OAAO,CAAC,cAAc;IAkBtB;;OAEG;IACH,OAAO,CAAC,cAAc;IAItB;;OAEG;IACG,cAAc,IAAI,OAAO,CAAC,cAAc,CAAC;IAoC/C;;OAEG;IACG,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,cAAc,CAAC;IAqE1D;;OAEG;IACG,UAAU,CAAC,MAAM,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC;IAmF/D;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAG7B;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,EAAE;IAC3C,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B,GAAG,cAAc,CAYjB"}
|
|
@@ -0,0 +1,231 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Microsoft Sentinel Client
|
|
3
|
+
*
|
|
4
|
+
* Log Analytics Data Collector API client for Microsoft Sentinel integration.
|
|
5
|
+
*
|
|
6
|
+
* @module integrations/siem/sentinel
|
|
7
|
+
*/
|
|
8
|
+
import { createHmac } from "crypto";
|
|
9
|
+
import { logger } from "../../logger.js";
|
|
10
|
+
import { formatForSentinel } from "./format.js";
|
|
11
|
+
/**
|
|
12
|
+
* Microsoft Sentinel (Log Analytics) client
|
|
13
|
+
*/
|
|
14
|
+
export class SentinelClient {
|
|
15
|
+
provider = "sentinel";
|
|
16
|
+
config;
|
|
17
|
+
workspaceId;
|
|
18
|
+
sharedKey;
|
|
19
|
+
logType;
|
|
20
|
+
constructor(config) {
|
|
21
|
+
this.config = config;
|
|
22
|
+
this.workspaceId = config.options?.workspaceId || "";
|
|
23
|
+
this.sharedKey = config.token;
|
|
24
|
+
this.logType = config.options?.logType || "VasperaHardening";
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Build authorization signature for Log Analytics API
|
|
28
|
+
*/
|
|
29
|
+
buildSignature(date, contentLength, method, contentType, resource) {
|
|
30
|
+
const xHeaders = `x-ms-date:${date}`;
|
|
31
|
+
const stringToHash = `${method}\n${contentLength}\n${contentType}\n${xHeaders}\n${resource}`;
|
|
32
|
+
const decodedKey = Buffer.from(this.sharedKey, "base64");
|
|
33
|
+
const hmac = createHmac("sha256", decodedKey);
|
|
34
|
+
hmac.update(stringToHash, "utf8");
|
|
35
|
+
const encodedHash = hmac.digest("base64");
|
|
36
|
+
return `SharedKey ${this.workspaceId}:${encodedHash}`;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Get RFC1123 formatted date
|
|
40
|
+
*/
|
|
41
|
+
getRfc1123Date() {
|
|
42
|
+
return new Date().toUTCString();
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Test connection to Sentinel
|
|
46
|
+
*/
|
|
47
|
+
async testConnection() {
|
|
48
|
+
const startTime = Date.now();
|
|
49
|
+
// Sentinel doesn't have a health endpoint, so we send a test event
|
|
50
|
+
try {
|
|
51
|
+
const testEvent = {
|
|
52
|
+
timestamp: new Date().toISOString(),
|
|
53
|
+
eventType: "scan.started",
|
|
54
|
+
severity: "informational",
|
|
55
|
+
project: "test",
|
|
56
|
+
message: "Vaspera connection test",
|
|
57
|
+
source: "vaspera",
|
|
58
|
+
data: { test: true },
|
|
59
|
+
};
|
|
60
|
+
const result = await this.sendEvent(testEvent);
|
|
61
|
+
return {
|
|
62
|
+
success: result.success,
|
|
63
|
+
provider: "sentinel",
|
|
64
|
+
endpoint: this.config.endpoint,
|
|
65
|
+
latencyMs: Date.now() - startTime,
|
|
66
|
+
error: result.error,
|
|
67
|
+
details: { workspaceId: this.workspaceId, logType: this.logType },
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
return {
|
|
72
|
+
success: false,
|
|
73
|
+
provider: "sentinel",
|
|
74
|
+
endpoint: this.config.endpoint,
|
|
75
|
+
latencyMs: Date.now() - startTime,
|
|
76
|
+
error: error instanceof Error ? error.message : String(error),
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Send a single event to Sentinel
|
|
82
|
+
*/
|
|
83
|
+
async sendEvent(event) {
|
|
84
|
+
const timestamp = new Date().toISOString();
|
|
85
|
+
try {
|
|
86
|
+
const payload = formatForSentinel(event);
|
|
87
|
+
const body = JSON.stringify([payload]);
|
|
88
|
+
const contentLength = Buffer.byteLength(body, "utf8");
|
|
89
|
+
const date = this.getRfc1123Date();
|
|
90
|
+
const resource = `/api/logs`;
|
|
91
|
+
const contentType = "application/json";
|
|
92
|
+
const signature = this.buildSignature(date, contentLength, "POST", contentType, resource);
|
|
93
|
+
const url = `https://${this.workspaceId}.ods.opinsights.azure.com${resource}?api-version=2016-04-01`;
|
|
94
|
+
const response = await fetch(url, {
|
|
95
|
+
method: "POST",
|
|
96
|
+
headers: {
|
|
97
|
+
"Content-Type": contentType,
|
|
98
|
+
Authorization: signature,
|
|
99
|
+
"Log-Type": this.logType,
|
|
100
|
+
"x-ms-date": date,
|
|
101
|
+
"time-generated-field": this.config.options?.timeGeneratedField || "TimeGenerated",
|
|
102
|
+
},
|
|
103
|
+
body,
|
|
104
|
+
signal: AbortSignal.timeout(30000),
|
|
105
|
+
});
|
|
106
|
+
if (response.ok || response.status === 200) {
|
|
107
|
+
logger.debug("siem.sentinel.event_sent", {
|
|
108
|
+
eventType: event.eventType,
|
|
109
|
+
logType: this.logType,
|
|
110
|
+
});
|
|
111
|
+
return {
|
|
112
|
+
success: true,
|
|
113
|
+
timestamp,
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
const errorText = await response.text();
|
|
117
|
+
logger.warn("siem.sentinel.send_failed", {
|
|
118
|
+
status: response.status,
|
|
119
|
+
error: errorText,
|
|
120
|
+
});
|
|
121
|
+
return {
|
|
122
|
+
success: false,
|
|
123
|
+
timestamp,
|
|
124
|
+
error: `HTTP ${response.status}: ${errorText}`,
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
catch (error) {
|
|
128
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
129
|
+
logger.error("siem.sentinel.send_error", { error: errorMessage });
|
|
130
|
+
return {
|
|
131
|
+
success: false,
|
|
132
|
+
timestamp,
|
|
133
|
+
error: errorMessage,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Send multiple events in batch
|
|
139
|
+
*/
|
|
140
|
+
async sendEvents(events) {
|
|
141
|
+
if (events.length === 0) {
|
|
142
|
+
return {
|
|
143
|
+
success: true,
|
|
144
|
+
totalEvents: 0,
|
|
145
|
+
successCount: 0,
|
|
146
|
+
failureCount: 0,
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
try {
|
|
150
|
+
const payloads = events.map((event) => formatForSentinel(event));
|
|
151
|
+
const body = JSON.stringify(payloads);
|
|
152
|
+
const contentLength = Buffer.byteLength(body, "utf8");
|
|
153
|
+
const date = this.getRfc1123Date();
|
|
154
|
+
const resource = `/api/logs`;
|
|
155
|
+
const contentType = "application/json";
|
|
156
|
+
const signature = this.buildSignature(date, contentLength, "POST", contentType, resource);
|
|
157
|
+
const url = `https://${this.workspaceId}.ods.opinsights.azure.com${resource}?api-version=2016-04-01`;
|
|
158
|
+
const response = await fetch(url, {
|
|
159
|
+
method: "POST",
|
|
160
|
+
headers: {
|
|
161
|
+
"Content-Type": contentType,
|
|
162
|
+
Authorization: signature,
|
|
163
|
+
"Log-Type": this.logType,
|
|
164
|
+
"x-ms-date": date,
|
|
165
|
+
"time-generated-field": this.config.options?.timeGeneratedField || "TimeGenerated",
|
|
166
|
+
},
|
|
167
|
+
body,
|
|
168
|
+
signal: AbortSignal.timeout(60000),
|
|
169
|
+
});
|
|
170
|
+
if (response.ok || response.status === 200) {
|
|
171
|
+
logger.info("siem.sentinel.batch_sent", {
|
|
172
|
+
eventCount: events.length,
|
|
173
|
+
logType: this.logType,
|
|
174
|
+
});
|
|
175
|
+
return {
|
|
176
|
+
success: true,
|
|
177
|
+
totalEvents: events.length,
|
|
178
|
+
successCount: events.length,
|
|
179
|
+
failureCount: 0,
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
const errorText = await response.text();
|
|
183
|
+
logger.warn("siem.sentinel.batch_failed", {
|
|
184
|
+
status: response.status,
|
|
185
|
+
error: errorText,
|
|
186
|
+
eventCount: events.length,
|
|
187
|
+
});
|
|
188
|
+
return {
|
|
189
|
+
success: false,
|
|
190
|
+
totalEvents: events.length,
|
|
191
|
+
successCount: 0,
|
|
192
|
+
failureCount: events.length,
|
|
193
|
+
errors: [{ index: 0, error: `HTTP ${response.status}: ${errorText}` }],
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
catch (error) {
|
|
197
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
198
|
+
logger.error("siem.sentinel.batch_error", { error: errorMessage });
|
|
199
|
+
return {
|
|
200
|
+
success: false,
|
|
201
|
+
totalEvents: events.length,
|
|
202
|
+
successCount: 0,
|
|
203
|
+
failureCount: events.length,
|
|
204
|
+
errors: [{ index: 0, error: errorMessage }],
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* Close connection
|
|
210
|
+
*/
|
|
211
|
+
async close() {
|
|
212
|
+
// No persistent connection to close for Log Analytics API
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* Create a Sentinel client from configuration
|
|
217
|
+
*/
|
|
218
|
+
export function createSentinelClient(config) {
|
|
219
|
+
return new SentinelClient({
|
|
220
|
+
provider: "sentinel",
|
|
221
|
+
enabled: true,
|
|
222
|
+
endpoint: `https://${config.workspaceId}.ods.opinsights.azure.com`,
|
|
223
|
+
token: config.sharedKey,
|
|
224
|
+
options: {
|
|
225
|
+
workspaceId: config.workspaceId,
|
|
226
|
+
logType: config.logType || "VasperaHardening",
|
|
227
|
+
timeGeneratedField: config.timeGeneratedField,
|
|
228
|
+
},
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
//# sourceMappingURL=sentinel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentinel.js","sourceRoot":"","sources":["../../../src/integrations/siem/sentinel.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Splunk HEC Client
|
|
3
|
+
*
|
|
4
|
+
* HTTP Event Collector client for Splunk integration.
|
|
5
|
+
*
|
|
6
|
+
* @module integrations/siem/splunk
|
|
7
|
+
*/
|
|
8
|
+
import type { SIEMClient, SIEMEvent, SIEMTestResult, SIEMSendResult, SIEMBatchResult, SplunkConfig } from "./types.js";
|
|
9
|
+
/**
|
|
10
|
+
* Splunk HTTP Event Collector client
|
|
11
|
+
*/
|
|
12
|
+
export declare class SplunkClient implements SIEMClient {
|
|
13
|
+
readonly provider: "splunk";
|
|
14
|
+
private config;
|
|
15
|
+
private abortController;
|
|
16
|
+
constructor(config: SplunkConfig);
|
|
17
|
+
/**
|
|
18
|
+
* Test connection to Splunk HEC
|
|
19
|
+
*/
|
|
20
|
+
testConnection(): Promise<SIEMTestResult>;
|
|
21
|
+
/**
|
|
22
|
+
* Send a single event to Splunk
|
|
23
|
+
*/
|
|
24
|
+
sendEvent(event: SIEMEvent): Promise<SIEMSendResult>;
|
|
25
|
+
/**
|
|
26
|
+
* Send multiple events in batch
|
|
27
|
+
*/
|
|
28
|
+
sendEvents(events: SIEMEvent[]): Promise<SIEMBatchResult>;
|
|
29
|
+
/**
|
|
30
|
+
* Close connection
|
|
31
|
+
*/
|
|
32
|
+
close(): Promise<void>;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Create a Splunk client from configuration
|
|
36
|
+
*/
|
|
37
|
+
export declare function createSplunkClient(config: {
|
|
38
|
+
endpoint: string;
|
|
39
|
+
token: string;
|
|
40
|
+
index?: string;
|
|
41
|
+
sourceType?: string;
|
|
42
|
+
source?: string;
|
|
43
|
+
host?: string;
|
|
44
|
+
verifySsl?: boolean;
|
|
45
|
+
}): SplunkClient;
|
|
46
|
+
//# sourceMappingURL=splunk.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"splunk.d.ts","sourceRoot":"","sources":["../../../src/integrations/siem/splunk.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAIH,OAAO,KAAK,EACV,UAAU,EACV,SAAS,EACT,cAAc,EACd,cAAc,EACd,eAAe,EACf,YAAY,EACb,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,qBAAa,YAAa,YAAW,UAAU;IAC7C,QAAQ,CAAC,QAAQ,EAAG,QAAQ,CAAU;IACtC,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,eAAe,CAAgC;gBAE3C,MAAM,EAAE,YAAY;IAIhC;;OAEG;IACG,cAAc,IAAI,OAAO,CAAC,cAAc,CAAC;IA2C/C;;OAEG;IACG,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,cAAc,CAAC;IAyD1D;;OAEG;IACG,UAAU,CAAC,MAAM,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC;IA0E/D;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAM7B;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE;IACzC,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,GAAG,YAAY,CAcf"}
|