beddel 0.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.
- package/README.md +297 -0
- package/dist/agents/agentRegistry.d.ts +68 -0
- package/dist/agents/agentRegistry.d.ts.map +1 -0
- package/dist/agents/agentRegistry.js +222 -0
- package/dist/agents/agentRegistry.js.map +1 -0
- package/dist/agents/formatter-agent.d.ts +10 -0
- package/dist/agents/formatter-agent.d.ts.map +1 -0
- package/dist/agents/formatter-agent.js +49 -0
- package/dist/agents/formatter-agent.js.map +1 -0
- package/dist/agents/genkit-agent.d.ts +12 -0
- package/dist/agents/genkit-agent.d.ts.map +1 -0
- package/dist/agents/genkit-agent.js +119 -0
- package/dist/agents/genkit-agent.js.map +1 -0
- package/dist/agents/i18n-messages.d.ts +17 -0
- package/dist/agents/i18n-messages.d.ts.map +1 -0
- package/dist/agents/i18n-messages.js +92 -0
- package/dist/agents/i18n-messages.js.map +1 -0
- package/dist/agents/index.d.ts +10 -0
- package/dist/agents/index.d.ts.map +1 -0
- package/dist/agents/index.js +26 -0
- package/dist/agents/index.js.map +1 -0
- package/dist/agents/pipeline.d.ts +15 -0
- package/dist/agents/pipeline.d.ts.map +1 -0
- package/dist/agents/pipeline.js +45 -0
- package/dist/agents/pipeline.js.map +1 -0
- package/dist/agents/schema-factory.d.ts +40 -0
- package/dist/agents/schema-factory.d.ts.map +1 -0
- package/dist/agents/schema-factory.js +121 -0
- package/dist/agents/schema-factory.js.map +1 -0
- package/dist/agents/translation-validators.d.ts +26 -0
- package/dist/agents/translation-validators.d.ts.map +1 -0
- package/dist/agents/translation-validators.js +77 -0
- package/dist/agents/translation-validators.js.map +1 -0
- package/dist/agents/translator-agents.d.ts +184 -0
- package/dist/agents/translator-agents.d.ts.map +1 -0
- package/dist/agents/translator-agents.js +613 -0
- package/dist/agents/translator-agents.js.map +1 -0
- package/dist/agents/types/translation.types.d.ts +100 -0
- package/dist/agents/types/translation.types.d.ts.map +1 -0
- package/dist/agents/types/translation.types.js +3 -0
- package/dist/agents/types/translation.types.js.map +1 -0
- package/dist/agents/validator-agent.d.ts +42 -0
- package/dist/agents/validator-agent.d.ts.map +1 -0
- package/dist/agents/validator-agent.js +122 -0
- package/dist/agents/validator-agent.js.map +1 -0
- package/dist/audit/auditTrail.d.ts +55 -0
- package/dist/audit/auditTrail.d.ts.map +1 -0
- package/dist/audit/auditTrail.js +93 -0
- package/dist/audit/auditTrail.js.map +1 -0
- package/dist/compliance/gdprEngine.d.ts +44 -0
- package/dist/compliance/gdprEngine.d.ts.map +1 -0
- package/dist/compliance/gdprEngine.js +178 -0
- package/dist/compliance/gdprEngine.js.map +1 -0
- package/dist/compliance/lgpdEngine.d.ts +51 -0
- package/dist/compliance/lgpdEngine.d.ts.map +1 -0
- package/dist/compliance/lgpdEngine.js +221 -0
- package/dist/compliance/lgpdEngine.js.map +1 -0
- package/dist/config.d.ts +78 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +77 -0
- package/dist/config.js.map +1 -0
- package/dist/errors.d.ts +17 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +40 -0
- package/dist/errors.js.map +1 -0
- package/dist/firebase/tenantManager.d.ts +84 -0
- package/dist/firebase/tenantManager.d.ts.map +1 -0
- package/dist/firebase/tenantManager.js +378 -0
- package/dist/firebase/tenantManager.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +118 -0
- package/dist/index.js.map +1 -0
- package/dist/integration/secure-yaml-runtime.d.ts +68 -0
- package/dist/integration/secure-yaml-runtime.d.ts.map +1 -0
- package/dist/integration/secure-yaml-runtime.js +245 -0
- package/dist/integration/secure-yaml-runtime.js.map +1 -0
- package/dist/parser/secure-yaml-parser.d.ts +62 -0
- package/dist/parser/secure-yaml-parser.d.ts.map +1 -0
- package/dist/parser/secure-yaml-parser.js +234 -0
- package/dist/parser/secure-yaml-parser.js.map +1 -0
- package/dist/performance/autoscaling.d.ts +100 -0
- package/dist/performance/autoscaling.d.ts.map +1 -0
- package/dist/performance/autoscaling.js +339 -0
- package/dist/performance/autoscaling.js.map +1 -0
- package/dist/performance/benchmark.d.ts +104 -0
- package/dist/performance/benchmark.d.ts.map +1 -0
- package/dist/performance/benchmark.js +514 -0
- package/dist/performance/benchmark.js.map +1 -0
- package/dist/performance/index.d.ts +14 -0
- package/dist/performance/index.d.ts.map +1 -0
- package/dist/performance/index.js +35 -0
- package/dist/performance/index.js.map +1 -0
- package/dist/performance/monitor.d.ts +126 -0
- package/dist/performance/monitor.d.ts.map +1 -0
- package/dist/performance/monitor.js +324 -0
- package/dist/performance/monitor.js.map +1 -0
- package/dist/performance/streaming.d.ts +82 -0
- package/dist/performance/streaming.d.ts.map +1 -0
- package/dist/performance/streaming.js +287 -0
- package/dist/performance/streaming.js.map +1 -0
- package/dist/runtime/audit.d.ts +240 -0
- package/dist/runtime/audit.d.ts.map +1 -0
- package/dist/runtime/audit.js +641 -0
- package/dist/runtime/audit.js.map +1 -0
- package/dist/runtime/declarativeAgentRuntime.d.ts +123 -0
- package/dist/runtime/declarativeAgentRuntime.d.ts.map +1 -0
- package/dist/runtime/declarativeAgentRuntime.js +576 -0
- package/dist/runtime/declarativeAgentRuntime.js.map +1 -0
- package/dist/runtime/isolatedRuntime.d.ts +119 -0
- package/dist/runtime/isolatedRuntime.d.ts.map +1 -0
- package/dist/runtime/isolatedRuntime.js +425 -0
- package/dist/runtime/isolatedRuntime.js.map +1 -0
- package/dist/runtime/schemaCompiler.d.ts +35 -0
- package/dist/runtime/schemaCompiler.d.ts.map +1 -0
- package/dist/runtime/schemaCompiler.js +151 -0
- package/dist/runtime/schemaCompiler.js.map +1 -0
- package/dist/runtime/simpleRuntime.d.ts +57 -0
- package/dist/runtime/simpleRuntime.d.ts.map +1 -0
- package/dist/runtime/simpleRuntime.js +187 -0
- package/dist/runtime/simpleRuntime.js.map +1 -0
- package/dist/security/dashboard.d.ts +89 -0
- package/dist/security/dashboard.d.ts.map +1 -0
- package/dist/security/dashboard.js +300 -0
- package/dist/security/dashboard.js.map +1 -0
- package/dist/security/hardening.d.ts +130 -0
- package/dist/security/hardening.d.ts.map +1 -0
- package/dist/security/hardening.js +414 -0
- package/dist/security/hardening.js.map +1 -0
- package/dist/security/index.d.ts +128 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +353 -0
- package/dist/security/index.js.map +1 -0
- package/dist/security/monitor.d.ts +88 -0
- package/dist/security/monitor.d.ts.map +1 -0
- package/dist/security/monitor.js +356 -0
- package/dist/security/monitor.js.map +1 -0
- package/dist/security/scanner.d.ts +104 -0
- package/dist/security/scanner.d.ts.map +1 -0
- package/dist/security/scanner.js +298 -0
- package/dist/security/scanner.js.map +1 -0
- package/dist/security/score.d.ts +150 -0
- package/dist/security/score.d.ts.map +1 -0
- package/dist/security/score.js +983 -0
- package/dist/security/score.js.map +1 -0
- package/dist/security/test-security.d.ts +22 -0
- package/dist/security/test-security.d.ts.map +1 -0
- package/dist/security/test-security.js +154 -0
- package/dist/security/test-security.js.map +1 -0
- package/dist/security/threatDetector.d.ts +39 -0
- package/dist/security/threatDetector.d.ts.map +1 -0
- package/dist/security/threatDetector.js +354 -0
- package/dist/security/threatDetector.js.map +1 -0
- package/dist/security/validation.d.ts +69 -0
- package/dist/security/validation.d.ts.map +1 -0
- package/dist/security/validation.js +286 -0
- package/dist/security/validation.js.map +1 -0
- package/dist/server/api/clientsRoute.d.ts +9 -0
- package/dist/server/api/clientsRoute.d.ts.map +1 -0
- package/dist/server/api/clientsRoute.js +71 -0
- package/dist/server/api/clientsRoute.js.map +1 -0
- package/dist/server/api/endpointsRoute.d.ts +8 -0
- package/dist/server/api/endpointsRoute.d.ts.map +1 -0
- package/dist/server/api/endpointsRoute.js +76 -0
- package/dist/server/api/endpointsRoute.js.map +1 -0
- package/dist/server/api/graphql.d.ts +9 -0
- package/dist/server/api/graphql.d.ts.map +1 -0
- package/dist/server/api/graphql.js +180 -0
- package/dist/server/api/graphql.js.map +1 -0
- package/dist/server/errors.d.ts +19 -0
- package/dist/server/errors.d.ts.map +1 -0
- package/dist/server/errors.js +42 -0
- package/dist/server/errors.js.map +1 -0
- package/dist/server/index.d.ts +7 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +24 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/kvStore.d.ts +27 -0
- package/dist/server/kvStore.d.ts.map +1 -0
- package/dist/server/kvStore.js +128 -0
- package/dist/server/kvStore.js.map +1 -0
- package/dist/server/runtimeSecurity.d.ts +28 -0
- package/dist/server/runtimeSecurity.d.ts.map +1 -0
- package/dist/server/runtimeSecurity.js +85 -0
- package/dist/server/runtimeSecurity.js.map +1 -0
- package/dist/server/types.d.ts +53 -0
- package/dist/server/types.d.ts.map +1 -0
- package/dist/server/types.js +8 -0
- package/dist/server/types.js.map +1 -0
- package/dist/types/executionContext.d.ts +16 -0
- package/dist/types/executionContext.d.ts.map +1 -0
- package/dist/types/executionContext.js +3 -0
- package/dist/types/executionContext.js.map +1 -0
- package/package.json +77 -0
- package/src/agents/agentRegistry.ts +272 -0
- package/src/agents/image-agent.yaml +86 -0
- package/src/agents/joker-agent.yaml +47 -0
- package/src/agents/translator-agent.yaml +80 -0
- package/src/audit/auditTrail.ts +134 -0
- package/src/compliance/gdprEngine.ts +209 -0
- package/src/compliance/lgpdEngine.ts +268 -0
- package/src/config.ts +179 -0
- package/src/errors.ts +35 -0
- package/src/firebase/tenantManager.ts +443 -0
- package/src/index.ts +125 -0
- package/src/integration/secure-yaml-runtime.ts +341 -0
- package/src/parser/secure-yaml-parser.ts +273 -0
- package/src/performance/autoscaling.ts +495 -0
- package/src/performance/benchmark.ts +644 -0
- package/src/performance/index.ts +34 -0
- package/src/performance/monitor.ts +469 -0
- package/src/performance/streaming.ts +317 -0
- package/src/runtime/audit.ts +907 -0
- package/src/runtime/declarativeAgentRuntime.ts +836 -0
- package/src/runtime/isolatedRuntime.ts +572 -0
- package/src/runtime/schemaCompiler.ts +228 -0
- package/src/runtime/simpleRuntime.ts +201 -0
- package/src/security/dashboard.ts +462 -0
- package/src/security/hardening.ts +560 -0
- package/src/security/index.ts +439 -0
- package/src/security/monitor.ts +490 -0
- package/src/security/scanner.ts +368 -0
- package/src/security/score.ts +1138 -0
- package/src/security/threatDetector.ts +481 -0
- package/src/security/validation.ts +365 -0
- package/src/server/api/clientsRoute.ts +92 -0
- package/src/server/api/endpointsRoute.ts +97 -0
- package/src/server/api/graphql.ts +249 -0
- package/src/server/errors.ts +38 -0
- package/src/server/index.ts +6 -0
- package/src/server/kvStore.ts +152 -0
- package/src/server/runtimeSecurity.ts +102 -0
- package/src/server/types.ts +60 -0
- package/src/types/executionContext.ts +16 -0
- package/tools/seed.ts +365 -0
- package/tools/test-endpoints.ts +174 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"score.js","sourceRoot":"","sources":["../../src/security/score.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Testes de segurança para validar a implementação
|
|
3
|
+
*/
|
|
4
|
+
export declare function runSimpleSecurityTest(): import("./score").SecurityScoreResult;
|
|
5
|
+
export declare function runScannerTest(): Promise<import("./scanner").ScanResult>;
|
|
6
|
+
export declare function runYamlValidationTest(): any;
|
|
7
|
+
export declare function runQuickValidation(): any;
|
|
8
|
+
export declare function runAllSecurityTests(): Promise<{
|
|
9
|
+
securityScore: import("./score").SecurityScoreResult;
|
|
10
|
+
scanner: import("./scanner").ScanResult;
|
|
11
|
+
yamlValidation: any;
|
|
12
|
+
quickValidation: any;
|
|
13
|
+
}>;
|
|
14
|
+
declare const _default: {
|
|
15
|
+
runAllSecurityTests: typeof runAllSecurityTests;
|
|
16
|
+
runSimpleSecurityTest: typeof runSimpleSecurityTest;
|
|
17
|
+
runScannerTest: typeof runScannerTest;
|
|
18
|
+
runYamlValidationTest: typeof runYamlValidationTest;
|
|
19
|
+
runQuickValidation: typeof runQuickValidation;
|
|
20
|
+
};
|
|
21
|
+
export default _default;
|
|
22
|
+
//# sourceMappingURL=test-security.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-security.d.ts","sourceRoot":"","sources":["../../src/security/test-security.ts"],"names":[],"mappings":"AAAA;;GAEG;AAqCH,wBAAgB,qBAAqB,0CA6BpC;AAGD,wBAAsB,cAAc,4CAoBnC;AAGD,wBAAgB,qBAAqB,QAgBpC;AAGD,wBAAgB,kBAAkB,QAgBjC;AAGD,wBAAsB,mBAAmB;;;;;GAqBxC;;;;;;;;AAYD,wBAME"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Testes de segurança para validar a implementação
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.runSimpleSecurityTest = runSimpleSecurityTest;
|
|
7
|
+
exports.runScannerTest = runScannerTest;
|
|
8
|
+
exports.runYamlValidationTest = runYamlValidationTest;
|
|
9
|
+
exports.runQuickValidation = runQuickValidation;
|
|
10
|
+
exports.runAllSecurityTests = runAllSecurityTests;
|
|
11
|
+
const scanner_1 = require("./scanner");
|
|
12
|
+
const score_1 = require("./score");
|
|
13
|
+
const index_1 = require("./index");
|
|
14
|
+
// Dados de teste - YAML malicioso simulado
|
|
15
|
+
const maliciousYaml = `
|
|
16
|
+
name: "John Doe"
|
|
17
|
+
description: "<script>alert('XSS')</script>"
|
|
18
|
+
api_key: "sk-1234567890abcdef"
|
|
19
|
+
nested:
|
|
20
|
+
deep:
|
|
21
|
+
more:
|
|
22
|
+
malicious: "javascript:const x = 'injection'"
|
|
23
|
+
`;
|
|
24
|
+
// Objeto malicioso direto
|
|
25
|
+
const maliciousObject = {
|
|
26
|
+
name: "John Doe",
|
|
27
|
+
xss_payload: "<script>alert('XSS')</script>",
|
|
28
|
+
api_key: "sk-1234567890abcdef",
|
|
29
|
+
injection: "javascript:var x = 'test'",
|
|
30
|
+
oversized: "x".repeat(1024 * 1024 * 50), // 50MB
|
|
31
|
+
deep: {}
|
|
32
|
+
};
|
|
33
|
+
// Criar objeto com profundidade maliciosa
|
|
34
|
+
let current = maliciousObject.deep;
|
|
35
|
+
for (let i = 0; i < 1500; i++) {
|
|
36
|
+
current.nested = {};
|
|
37
|
+
current = current.nested;
|
|
38
|
+
}
|
|
39
|
+
// Teste de Segurança Simples
|
|
40
|
+
function runSimpleSecurityTest() {
|
|
41
|
+
console.log("🔒 Rodando testes de segurança básicos...\n");
|
|
42
|
+
try {
|
|
43
|
+
const scoreCalculator = new score_1.SecurityScore();
|
|
44
|
+
const result = scoreCalculator.calculate(maliciousObject);
|
|
45
|
+
console.log("📊 Score de Segurança:", result.score);
|
|
46
|
+
console.log("🎯 Grau:", result.grade);
|
|
47
|
+
console.log("⚠️ Nível de Risco:", result.riskLevel);
|
|
48
|
+
console.log("🔴 Vulnerabilidades:", result.vulnerabilities.length);
|
|
49
|
+
console.log("✅ Features de Hardening:", result.hardeningApplied.length);
|
|
50
|
+
console.log("💡 Recomendações:", result.recommendations.length);
|
|
51
|
+
console.log("\n🔍 Detalhes de Vulnerabilidades:");
|
|
52
|
+
result.vulnerabilities.forEach((vuln, index) => {
|
|
53
|
+
console.log(` ${index + 1}. [${vuln.severity.toUpperCase()}] ${vuln.type}: ${vuln.description}`);
|
|
54
|
+
});
|
|
55
|
+
console.log("\n🔧 Features de Hardening Aplicadas:");
|
|
56
|
+
result.hardeningApplied.forEach((feature, index) => {
|
|
57
|
+
console.log(` ${index + 1}. ${feature.name} (${feature.status}): ${feature.description}`);
|
|
58
|
+
});
|
|
59
|
+
return result;
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
console.error("❌ Falha no teste de segurança:", error);
|
|
63
|
+
throw error;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
// Teste de Scanner Completo
|
|
67
|
+
async function runScannerTest() {
|
|
68
|
+
console.log("\n🔍 Rodando teste de Scanner de Segurança...\n");
|
|
69
|
+
try {
|
|
70
|
+
const scanner = new scanner_1.SecurityScanner();
|
|
71
|
+
const result = await scanner.scan(maliciousObject);
|
|
72
|
+
console.log("📊 Scanner Result:");
|
|
73
|
+
console.log(" - Seguro:", result.secure);
|
|
74
|
+
console.log(" - Score:", result.score);
|
|
75
|
+
console.log(" - Grau:", result.grade);
|
|
76
|
+
console.log(" - Vulnerabilidades:", result.vulnerabilities.length);
|
|
77
|
+
console.log(" - Advertências:", result.warnings.length);
|
|
78
|
+
console.log(" - Recomendações:", result.recommendations.length);
|
|
79
|
+
return result;
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
console.error("❌ Falha no teste do scanner:", error);
|
|
83
|
+
throw error;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
// Teste de Validação YAML
|
|
87
|
+
function runYamlValidationTest() {
|
|
88
|
+
console.log("\n📋 Rodando teste de validação YAML...\n");
|
|
89
|
+
try {
|
|
90
|
+
const result = (0, index_1.validateYamlSecurity)(maliciousYaml);
|
|
91
|
+
console.log("🔒 Resultado da Validação YAML:");
|
|
92
|
+
console.log(" - Seguro:", result.secure);
|
|
93
|
+
console.log(" - Problemas:", result.issues.join(", "));
|
|
94
|
+
console.log(" - Recomendações:", result.recommendations.length);
|
|
95
|
+
return result;
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
console.error("❌ Falha no teste de validação YAML:", error);
|
|
99
|
+
throw error;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
// Teste de Validação Rápida
|
|
103
|
+
function runQuickValidation() {
|
|
104
|
+
console.log("\n⚡ Rodando teste de validação rápida...\n");
|
|
105
|
+
try {
|
|
106
|
+
const result = (0, index_1.quickSecurityValidation)(maliciousObject);
|
|
107
|
+
console.log("🚀 Validação Rápida:");
|
|
108
|
+
console.log(" - Válido:", result.isValid);
|
|
109
|
+
console.log(" - Score:", result.score);
|
|
110
|
+
console.log(" - Grau:", result.grade);
|
|
111
|
+
return result;
|
|
112
|
+
}
|
|
113
|
+
catch (error) {
|
|
114
|
+
console.error("❌ Falha no teste de validação rápida:", error);
|
|
115
|
+
throw error;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
// Função principal executando todos os testes
|
|
119
|
+
async function runAllSecurityTests() {
|
|
120
|
+
console.log("🛡️ INICIANDO BATERIA DE TESTES DE SEGURANÇA");
|
|
121
|
+
console.log("=".repeat(50));
|
|
122
|
+
const results = {
|
|
123
|
+
securityScore: runSimpleSecurityTest(),
|
|
124
|
+
scanner: await runScannerTest(),
|
|
125
|
+
yamlValidation: runYamlValidationTest(),
|
|
126
|
+
quickValidation: runQuickValidation()
|
|
127
|
+
};
|
|
128
|
+
console.log("\n".repeat(2));
|
|
129
|
+
console.log("🎉 🛡️ BATERIA DE TESTES COMPLETADA COM SUCESSO!");
|
|
130
|
+
console.log("📊 Resumo:", JSON.stringify({
|
|
131
|
+
securityScore: results.securityScore.score,
|
|
132
|
+
scannerSecure: results.scanner.secure,
|
|
133
|
+
yamlSecure: results.yamlValidation.secure,
|
|
134
|
+
quickValid: results.quickValidation.isValid && results.quickValidation.score >= 60
|
|
135
|
+
}, null, 2));
|
|
136
|
+
return results;
|
|
137
|
+
}
|
|
138
|
+
// Executar testes se este arquivo for chamado diretamente
|
|
139
|
+
if (require.main === module) {
|
|
140
|
+
runAllSecurityTests().then(() => {
|
|
141
|
+
console.log("✅ Testes finalizados");
|
|
142
|
+
}).catch((error) => {
|
|
143
|
+
console.error("🔥 Falha nos testes:", error);
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
// Exportação dos testes
|
|
147
|
+
exports.default = {
|
|
148
|
+
runAllSecurityTests,
|
|
149
|
+
runSimpleSecurityTest,
|
|
150
|
+
runScannerTest,
|
|
151
|
+
runYamlValidationTest,
|
|
152
|
+
runQuickValidation
|
|
153
|
+
};
|
|
154
|
+
//# sourceMappingURL=test-security.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-security.js","sourceRoot":"","sources":["../../src/security/test-security.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export interface ThreatAnalysis {
|
|
2
|
+
riskScore: number;
|
|
3
|
+
threatType: string;
|
|
4
|
+
confidence: number;
|
|
5
|
+
recommendations: string[];
|
|
6
|
+
}
|
|
7
|
+
export declare class ThreatDetectionEngine {
|
|
8
|
+
private patterns;
|
|
9
|
+
private anomalyDetector;
|
|
10
|
+
private mlModel;
|
|
11
|
+
constructor();
|
|
12
|
+
private initializePatterns;
|
|
13
|
+
analyze(tenantId: string, operation: string, metadata: any): Promise<ThreatAnalysis>;
|
|
14
|
+
private applyRiskFactors;
|
|
15
|
+
private generateRecommendations;
|
|
16
|
+
getStatistics(): any;
|
|
17
|
+
}
|
|
18
|
+
export declare class AnomalyDetector {
|
|
19
|
+
private normalPatterns;
|
|
20
|
+
private anomalyThreshold;
|
|
21
|
+
private historicalData;
|
|
22
|
+
constructor();
|
|
23
|
+
private initializeHistoricalData;
|
|
24
|
+
detectAnomaly(tenantId: string, operation: string, metadata: any): Promise<number>;
|
|
25
|
+
private calculateAverageInterval;
|
|
26
|
+
private getAverageSize;
|
|
27
|
+
}
|
|
28
|
+
export declare class ThreatMLModel {
|
|
29
|
+
private modelWeights;
|
|
30
|
+
private trainingData;
|
|
31
|
+
private modelVersion;
|
|
32
|
+
constructor();
|
|
33
|
+
private initializeModel;
|
|
34
|
+
private loadTrainingData;
|
|
35
|
+
predict(tenantId: string, operation: string, metadata: any): Promise<number>;
|
|
36
|
+
getModelInfo(): any;
|
|
37
|
+
retrainModel(newData: any[]): void;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=threatDetector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"threatDetector.d.ts","sourceRoot":"","sources":["../../src/security/threatDetector.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,EAAE,CAAC;CAC3B;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,QAAQ,CAAkC;IAClD,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,OAAO,CAAgB;;IAQ/B,OAAO,CAAC,kBAAkB;IAmCb,OAAO,CAClB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,GAAG,GACZ,OAAO,CAAC,cAAc,CAAC;IAyE1B,OAAO,CAAC,gBAAgB;IAsCxB,OAAO,CAAC,uBAAuB;IAkDxB,aAAa,IAAI,GAAG;CAS5B;AAED,qBAAa,eAAe;IAC1B,OAAO,CAAC,cAAc,CAAiC;IACvD,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,cAAc,CAGR;;IAMd,OAAO,CAAC,wBAAwB;IAWnB,aAAa,CACxB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,GAAG,GACZ,OAAO,CAAC,MAAM,CAAC;IA8ElB,OAAO,CAAC,wBAAwB;IAWhC,OAAO,CAAC,cAAc;CAIvB;AAED,qBAAa,aAAa;IACxB,OAAO,CAAC,YAAY,CAAkC;IACtD,OAAO,CAAC,YAAY,CAAiC;IACrD,OAAO,CAAC,YAAY,CAAsB;;IAO1C,OAAO,CAAC,eAAe;IAUvB,OAAO,CAAC,gBAAgB;IA6BX,OAAO,CAClB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,GAAG,GACZ,OAAO,CAAC,MAAM,CAAC;IA8CX,YAAY,IAAI,GAAG;IAgBnB,YAAY,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,IAAI;CAY1C"}
|
|
@@ -0,0 +1,354 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ThreatMLModel = exports.AnomalyDetector = exports.ThreatDetectionEngine = void 0;
|
|
4
|
+
class ThreatDetectionEngine {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.patterns = new Map();
|
|
7
|
+
this.initializePatterns();
|
|
8
|
+
this.anomalyDetector = new AnomalyDetector();
|
|
9
|
+
this.mlModel = new ThreatMLModel();
|
|
10
|
+
}
|
|
11
|
+
initializePatterns() {
|
|
12
|
+
this.patterns.set("brute_force", /multiple_failed_attempts|rapid_login_sequence|authentication_failure|login_fail/i);
|
|
13
|
+
this.patterns.set("sql_injection", /union.*select|drop.*table|exec.*\(.*\)|';.*--|xp_cmdshell|information_schema/i);
|
|
14
|
+
this.patterns.set("data_exfiltration", /bulk.*export|mass.*download|unusual.*access|data.*leak|unauthorized.*download/i);
|
|
15
|
+
this.patterns.set("cross_tenant", /cross.*tenant|tenant.*injection|unauthorized.*access|tenant.*spoofing|bypass.*isolation/i);
|
|
16
|
+
this.patterns.set("lgpd_violation", /unauthorized.*data|consent.*violation|retention.*breach|right.*to.*be.*forgotten|data.*portability/i);
|
|
17
|
+
this.patterns.set("ddos_attack", /flood.*attack|denial.*of.*service|rate.*limit.*bypass|connection.*flood/i);
|
|
18
|
+
this.patterns.set("privilege_escalation", /privilege.*escalation|permission.*bypass|role.*elevation|admin.*bypass/i);
|
|
19
|
+
this.patterns.set("malware_detection", /malware|virus|trojan|ransomware|backdoor|rootkit/i);
|
|
20
|
+
}
|
|
21
|
+
async analyze(tenantId, operation, metadata) {
|
|
22
|
+
let riskScore = 0.1; // Base risk score
|
|
23
|
+
let threatType = "low_risk";
|
|
24
|
+
let confidence = 0.9;
|
|
25
|
+
// Pattern matching detection
|
|
26
|
+
for (const [patternName, pattern] of this.patterns) {
|
|
27
|
+
if (pattern.test(operation) || pattern.test(JSON.stringify(metadata))) {
|
|
28
|
+
switch (patternName) {
|
|
29
|
+
case "brute_force":
|
|
30
|
+
riskScore += 0.4;
|
|
31
|
+
break;
|
|
32
|
+
case "sql_injection":
|
|
33
|
+
riskScore += 0.6;
|
|
34
|
+
break;
|
|
35
|
+
case "data_exfiltration":
|
|
36
|
+
riskScore += 0.8;
|
|
37
|
+
break;
|
|
38
|
+
case "cross_tenant":
|
|
39
|
+
riskScore += 0.9;
|
|
40
|
+
break;
|
|
41
|
+
case "lgpd_violation":
|
|
42
|
+
riskScore += 0.7;
|
|
43
|
+
break;
|
|
44
|
+
case "ddos_attack":
|
|
45
|
+
riskScore += 0.5;
|
|
46
|
+
break;
|
|
47
|
+
case "privilege_escalation":
|
|
48
|
+
riskScore += 0.7;
|
|
49
|
+
break;
|
|
50
|
+
case "malware_detection":
|
|
51
|
+
riskScore += 0.8;
|
|
52
|
+
break;
|
|
53
|
+
default:
|
|
54
|
+
riskScore += 0.3;
|
|
55
|
+
}
|
|
56
|
+
threatType = patternName;
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
// Machine learning based anomaly detection
|
|
61
|
+
const mlScore = await this.mlModel.predict(tenantId, operation, metadata);
|
|
62
|
+
riskScore += mlScore;
|
|
63
|
+
// Time-based anomaly detection
|
|
64
|
+
const anomalyScore = await this.anomalyDetector.detectAnomaly(tenantId, operation, metadata);
|
|
65
|
+
riskScore += anomalyScore * 0.3;
|
|
66
|
+
// Apply additional risk factors
|
|
67
|
+
riskScore = this.applyRiskFactors(riskScore, tenantId, metadata);
|
|
68
|
+
// Cap risk score at maximum of 1.0
|
|
69
|
+
riskScore = Math.min(riskScore, 1.0);
|
|
70
|
+
const recommendations = this.generateRecommendations(riskScore, threatType, tenantId);
|
|
71
|
+
return {
|
|
72
|
+
riskScore,
|
|
73
|
+
threatType,
|
|
74
|
+
confidence,
|
|
75
|
+
recommendations,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
applyRiskFactors(riskScore, tenantId, metadata) {
|
|
79
|
+
// Increase risk for operations during unusual hours
|
|
80
|
+
const hour = new Date().getHours();
|
|
81
|
+
if (hour < 6 || hour > 22) {
|
|
82
|
+
riskScore += 0.15; // Night operations increase risk
|
|
83
|
+
}
|
|
84
|
+
// Increase risk for bulk operations
|
|
85
|
+
if (metadata && metadata.count && metadata.count > 1000) {
|
|
86
|
+
riskScore += 0.2;
|
|
87
|
+
}
|
|
88
|
+
// Increase risk for unauthorized access attempts
|
|
89
|
+
if (metadata && metadata.isUnauthorized) {
|
|
90
|
+
riskScore += 0.25;
|
|
91
|
+
}
|
|
92
|
+
// Increase risk for cross-tenant operations
|
|
93
|
+
if (metadata &&
|
|
94
|
+
metadata.targetTenant &&
|
|
95
|
+
metadata.targetTenant !== tenantId) {
|
|
96
|
+
riskScore += 0.3;
|
|
97
|
+
}
|
|
98
|
+
// Increase risk for operations without proper consent
|
|
99
|
+
if (metadata && metadata.consentStatus === "missing") {
|
|
100
|
+
riskScore += 0.4;
|
|
101
|
+
}
|
|
102
|
+
return Math.min(riskScore, 1.0);
|
|
103
|
+
}
|
|
104
|
+
generateRecommendations(riskScore, threatType, tenantId) {
|
|
105
|
+
const recommendations = [];
|
|
106
|
+
// Critical threats (>0.8)
|
|
107
|
+
if (riskScore > 0.8) {
|
|
108
|
+
recommendations.push("🚨 EMERGENCY: Immediate action required");
|
|
109
|
+
recommendations.push(`Isolate tenant ${tenantId} immediately`);
|
|
110
|
+
recommendations.push("Contact security team NOW");
|
|
111
|
+
recommendations.push("Preserve audit logs");
|
|
112
|
+
recommendations.push(`Potential ${threatType} attack detected`);
|
|
113
|
+
}
|
|
114
|
+
// High threats (>0.6)
|
|
115
|
+
else if (riskScore > 0.6) {
|
|
116
|
+
recommendations.push("⚠️ CRITICAL: Investigate immediately");
|
|
117
|
+
recommendations.push(`Block suspicious activities from tenant ${tenantId}`);
|
|
118
|
+
recommendations.push("Monitor all operations from this tenant");
|
|
119
|
+
recommendations.push("Notify security team within 5 minutes");
|
|
120
|
+
recommendations.push(`Check for ${threatType} indicators`);
|
|
121
|
+
}
|
|
122
|
+
// Medium threats (>0.4)
|
|
123
|
+
else if (riskScore > 0.4) {
|
|
124
|
+
recommendations.push("⚠️ WARNING: Monitor closely");
|
|
125
|
+
recommendations.push(`Increase monitoring for tenant ${tenantId}`);
|
|
126
|
+
recommendations.push("Check access patterns");
|
|
127
|
+
recommendations.push("Review permissions");
|
|
128
|
+
recommendations.push(`Investigate ${threatType} patterns`);
|
|
129
|
+
}
|
|
130
|
+
// Low threats (>0.2)
|
|
131
|
+
else if (riskScore > 0.2) {
|
|
132
|
+
recommendations.push("ℹ️ INFO: Routine observation");
|
|
133
|
+
recommendations.push("Document the pattern");
|
|
134
|
+
recommendations.push("Check if pattern repeats");
|
|
135
|
+
recommendations.push(`Normal monitoring for ${threatType}`);
|
|
136
|
+
}
|
|
137
|
+
// Very low threats
|
|
138
|
+
else {
|
|
139
|
+
recommendations.push("✅ Normal activity");
|
|
140
|
+
recommendations.push("Continue regular monitoring");
|
|
141
|
+
recommendations.push("No special actions required");
|
|
142
|
+
}
|
|
143
|
+
return recommendations;
|
|
144
|
+
}
|
|
145
|
+
getStatistics() {
|
|
146
|
+
return {
|
|
147
|
+
patternsLoaded: this.patterns.size,
|
|
148
|
+
lastUpdate: new Date().toISOString(),
|
|
149
|
+
mlModelVersion: "2025.1.0",
|
|
150
|
+
detectorVersion: "v3.0",
|
|
151
|
+
threatTypes: Array.from(this.patterns.keys()),
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
exports.ThreatDetectionEngine = ThreatDetectionEngine;
|
|
156
|
+
class AnomalyDetector {
|
|
157
|
+
constructor() {
|
|
158
|
+
this.normalPatterns = new Map();
|
|
159
|
+
this.anomalyThreshold = 2.5;
|
|
160
|
+
this.historicalData = new Map();
|
|
161
|
+
this.initializeHistoricalData();
|
|
162
|
+
}
|
|
163
|
+
initializeHistoricalData() {
|
|
164
|
+
// Initialize with some baseline patterns
|
|
165
|
+
const baselineTenants = ["tenant-alpha", "tenant-beta", "tenant-gamma"];
|
|
166
|
+
baselineTenants.forEach((tenantId) => {
|
|
167
|
+
this.historicalData.set(tenantId, {
|
|
168
|
+
timestamps: [],
|
|
169
|
+
operations: [],
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
async detectAnomaly(tenantId, operation, metadata) {
|
|
174
|
+
const key = `${tenantId}:${operation}`;
|
|
175
|
+
const currentTime = new Date().getTime();
|
|
176
|
+
// Initialize if not exists
|
|
177
|
+
if (!this.normalPatterns.has(key)) {
|
|
178
|
+
this.normalPatterns.set(key, []);
|
|
179
|
+
}
|
|
180
|
+
const patterns = this.normalPatterns.get(key);
|
|
181
|
+
// Advanced anomaly detection
|
|
182
|
+
let anomalyScore = 0.0;
|
|
183
|
+
// 1. Velocity-based anomaly detection
|
|
184
|
+
if (patterns.length > 5) {
|
|
185
|
+
const recentTimestamps = patterns.slice(-5).map((p) => p.timestamp);
|
|
186
|
+
const avgTimeInterval = this.calculateAverageInterval(recentTimestamps);
|
|
187
|
+
if (avgTimeInterval > 0) {
|
|
188
|
+
const currentTimeInterval = currentTime - recentTimestamps[recentTimestamps.length - 1];
|
|
189
|
+
const deviation = Math.abs(currentTimeInterval - avgTimeInterval) / avgTimeInterval;
|
|
190
|
+
if (deviation > 3.0) {
|
|
191
|
+
anomalyScore += 0.4; // High velocity anomaly
|
|
192
|
+
}
|
|
193
|
+
else if (deviation > 1.5) {
|
|
194
|
+
anomalyScore += 0.2; // Medium velocity anomaly
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
// 2. Pattern-based anomaly detection
|
|
199
|
+
if (metadata && metadata.size) {
|
|
200
|
+
const historicalData = this.historicalData.get(tenantId);
|
|
201
|
+
if (historicalData) {
|
|
202
|
+
const avgSize = this.getAverageSize(historicalData.operations);
|
|
203
|
+
const currentSize = metadata.size;
|
|
204
|
+
if (currentSize > avgSize * 100) {
|
|
205
|
+
anomalyScore += 0.3; // Unusual data size
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
// 3. Time-based anomaly detection
|
|
210
|
+
const hour = new Date().getHours();
|
|
211
|
+
if (hour < 6 || hour > 22) {
|
|
212
|
+
anomalyScore += 0.15; // Night operations are more suspicious
|
|
213
|
+
}
|
|
214
|
+
// 4. Cross-tenant anomaly detection
|
|
215
|
+
if (metadata &&
|
|
216
|
+
metadata.targetTenant &&
|
|
217
|
+
metadata.targetTenant !== tenantId) {
|
|
218
|
+
anomalyScore += 0.25; // Cross-tenant operations are high risk
|
|
219
|
+
}
|
|
220
|
+
// Store current pattern for future comparison
|
|
221
|
+
patterns.push({
|
|
222
|
+
timestamp: currentTime,
|
|
223
|
+
operation,
|
|
224
|
+
metadata,
|
|
225
|
+
});
|
|
226
|
+
// Keep only recent patterns (last 24 hours)
|
|
227
|
+
const cutoff = currentTime - 24 * 60 * 60 * 1000;
|
|
228
|
+
this.normalPatterns.set(key, patterns.filter((p) => p.timestamp > cutoff));
|
|
229
|
+
return Math.min(anomalyScore, 0.8);
|
|
230
|
+
}
|
|
231
|
+
calculateAverageInterval(timestamps) {
|
|
232
|
+
if (timestamps.length < 2)
|
|
233
|
+
return 0;
|
|
234
|
+
let totalInterval = 0;
|
|
235
|
+
for (let i = 1; i < timestamps.length; i++) {
|
|
236
|
+
totalInterval += timestamps[i] - timestamps[i - 1];
|
|
237
|
+
}
|
|
238
|
+
return totalInterval / (timestamps.length - 1);
|
|
239
|
+
}
|
|
240
|
+
getAverageSize(operations) {
|
|
241
|
+
if (operations.length === 0)
|
|
242
|
+
return 0;
|
|
243
|
+
return 1000; // Default average size
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
exports.AnomalyDetector = AnomalyDetector;
|
|
247
|
+
class ThreatMLModel {
|
|
248
|
+
constructor() {
|
|
249
|
+
this.modelWeights = new Map();
|
|
250
|
+
this.trainingData = new Map();
|
|
251
|
+
this.modelVersion = "2025.1.0";
|
|
252
|
+
this.initializeModel();
|
|
253
|
+
this.loadTrainingData();
|
|
254
|
+
}
|
|
255
|
+
initializeModel() {
|
|
256
|
+
// Advanced ML model weights based on tenant behavior patterns
|
|
257
|
+
this.modelWeights.set("tenant_historical_risk", 0.35);
|
|
258
|
+
this.modelWeights.set("operation_frequency_anomaly", 0.25);
|
|
259
|
+
this.modelWeights.set("metadata_complexity_risk", 0.2);
|
|
260
|
+
this.modelWeights.set("time_deviation_risk", 0.15);
|
|
261
|
+
this.modelWeights.set("cross_tenant_detection", 0.4);
|
|
262
|
+
this.modelWeights.set("lgpd_compliance_checker", 0.3);
|
|
263
|
+
}
|
|
264
|
+
loadTrainingData() {
|
|
265
|
+
// Load historical training data
|
|
266
|
+
const sampleTrainingData = [
|
|
267
|
+
{
|
|
268
|
+
tenantId: "tenant-alpha",
|
|
269
|
+
operation: "normal_access",
|
|
270
|
+
metadata: { size: 100 },
|
|
271
|
+
riskScore: 0.1,
|
|
272
|
+
},
|
|
273
|
+
{
|
|
274
|
+
tenantId: "tenant-beta",
|
|
275
|
+
operation: "bulk_export",
|
|
276
|
+
metadata: { size: 10000 },
|
|
277
|
+
riskScore: 0.8,
|
|
278
|
+
},
|
|
279
|
+
{
|
|
280
|
+
tenantId: "tenant-gamma",
|
|
281
|
+
operation: "cross_tenant_access",
|
|
282
|
+
metadata: { targetTenant: "other" },
|
|
283
|
+
riskScore: 0.9,
|
|
284
|
+
},
|
|
285
|
+
];
|
|
286
|
+
sampleTrainingData.forEach((data) => {
|
|
287
|
+
const key = `${data.tenantId}:${data.operation}`;
|
|
288
|
+
this.trainingData.set(key, [data]);
|
|
289
|
+
});
|
|
290
|
+
}
|
|
291
|
+
async predict(tenantId, operation, metadata) {
|
|
292
|
+
let riskScore = 0.0;
|
|
293
|
+
// 1. Historical tenant behavior analysis
|
|
294
|
+
const historicalKey = `${tenantId}:${operation}`;
|
|
295
|
+
if (this.trainingData.has(historicalKey)) {
|
|
296
|
+
const historicalData = this.trainingData.get(historicalKey);
|
|
297
|
+
const avgRisk = historicalData.reduce((sum, data) => sum + data.riskScore, 0) /
|
|
298
|
+
historicalData.length;
|
|
299
|
+
riskScore += avgRisk * this.modelWeights.get("tenant_historical_risk");
|
|
300
|
+
}
|
|
301
|
+
// 2. Operation frequency analysis
|
|
302
|
+
const hour = new Date().getHours();
|
|
303
|
+
if (hour < 6 || hour > 22) {
|
|
304
|
+
riskScore += 0.3 * this.modelWeights.get("time_deviation_risk");
|
|
305
|
+
}
|
|
306
|
+
// 3. Metadata complexity analysis
|
|
307
|
+
if (metadata && JSON.stringify(metadata).length > 2000) {
|
|
308
|
+
riskScore += 0.2 * this.modelWeights.get("metadata_complexity_risk");
|
|
309
|
+
}
|
|
310
|
+
// 4. Cross-tenant operation detection
|
|
311
|
+
if (metadata &&
|
|
312
|
+
metadata.targetTenant &&
|
|
313
|
+
metadata.targetTenant !== tenantId) {
|
|
314
|
+
riskScore += 0.8 * this.modelWeights.get("cross_tenant_detection");
|
|
315
|
+
}
|
|
316
|
+
// 5. LGPD compliance violation detection
|
|
317
|
+
if (metadata && metadata.consentStatus === "missing") {
|
|
318
|
+
riskScore += 0.6 * this.modelWeights.get("lgpd_compliance_checker");
|
|
319
|
+
}
|
|
320
|
+
// 6. High-frequency operation detection
|
|
321
|
+
if (metadata && metadata.operationCount && metadata.operationCount > 1000) {
|
|
322
|
+
riskScore += 0.3 * this.modelWeights.get("operation_frequency_anomaly");
|
|
323
|
+
}
|
|
324
|
+
return Math.min(riskScore, 1.0);
|
|
325
|
+
}
|
|
326
|
+
getModelInfo() {
|
|
327
|
+
return {
|
|
328
|
+
version: this.modelVersion,
|
|
329
|
+
weights: Object.fromEntries(this.modelWeights),
|
|
330
|
+
trainingDataSize: this.trainingData.size,
|
|
331
|
+
features: [
|
|
332
|
+
"tenant_historical_risk",
|
|
333
|
+
"operation_frequency_anomaly",
|
|
334
|
+
"metadata_complexity_risk",
|
|
335
|
+
"time_deviation_risk",
|
|
336
|
+
"cross_tenant_detection",
|
|
337
|
+
"lgpd_compliance_checker",
|
|
338
|
+
],
|
|
339
|
+
};
|
|
340
|
+
}
|
|
341
|
+
retrainModel(newData) {
|
|
342
|
+
// Simplified retraining logic
|
|
343
|
+
newData.forEach((data) => {
|
|
344
|
+
const key = `${data.tenantId}:${data.operation}`;
|
|
345
|
+
if (!this.trainingData.has(key)) {
|
|
346
|
+
this.trainingData.set(key, []);
|
|
347
|
+
}
|
|
348
|
+
this.trainingData.get(key).push(data);
|
|
349
|
+
});
|
|
350
|
+
this.modelVersion = `2025.${new Date().getMonth()}.${new Date().getDate()}`;
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
exports.ThreatMLModel = ThreatMLModel;
|
|
354
|
+
//# sourceMappingURL=threatDetector.js.map
|