@gsep/core 0.8.0 → 1.0.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 +12 -12
- package/dist/{PGA.d.ts → GSEP.d.ts} +120 -8
- package/dist/GSEP.d.ts.map +1 -0
- package/dist/{PGA.js → GSEP.js} +1248 -46
- package/dist/GSEP.js.map +1 -0
- package/dist/adapters/langchain.d.ts +52 -0
- package/dist/adapters/langchain.d.ts.map +1 -0
- package/dist/adapters/langchain.js +89 -0
- package/dist/adapters/langchain.js.map +1 -0
- package/dist/adapters/openclaw-plugin.d.ts +42 -0
- package/dist/adapters/openclaw-plugin.d.ts.map +1 -0
- package/dist/adapters/openclaw-plugin.js +149 -0
- package/dist/adapters/openclaw-plugin.js.map +1 -0
- package/dist/adapters/vercel-ai.d.ts +74 -0
- package/dist/adapters/vercel-ai.d.ts.map +1 -0
- package/dist/adapters/vercel-ai.js +151 -0
- package/dist/adapters/vercel-ai.js.map +1 -0
- package/dist/advanced-ai/EnhancedSelfModel.js +2 -2
- package/dist/advanced-ai/EnhancedSelfModel.js.map +1 -1
- package/dist/advanced-ai/ModelRouter.js.map +1 -1
- package/dist/auto.d.ts +6 -0
- package/dist/auto.d.ts.map +1 -0
- package/dist/auto.js +197 -0
- package/dist/auto.js.map +1 -0
- package/dist/core/CoherenceValidator.d.ts +25 -0
- package/dist/core/CoherenceValidator.d.ts.map +1 -0
- package/dist/core/CoherenceValidator.js +182 -0
- package/dist/core/CoherenceValidator.js.map +1 -0
- package/dist/core/ContextMemory.d.ts.map +1 -1
- package/dist/core/ContextMemory.js +1 -1
- package/dist/core/ContextMemory.js.map +1 -1
- package/dist/core/DNAProfile.d.ts +5 -1
- package/dist/core/DNAProfile.d.ts.map +1 -1
- package/dist/core/DNAProfile.js +14 -1
- package/dist/core/DNAProfile.js.map +1 -1
- package/dist/core/GSEPIdentitySection.d.ts.map +1 -1
- package/dist/core/GSEPIdentitySection.js +12 -3
- package/dist/core/GSEPIdentitySection.js.map +1 -1
- package/dist/core/GenomeKernel.d.ts.map +1 -1
- package/dist/core/GenomeKernel.js +3 -0
- package/dist/core/GenomeKernel.js.map +1 -1
- package/dist/core/GenomeManager.js +1 -1
- package/dist/core/GenomeManager.js.map +1 -1
- package/dist/core/ProactiveSuggestions.js +1 -1
- package/dist/core/ProactiveSuggestions.js.map +1 -1
- package/dist/dashboard/DashboardServer.d.ts +64 -0
- package/dist/dashboard/DashboardServer.d.ts.map +1 -0
- package/dist/dashboard/DashboardServer.js +409 -0
- package/dist/dashboard/DashboardServer.js.map +1 -0
- package/dist/dashboard/DashboardToken.d.ts +16 -0
- package/dist/dashboard/DashboardToken.d.ts.map +1 -0
- package/dist/dashboard/DashboardToken.js +54 -0
- package/dist/dashboard/DashboardToken.js.map +1 -0
- package/dist/dashboard/dashboard.html +2731 -0
- package/dist/dashboard/index.d.ts +3 -0
- package/dist/dashboard/index.d.ts.map +1 -0
- package/dist/dashboard/index.js +3 -0
- package/dist/dashboard/index.js.map +1 -0
- package/dist/evaluation/BenchmarkSuites.d.ts +2 -2
- package/dist/evaluation/BenchmarkSuites.d.ts.map +1 -1
- package/dist/evaluation/BenchmarkSuites.js +6 -6
- package/dist/evaluation/BenchmarkSuites.js.map +1 -1
- package/dist/evaluation/ConstitutionalGate.d.ts +18 -0
- package/dist/evaluation/ConstitutionalGate.d.ts.map +1 -0
- package/dist/evaluation/ConstitutionalGate.js +149 -0
- package/dist/evaluation/ConstitutionalGate.js.map +1 -0
- package/dist/evaluation/Evaluator.d.ts +4 -4
- package/dist/evaluation/Evaluator.d.ts.map +1 -1
- package/dist/evaluation/Evaluator.js +27 -27
- package/dist/evaluation/Evaluator.js.map +1 -1
- package/dist/evaluation/EvolutionGuardrails.d.ts +3 -1
- package/dist/evaluation/EvolutionGuardrails.d.ts.map +1 -1
- package/dist/evaluation/EvolutionGuardrails.js +29 -11
- package/dist/evaluation/EvolutionGuardrails.js.map +1 -1
- package/dist/evolution/MutationOperator.d.ts +19 -6
- package/dist/evolution/MutationOperator.d.ts.map +1 -1
- package/dist/evolution/MutationOperator.js +264 -9
- package/dist/evolution/MutationOperator.js.map +1 -1
- package/dist/evolution/boost/operators/BreakthroughOperator.d.ts +1 -1
- package/dist/evolution/boost/operators/BreakthroughOperator.d.ts.map +1 -1
- package/dist/evolution/boost/operators/BreakthroughOperator.js.map +1 -1
- package/dist/evolution/boost/operators/CrossoverMutationOperator.d.ts +1 -1
- package/dist/evolution/boost/operators/CrossoverMutationOperator.d.ts.map +1 -1
- package/dist/evolution/boost/operators/CrossoverMutationOperator.js.map +1 -1
- package/dist/evolution/boost/operators/PatternExtractionOperator.d.ts +1 -1
- package/dist/evolution/boost/operators/PatternExtractionOperator.d.ts.map +1 -1
- package/dist/evolution/boost/operators/PatternExtractionOperator.js.map +1 -1
- package/dist/evolution/boost/operators/SemanticRestructuringOperator.d.ts +1 -1
- package/dist/evolution/boost/operators/SemanticRestructuringOperator.d.ts.map +1 -1
- package/dist/evolution/boost/operators/SemanticRestructuringOperator.js.map +1 -1
- package/dist/firewall/AnomalyDetector.d.ts +42 -0
- package/dist/firewall/AnomalyDetector.d.ts.map +1 -0
- package/dist/firewall/AnomalyDetector.js +181 -0
- package/dist/firewall/AnomalyDetector.js.map +1 -0
- package/dist/firewall/ContentFirewall.d.ts +5 -0
- package/dist/firewall/ContentFirewall.d.ts.map +1 -1
- package/dist/firewall/ContentFirewall.js +5 -0
- package/dist/firewall/ContentFirewall.js.map +1 -1
- package/dist/firewall/PurposeLock.d.ts +41 -0
- package/dist/firewall/PurposeLock.d.ts.map +1 -0
- package/dist/firewall/PurposeLock.js +199 -0
- package/dist/firewall/PurposeLock.js.map +1 -0
- package/dist/gene-bank/CognitiveGene.d.ts +118 -118
- package/dist/gene-bank/{PGAIntegration.d.ts → GSEPIntegration.d.ts} +10 -10
- package/dist/gene-bank/GSEPIntegration.d.ts.map +1 -0
- package/dist/gene-bank/{PGAIntegration.js → GSEPIntegration.js} +6 -6
- package/dist/gene-bank/GSEPIntegration.js.map +1 -0
- package/dist/gene-bank/GeneAdopter.d.ts +6 -6
- package/dist/gene-bank/GeneAdopter.d.ts.map +1 -1
- package/dist/gene-bank/GeneAdopter.js +2 -2
- package/dist/gene-bank/GeneAdopter.js.map +1 -1
- package/dist/gene-bank/GeneBank.d.ts +13 -9
- package/dist/gene-bank/GeneBank.d.ts.map +1 -1
- package/dist/gene-bank/GeneBank.js +8 -1
- package/dist/gene-bank/GeneBank.js.map +1 -1
- package/dist/gene-bank/GeneExtractor.d.ts +7 -7
- package/dist/gene-bank/GeneExtractor.d.ts.map +1 -1
- package/dist/gene-bank/GeneExtractor.js +1 -1
- package/dist/gene-bank/GeneExtractor.js.map +1 -1
- package/dist/gene-bank/GeneMatcher.d.ts +1 -1
- package/dist/gene-bank/GeneMatcher.d.ts.map +1 -1
- package/dist/gene-bank/MarketplaceClient.d.ts +17 -1
- package/dist/gene-bank/MarketplaceClient.d.ts.map +1 -1
- package/dist/gene-bank/MarketplaceClient.js +106 -35
- package/dist/gene-bank/MarketplaceClient.js.map +1 -1
- package/dist/gene-bank/MarketplaceMapper.d.ts +7 -0
- package/dist/gene-bank/MarketplaceMapper.d.ts.map +1 -0
- package/dist/gene-bank/MarketplaceMapper.js +95 -0
- package/dist/gene-bank/MarketplaceMapper.js.map +1 -0
- package/dist/gene-bank/MarketplaceTypes.d.ts +121 -0
- package/dist/gene-bank/MarketplaceTypes.d.ts.map +1 -0
- package/dist/gene-bank/MarketplaceTypes.js +2 -0
- package/dist/gene-bank/MarketplaceTypes.js.map +1 -0
- package/dist/gene-bank/SandboxTester.d.ts +3 -3
- package/dist/gene-bank/SandboxTester.d.ts.map +1 -1
- package/dist/gene-bank/adapters/InMemoryGeneStorage.d.ts +3 -3
- package/dist/gene-bank/adapters/InMemoryGeneStorage.d.ts.map +1 -1
- package/dist/gene-bank/adapters/PostgresGeneStorage.d.ts +4 -4
- package/dist/gene-bank/adapters/PostgresGeneStorage.d.ts.map +1 -1
- package/dist/gene-bank/adapters/PostgresGeneStorage.js.map +1 -1
- package/dist/gene-bank/adapters/SQLiteGeneStorage.d.ts +28 -0
- package/dist/gene-bank/adapters/SQLiteGeneStorage.d.ts.map +1 -0
- package/dist/gene-bank/adapters/SQLiteGeneStorage.js +158 -0
- package/dist/gene-bank/adapters/SQLiteGeneStorage.js.map +1 -0
- package/dist/gene-bank/index.d.ts +10 -7
- package/dist/gene-bank/index.d.ts.map +1 -1
- package/dist/gene-bank/index.js +8 -7
- package/dist/gene-bank/index.js.map +1 -1
- package/dist/immune/BehavioralImmuneSystem.d.ts +6 -0
- package/dist/immune/BehavioralImmuneSystem.d.ts.map +1 -1
- package/dist/immune/BehavioralImmuneSystem.js +6 -0
- package/dist/immune/BehavioralImmuneSystem.js.map +1 -1
- package/dist/index.d.ts +44 -9
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +22 -4
- package/dist/index.js.map +1 -1
- package/dist/memory/LayeredMemory.d.ts +1 -1
- package/dist/memory/LayeredMemory.d.ts.map +1 -1
- package/dist/memory/LayeredMemory.js.map +1 -1
- package/dist/middleware/GSEPMiddleware.d.ts +57 -0
- package/dist/middleware/GSEPMiddleware.d.ts.map +1 -0
- package/dist/middleware/GSEPMiddleware.js +91 -0
- package/dist/middleware/GSEPMiddleware.js.map +1 -0
- package/dist/middleware/RuntimeDetector.d.ts +10 -0
- package/dist/middleware/RuntimeDetector.d.ts.map +1 -0
- package/dist/middleware/RuntimeDetector.js +70 -0
- package/dist/middleware/RuntimeDetector.js.map +1 -0
- package/dist/middleware/ServerlessAdapter.d.ts +23 -0
- package/dist/middleware/ServerlessAdapter.d.ts.map +1 -0
- package/dist/middleware/ServerlessAdapter.js +77 -0
- package/dist/middleware/ServerlessAdapter.js.map +1 -0
- package/dist/monitoring/AlertWebhooks.d.ts +17 -0
- package/dist/monitoring/AlertWebhooks.d.ts.map +1 -1
- package/dist/monitoring/AlertWebhooks.js.map +1 -1
- package/dist/monitoring/WeeklyReportGenerator.d.ts +73 -0
- package/dist/monitoring/WeeklyReportGenerator.d.ts.map +1 -0
- package/dist/monitoring/WeeklyReportGenerator.js +148 -0
- package/dist/monitoring/WeeklyReportGenerator.js.map +1 -0
- package/dist/rag/RAGEngine.d.ts +1 -1
- package/dist/rag/RAGEngine.d.ts.map +1 -1
- package/dist/rag/VectorStoreAdapter.d.ts +2 -2
- package/dist/rag/VectorStoreAdapter.d.ts.map +1 -1
- package/dist/rag/VectorStoreAdapter.js.map +1 -1
- package/dist/realtime/EventEmitter.d.ts +110 -17
- package/dist/realtime/EventEmitter.d.ts.map +1 -1
- package/dist/realtime/EventEmitter.js +3 -4
- package/dist/realtime/EventEmitter.js.map +1 -1
- package/dist/security/CapabilityBroker.d.ts +41 -0
- package/dist/security/CapabilityBroker.d.ts.map +1 -0
- package/dist/security/CapabilityBroker.js +125 -0
- package/dist/security/CapabilityBroker.js.map +1 -0
- package/dist/security/CommandExecutionGuard.d.ts +47 -0
- package/dist/security/CommandExecutionGuard.d.ts.map +1 -0
- package/dist/security/CommandExecutionGuard.js +175 -0
- package/dist/security/CommandExecutionGuard.js.map +1 -0
- package/dist/security/ComplianceExporter.d.ts +32 -0
- package/dist/security/ComplianceExporter.d.ts.map +1 -0
- package/dist/security/ComplianceExporter.js +129 -0
- package/dist/security/ComplianceExporter.js.map +1 -0
- package/dist/security/DataAccessTracker.d.ts +38 -0
- package/dist/security/DataAccessTracker.d.ts.map +1 -0
- package/dist/security/DataAccessTracker.js +71 -0
- package/dist/security/DataAccessTracker.js.map +1 -0
- package/dist/security/DataClassifier.d.ts +14 -0
- package/dist/security/DataClassifier.d.ts.map +1 -0
- package/dist/security/DataClassifier.js +146 -0
- package/dist/security/DataClassifier.js.map +1 -0
- package/dist/security/EncryptedConfigStore.d.ts +21 -0
- package/dist/security/EncryptedConfigStore.d.ts.map +1 -0
- package/dist/security/EncryptedConfigStore.js +119 -0
- package/dist/security/EncryptedConfigStore.js.map +1 -0
- package/dist/security/EnterprisePolicyEngine.d.ts +90 -0
- package/dist/security/EnterprisePolicyEngine.d.ts.map +1 -0
- package/dist/security/EnterprisePolicyEngine.js +240 -0
- package/dist/security/EnterprisePolicyEngine.js.map +1 -0
- package/dist/security/FileSystemBoundary.d.ts +33 -0
- package/dist/security/FileSystemBoundary.d.ts.map +1 -0
- package/dist/security/FileSystemBoundary.js +94 -0
- package/dist/security/FileSystemBoundary.js.map +1 -0
- package/dist/security/GDPREngine.d.ts +65 -0
- package/dist/security/GDPREngine.d.ts.map +1 -0
- package/dist/security/GDPREngine.js +180 -0
- package/dist/security/GDPREngine.js.map +1 -0
- package/dist/security/GenomeSecurityBridge.d.ts +47 -0
- package/dist/security/GenomeSecurityBridge.d.ts.map +1 -0
- package/dist/security/GenomeSecurityBridge.js +157 -0
- package/dist/security/GenomeSecurityBridge.js.map +1 -0
- package/dist/security/KeyHierarchy.d.ts +23 -0
- package/dist/security/KeyHierarchy.d.ts.map +1 -0
- package/dist/security/KeyHierarchy.js +78 -0
- package/dist/security/KeyHierarchy.js.map +1 -0
- package/dist/security/KeychainAdapter.d.ts +19 -0
- package/dist/security/KeychainAdapter.d.ts.map +1 -0
- package/dist/security/KeychainAdapter.js +104 -0
- package/dist/security/KeychainAdapter.js.map +1 -0
- package/dist/security/LLMProxyLayer.d.ts +63 -0
- package/dist/security/LLMProxyLayer.d.ts.map +1 -0
- package/dist/security/LLMProxyLayer.js +148 -0
- package/dist/security/LLMProxyLayer.js.map +1 -0
- package/dist/security/MFAProvider.d.ts +35 -0
- package/dist/security/MFAProvider.d.ts.map +1 -0
- package/dist/security/MFAProvider.js +174 -0
- package/dist/security/MFAProvider.js.map +1 -0
- package/dist/security/NetworkAuditLogger.d.ts +35 -0
- package/dist/security/NetworkAuditLogger.d.ts.map +1 -0
- package/dist/security/NetworkAuditLogger.js +99 -0
- package/dist/security/NetworkAuditLogger.js.map +1 -0
- package/dist/security/OutboundAllowlist.d.ts +33 -0
- package/dist/security/OutboundAllowlist.d.ts.map +1 -0
- package/dist/security/OutboundAllowlist.js +112 -0
- package/dist/security/OutboundAllowlist.js.map +1 -0
- package/dist/security/PIIRedactionEngine.d.ts +40 -0
- package/dist/security/PIIRedactionEngine.d.ts.map +1 -0
- package/dist/security/PIIRedactionEngine.js +232 -0
- package/dist/security/PIIRedactionEngine.js.map +1 -0
- package/dist/security/RBACEngine.d.ts +44 -0
- package/dist/security/RBACEngine.d.ts.map +1 -0
- package/dist/security/RBACEngine.js +209 -0
- package/dist/security/RBACEngine.js.map +1 -0
- package/dist/security/SOC2Controls.d.ts +37 -0
- package/dist/security/SOC2Controls.d.ts.map +1 -0
- package/dist/security/SOC2Controls.js +151 -0
- package/dist/security/SOC2Controls.js.map +1 -0
- package/dist/security/SecretRotationEngine.d.ts +46 -0
- package/dist/security/SecretRotationEngine.d.ts.map +1 -0
- package/dist/security/SecretRotationEngine.js +102 -0
- package/dist/security/SecretRotationEngine.js.map +1 -0
- package/dist/security/SecretsMigrator.d.ts +28 -0
- package/dist/security/SecretsMigrator.d.ts.map +1 -0
- package/dist/security/SecretsMigrator.js +170 -0
- package/dist/security/SecretsMigrator.js.map +1 -0
- package/dist/security/SecurityEventBus.d.ts +48 -0
- package/dist/security/SecurityEventBus.d.ts.map +1 -0
- package/dist/security/SecurityEventBus.js +105 -0
- package/dist/security/SecurityEventBus.js.map +1 -0
- package/dist/security/SecurityPresets.d.ts +42 -0
- package/dist/security/SecurityPresets.d.ts.map +1 -0
- package/dist/security/SecurityPresets.js +162 -0
- package/dist/security/SecurityPresets.js.map +1 -0
- package/dist/security/SkillManifest.d.ts +34 -0
- package/dist/security/SkillManifest.d.ts.map +1 -0
- package/dist/security/SkillManifest.js +91 -0
- package/dist/security/SkillManifest.js.map +1 -0
- package/dist/security/SkillSigner.d.ts +22 -0
- package/dist/security/SkillSigner.d.ts.map +1 -0
- package/dist/security/SkillSigner.js +80 -0
- package/dist/security/SkillSigner.js.map +1 -0
- package/dist/security/TamperProofAuditLog.d.ts +58 -0
- package/dist/security/TamperProofAuditLog.d.ts.map +1 -0
- package/dist/security/TamperProofAuditLog.js +214 -0
- package/dist/security/TamperProofAuditLog.js.map +1 -0
- package/dist/security/index.d.ts +27 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +27 -0
- package/dist/security/index.js.map +1 -0
- package/dist/skills/ProactiveEngine.d.ts +55 -0
- package/dist/skills/ProactiveEngine.d.ts.map +1 -0
- package/dist/skills/ProactiveEngine.js +201 -0
- package/dist/skills/ProactiveEngine.js.map +1 -0
- package/dist/skills/SkillExecutor.d.ts +21 -0
- package/dist/skills/SkillExecutor.d.ts.map +1 -0
- package/dist/skills/SkillExecutor.js +131 -0
- package/dist/skills/SkillExecutor.js.map +1 -0
- package/dist/skills/SkillRegistry.d.ts +47 -0
- package/dist/skills/SkillRegistry.d.ts.map +1 -0
- package/dist/skills/SkillRegistry.js +94 -0
- package/dist/skills/SkillRegistry.js.map +1 -0
- package/dist/skills/SkillRouter.d.ts +30 -0
- package/dist/skills/SkillRouter.d.ts.map +1 -0
- package/dist/skills/SkillRouter.js +113 -0
- package/dist/skills/SkillRouter.js.map +1 -0
- package/dist/skills/index.d.ts +9 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/index.js +5 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/types/GenomeV2.d.ts +12 -0
- package/dist/types/GenomeV2.d.ts.map +1 -1
- package/dist/types/index.d.ts +19 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/wrap/FileStorageAdapter.d.ts +113 -0
- package/dist/wrap/FileStorageAdapter.d.ts.map +1 -0
- package/dist/wrap/FileStorageAdapter.js +239 -0
- package/dist/wrap/FileStorageAdapter.js.map +1 -0
- package/dist/wrap/SQLiteStorageAdapter.d.ts +96 -0
- package/dist/wrap/SQLiteStorageAdapter.d.ts.map +1 -0
- package/dist/wrap/SQLiteStorageAdapter.js +251 -0
- package/dist/wrap/SQLiteStorageAdapter.js.map +1 -0
- package/dist/wrap/WrappedAgent.d.ts +2 -2
- package/dist/wrap/WrappedAgent.d.ts.map +1 -1
- package/dist/wrap/WrappedAgent.js +7 -7
- package/dist/wrap/WrappedAgent.js.map +1 -1
- package/dist/wrap.d.ts +39 -0
- package/dist/wrap.d.ts.map +1 -0
- package/dist/wrap.js +96 -0
- package/dist/wrap.js.map +1 -0
- package/package.json +34 -7
- package/dist/PGA.d.ts.map +0 -1
- package/dist/PGA.js.map +0 -1
- package/dist/evolution/PromotionGate.d.ts +0 -45
- package/dist/evolution/PromotionGate.d.ts.map +0 -1
- package/dist/evolution/PromotionGate.js +0 -248
- package/dist/evolution/PromotionGate.js.map +0 -1
- package/dist/gene-bank/PGAIntegration.d.ts.map +0 -1
- package/dist/gene-bank/PGAIntegration.js.map +0 -1
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
export class DataAccessTracker {
|
|
2
|
+
eventBus;
|
|
3
|
+
records = [];
|
|
4
|
+
maxRecords = 10_000;
|
|
5
|
+
constructor(eventBus) {
|
|
6
|
+
this.eventBus = eventBus;
|
|
7
|
+
}
|
|
8
|
+
record(access) {
|
|
9
|
+
const record = {
|
|
10
|
+
...access,
|
|
11
|
+
timestamp: new Date(),
|
|
12
|
+
};
|
|
13
|
+
this.records.push(record);
|
|
14
|
+
if (this.records.length > this.maxRecords) {
|
|
15
|
+
this.records = this.records.slice(-this.maxRecords);
|
|
16
|
+
}
|
|
17
|
+
this.eventBus.emit({
|
|
18
|
+
type: 'security:audit-entry',
|
|
19
|
+
timestamp: record.timestamp,
|
|
20
|
+
layer: 7,
|
|
21
|
+
decision: 'info',
|
|
22
|
+
actor: { skillId: access.skillId },
|
|
23
|
+
resource: {
|
|
24
|
+
type: `data:${access.source}`,
|
|
25
|
+
id: access.category,
|
|
26
|
+
detail: `${access.itemCount} items${access.sentToCloud ? ` → ${access.cloudProvider ?? 'cloud'}` : ' (local only)'}`,
|
|
27
|
+
},
|
|
28
|
+
severity: access.sentToCloud ? 'warning' : 'info',
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
getReport(from, to) {
|
|
32
|
+
const start = from ?? new Date(0);
|
|
33
|
+
const end = to ?? new Date();
|
|
34
|
+
const filtered = this.records.filter(r => r.timestamp >= start && r.timestamp <= end);
|
|
35
|
+
const bySource = {};
|
|
36
|
+
const byCategory = {};
|
|
37
|
+
const bySkill = {};
|
|
38
|
+
let sentToCloud = 0;
|
|
39
|
+
for (const r of filtered) {
|
|
40
|
+
bySource[r.source] = (bySource[r.source] || 0) + 1;
|
|
41
|
+
byCategory[r.category] = (byCategory[r.category] || 0) + 1;
|
|
42
|
+
bySkill[r.skillId] = (bySkill[r.skillId] || 0) + 1;
|
|
43
|
+
if (r.sentToCloud)
|
|
44
|
+
sentToCloud++;
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
period: { from: start, to: end },
|
|
48
|
+
totalAccesses: filtered.length,
|
|
49
|
+
sentToCloud,
|
|
50
|
+
bySource,
|
|
51
|
+
byCategory,
|
|
52
|
+
bySkill,
|
|
53
|
+
records: filtered,
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
getRecent(limit = 50) {
|
|
57
|
+
return this.records.slice(-limit);
|
|
58
|
+
}
|
|
59
|
+
getCount() {
|
|
60
|
+
return this.records.length;
|
|
61
|
+
}
|
|
62
|
+
wasAccessed(source, since) {
|
|
63
|
+
const start = since ?? new Date(0);
|
|
64
|
+
return this.records.some(r => r.source === source && r.timestamp >= start);
|
|
65
|
+
}
|
|
66
|
+
getCloudExposures(since) {
|
|
67
|
+
const start = since ?? new Date(0);
|
|
68
|
+
return this.records.filter(r => r.sentToCloud && r.timestamp >= start);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=DataAccessTracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataAccessTracker.js","sourceRoot":"","sources":["../../src/security/DataAccessTracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export type DataClassification = 'public' | 'internal' | 'confidential' | 'restricted';
|
|
2
|
+
export interface ClassificationResult {
|
|
3
|
+
classification: DataClassification;
|
|
4
|
+
confidence: number;
|
|
5
|
+
reasons: string[];
|
|
6
|
+
categories: string[];
|
|
7
|
+
}
|
|
8
|
+
export declare class DataClassifier {
|
|
9
|
+
private stats;
|
|
10
|
+
classify(text: string): ClassificationResult;
|
|
11
|
+
isAtLeast(text: string, threshold: DataClassification): boolean;
|
|
12
|
+
getStats(): typeof this.stats;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=DataClassifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataClassifier.d.ts","sourceRoot":"","sources":["../../src/security/DataClassifier.ts"],"names":[],"mappings":"AAaA,MAAM,MAAM,kBAAkB,GAAG,QAAQ,GAAG,UAAU,GAAG,cAAc,GAAG,YAAY,CAAC;AAEvF,MAAM,WAAW,oBAAoB;IACjC,cAAc,EAAE,kBAAkB,CAAC;IACnC,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB;AAqHD,qBAAa,cAAc;IACvB,OAAO,CAAC,KAAK,CAGX;IAKF,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,oBAAoB;IAuD5C,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,kBAAkB,GAAG,OAAO;IAW/D,QAAQ,IAAI,OAAO,IAAI,CAAC,KAAK;CAGhC"}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
const RULES = [
|
|
2
|
+
{
|
|
3
|
+
classification: 'restricted',
|
|
4
|
+
category: 'credentials',
|
|
5
|
+
patterns: [
|
|
6
|
+
/\b(?:sk-[A-Za-z0-9]{20,}|sk-ant-|ghp_|AKIA[A-Z0-9]{16})/,
|
|
7
|
+
/(?:password|passwd|secret)\s*[:=]\s*\S+/i,
|
|
8
|
+
/-----BEGIN (?:RSA |EC |DSA )?PRIVATE KEY-----/,
|
|
9
|
+
/-----BEGIN CERTIFICATE-----/,
|
|
10
|
+
],
|
|
11
|
+
weight: 1.0,
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
classification: 'restricted',
|
|
15
|
+
category: 'financial',
|
|
16
|
+
patterns: [
|
|
17
|
+
/\b(?:\d{4}[-\s]?){3}\d{1,4}\b/,
|
|
18
|
+
/\b[A-Z]{2}\d{2}\s?[A-Z0-9]{4}(?:\s?[A-Z0-9]{4}){2,7}/,
|
|
19
|
+
/\b(?:bank\s*account|routing\s*number|swift\s*code)\b/i,
|
|
20
|
+
/\b(?:social\s*security|SSN)\s*[:=]?\s*\d/i,
|
|
21
|
+
],
|
|
22
|
+
weight: 1.0,
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
classification: 'restricted',
|
|
26
|
+
category: 'health',
|
|
27
|
+
patterns: [
|
|
28
|
+
/\b(?:diagnosis|prescription|patient\s*id|medical\s*record|health\s*insurance)\b/i,
|
|
29
|
+
/\b(?:ICD-\d{1,2}|CPT\s*code|NPI\s*number)\b/i,
|
|
30
|
+
/\b(?:blood\s*type|allergy|medication|dosage)\b/i,
|
|
31
|
+
],
|
|
32
|
+
weight: 0.9,
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
classification: 'confidential',
|
|
36
|
+
category: 'personal-identity',
|
|
37
|
+
patterns: [
|
|
38
|
+
/\b\d{3}-\d{2}-\d{4}\b/,
|
|
39
|
+
/\b(?:passport\s*(?:number|no|#))\b/i,
|
|
40
|
+
/\b(?:driver'?s?\s*license|DL\s*#)\b/i,
|
|
41
|
+
/\b(?:date\s*of\s*birth|DOB)\s*[:=]?\s*\d/i,
|
|
42
|
+
],
|
|
43
|
+
weight: 0.8,
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
classification: 'confidential',
|
|
47
|
+
category: 'contact-info',
|
|
48
|
+
patterns: [
|
|
49
|
+
/\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}\b/,
|
|
50
|
+
/\+\d{1,3}[-.\s]?\(?\d{2,4}\)?[-.\s]?\d{3,4}[-.\s]?\d{3,4}/,
|
|
51
|
+
/\b\d{1,5}\s+[A-Za-z]+\s+(?:St|Ave|Blvd|Dr|Rd|Ln|Way|Ct)\b/i,
|
|
52
|
+
],
|
|
53
|
+
weight: 0.7,
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
classification: 'confidential',
|
|
57
|
+
category: 'legal',
|
|
58
|
+
patterns: [
|
|
59
|
+
/\b(?:attorney[- ]client|privileged|confidential\s*(?:and|&)\s*proprietary)\b/i,
|
|
60
|
+
/\b(?:NDA|non-disclosure|trade\s*secret|patent\s*pending)\b/i,
|
|
61
|
+
/\b(?:settlement|litigation|court\s*order|subpoena)\b/i,
|
|
62
|
+
],
|
|
63
|
+
weight: 0.7,
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
classification: 'internal',
|
|
67
|
+
category: 'business',
|
|
68
|
+
patterns: [
|
|
69
|
+
/\b(?:revenue|profit|loss|budget|forecast|Q[1-4]\s*\d{4})\b/i,
|
|
70
|
+
/\b(?:employee\s*id|salary|compensation|performance\s*review)\b/i,
|
|
71
|
+
/\b(?:customer\s*list|vendor\s*contract|pricing\s*sheet)\b/i,
|
|
72
|
+
/\b(?:roadmap|strategy|competitive\s*analysis)\b/i,
|
|
73
|
+
],
|
|
74
|
+
weight: 0.5,
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
classification: 'internal',
|
|
78
|
+
category: 'infrastructure',
|
|
79
|
+
patterns: [
|
|
80
|
+
/\b(?:192\.168\.\d+\.\d+|10\.\d+\.\d+\.\d+|172\.(?:1[6-9]|2\d|3[01])\.\d+\.\d+)/,
|
|
81
|
+
/\b(?:localhost|127\.0\.0\.1):\d{4,5}\b/,
|
|
82
|
+
/\b(?:database\s*(?:url|host|connection)|redis:|mongodb:)/i,
|
|
83
|
+
/\b(?:AWS_|AZURE_|GCP_|GOOGLE_CLOUD_)\w+/,
|
|
84
|
+
],
|
|
85
|
+
weight: 0.4,
|
|
86
|
+
},
|
|
87
|
+
];
|
|
88
|
+
export class DataClassifier {
|
|
89
|
+
stats = {
|
|
90
|
+
totalClassified: 0,
|
|
91
|
+
byClassification: {},
|
|
92
|
+
};
|
|
93
|
+
classify(text) {
|
|
94
|
+
this.stats.totalClassified++;
|
|
95
|
+
let highestClassification = 'public';
|
|
96
|
+
let highestWeight = 0;
|
|
97
|
+
const reasons = [];
|
|
98
|
+
const categories = [];
|
|
99
|
+
const classOrder = {
|
|
100
|
+
public: 0,
|
|
101
|
+
internal: 1,
|
|
102
|
+
confidential: 2,
|
|
103
|
+
restricted: 3,
|
|
104
|
+
};
|
|
105
|
+
for (const rule of RULES) {
|
|
106
|
+
for (const pattern of rule.patterns) {
|
|
107
|
+
pattern.lastIndex = 0;
|
|
108
|
+
if (pattern.test(text)) {
|
|
109
|
+
if (classOrder[rule.classification] > classOrder[highestClassification]) {
|
|
110
|
+
highestClassification = rule.classification;
|
|
111
|
+
highestWeight = rule.weight;
|
|
112
|
+
}
|
|
113
|
+
else if (classOrder[rule.classification] === classOrder[highestClassification] &&
|
|
114
|
+
rule.weight > highestWeight) {
|
|
115
|
+
highestWeight = rule.weight;
|
|
116
|
+
}
|
|
117
|
+
if (!categories.includes(rule.category)) {
|
|
118
|
+
categories.push(rule.category);
|
|
119
|
+
reasons.push(`${rule.category}: matches ${rule.classification} pattern`);
|
|
120
|
+
}
|
|
121
|
+
break;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const confidence = categories.length === 0 ? 1.0 : Math.min(highestWeight + categories.length * 0.1, 1.0);
|
|
126
|
+
this.stats.byClassification[highestClassification] =
|
|
127
|
+
(this.stats.byClassification[highestClassification] || 0) + 1;
|
|
128
|
+
return {
|
|
129
|
+
classification: highestClassification,
|
|
130
|
+
confidence,
|
|
131
|
+
reasons,
|
|
132
|
+
categories,
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
isAtLeast(text, threshold) {
|
|
136
|
+
const order = {
|
|
137
|
+
public: 0, internal: 1, confidential: 2, restricted: 3,
|
|
138
|
+
};
|
|
139
|
+
const result = this.classify(text);
|
|
140
|
+
return order[result.classification] >= order[threshold];
|
|
141
|
+
}
|
|
142
|
+
getStats() {
|
|
143
|
+
return { ...this.stats };
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
//# sourceMappingURL=DataClassifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataClassifier.js","sourceRoot":"","sources":["../../src/security/DataClassifier.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare class EncryptedConfigStore {
|
|
2
|
+
private key;
|
|
3
|
+
private filePath;
|
|
4
|
+
private data;
|
|
5
|
+
private loaded;
|
|
6
|
+
constructor(encryptionKey: Buffer, storePath?: string);
|
|
7
|
+
load(): Promise<void>;
|
|
8
|
+
get(key: string): string | undefined;
|
|
9
|
+
set(key: string, value: string): Promise<void>;
|
|
10
|
+
delete(key: string): Promise<boolean>;
|
|
11
|
+
has(key: string): boolean;
|
|
12
|
+
keys(): string[];
|
|
13
|
+
size(): number;
|
|
14
|
+
import(entries: Record<string, string>): Promise<number>;
|
|
15
|
+
exportAll(): Record<string, string>;
|
|
16
|
+
private save;
|
|
17
|
+
private encrypt;
|
|
18
|
+
private decrypt;
|
|
19
|
+
private ensureLoaded;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=EncryptedConfigStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EncryptedConfigStore.d.ts","sourceRoot":"","sources":["../../src/security/EncryptedConfigStore.ts"],"names":[],"mappings":"AAuCA,qBAAa,oBAAoB;IAC7B,OAAO,CAAC,GAAG,CAAS;IACpB,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,IAAI,CAA0C;IACtD,OAAO,CAAC,MAAM,CAAS;gBAEX,aAAa,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM;IAW/C,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAkB3B,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAQ9B,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS9C,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAW3C,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAQzB,IAAI,IAAI,MAAM,EAAE;IAQhB,IAAI,IAAI,MAAM;IAQR,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAgB9D,SAAS,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;YAOrB,IAAI;IAUlB,OAAO,CAAC,OAAO;IAYf,OAAO,CAAC,OAAO;IAsBf,OAAO,CAAC,YAAY;CAKvB"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { createCipheriv, createDecipheriv, randomBytes } from 'node:crypto';
|
|
2
|
+
import { readFile, writeFile, rename, mkdir } from 'node:fs/promises';
|
|
3
|
+
import { dirname, join } from 'node:path';
|
|
4
|
+
import { homedir } from 'node:os';
|
|
5
|
+
const ALGORITHM = 'aes-256-gcm';
|
|
6
|
+
const IV_BYTES = 12;
|
|
7
|
+
const AUTH_TAG_BYTES = 16;
|
|
8
|
+
const STORE_DIR = join(homedir(), '.genome');
|
|
9
|
+
const STORE_FILE = 'config.enc';
|
|
10
|
+
export class EncryptedConfigStore {
|
|
11
|
+
key;
|
|
12
|
+
filePath;
|
|
13
|
+
data = { version: 1, entries: {} };
|
|
14
|
+
loaded = false;
|
|
15
|
+
constructor(encryptionKey, storePath) {
|
|
16
|
+
if (encryptionKey.length !== 32) {
|
|
17
|
+
throw new Error('[EncryptedConfigStore] Key must be 32 bytes (256 bits).');
|
|
18
|
+
}
|
|
19
|
+
this.key = encryptionKey;
|
|
20
|
+
this.filePath = storePath ?? join(STORE_DIR, STORE_FILE);
|
|
21
|
+
}
|
|
22
|
+
async load() {
|
|
23
|
+
try {
|
|
24
|
+
const raw = await readFile(this.filePath);
|
|
25
|
+
this.data = this.decrypt(raw);
|
|
26
|
+
}
|
|
27
|
+
catch (err) {
|
|
28
|
+
if (err.code === 'ENOENT') {
|
|
29
|
+
this.data = { version: 1, entries: {} };
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
throw new Error(`[EncryptedConfigStore] Failed to load: ${err.message}`);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
this.loaded = true;
|
|
36
|
+
}
|
|
37
|
+
get(key) {
|
|
38
|
+
this.ensureLoaded();
|
|
39
|
+
return this.data.entries[key];
|
|
40
|
+
}
|
|
41
|
+
async set(key, value) {
|
|
42
|
+
this.ensureLoaded();
|
|
43
|
+
this.data.entries[key] = value;
|
|
44
|
+
await this.save();
|
|
45
|
+
}
|
|
46
|
+
async delete(key) {
|
|
47
|
+
this.ensureLoaded();
|
|
48
|
+
if (!(key in this.data.entries))
|
|
49
|
+
return false;
|
|
50
|
+
delete this.data.entries[key];
|
|
51
|
+
await this.save();
|
|
52
|
+
return true;
|
|
53
|
+
}
|
|
54
|
+
has(key) {
|
|
55
|
+
this.ensureLoaded();
|
|
56
|
+
return key in this.data.entries;
|
|
57
|
+
}
|
|
58
|
+
keys() {
|
|
59
|
+
this.ensureLoaded();
|
|
60
|
+
return Object.keys(this.data.entries).sort();
|
|
61
|
+
}
|
|
62
|
+
size() {
|
|
63
|
+
this.ensureLoaded();
|
|
64
|
+
return Object.keys(this.data.entries).length;
|
|
65
|
+
}
|
|
66
|
+
async import(entries) {
|
|
67
|
+
this.ensureLoaded();
|
|
68
|
+
let count = 0;
|
|
69
|
+
for (const [key, value] of Object.entries(entries)) {
|
|
70
|
+
if (value !== undefined && value !== '') {
|
|
71
|
+
this.data.entries[key] = value;
|
|
72
|
+
count++;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
await this.save();
|
|
76
|
+
return count;
|
|
77
|
+
}
|
|
78
|
+
exportAll() {
|
|
79
|
+
this.ensureLoaded();
|
|
80
|
+
return { ...this.data.entries };
|
|
81
|
+
}
|
|
82
|
+
async save() {
|
|
83
|
+
const encrypted = this.encrypt(this.data);
|
|
84
|
+
await mkdir(dirname(this.filePath), { recursive: true });
|
|
85
|
+
const tmpPath = `${this.filePath}.tmp.${Date.now()}`;
|
|
86
|
+
await writeFile(tmpPath, encrypted, { mode: 0o600 });
|
|
87
|
+
await rename(tmpPath, this.filePath);
|
|
88
|
+
}
|
|
89
|
+
encrypt(data) {
|
|
90
|
+
const iv = randomBytes(IV_BYTES);
|
|
91
|
+
const plaintext = Buffer.from(JSON.stringify(data), 'utf-8');
|
|
92
|
+
const cipher = createCipheriv(ALGORITHM, this.key, iv);
|
|
93
|
+
const encrypted = Buffer.concat([cipher.update(plaintext), cipher.final()]);
|
|
94
|
+
const authTag = cipher.getAuthTag();
|
|
95
|
+
return Buffer.concat([iv, authTag, encrypted]);
|
|
96
|
+
}
|
|
97
|
+
decrypt(raw) {
|
|
98
|
+
if (raw.length < IV_BYTES + AUTH_TAG_BYTES + 1) {
|
|
99
|
+
throw new Error('[EncryptedConfigStore] Corrupted file — too short.');
|
|
100
|
+
}
|
|
101
|
+
const iv = raw.subarray(0, IV_BYTES);
|
|
102
|
+
const authTag = raw.subarray(IV_BYTES, IV_BYTES + AUTH_TAG_BYTES);
|
|
103
|
+
const ciphertext = raw.subarray(IV_BYTES + AUTH_TAG_BYTES);
|
|
104
|
+
const decipher = createDecipheriv(ALGORITHM, this.key, iv);
|
|
105
|
+
decipher.setAuthTag(authTag);
|
|
106
|
+
const decrypted = Buffer.concat([decipher.update(ciphertext), decipher.final()]);
|
|
107
|
+
const parsed = JSON.parse(decrypted.toString('utf-8'));
|
|
108
|
+
if (parsed.version !== 1 || typeof parsed.entries !== 'object') {
|
|
109
|
+
throw new Error('[EncryptedConfigStore] Invalid store format.');
|
|
110
|
+
}
|
|
111
|
+
return parsed;
|
|
112
|
+
}
|
|
113
|
+
ensureLoaded() {
|
|
114
|
+
if (!this.loaded) {
|
|
115
|
+
throw new Error('[EncryptedConfigStore] Not loaded. Call load() first.');
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=EncryptedConfigStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EncryptedConfigStore.js","sourceRoot":"","sources":["../../src/security/EncryptedConfigStore.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { SecurityEventBus } from './SecurityEventBus.js';
|
|
2
|
+
export interface EnterprisePolicy {
|
|
3
|
+
version: string;
|
|
4
|
+
organization: string;
|
|
5
|
+
effectiveDate: string;
|
|
6
|
+
signature?: string;
|
|
7
|
+
globalSettings: {
|
|
8
|
+
securityLevel: 'paranoid' | 'secure' | 'standard';
|
|
9
|
+
mfaRequired: boolean;
|
|
10
|
+
sessionTimeoutMinutes: number;
|
|
11
|
+
maxConcurrentSessions: number;
|
|
12
|
+
auditRetentionDays: number;
|
|
13
|
+
encryptionRequired: boolean;
|
|
14
|
+
};
|
|
15
|
+
roles: Record<string, RolePolicy>;
|
|
16
|
+
compliance: {
|
|
17
|
+
gdpr: {
|
|
18
|
+
enabled: boolean;
|
|
19
|
+
dataRetentionDays: number;
|
|
20
|
+
consentRequired: boolean;
|
|
21
|
+
};
|
|
22
|
+
soc2: {
|
|
23
|
+
enabled: boolean;
|
|
24
|
+
accessReviewIntervalDays: number;
|
|
25
|
+
};
|
|
26
|
+
hipaa: {
|
|
27
|
+
enabled: boolean;
|
|
28
|
+
phiEncryptionRequired: boolean;
|
|
29
|
+
minimumNecessaryRule: boolean;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
alerts: AlertRule[];
|
|
33
|
+
}
|
|
34
|
+
export interface RolePolicy {
|
|
35
|
+
inherits?: string;
|
|
36
|
+
skills: {
|
|
37
|
+
allowed: string[];
|
|
38
|
+
denied: string[];
|
|
39
|
+
};
|
|
40
|
+
execution: {
|
|
41
|
+
securityLevel: string;
|
|
42
|
+
maxCommandsPerHour: number;
|
|
43
|
+
requireApprovalFor: string[];
|
|
44
|
+
};
|
|
45
|
+
dataAccess: {
|
|
46
|
+
classifications: string[];
|
|
47
|
+
piiAccess: boolean;
|
|
48
|
+
};
|
|
49
|
+
network: {
|
|
50
|
+
allowedDomains: string[];
|
|
51
|
+
deniedDomains: string[];
|
|
52
|
+
};
|
|
53
|
+
filesystem: {
|
|
54
|
+
allowedPaths: string[];
|
|
55
|
+
deniedPaths: string[];
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
export interface AlertRule {
|
|
59
|
+
type: string;
|
|
60
|
+
threshold: number;
|
|
61
|
+
windowMinutes: number;
|
|
62
|
+
action: 'alert_admin' | 'lock_account' | 'disable_skill' | 'log_only';
|
|
63
|
+
}
|
|
64
|
+
export interface PolicyValidationResult {
|
|
65
|
+
valid: boolean;
|
|
66
|
+
errors: string[];
|
|
67
|
+
warnings: string[];
|
|
68
|
+
}
|
|
69
|
+
export declare class EnterprisePolicyEngine {
|
|
70
|
+
private eventBus;
|
|
71
|
+
private policy;
|
|
72
|
+
private alertCounters;
|
|
73
|
+
constructor(eventBus: SecurityEventBus, policy?: EnterprisePolicy);
|
|
74
|
+
loadFromFile(filePath: string): Promise<PolicyValidationResult>;
|
|
75
|
+
setPolicy(policy: EnterprisePolicy): PolicyValidationResult;
|
|
76
|
+
getPolicy(): EnterprisePolicy;
|
|
77
|
+
getRolePolicy(roleName: string): RolePolicy | null;
|
|
78
|
+
isSkillAllowed(roleName: string, skillName: string): boolean;
|
|
79
|
+
isDomainAllowed(roleName: string, domain: string): boolean;
|
|
80
|
+
isPathAllowed(roleName: string, path: string): boolean;
|
|
81
|
+
getGlobalSettings(): EnterprisePolicy['globalSettings'];
|
|
82
|
+
getCompliance(): EnterprisePolicy['compliance'];
|
|
83
|
+
validate(policy: EnterprisePolicy): PolicyValidationResult;
|
|
84
|
+
signPolicy(signingKey: string): string;
|
|
85
|
+
private mergeRolePolicies;
|
|
86
|
+
private matchDomain;
|
|
87
|
+
private matchPath;
|
|
88
|
+
private checkAlertRules;
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=EnterprisePolicyEngine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EnterprisePolicyEngine.d.ts","sourceRoot":"","sources":["../../src/security/EnterprisePolicyEngine.ts"],"names":[],"mappings":"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"}
|