@gitgov/core 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 +303 -0
- package/dist/scripts/compile-json-to-types.d.ts +11 -0
- package/dist/scripts/compile-json-to-types.d.ts.map +1 -0
- package/dist/scripts/compile-json-to-types.js +129 -0
- package/dist/scripts/compile-json-to-types.js.map +1 -0
- package/dist/scripts/diagnose-duplicates.d.ts +7 -0
- package/dist/scripts/diagnose-duplicates.d.ts.map +1 -0
- package/dist/scripts/diagnose-duplicates.js +72 -0
- package/dist/scripts/diagnose-duplicates.js.map +1 -0
- package/dist/scripts/generate-indexes.d.ts +22 -0
- package/dist/scripts/generate-indexes.d.ts.map +1 -0
- package/dist/scripts/generate-indexes.js +168 -0
- package/dist/scripts/generate-indexes.js.map +1 -0
- package/dist/scripts/sync-schemas.d.ts +10 -0
- package/dist/scripts/sync-schemas.d.ts.map +1 -0
- package/dist/scripts/sync-schemas.js +84 -0
- package/dist/scripts/sync-schemas.js.map +1 -0
- package/dist/scripts/sync-workflow-configs.d.ts +11 -0
- package/dist/scripts/sync-workflow-configs.d.ts.map +1 -0
- package/dist/scripts/sync-workflow-configs.js +61 -0
- package/dist/scripts/sync-workflow-configs.js.map +1 -0
- package/dist/scripts/update-diagram.d.ts +7 -0
- package/dist/scripts/update-diagram.d.ts.map +1 -0
- package/dist/scripts/update-diagram.js +47 -0
- package/dist/scripts/update-diagram.js.map +1 -0
- package/dist/scripts/validate-schemas.d.ts +18 -0
- package/dist/scripts/validate-schemas.d.ts.map +1 -0
- package/dist/scripts/validate-schemas.js +313 -0
- package/dist/scripts/validate-schemas.js.map +1 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.integration.test.d.ts +2 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.integration.test.d.ts.map +1 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.integration.test.js +507 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.integration.test.js.map +1 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.test.d.ts +2 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.test.js +1282 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter.test.js.map +1 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter_e2e.test.d.ts +10 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter_e2e.test.d.ts.map +1 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter_e2e.test.js +144 -0
- package/dist/src/adapters/backlog_adapter/backlog_adapter_e2e.test.js.map +1 -0
- package/dist/src/adapters/backlog_adapter/index.d.ts +213 -0
- package/dist/src/adapters/backlog_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/backlog_adapter/index.js +924 -0
- package/dist/src/adapters/backlog_adapter/index.js.map +1 -0
- package/dist/src/adapters/changelog_adapter/changelog_adapter.test.d.ts +2 -0
- package/dist/src/adapters/changelog_adapter/changelog_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/changelog_adapter/changelog_adapter.test.js +505 -0
- package/dist/src/adapters/changelog_adapter/changelog_adapter.test.js.map +1 -0
- package/dist/src/adapters/changelog_adapter/index.d.ts +101 -0
- package/dist/src/adapters/changelog_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/changelog_adapter/index.js +197 -0
- package/dist/src/adapters/changelog_adapter/index.js.map +1 -0
- package/dist/src/adapters/execution_adapter/execution_adapter.test.d.ts +2 -0
- package/dist/src/adapters/execution_adapter/execution_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/execution_adapter/execution_adapter.test.js +266 -0
- package/dist/src/adapters/execution_adapter/execution_adapter.test.js.map +1 -0
- package/dist/src/adapters/execution_adapter/index.d.ts +90 -0
- package/dist/src/adapters/execution_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/execution_adapter/index.js +150 -0
- package/dist/src/adapters/execution_adapter/index.js.map +1 -0
- package/dist/src/adapters/feedback_adapter/feedback_adapter.test.d.ts +2 -0
- package/dist/src/adapters/feedback_adapter/feedback_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/feedback_adapter/feedback_adapter.test.js +256 -0
- package/dist/src/adapters/feedback_adapter/feedback_adapter.test.js.map +1 -0
- package/dist/src/adapters/feedback_adapter/index.d.ts +95 -0
- package/dist/src/adapters/feedback_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/feedback_adapter/index.js +192 -0
- package/dist/src/adapters/feedback_adapter/index.js.map +1 -0
- package/dist/src/adapters/identity_adapter/identity_adapter.test.d.ts +2 -0
- package/dist/src/adapters/identity_adapter/identity_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/identity_adapter/identity_adapter.test.js +624 -0
- package/dist/src/adapters/identity_adapter/identity_adapter.test.js.map +1 -0
- package/dist/src/adapters/identity_adapter/index.d.ts +82 -0
- package/dist/src/adapters/identity_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/identity_adapter/index.js +336 -0
- package/dist/src/adapters/identity_adapter/index.js.map +1 -0
- package/dist/src/adapters/index.d.ts +10 -0
- package/dist/src/adapters/index.d.ts.map +1 -0
- package/dist/src/adapters/index.js +10 -0
- package/dist/src/adapters/index.js.map +1 -0
- package/dist/src/adapters/indexer_adapter/index.d.ts +214 -0
- package/dist/src/adapters/indexer_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/indexer_adapter/index.js +643 -0
- package/dist/src/adapters/indexer_adapter/index.js.map +1 -0
- package/dist/src/adapters/indexer_adapter/indexer_adapter.test.d.ts +2 -0
- package/dist/src/adapters/indexer_adapter/indexer_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/indexer_adapter/indexer_adapter.test.js +409 -0
- package/dist/src/adapters/indexer_adapter/indexer_adapter.test.js.map +1 -0
- package/dist/src/adapters/metrics_adapter/index.d.ts +189 -0
- package/dist/src/adapters/metrics_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/metrics_adapter/index.js +592 -0
- package/dist/src/adapters/metrics_adapter/index.js.map +1 -0
- package/dist/src/adapters/metrics_adapter/metrics_adapter.test.d.ts +2 -0
- package/dist/src/adapters/metrics_adapter/metrics_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/metrics_adapter/metrics_adapter.test.js +558 -0
- package/dist/src/adapters/metrics_adapter/metrics_adapter.test.js.map +1 -0
- package/dist/src/adapters/project_adapter/index.d.ts +164 -0
- package/dist/src/adapters/project_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/project_adapter/index.js +445 -0
- package/dist/src/adapters/project_adapter/index.js.map +1 -0
- package/dist/src/adapters/project_adapter/project_adapter.test.d.ts +2 -0
- package/dist/src/adapters/project_adapter/project_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/project_adapter/project_adapter.test.js +627 -0
- package/dist/src/adapters/project_adapter/project_adapter.test.js.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/index.d.ts +75 -0
- package/dist/src/adapters/workflow_methodology_adapter/index.d.ts.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/index.js +205 -0
- package/dist/src/adapters/workflow_methodology_adapter/index.js.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter.test.d.ts +2 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter.test.d.ts.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter.test.js +463 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter.test.js.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_integration.test.d.ts +2 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_integration.test.d.ts.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_integration.test.js +287 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_integration.test.js.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_scrum_integration.test.d.ts +2 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_scrum_integration.test.d.ts.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_scrum_integration.test.js +278 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_adapter_scrum_integration.test.js.map +1 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_default.json +188 -0
- package/dist/src/adapters/workflow_methodology_adapter/workflow_methodology_scrum.json +284 -0
- package/dist/src/config_manager/config_manager.test.d.ts +2 -0
- package/dist/src/config_manager/config_manager.test.d.ts.map +1 -0
- package/dist/src/config_manager/config_manager.test.js +321 -0
- package/dist/src/config_manager/config_manager.test.js.map +1 -0
- package/dist/src/config_manager/index.d.ts +107 -0
- package/dist/src/config_manager/index.d.ts.map +1 -0
- package/dist/src/config_manager/index.js +192 -0
- package/dist/src/config_manager/index.js.map +1 -0
- package/dist/src/crypto/checksum.d.ts +6 -0
- package/dist/src/crypto/checksum.d.ts.map +1 -0
- package/dist/src/crypto/checksum.js +38 -0
- package/dist/src/crypto/checksum.js.map +1 -0
- package/dist/src/crypto/checksum.test.d.ts +2 -0
- package/dist/src/crypto/checksum.test.d.ts.map +1 -0
- package/dist/src/crypto/checksum.test.js +167 -0
- package/dist/src/crypto/checksum.test.js.map +1 -0
- package/dist/src/crypto/index.d.ts +3 -0
- package/dist/src/crypto/index.d.ts.map +1 -0
- package/dist/src/crypto/index.js +3 -0
- package/dist/src/crypto/index.js.map +1 -0
- package/dist/src/crypto/signatures.d.ts +24 -0
- package/dist/src/crypto/signatures.d.ts.map +1 -0
- package/dist/src/crypto/signatures.js +67 -0
- package/dist/src/crypto/signatures.js.map +1 -0
- package/dist/src/crypto/signatures.test.d.ts +2 -0
- package/dist/src/crypto/signatures.test.d.ts.map +1 -0
- package/dist/src/crypto/signatures.test.js +378 -0
- package/dist/src/crypto/signatures.test.js.map +1 -0
- package/dist/src/diagram_generator/diagram_generator.d.ts +76 -0
- package/dist/src/diagram_generator/diagram_generator.d.ts.map +1 -0
- package/dist/src/diagram_generator/diagram_generator.js +233 -0
- package/dist/src/diagram_generator/diagram_generator.js.map +1 -0
- package/dist/src/diagram_generator/graph_validator.d.ts +19 -0
- package/dist/src/diagram_generator/graph_validator.d.ts.map +1 -0
- package/dist/src/diagram_generator/graph_validator.js +98 -0
- package/dist/src/diagram_generator/graph_validator.js.map +1 -0
- package/dist/src/diagram_generator/index.d.ts +4 -0
- package/dist/src/diagram_generator/index.d.ts.map +1 -0
- package/dist/src/diagram_generator/index.js +4 -0
- package/dist/src/diagram_generator/index.js.map +1 -0
- package/dist/src/diagram_generator/mermaid_renderer.d.ts +82 -0
- package/dist/src/diagram_generator/mermaid_renderer.d.ts.map +1 -0
- package/dist/src/diagram_generator/mermaid_renderer.js +306 -0
- package/dist/src/diagram_generator/mermaid_renderer.js.map +1 -0
- package/dist/src/diagram_generator/relationship_analyzer.d.ts +116 -0
- package/dist/src/diagram_generator/relationship_analyzer.d.ts.map +1 -0
- package/dist/src/diagram_generator/relationship_analyzer.js +381 -0
- package/dist/src/diagram_generator/relationship_analyzer.js.map +1 -0
- package/dist/src/event_bus/event_bus.d.ts +110 -0
- package/dist/src/event_bus/event_bus.d.ts.map +1 -0
- package/dist/src/event_bus/event_bus.js +161 -0
- package/dist/src/event_bus/event_bus.js.map +1 -0
- package/dist/src/event_bus/event_bus.test.d.ts +2 -0
- package/dist/src/event_bus/event_bus.test.d.ts.map +1 -0
- package/dist/src/event_bus/event_bus.test.js +332 -0
- package/dist/src/event_bus/event_bus.test.js.map +1 -0
- package/dist/src/event_bus/event_bus_integration.test.d.ts +2 -0
- package/dist/src/event_bus/event_bus_integration.test.d.ts.map +1 -0
- package/dist/src/event_bus/event_bus_integration.test.js +474 -0
- package/dist/src/event_bus/event_bus_integration.test.js.map +1 -0
- package/dist/src/event_bus/index.d.ts +3 -0
- package/dist/src/event_bus/index.d.ts.map +1 -0
- package/dist/src/event_bus/index.js +3 -0
- package/dist/src/event_bus/index.js.map +1 -0
- package/dist/src/event_bus/types.d.ts +203 -0
- package/dist/src/event_bus/types.d.ts.map +1 -0
- package/dist/src/event_bus/types.js +5 -0
- package/dist/src/event_bus/types.js.map +1 -0
- package/dist/src/factories/actor_factory.d.ts +6 -0
- package/dist/src/factories/actor_factory.d.ts.map +1 -0
- package/dist/src/factories/actor_factory.js +25 -0
- package/dist/src/factories/actor_factory.js.map +1 -0
- package/dist/src/factories/actor_factory.test.d.ts +2 -0
- package/dist/src/factories/actor_factory.test.d.ts.map +1 -0
- package/dist/src/factories/actor_factory.test.js +169 -0
- package/dist/src/factories/actor_factory.test.js.map +1 -0
- package/dist/src/factories/agent_factory.d.ts +6 -0
- package/dist/src/factories/agent_factory.d.ts.map +1 -0
- package/dist/src/factories/agent_factory.js +25 -0
- package/dist/src/factories/agent_factory.js.map +1 -0
- package/dist/src/factories/agent_factory.test.d.ts +2 -0
- package/dist/src/factories/agent_factory.test.d.ts.map +1 -0
- package/dist/src/factories/agent_factory.test.js +199 -0
- package/dist/src/factories/agent_factory.test.js.map +1 -0
- package/dist/src/factories/changelog_factory.d.ts +9 -0
- package/dist/src/factories/changelog_factory.d.ts.map +1 -0
- package/dist/src/factories/changelog_factory.js +46 -0
- package/dist/src/factories/changelog_factory.js.map +1 -0
- package/dist/src/factories/changelog_factory.test.d.ts +2 -0
- package/dist/src/factories/changelog_factory.test.d.ts.map +1 -0
- package/dist/src/factories/changelog_factory.test.js +368 -0
- package/dist/src/factories/changelog_factory.test.js.map +1 -0
- package/dist/src/factories/cycle_factory.d.ts +6 -0
- package/dist/src/factories/cycle_factory.d.ts.map +1 -0
- package/dist/src/factories/cycle_factory.js +28 -0
- package/dist/src/factories/cycle_factory.js.map +1 -0
- package/dist/src/factories/cycle_factory.test.d.ts +2 -0
- package/dist/src/factories/cycle_factory.test.d.ts.map +1 -0
- package/dist/src/factories/cycle_factory.test.js +175 -0
- package/dist/src/factories/cycle_factory.test.js.map +1 -0
- package/dist/src/factories/execution_factory.d.ts +9 -0
- package/dist/src/factories/execution_factory.d.ts.map +1 -0
- package/dist/src/factories/execution_factory.js +29 -0
- package/dist/src/factories/execution_factory.js.map +1 -0
- package/dist/src/factories/execution_factory.test.d.ts +2 -0
- package/dist/src/factories/execution_factory.test.d.ts.map +1 -0
- package/dist/src/factories/execution_factory.test.js +207 -0
- package/dist/src/factories/execution_factory.test.js.map +1 -0
- package/dist/src/factories/feedback_factory.d.ts +9 -0
- package/dist/src/factories/feedback_factory.d.ts.map +1 -0
- package/dist/src/factories/feedback_factory.js +30 -0
- package/dist/src/factories/feedback_factory.js.map +1 -0
- package/dist/src/factories/feedback_factory.test.d.ts +2 -0
- package/dist/src/factories/feedback_factory.test.d.ts.map +1 -0
- package/dist/src/factories/feedback_factory.test.js +256 -0
- package/dist/src/factories/feedback_factory.test.js.map +1 -0
- package/dist/src/factories/index.d.ts +9 -0
- package/dist/src/factories/index.d.ts.map +1 -0
- package/dist/src/factories/index.js +9 -0
- package/dist/src/factories/index.js.map +1 -0
- package/dist/src/factories/task_factory.d.ts +6 -0
- package/dist/src/factories/task_factory.d.ts.map +1 -0
- package/dist/src/factories/task_factory.js +30 -0
- package/dist/src/factories/task_factory.js.map +1 -0
- package/dist/src/factories/task_factory.test.d.ts +2 -0
- package/dist/src/factories/task_factory.test.d.ts.map +1 -0
- package/dist/src/factories/task_factory.test.js +197 -0
- package/dist/src/factories/task_factory.test.js.map +1 -0
- package/dist/src/factories/workflow_methodology_factory.d.ts +11 -0
- package/dist/src/factories/workflow_methodology_factory.d.ts.map +1 -0
- package/dist/src/factories/workflow_methodology_factory.js +173 -0
- package/dist/src/factories/workflow_methodology_factory.js.map +1 -0
- package/dist/src/factories/workflow_methodology_factory.test.d.ts +2 -0
- package/dist/src/factories/workflow_methodology_factory.test.d.ts.map +1 -0
- package/dist/src/factories/workflow_methodology_factory.test.js +244 -0
- package/dist/src/factories/workflow_methodology_factory.test.js.map +1 -0
- package/dist/src/index.d.ts +21 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +23 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/integration/cycles_tasks_integration.test.d.ts +2 -0
- package/dist/src/integration/cycles_tasks_integration.test.d.ts.map +1 -0
- package/dist/src/integration/cycles_tasks_integration.test.js +258 -0
- package/dist/src/integration/cycles_tasks_integration.test.js.map +1 -0
- package/dist/src/integration/schema_integration.test.d.ts +8 -0
- package/dist/src/integration/schema_integration.test.d.ts.map +1 -0
- package/dist/src/integration/schema_integration.test.js +279 -0
- package/dist/src/integration/schema_integration.test.js.map +1 -0
- package/dist/src/logger/index.d.ts +2 -0
- package/dist/src/logger/index.d.ts.map +1 -0
- package/dist/src/logger/index.js +2 -0
- package/dist/src/logger/index.js.map +1 -0
- package/dist/src/logger/logger.d.ts +10 -0
- package/dist/src/logger/logger.d.ts.map +1 -0
- package/dist/src/logger/logger.js +48 -0
- package/dist/src/logger/logger.js.map +1 -0
- package/dist/src/schemas/errors.d.ts +28 -0
- package/dist/src/schemas/errors.d.ts.map +1 -0
- package/dist/src/schemas/errors.js +31 -0
- package/dist/src/schemas/errors.js.map +1 -0
- package/dist/src/schemas/generated/actor_record_schema.json +91 -0
- package/dist/src/schemas/generated/agent_record_schema.json +142 -0
- package/dist/src/schemas/generated/changelog_record_schema.json +227 -0
- package/dist/src/schemas/generated/cycle_record_schema.json +80 -0
- package/dist/src/schemas/generated/embedded_metadata_schema.json +318 -0
- package/dist/src/schemas/generated/execution_record_schema.json +89 -0
- package/dist/src/schemas/generated/feedback_record_schema.json +83 -0
- package/dist/src/schemas/generated/index.d.ts +2221 -0
- package/dist/src/schemas/generated/index.d.ts.map +1 -0
- package/dist/src/schemas/generated/index.js +48 -0
- package/dist/src/schemas/generated/index.js.map +1 -0
- package/dist/src/schemas/generated/task_record_schema.json +103 -0
- package/dist/src/schemas/generated/workflow_methodology_record_schema.json +393 -0
- package/dist/src/schemas/index.d.ts +4 -0
- package/dist/src/schemas/index.d.ts.map +1 -0
- package/dist/src/schemas/index.js +4 -0
- package/dist/src/schemas/index.js.map +1 -0
- package/dist/src/schemas/schema_cache.d.ts +39 -0
- package/dist/src/schemas/schema_cache.d.ts.map +1 -0
- package/dist/src/schemas/schema_cache.js +109 -0
- package/dist/src/schemas/schema_cache.js.map +1 -0
- package/dist/src/schemas/schema_cache.test.d.ts +2 -0
- package/dist/src/schemas/schema_cache.test.d.ts.map +1 -0
- package/dist/src/schemas/schema_cache.test.js +163 -0
- package/dist/src/schemas/schema_cache.test.js.map +1 -0
- package/dist/src/store/index.d.ts +2 -0
- package/dist/src/store/index.d.ts.map +1 -0
- package/dist/src/store/index.js +2 -0
- package/dist/src/store/index.js.map +1 -0
- package/dist/src/store/record_store.d.ts +30 -0
- package/dist/src/store/record_store.d.ts.map +1 -0
- package/dist/src/store/record_store.js +83 -0
- package/dist/src/store/record_store.js.map +1 -0
- package/dist/src/store/record_store.test.d.ts +2 -0
- package/dist/src/store/record_store.test.d.ts.map +1 -0
- package/dist/src/store/record_store.test.js +646 -0
- package/dist/src/store/record_store.test.js.map +1 -0
- package/dist/src/types/common.types.d.ts +43 -0
- package/dist/src/types/common.types.d.ts.map +1 -0
- package/dist/src/types/common.types.js +13 -0
- package/dist/src/types/common.types.js.map +1 -0
- package/dist/src/types/embedded.types.d.ts +17 -0
- package/dist/src/types/embedded.types.d.ts.map +1 -0
- package/dist/src/types/embedded.types.js +2 -0
- package/dist/src/types/embedded.types.js.map +1 -0
- package/dist/src/types/generated/actor_record.d.ts +45 -0
- package/dist/src/types/generated/actor_record.d.ts.map +1 -0
- package/dist/src/types/generated/actor_record.js +7 -0
- package/dist/src/types/generated/actor_record.js.map +1 -0
- package/dist/src/types/generated/agent_record.d.ts +40 -0
- package/dist/src/types/generated/agent_record.d.ts.map +1 -0
- package/dist/src/types/generated/agent_record.js +7 -0
- package/dist/src/types/generated/agent_record.js.map +1 -0
- package/dist/src/types/generated/changelog_record.d.ts +100 -0
- package/dist/src/types/generated/changelog_record.d.ts.map +1 -0
- package/dist/src/types/generated/changelog_record.js +7 -0
- package/dist/src/types/generated/changelog_record.js.map +1 -0
- package/dist/src/types/generated/cycle_record.d.ts +36 -0
- package/dist/src/types/generated/cycle_record.d.ts.map +1 -0
- package/dist/src/types/generated/cycle_record.js +7 -0
- package/dist/src/types/generated/cycle_record.js.map +1 -0
- package/dist/src/types/generated/embedded_metadata.d.ts +94 -0
- package/dist/src/types/generated/embedded_metadata.d.ts.map +1 -0
- package/dist/src/types/generated/embedded_metadata.js +7 -0
- package/dist/src/types/generated/embedded_metadata.js.map +1 -0
- package/dist/src/types/generated/execution_record.d.ts +39 -0
- package/dist/src/types/generated/execution_record.d.ts.map +1 -0
- package/dist/src/types/generated/execution_record.js +7 -0
- package/dist/src/types/generated/execution_record.js.map +1 -0
- package/dist/src/types/generated/feedback_record.d.ts +43 -0
- package/dist/src/types/generated/feedback_record.d.ts.map +1 -0
- package/dist/src/types/generated/feedback_record.js +7 -0
- package/dist/src/types/generated/feedback_record.js.map +1 -0
- package/dist/src/types/generated/index.d.ts +15 -0
- package/dist/src/types/generated/index.d.ts.map +1 -0
- package/dist/src/types/generated/index.js +15 -0
- package/dist/src/types/generated/index.js.map +1 -0
- package/dist/src/types/generated/task_record.d.ts +47 -0
- package/dist/src/types/generated/task_record.d.ts.map +1 -0
- package/dist/src/types/generated/task_record.js +7 -0
- package/dist/src/types/generated/task_record.js.map +1 -0
- package/dist/src/types/generated/workflow_methodology_record.d.ts +211 -0
- package/dist/src/types/generated/workflow_methodology_record.d.ts.map +1 -0
- package/dist/src/types/generated/workflow_methodology_record.js +7 -0
- package/dist/src/types/generated/workflow_methodology_record.js.map +1 -0
- package/dist/src/types/index.d.ts +4 -0
- package/dist/src/types/index.d.ts.map +1 -0
- package/dist/src/types/index.js +4 -0
- package/dist/src/types/index.js.map +1 -0
- package/dist/src/utils/id_generator.d.ts +44 -0
- package/dist/src/utils/id_generator.d.ts.map +1 -0
- package/dist/src/utils/id_generator.js +107 -0
- package/dist/src/utils/id_generator.js.map +1 -0
- package/dist/src/utils/id_generator.test.d.ts +2 -0
- package/dist/src/utils/id_generator.test.d.ts.map +1 -0
- package/dist/src/utils/id_generator.test.js +100 -0
- package/dist/src/utils/id_generator.test.js.map +1 -0
- package/dist/src/utils/index.d.ts +2 -0
- package/dist/src/utils/index.d.ts.map +1 -0
- package/dist/src/utils/index.js +3 -0
- package/dist/src/utils/index.js.map +1 -0
- package/dist/src/validation/actor_validator.d.ts +21 -0
- package/dist/src/validation/actor_validator.d.ts.map +1 -0
- package/dist/src/validation/actor_validator.js +48 -0
- package/dist/src/validation/actor_validator.js.map +1 -0
- package/dist/src/validation/actor_validator.test.d.ts +2 -0
- package/dist/src/validation/actor_validator.test.d.ts.map +1 -0
- package/dist/src/validation/actor_validator.test.js +83 -0
- package/dist/src/validation/actor_validator.test.js.map +1 -0
- package/dist/src/validation/agent_validator.d.ts +30 -0
- package/dist/src/validation/agent_validator.d.ts.map +1 -0
- package/dist/src/validation/agent_validator.js +66 -0
- package/dist/src/validation/agent_validator.js.map +1 -0
- package/dist/src/validation/agent_validator.test.d.ts +2 -0
- package/dist/src/validation/agent_validator.test.d.ts.map +1 -0
- package/dist/src/validation/agent_validator.test.js +73 -0
- package/dist/src/validation/agent_validator.test.js.map +1 -0
- package/dist/src/validation/changelog_validator.d.ts +23 -0
- package/dist/src/validation/changelog_validator.d.ts.map +1 -0
- package/dist/src/validation/changelog_validator.js +58 -0
- package/dist/src/validation/changelog_validator.js.map +1 -0
- package/dist/src/validation/changelog_validator.test.d.ts +2 -0
- package/dist/src/validation/changelog_validator.test.d.ts.map +1 -0
- package/dist/src/validation/changelog_validator.test.js +401 -0
- package/dist/src/validation/changelog_validator.test.js.map +1 -0
- package/dist/src/validation/common.d.ts +10 -0
- package/dist/src/validation/common.d.ts.map +1 -0
- package/dist/src/validation/common.js +12 -0
- package/dist/src/validation/common.js.map +1 -0
- package/dist/src/validation/cycle_validator.d.ts +24 -0
- package/dist/src/validation/cycle_validator.d.ts.map +1 -0
- package/dist/src/validation/cycle_validator.js +51 -0
- package/dist/src/validation/cycle_validator.js.map +1 -0
- package/dist/src/validation/cycle_validator.test.d.ts +2 -0
- package/dist/src/validation/cycle_validator.test.d.ts.map +1 -0
- package/dist/src/validation/cycle_validator.test.js +182 -0
- package/dist/src/validation/cycle_validator.test.js.map +1 -0
- package/dist/src/validation/embedded_metadata_validator.d.ts +26 -0
- package/dist/src/validation/embedded_metadata_validator.d.ts.map +1 -0
- package/dist/src/validation/embedded_metadata_validator.js +122 -0
- package/dist/src/validation/embedded_metadata_validator.js.map +1 -0
- package/dist/src/validation/embedded_metadata_validator.test.d.ts +2 -0
- package/dist/src/validation/embedded_metadata_validator.test.d.ts.map +1 -0
- package/dist/src/validation/embedded_metadata_validator.test.js +316 -0
- package/dist/src/validation/embedded_metadata_validator.test.js.map +1 -0
- package/dist/src/validation/errors.d.ts +67 -0
- package/dist/src/validation/errors.d.ts.map +1 -0
- package/dist/src/validation/errors.js +83 -0
- package/dist/src/validation/errors.js.map +1 -0
- package/dist/src/validation/execution_validator.d.ts +23 -0
- package/dist/src/validation/execution_validator.d.ts.map +1 -0
- package/dist/src/validation/execution_validator.js +58 -0
- package/dist/src/validation/execution_validator.js.map +1 -0
- package/dist/src/validation/execution_validator.test.d.ts +2 -0
- package/dist/src/validation/execution_validator.test.d.ts.map +1 -0
- package/dist/src/validation/execution_validator.test.js +167 -0
- package/dist/src/validation/execution_validator.test.js.map +1 -0
- package/dist/src/validation/feedback_validator.d.ts +23 -0
- package/dist/src/validation/feedback_validator.d.ts.map +1 -0
- package/dist/src/validation/feedback_validator.js +58 -0
- package/dist/src/validation/feedback_validator.js.map +1 -0
- package/dist/src/validation/feedback_validator.test.d.ts +2 -0
- package/dist/src/validation/feedback_validator.test.d.ts.map +1 -0
- package/dist/src/validation/feedback_validator.test.js +131 -0
- package/dist/src/validation/feedback_validator.test.js.map +1 -0
- package/dist/src/validation/index.d.ts +11 -0
- package/dist/src/validation/index.d.ts.map +1 -0
- package/dist/src/validation/index.js +10 -0
- package/dist/src/validation/index.js.map +1 -0
- package/dist/src/validation/task_validator.d.ts +24 -0
- package/dist/src/validation/task_validator.d.ts.map +1 -0
- package/dist/src/validation/task_validator.js +50 -0
- package/dist/src/validation/task_validator.js.map +1 -0
- package/dist/src/validation/task_validator.test.d.ts +2 -0
- package/dist/src/validation/task_validator.test.d.ts.map +1 -0
- package/dist/src/validation/task_validator.test.js +185 -0
- package/dist/src/validation/task_validator.test.js.map +1 -0
- package/dist/src/validation/workflow_methodology_validator.d.ts +32 -0
- package/dist/src/validation/workflow_methodology_validator.d.ts.map +1 -0
- package/dist/src/validation/workflow_methodology_validator.js +91 -0
- package/dist/src/validation/workflow_methodology_validator.js.map +1 -0
- package/dist/src/validation/workflow_methodology_validator.test.d.ts +2 -0
- package/dist/src/validation/workflow_methodology_validator.test.d.ts.map +1 -0
- package/dist/src/validation/workflow_methodology_validator.test.js +229 -0
- package/dist/src/validation/workflow_methodology_validator.test.js.map +1 -0
- package/package.json +63 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checksum.d.ts","sourceRoot":"","sources":["../../../src/crypto/checksum.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAiCpD;;GAEG;AACH,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,mBAAmB,GAAG,MAAM,CAG7E"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { createHash } from "crypto";
|
|
2
|
+
/**
|
|
3
|
+
* Recursively sorts the keys of an object, including nested objects.
|
|
4
|
+
* This is the core of canonical serialization.
|
|
5
|
+
* @param obj The object to sort.
|
|
6
|
+
* @returns A new object with all keys sorted alphabetically.
|
|
7
|
+
*/
|
|
8
|
+
function sortKeys(obj) {
|
|
9
|
+
if (typeof obj !== 'object' || obj === null) {
|
|
10
|
+
return obj;
|
|
11
|
+
}
|
|
12
|
+
if (Array.isArray(obj)) {
|
|
13
|
+
return obj.map(sortKeys);
|
|
14
|
+
}
|
|
15
|
+
const sortedKeys = Object.keys(obj).sort();
|
|
16
|
+
const newObj = {};
|
|
17
|
+
for (const key of sortedKeys) {
|
|
18
|
+
newObj[key] = sortKeys(obj[key]);
|
|
19
|
+
}
|
|
20
|
+
return newObj;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Canonically serializes a payload object.
|
|
24
|
+
* @param payload The object to serialize.
|
|
25
|
+
* @returns A deterministic JSON string.
|
|
26
|
+
*/
|
|
27
|
+
function canonicalize(payload) {
|
|
28
|
+
const sortedPayload = sortKeys(payload);
|
|
29
|
+
return JSON.stringify(sortedPayload);
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Calculates the SHA-256 checksum of a record's payload.
|
|
33
|
+
*/
|
|
34
|
+
export function calculatePayloadChecksum(payload) {
|
|
35
|
+
const jsonString = canonicalize(payload);
|
|
36
|
+
return createHash("sha256").update(jsonString, "utf8").digest("hex");
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=checksum.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checksum.js","sourceRoot":"","sources":["../../../src/crypto/checksum.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAGpC;;;;;GAKG;AACH,SAAS,QAAQ,CAAC,GAAQ;IACxB,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;QAC5C,OAAO,GAAG,CAAC;IACb,CAAC;IACD,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QACvB,OAAO,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC3B,CAAC;IACD,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;IAC3C,MAAM,MAAM,GAAwB,EAAE,CAAC;IACvC,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC7B,MAAM,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IACnC,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;;;GAIG;AACH,SAAS,YAAY,CAAC,OAAe;IACnC,MAAM,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;IACxC,OAAO,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;AACvC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,wBAAwB,CAAC,OAA4B;IACnE,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IACzC,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AACvE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checksum.test.d.ts","sourceRoot":"","sources":["../../../src/crypto/checksum.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { calculatePayloadChecksum } from "./checksum";
|
|
2
|
+
describe("calculatePayloadChecksum", () => {
|
|
3
|
+
const testCases = [
|
|
4
|
+
{
|
|
5
|
+
name: 'actor',
|
|
6
|
+
payload: {
|
|
7
|
+
id: 'actor:test', type: 'human', displayName: 'Test User',
|
|
8
|
+
publicKey: 'key', roles: ['user'], status: 'active',
|
|
9
|
+
}
|
|
10
|
+
},
|
|
11
|
+
{
|
|
12
|
+
name: 'agent',
|
|
13
|
+
payload: {
|
|
14
|
+
id: 'agent:test-agent', guild: 'design', status: 'active',
|
|
15
|
+
engine: { type: 'local', runtime: 'typescript', entrypoint: 'test.ts', function: 'run' },
|
|
16
|
+
triggers: [], knowledge_dependencies: [], prompt_engine_requirements: {}
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
name: 'task',
|
|
21
|
+
payload: {
|
|
22
|
+
id: '1752274500-task-test-task', title: 'Test Task',
|
|
23
|
+
status: 'draft', priority: 'medium', description: 'A test task for checksum validation', tags: ['test']
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
name: 'cycle',
|
|
28
|
+
payload: {
|
|
29
|
+
id: '1754400000-cycle-test-cycle', title: 'Test Cycle',
|
|
30
|
+
status: 'planning', taskIds: ['1752274500-task-test-task'], tags: ['test']
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
name: 'execution',
|
|
35
|
+
payload: {
|
|
36
|
+
id: '1752275500-exec-test-execution', taskId: '1752274500-task-test-task',
|
|
37
|
+
result: 'Successfully implemented the feature', type: 'progress'
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
name: 'changelog',
|
|
42
|
+
payload: {
|
|
43
|
+
id: '1752707800-changelog-task-test-task',
|
|
44
|
+
entityType: 'task',
|
|
45
|
+
entityId: '1752274500-task-test-task',
|
|
46
|
+
changeType: 'completion',
|
|
47
|
+
title: 'Test Task Completion',
|
|
48
|
+
description: 'Successfully completed the test task with all requirements',
|
|
49
|
+
timestamp: 1752707800,
|
|
50
|
+
trigger: 'manual',
|
|
51
|
+
triggeredBy: 'human:developer',
|
|
52
|
+
reason: 'All acceptance criteria met and code review passed',
|
|
53
|
+
riskLevel: 'low'
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
name: 'feedback',
|
|
58
|
+
payload: {
|
|
59
|
+
id: '1752788100-feedback-blocking-issue', entityType: 'task', entityId: '1752274500-task-test-task',
|
|
60
|
+
type: 'blocking', status: 'open', content: 'This task has a blocking issue'
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
];
|
|
64
|
+
for (const tc of testCases) {
|
|
65
|
+
it(`[EARS-1] should produce a deterministic checksum for a ${tc.name}`, () => {
|
|
66
|
+
// Create two versions with disordered keys
|
|
67
|
+
const payload1 = { ...tc.payload, z: 'last', a: 'first' };
|
|
68
|
+
const payload2 = { a: 'first', ...tc.payload, z: 'last' };
|
|
69
|
+
const checksum1 = calculatePayloadChecksum(payload1);
|
|
70
|
+
const checksum2 = calculatePayloadChecksum(payload2);
|
|
71
|
+
expect(checksum1).toBe(checksum2);
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
describe('ChangelogRecord v2 Enhanced Determinism Tests', () => {
|
|
75
|
+
it('[EARS-1] should produce deterministic checksum for complex ChangelogRecord with nested objects and arrays', () => {
|
|
76
|
+
// Create complex changelog v2 with all optional fields
|
|
77
|
+
const complexChangelog1 = {
|
|
78
|
+
id: '1752707800-changelog-system-payment-gateway',
|
|
79
|
+
entityType: 'system',
|
|
80
|
+
entityId: 'payment-gateway',
|
|
81
|
+
changeType: 'hotfix',
|
|
82
|
+
title: 'Critical Payment Gateway Fix',
|
|
83
|
+
description: 'Fixed critical payment processing issue affecting 15% of transactions',
|
|
84
|
+
timestamp: 1752707800,
|
|
85
|
+
trigger: 'emergency',
|
|
86
|
+
triggeredBy: 'human:on-call-engineer',
|
|
87
|
+
reason: 'Payment failures spiked to 15% due to third-party API latency',
|
|
88
|
+
riskLevel: 'critical',
|
|
89
|
+
// Complex nested structures
|
|
90
|
+
affectedSystems: ['payment-gateway', 'order-service', 'notification-service'],
|
|
91
|
+
usersAffected: 25000,
|
|
92
|
+
downtime: 300,
|
|
93
|
+
files: ['src/payment/gateway.ts', 'src/payment/processor.ts'],
|
|
94
|
+
commits: ['abc123def', 'def456ghi'],
|
|
95
|
+
rollbackInstructions: 'Revert to payment-gateway:v2.1.4 and restart services',
|
|
96
|
+
references: {
|
|
97
|
+
tasks: ['1752274500-task-payment-fix'],
|
|
98
|
+
executions: ['1752707750-exec-hotfix-implementation'],
|
|
99
|
+
cycles: ['1752600000-cycle-payment-stability']
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
// Create same object with keys in different order
|
|
103
|
+
const complexChangelog2 = {
|
|
104
|
+
riskLevel: 'critical',
|
|
105
|
+
references: {
|
|
106
|
+
cycles: ['1752600000-cycle-payment-stability'],
|
|
107
|
+
tasks: ['1752274500-task-payment-fix'],
|
|
108
|
+
executions: ['1752707750-exec-hotfix-implementation']
|
|
109
|
+
},
|
|
110
|
+
rollbackInstructions: 'Revert to payment-gateway:v2.1.4 and restart services',
|
|
111
|
+
commits: ['abc123def', 'def456ghi'],
|
|
112
|
+
files: ['src/payment/gateway.ts', 'src/payment/processor.ts'],
|
|
113
|
+
downtime: 300,
|
|
114
|
+
usersAffected: 25000,
|
|
115
|
+
affectedSystems: ['payment-gateway', 'order-service', 'notification-service'],
|
|
116
|
+
reason: 'Payment failures spiked to 15% due to third-party API latency',
|
|
117
|
+
triggeredBy: 'human:on-call-engineer',
|
|
118
|
+
trigger: 'emergency',
|
|
119
|
+
timestamp: 1752707800,
|
|
120
|
+
description: 'Fixed critical payment processing issue affecting 15% of transactions',
|
|
121
|
+
title: 'Critical Payment Gateway Fix',
|
|
122
|
+
changeType: 'hotfix',
|
|
123
|
+
entityId: 'payment-gateway',
|
|
124
|
+
entityType: 'system',
|
|
125
|
+
id: '1752707800-changelog-system-payment-gateway'
|
|
126
|
+
};
|
|
127
|
+
const checksum1 = calculatePayloadChecksum(complexChangelog1);
|
|
128
|
+
const checksum2 = calculatePayloadChecksum(complexChangelog2);
|
|
129
|
+
expect(checksum1).toBe(checksum2);
|
|
130
|
+
expect(checksum1).toMatch(/^[a-f0-9]{64}$/); // Valid SHA-256 hex
|
|
131
|
+
});
|
|
132
|
+
it('[EARS-1] should produce different checksums for different ChangelogRecord v2 content', () => {
|
|
133
|
+
const changelog1 = {
|
|
134
|
+
id: '1752707800-changelog-task-feature-a',
|
|
135
|
+
entityType: 'task',
|
|
136
|
+
entityId: '1752274500-task-feature-a',
|
|
137
|
+
changeType: 'completion',
|
|
138
|
+
title: 'Feature A Completed',
|
|
139
|
+
description: 'Successfully implemented feature A',
|
|
140
|
+
timestamp: 1752707800,
|
|
141
|
+
trigger: 'manual',
|
|
142
|
+
triggeredBy: 'human:developer',
|
|
143
|
+
reason: 'All requirements met',
|
|
144
|
+
riskLevel: 'low'
|
|
145
|
+
};
|
|
146
|
+
const changelog2 = {
|
|
147
|
+
id: '1752707800-changelog-task-feature-b',
|
|
148
|
+
entityType: 'task',
|
|
149
|
+
entityId: '1752274500-task-feature-b',
|
|
150
|
+
changeType: 'completion',
|
|
151
|
+
title: 'Feature B Completed',
|
|
152
|
+
description: 'Successfully implemented feature B',
|
|
153
|
+
timestamp: 1752707800,
|
|
154
|
+
trigger: 'manual',
|
|
155
|
+
triggeredBy: 'human:developer',
|
|
156
|
+
reason: 'All requirements met',
|
|
157
|
+
riskLevel: 'low'
|
|
158
|
+
};
|
|
159
|
+
const checksum1 = calculatePayloadChecksum(changelog1);
|
|
160
|
+
const checksum2 = calculatePayloadChecksum(changelog2);
|
|
161
|
+
expect(checksum1).not.toBe(checksum2);
|
|
162
|
+
expect(checksum1).toMatch(/^[a-f0-9]{64}$/);
|
|
163
|
+
expect(checksum2).toMatch(/^[a-f0-9]{64}$/);
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
//# sourceMappingURL=checksum.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checksum.test.js","sourceRoot":"","sources":["../../../src/crypto/checksum.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/crypto/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { GitGovRecordPayload, Signature } from "../types";
|
|
2
|
+
/**
|
|
3
|
+
* Generates a new Ed25519 key pair.
|
|
4
|
+
* @returns A promise that resolves to an object with publicKey and privateKey in base64 format.
|
|
5
|
+
*/
|
|
6
|
+
export declare function generateKeys(): Promise<{
|
|
7
|
+
publicKey: string;
|
|
8
|
+
privateKey: string;
|
|
9
|
+
}>;
|
|
10
|
+
/**
|
|
11
|
+
* Creates a signature for a given payload.
|
|
12
|
+
*/
|
|
13
|
+
export declare function signPayload(payload: GitGovRecordPayload, privateKey: string, keyId: string, role: string): Signature;
|
|
14
|
+
/**
|
|
15
|
+
* Verifies all signatures on a record.
|
|
16
|
+
*/
|
|
17
|
+
export declare function verifySignatures(record: {
|
|
18
|
+
header: {
|
|
19
|
+
payloadChecksum: string;
|
|
20
|
+
signatures: Signature[];
|
|
21
|
+
};
|
|
22
|
+
payload: GitGovRecordPayload;
|
|
23
|
+
}, getActorPublicKey: (keyId: string) => Promise<string | null>): Promise<boolean>;
|
|
24
|
+
//# sourceMappingURL=signatures.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signatures.d.ts","sourceRoot":"","sources":["../../../src/crypto/signatures.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,mBAAmB,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAK/D;;;GAGG;AACH,wBAAsB,YAAY,IAAI,OAAO,CAAC;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;CAAE,CAAC,CASxF;AAED;;GAEG;AACH,wBAAgB,WAAW,CACzB,OAAO,EAAE,mBAAmB,EAC5B,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,GACX,SAAS,CAqBX;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,MAAM,EAAE;IAAE,MAAM,EAAE;QAAE,eAAe,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,SAAS,EAAE,CAAA;KAAE,CAAC;IAAC,OAAO,EAAE,mBAAmB,CAAA;CAAE,EACtG,iBAAiB,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,GAC3D,OAAO,CAAC,OAAO,CAAC,CA6BlB"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { generateKeyPair, sign, verify, createHash } from "crypto";
|
|
2
|
+
import { promisify } from "util";
|
|
3
|
+
import { calculatePayloadChecksum } from "./checksum";
|
|
4
|
+
import { createLogger } from "../logger";
|
|
5
|
+
const logger = createLogger("[CryptoModule] ");
|
|
6
|
+
const generateKeyPairAsync = promisify(generateKeyPair);
|
|
7
|
+
/**
|
|
8
|
+
* Generates a new Ed25519 key pair.
|
|
9
|
+
* @returns A promise that resolves to an object with publicKey and privateKey in base64 format.
|
|
10
|
+
*/
|
|
11
|
+
export async function generateKeys() {
|
|
12
|
+
const { publicKey, privateKey } = await generateKeyPairAsync('ed25519', {
|
|
13
|
+
publicKeyEncoding: { type: 'spki', format: 'pem' },
|
|
14
|
+
privateKeyEncoding: { type: 'pkcs8', format: 'pem' },
|
|
15
|
+
});
|
|
16
|
+
return {
|
|
17
|
+
publicKey: Buffer.from(publicKey).toString('base64'),
|
|
18
|
+
privateKey: Buffer.from(privateKey).toString('base64'),
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Creates a signature for a given payload.
|
|
23
|
+
*/
|
|
24
|
+
export function signPayload(payload, privateKey, keyId, role) {
|
|
25
|
+
const payloadChecksum = calculatePayloadChecksum(payload);
|
|
26
|
+
const timestamp = Math.floor(Date.now() / 1000);
|
|
27
|
+
const digest = `${payloadChecksum}:${keyId}:${role}:${timestamp}`;
|
|
28
|
+
// Per the blueprint, sign the SHA-256 hash of the digest
|
|
29
|
+
const digestHash = createHash('sha256').update(digest).digest();
|
|
30
|
+
const signature = sign(null, digestHash, {
|
|
31
|
+
key: Buffer.from(privateKey, 'base64'),
|
|
32
|
+
type: 'pkcs8',
|
|
33
|
+
format: 'pem'
|
|
34
|
+
});
|
|
35
|
+
return {
|
|
36
|
+
keyId,
|
|
37
|
+
role,
|
|
38
|
+
signature: signature.toString('base64'),
|
|
39
|
+
timestamp,
|
|
40
|
+
timestamp_iso: new Date(timestamp * 1000).toISOString(),
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Verifies all signatures on a record.
|
|
45
|
+
*/
|
|
46
|
+
export async function verifySignatures(record, getActorPublicKey) {
|
|
47
|
+
for (const signature of record.header.signatures) {
|
|
48
|
+
const publicKey = await getActorPublicKey(signature.keyId);
|
|
49
|
+
if (!publicKey) {
|
|
50
|
+
logger.warn(`Public key not found for actor: ${signature.keyId}`);
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
const digest = `${record.header.payloadChecksum}:${signature.keyId}:${signature.role}:${signature.timestamp}`;
|
|
54
|
+
// Per the blueprint, verify against the SHA-256 hash of the digest
|
|
55
|
+
const digestHash = createHash('sha256').update(digest).digest();
|
|
56
|
+
const isValid = verify(null, digestHash, {
|
|
57
|
+
key: Buffer.from(publicKey, 'base64'),
|
|
58
|
+
type: 'spki',
|
|
59
|
+
format: 'pem'
|
|
60
|
+
}, Buffer.from(signature.signature, 'base64'));
|
|
61
|
+
if (!isValid) {
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return true;
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=signatures.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signatures.js","sourceRoot":"","sources":["../../../src/crypto/signatures.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signatures.test.d.ts","sourceRoot":"","sources":["../../../src/crypto/signatures.test.ts"],"names":[],"mappings":""}
|