@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.
Files changed (344) hide show
  1. package/README.md +12 -12
  2. package/dist/{PGA.d.ts → GSEP.d.ts} +120 -8
  3. package/dist/GSEP.d.ts.map +1 -0
  4. package/dist/{PGA.js → GSEP.js} +1248 -46
  5. package/dist/GSEP.js.map +1 -0
  6. package/dist/adapters/langchain.d.ts +52 -0
  7. package/dist/adapters/langchain.d.ts.map +1 -0
  8. package/dist/adapters/langchain.js +89 -0
  9. package/dist/adapters/langchain.js.map +1 -0
  10. package/dist/adapters/openclaw-plugin.d.ts +42 -0
  11. package/dist/adapters/openclaw-plugin.d.ts.map +1 -0
  12. package/dist/adapters/openclaw-plugin.js +149 -0
  13. package/dist/adapters/openclaw-plugin.js.map +1 -0
  14. package/dist/adapters/vercel-ai.d.ts +74 -0
  15. package/dist/adapters/vercel-ai.d.ts.map +1 -0
  16. package/dist/adapters/vercel-ai.js +151 -0
  17. package/dist/adapters/vercel-ai.js.map +1 -0
  18. package/dist/advanced-ai/EnhancedSelfModel.js +2 -2
  19. package/dist/advanced-ai/EnhancedSelfModel.js.map +1 -1
  20. package/dist/advanced-ai/ModelRouter.js.map +1 -1
  21. package/dist/auto.d.ts +6 -0
  22. package/dist/auto.d.ts.map +1 -0
  23. package/dist/auto.js +197 -0
  24. package/dist/auto.js.map +1 -0
  25. package/dist/core/CoherenceValidator.d.ts +25 -0
  26. package/dist/core/CoherenceValidator.d.ts.map +1 -0
  27. package/dist/core/CoherenceValidator.js +182 -0
  28. package/dist/core/CoherenceValidator.js.map +1 -0
  29. package/dist/core/ContextMemory.d.ts.map +1 -1
  30. package/dist/core/ContextMemory.js +1 -1
  31. package/dist/core/ContextMemory.js.map +1 -1
  32. package/dist/core/DNAProfile.d.ts +5 -1
  33. package/dist/core/DNAProfile.d.ts.map +1 -1
  34. package/dist/core/DNAProfile.js +14 -1
  35. package/dist/core/DNAProfile.js.map +1 -1
  36. package/dist/core/GSEPIdentitySection.d.ts.map +1 -1
  37. package/dist/core/GSEPIdentitySection.js +12 -3
  38. package/dist/core/GSEPIdentitySection.js.map +1 -1
  39. package/dist/core/GenomeKernel.d.ts.map +1 -1
  40. package/dist/core/GenomeKernel.js +3 -0
  41. package/dist/core/GenomeKernel.js.map +1 -1
  42. package/dist/core/GenomeManager.js +1 -1
  43. package/dist/core/GenomeManager.js.map +1 -1
  44. package/dist/core/ProactiveSuggestions.js +1 -1
  45. package/dist/core/ProactiveSuggestions.js.map +1 -1
  46. package/dist/dashboard/DashboardServer.d.ts +64 -0
  47. package/dist/dashboard/DashboardServer.d.ts.map +1 -0
  48. package/dist/dashboard/DashboardServer.js +409 -0
  49. package/dist/dashboard/DashboardServer.js.map +1 -0
  50. package/dist/dashboard/DashboardToken.d.ts +16 -0
  51. package/dist/dashboard/DashboardToken.d.ts.map +1 -0
  52. package/dist/dashboard/DashboardToken.js +54 -0
  53. package/dist/dashboard/DashboardToken.js.map +1 -0
  54. package/dist/dashboard/dashboard.html +2731 -0
  55. package/dist/dashboard/index.d.ts +3 -0
  56. package/dist/dashboard/index.d.ts.map +1 -0
  57. package/dist/dashboard/index.js +3 -0
  58. package/dist/dashboard/index.js.map +1 -0
  59. package/dist/evaluation/BenchmarkSuites.d.ts +2 -2
  60. package/dist/evaluation/BenchmarkSuites.d.ts.map +1 -1
  61. package/dist/evaluation/BenchmarkSuites.js +6 -6
  62. package/dist/evaluation/BenchmarkSuites.js.map +1 -1
  63. package/dist/evaluation/ConstitutionalGate.d.ts +18 -0
  64. package/dist/evaluation/ConstitutionalGate.d.ts.map +1 -0
  65. package/dist/evaluation/ConstitutionalGate.js +149 -0
  66. package/dist/evaluation/ConstitutionalGate.js.map +1 -0
  67. package/dist/evaluation/Evaluator.d.ts +4 -4
  68. package/dist/evaluation/Evaluator.d.ts.map +1 -1
  69. package/dist/evaluation/Evaluator.js +27 -27
  70. package/dist/evaluation/Evaluator.js.map +1 -1
  71. package/dist/evaluation/EvolutionGuardrails.d.ts +3 -1
  72. package/dist/evaluation/EvolutionGuardrails.d.ts.map +1 -1
  73. package/dist/evaluation/EvolutionGuardrails.js +29 -11
  74. package/dist/evaluation/EvolutionGuardrails.js.map +1 -1
  75. package/dist/evolution/MutationOperator.d.ts +19 -6
  76. package/dist/evolution/MutationOperator.d.ts.map +1 -1
  77. package/dist/evolution/MutationOperator.js +264 -9
  78. package/dist/evolution/MutationOperator.js.map +1 -1
  79. package/dist/evolution/boost/operators/BreakthroughOperator.d.ts +1 -1
  80. package/dist/evolution/boost/operators/BreakthroughOperator.d.ts.map +1 -1
  81. package/dist/evolution/boost/operators/BreakthroughOperator.js.map +1 -1
  82. package/dist/evolution/boost/operators/CrossoverMutationOperator.d.ts +1 -1
  83. package/dist/evolution/boost/operators/CrossoverMutationOperator.d.ts.map +1 -1
  84. package/dist/evolution/boost/operators/CrossoverMutationOperator.js.map +1 -1
  85. package/dist/evolution/boost/operators/PatternExtractionOperator.d.ts +1 -1
  86. package/dist/evolution/boost/operators/PatternExtractionOperator.d.ts.map +1 -1
  87. package/dist/evolution/boost/operators/PatternExtractionOperator.js.map +1 -1
  88. package/dist/evolution/boost/operators/SemanticRestructuringOperator.d.ts +1 -1
  89. package/dist/evolution/boost/operators/SemanticRestructuringOperator.d.ts.map +1 -1
  90. package/dist/evolution/boost/operators/SemanticRestructuringOperator.js.map +1 -1
  91. package/dist/firewall/AnomalyDetector.d.ts +42 -0
  92. package/dist/firewall/AnomalyDetector.d.ts.map +1 -0
  93. package/dist/firewall/AnomalyDetector.js +181 -0
  94. package/dist/firewall/AnomalyDetector.js.map +1 -0
  95. package/dist/firewall/ContentFirewall.d.ts +5 -0
  96. package/dist/firewall/ContentFirewall.d.ts.map +1 -1
  97. package/dist/firewall/ContentFirewall.js +5 -0
  98. package/dist/firewall/ContentFirewall.js.map +1 -1
  99. package/dist/firewall/PurposeLock.d.ts +41 -0
  100. package/dist/firewall/PurposeLock.d.ts.map +1 -0
  101. package/dist/firewall/PurposeLock.js +199 -0
  102. package/dist/firewall/PurposeLock.js.map +1 -0
  103. package/dist/gene-bank/CognitiveGene.d.ts +118 -118
  104. package/dist/gene-bank/{PGAIntegration.d.ts → GSEPIntegration.d.ts} +10 -10
  105. package/dist/gene-bank/GSEPIntegration.d.ts.map +1 -0
  106. package/dist/gene-bank/{PGAIntegration.js → GSEPIntegration.js} +6 -6
  107. package/dist/gene-bank/GSEPIntegration.js.map +1 -0
  108. package/dist/gene-bank/GeneAdopter.d.ts +6 -6
  109. package/dist/gene-bank/GeneAdopter.d.ts.map +1 -1
  110. package/dist/gene-bank/GeneAdopter.js +2 -2
  111. package/dist/gene-bank/GeneAdopter.js.map +1 -1
  112. package/dist/gene-bank/GeneBank.d.ts +13 -9
  113. package/dist/gene-bank/GeneBank.d.ts.map +1 -1
  114. package/dist/gene-bank/GeneBank.js +8 -1
  115. package/dist/gene-bank/GeneBank.js.map +1 -1
  116. package/dist/gene-bank/GeneExtractor.d.ts +7 -7
  117. package/dist/gene-bank/GeneExtractor.d.ts.map +1 -1
  118. package/dist/gene-bank/GeneExtractor.js +1 -1
  119. package/dist/gene-bank/GeneExtractor.js.map +1 -1
  120. package/dist/gene-bank/GeneMatcher.d.ts +1 -1
  121. package/dist/gene-bank/GeneMatcher.d.ts.map +1 -1
  122. package/dist/gene-bank/MarketplaceClient.d.ts +17 -1
  123. package/dist/gene-bank/MarketplaceClient.d.ts.map +1 -1
  124. package/dist/gene-bank/MarketplaceClient.js +106 -35
  125. package/dist/gene-bank/MarketplaceClient.js.map +1 -1
  126. package/dist/gene-bank/MarketplaceMapper.d.ts +7 -0
  127. package/dist/gene-bank/MarketplaceMapper.d.ts.map +1 -0
  128. package/dist/gene-bank/MarketplaceMapper.js +95 -0
  129. package/dist/gene-bank/MarketplaceMapper.js.map +1 -0
  130. package/dist/gene-bank/MarketplaceTypes.d.ts +121 -0
  131. package/dist/gene-bank/MarketplaceTypes.d.ts.map +1 -0
  132. package/dist/gene-bank/MarketplaceTypes.js +2 -0
  133. package/dist/gene-bank/MarketplaceTypes.js.map +1 -0
  134. package/dist/gene-bank/SandboxTester.d.ts +3 -3
  135. package/dist/gene-bank/SandboxTester.d.ts.map +1 -1
  136. package/dist/gene-bank/adapters/InMemoryGeneStorage.d.ts +3 -3
  137. package/dist/gene-bank/adapters/InMemoryGeneStorage.d.ts.map +1 -1
  138. package/dist/gene-bank/adapters/PostgresGeneStorage.d.ts +4 -4
  139. package/dist/gene-bank/adapters/PostgresGeneStorage.d.ts.map +1 -1
  140. package/dist/gene-bank/adapters/PostgresGeneStorage.js.map +1 -1
  141. package/dist/gene-bank/adapters/SQLiteGeneStorage.d.ts +28 -0
  142. package/dist/gene-bank/adapters/SQLiteGeneStorage.d.ts.map +1 -0
  143. package/dist/gene-bank/adapters/SQLiteGeneStorage.js +158 -0
  144. package/dist/gene-bank/adapters/SQLiteGeneStorage.js.map +1 -0
  145. package/dist/gene-bank/index.d.ts +10 -7
  146. package/dist/gene-bank/index.d.ts.map +1 -1
  147. package/dist/gene-bank/index.js +8 -7
  148. package/dist/gene-bank/index.js.map +1 -1
  149. package/dist/immune/BehavioralImmuneSystem.d.ts +6 -0
  150. package/dist/immune/BehavioralImmuneSystem.d.ts.map +1 -1
  151. package/dist/immune/BehavioralImmuneSystem.js +6 -0
  152. package/dist/immune/BehavioralImmuneSystem.js.map +1 -1
  153. package/dist/index.d.ts +44 -9
  154. package/dist/index.d.ts.map +1 -1
  155. package/dist/index.js +22 -4
  156. package/dist/index.js.map +1 -1
  157. package/dist/memory/LayeredMemory.d.ts +1 -1
  158. package/dist/memory/LayeredMemory.d.ts.map +1 -1
  159. package/dist/memory/LayeredMemory.js.map +1 -1
  160. package/dist/middleware/GSEPMiddleware.d.ts +57 -0
  161. package/dist/middleware/GSEPMiddleware.d.ts.map +1 -0
  162. package/dist/middleware/GSEPMiddleware.js +91 -0
  163. package/dist/middleware/GSEPMiddleware.js.map +1 -0
  164. package/dist/middleware/RuntimeDetector.d.ts +10 -0
  165. package/dist/middleware/RuntimeDetector.d.ts.map +1 -0
  166. package/dist/middleware/RuntimeDetector.js +70 -0
  167. package/dist/middleware/RuntimeDetector.js.map +1 -0
  168. package/dist/middleware/ServerlessAdapter.d.ts +23 -0
  169. package/dist/middleware/ServerlessAdapter.d.ts.map +1 -0
  170. package/dist/middleware/ServerlessAdapter.js +77 -0
  171. package/dist/middleware/ServerlessAdapter.js.map +1 -0
  172. package/dist/monitoring/AlertWebhooks.d.ts +17 -0
  173. package/dist/monitoring/AlertWebhooks.d.ts.map +1 -1
  174. package/dist/monitoring/AlertWebhooks.js.map +1 -1
  175. package/dist/monitoring/WeeklyReportGenerator.d.ts +73 -0
  176. package/dist/monitoring/WeeklyReportGenerator.d.ts.map +1 -0
  177. package/dist/monitoring/WeeklyReportGenerator.js +148 -0
  178. package/dist/monitoring/WeeklyReportGenerator.js.map +1 -0
  179. package/dist/rag/RAGEngine.d.ts +1 -1
  180. package/dist/rag/RAGEngine.d.ts.map +1 -1
  181. package/dist/rag/VectorStoreAdapter.d.ts +2 -2
  182. package/dist/rag/VectorStoreAdapter.d.ts.map +1 -1
  183. package/dist/rag/VectorStoreAdapter.js.map +1 -1
  184. package/dist/realtime/EventEmitter.d.ts +110 -17
  185. package/dist/realtime/EventEmitter.d.ts.map +1 -1
  186. package/dist/realtime/EventEmitter.js +3 -4
  187. package/dist/realtime/EventEmitter.js.map +1 -1
  188. package/dist/security/CapabilityBroker.d.ts +41 -0
  189. package/dist/security/CapabilityBroker.d.ts.map +1 -0
  190. package/dist/security/CapabilityBroker.js +125 -0
  191. package/dist/security/CapabilityBroker.js.map +1 -0
  192. package/dist/security/CommandExecutionGuard.d.ts +47 -0
  193. package/dist/security/CommandExecutionGuard.d.ts.map +1 -0
  194. package/dist/security/CommandExecutionGuard.js +175 -0
  195. package/dist/security/CommandExecutionGuard.js.map +1 -0
  196. package/dist/security/ComplianceExporter.d.ts +32 -0
  197. package/dist/security/ComplianceExporter.d.ts.map +1 -0
  198. package/dist/security/ComplianceExporter.js +129 -0
  199. package/dist/security/ComplianceExporter.js.map +1 -0
  200. package/dist/security/DataAccessTracker.d.ts +38 -0
  201. package/dist/security/DataAccessTracker.d.ts.map +1 -0
  202. package/dist/security/DataAccessTracker.js +71 -0
  203. package/dist/security/DataAccessTracker.js.map +1 -0
  204. package/dist/security/DataClassifier.d.ts +14 -0
  205. package/dist/security/DataClassifier.d.ts.map +1 -0
  206. package/dist/security/DataClassifier.js +146 -0
  207. package/dist/security/DataClassifier.js.map +1 -0
  208. package/dist/security/EncryptedConfigStore.d.ts +21 -0
  209. package/dist/security/EncryptedConfigStore.d.ts.map +1 -0
  210. package/dist/security/EncryptedConfigStore.js +119 -0
  211. package/dist/security/EncryptedConfigStore.js.map +1 -0
  212. package/dist/security/EnterprisePolicyEngine.d.ts +90 -0
  213. package/dist/security/EnterprisePolicyEngine.d.ts.map +1 -0
  214. package/dist/security/EnterprisePolicyEngine.js +240 -0
  215. package/dist/security/EnterprisePolicyEngine.js.map +1 -0
  216. package/dist/security/FileSystemBoundary.d.ts +33 -0
  217. package/dist/security/FileSystemBoundary.d.ts.map +1 -0
  218. package/dist/security/FileSystemBoundary.js +94 -0
  219. package/dist/security/FileSystemBoundary.js.map +1 -0
  220. package/dist/security/GDPREngine.d.ts +65 -0
  221. package/dist/security/GDPREngine.d.ts.map +1 -0
  222. package/dist/security/GDPREngine.js +180 -0
  223. package/dist/security/GDPREngine.js.map +1 -0
  224. package/dist/security/GenomeSecurityBridge.d.ts +47 -0
  225. package/dist/security/GenomeSecurityBridge.d.ts.map +1 -0
  226. package/dist/security/GenomeSecurityBridge.js +157 -0
  227. package/dist/security/GenomeSecurityBridge.js.map +1 -0
  228. package/dist/security/KeyHierarchy.d.ts +23 -0
  229. package/dist/security/KeyHierarchy.d.ts.map +1 -0
  230. package/dist/security/KeyHierarchy.js +78 -0
  231. package/dist/security/KeyHierarchy.js.map +1 -0
  232. package/dist/security/KeychainAdapter.d.ts +19 -0
  233. package/dist/security/KeychainAdapter.d.ts.map +1 -0
  234. package/dist/security/KeychainAdapter.js +104 -0
  235. package/dist/security/KeychainAdapter.js.map +1 -0
  236. package/dist/security/LLMProxyLayer.d.ts +63 -0
  237. package/dist/security/LLMProxyLayer.d.ts.map +1 -0
  238. package/dist/security/LLMProxyLayer.js +148 -0
  239. package/dist/security/LLMProxyLayer.js.map +1 -0
  240. package/dist/security/MFAProvider.d.ts +35 -0
  241. package/dist/security/MFAProvider.d.ts.map +1 -0
  242. package/dist/security/MFAProvider.js +174 -0
  243. package/dist/security/MFAProvider.js.map +1 -0
  244. package/dist/security/NetworkAuditLogger.d.ts +35 -0
  245. package/dist/security/NetworkAuditLogger.d.ts.map +1 -0
  246. package/dist/security/NetworkAuditLogger.js +99 -0
  247. package/dist/security/NetworkAuditLogger.js.map +1 -0
  248. package/dist/security/OutboundAllowlist.d.ts +33 -0
  249. package/dist/security/OutboundAllowlist.d.ts.map +1 -0
  250. package/dist/security/OutboundAllowlist.js +112 -0
  251. package/dist/security/OutboundAllowlist.js.map +1 -0
  252. package/dist/security/PIIRedactionEngine.d.ts +40 -0
  253. package/dist/security/PIIRedactionEngine.d.ts.map +1 -0
  254. package/dist/security/PIIRedactionEngine.js +232 -0
  255. package/dist/security/PIIRedactionEngine.js.map +1 -0
  256. package/dist/security/RBACEngine.d.ts +44 -0
  257. package/dist/security/RBACEngine.d.ts.map +1 -0
  258. package/dist/security/RBACEngine.js +209 -0
  259. package/dist/security/RBACEngine.js.map +1 -0
  260. package/dist/security/SOC2Controls.d.ts +37 -0
  261. package/dist/security/SOC2Controls.d.ts.map +1 -0
  262. package/dist/security/SOC2Controls.js +151 -0
  263. package/dist/security/SOC2Controls.js.map +1 -0
  264. package/dist/security/SecretRotationEngine.d.ts +46 -0
  265. package/dist/security/SecretRotationEngine.d.ts.map +1 -0
  266. package/dist/security/SecretRotationEngine.js +102 -0
  267. package/dist/security/SecretRotationEngine.js.map +1 -0
  268. package/dist/security/SecretsMigrator.d.ts +28 -0
  269. package/dist/security/SecretsMigrator.d.ts.map +1 -0
  270. package/dist/security/SecretsMigrator.js +170 -0
  271. package/dist/security/SecretsMigrator.js.map +1 -0
  272. package/dist/security/SecurityEventBus.d.ts +48 -0
  273. package/dist/security/SecurityEventBus.d.ts.map +1 -0
  274. package/dist/security/SecurityEventBus.js +105 -0
  275. package/dist/security/SecurityEventBus.js.map +1 -0
  276. package/dist/security/SecurityPresets.d.ts +42 -0
  277. package/dist/security/SecurityPresets.d.ts.map +1 -0
  278. package/dist/security/SecurityPresets.js +162 -0
  279. package/dist/security/SecurityPresets.js.map +1 -0
  280. package/dist/security/SkillManifest.d.ts +34 -0
  281. package/dist/security/SkillManifest.d.ts.map +1 -0
  282. package/dist/security/SkillManifest.js +91 -0
  283. package/dist/security/SkillManifest.js.map +1 -0
  284. package/dist/security/SkillSigner.d.ts +22 -0
  285. package/dist/security/SkillSigner.d.ts.map +1 -0
  286. package/dist/security/SkillSigner.js +80 -0
  287. package/dist/security/SkillSigner.js.map +1 -0
  288. package/dist/security/TamperProofAuditLog.d.ts +58 -0
  289. package/dist/security/TamperProofAuditLog.d.ts.map +1 -0
  290. package/dist/security/TamperProofAuditLog.js +214 -0
  291. package/dist/security/TamperProofAuditLog.js.map +1 -0
  292. package/dist/security/index.d.ts +27 -0
  293. package/dist/security/index.d.ts.map +1 -0
  294. package/dist/security/index.js +27 -0
  295. package/dist/security/index.js.map +1 -0
  296. package/dist/skills/ProactiveEngine.d.ts +55 -0
  297. package/dist/skills/ProactiveEngine.d.ts.map +1 -0
  298. package/dist/skills/ProactiveEngine.js +201 -0
  299. package/dist/skills/ProactiveEngine.js.map +1 -0
  300. package/dist/skills/SkillExecutor.d.ts +21 -0
  301. package/dist/skills/SkillExecutor.d.ts.map +1 -0
  302. package/dist/skills/SkillExecutor.js +131 -0
  303. package/dist/skills/SkillExecutor.js.map +1 -0
  304. package/dist/skills/SkillRegistry.d.ts +47 -0
  305. package/dist/skills/SkillRegistry.d.ts.map +1 -0
  306. package/dist/skills/SkillRegistry.js +94 -0
  307. package/dist/skills/SkillRegistry.js.map +1 -0
  308. package/dist/skills/SkillRouter.d.ts +30 -0
  309. package/dist/skills/SkillRouter.d.ts.map +1 -0
  310. package/dist/skills/SkillRouter.js +113 -0
  311. package/dist/skills/SkillRouter.js.map +1 -0
  312. package/dist/skills/index.d.ts +9 -0
  313. package/dist/skills/index.d.ts.map +1 -0
  314. package/dist/skills/index.js +5 -0
  315. package/dist/skills/index.js.map +1 -0
  316. package/dist/types/GenomeV2.d.ts +12 -0
  317. package/dist/types/GenomeV2.d.ts.map +1 -1
  318. package/dist/types/index.d.ts +19 -0
  319. package/dist/types/index.d.ts.map +1 -1
  320. package/dist/wrap/FileStorageAdapter.d.ts +113 -0
  321. package/dist/wrap/FileStorageAdapter.d.ts.map +1 -0
  322. package/dist/wrap/FileStorageAdapter.js +239 -0
  323. package/dist/wrap/FileStorageAdapter.js.map +1 -0
  324. package/dist/wrap/SQLiteStorageAdapter.d.ts +96 -0
  325. package/dist/wrap/SQLiteStorageAdapter.d.ts.map +1 -0
  326. package/dist/wrap/SQLiteStorageAdapter.js +251 -0
  327. package/dist/wrap/SQLiteStorageAdapter.js.map +1 -0
  328. package/dist/wrap/WrappedAgent.d.ts +2 -2
  329. package/dist/wrap/WrappedAgent.d.ts.map +1 -1
  330. package/dist/wrap/WrappedAgent.js +7 -7
  331. package/dist/wrap/WrappedAgent.js.map +1 -1
  332. package/dist/wrap.d.ts +39 -0
  333. package/dist/wrap.d.ts.map +1 -0
  334. package/dist/wrap.js +96 -0
  335. package/dist/wrap.js.map +1 -0
  336. package/package.json +34 -7
  337. package/dist/PGA.d.ts.map +0 -1
  338. package/dist/PGA.js.map +0 -1
  339. package/dist/evolution/PromotionGate.d.ts +0 -45
  340. package/dist/evolution/PromotionGate.d.ts.map +0 -1
  341. package/dist/evolution/PromotionGate.js +0 -248
  342. package/dist/evolution/PromotionGate.js.map +0 -1
  343. package/dist/gene-bank/PGAIntegration.d.ts.map +0 -1
  344. 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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"}