@cstack-protocol/pingala 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/.agent/CSD.md +39 -0
- package/.agent/MANIFEST.md +4 -0
- package/.agent/MANIFEST.md.template +4 -0
- package/.agent/agent-contractor.md +45 -0
- package/.agent/architecture/consent-model-fsm.md +77 -0
- package/.agent/architecture/governor-maturity-fsm.md +101 -0
- package/.agent/architecture/governor-validation-fsm.md +106 -0
- package/.agent/architecture/humanized-audit-fsm.md +76 -0
- package/.agent/architecture/pingala-csi-fsm.md +81 -0
- package/.agent/architecture.md +34 -0
- package/.agent/behavior.md +29 -0
- package/.agent/compute.md +32 -0
- package/.agent/consent-prompts.md +41 -0
- package/.agent/governance.yaml +5 -0
- package/.agent/identity.md +29 -0
- package/.agent/knowledge-lattice.json +96 -0
- package/.agent/knowledge-lattice.md +53 -0
- package/.agent/lattice-viz.html +157 -0
- package/.agent/mission.md +37 -0
- package/.agent/pairing-protocol.md +89 -0
- package/.agent/pairing.csp +108 -0
- package/.agent/personas/reflective-operator.md +67 -0
- package/.agent/personas/research.md +62 -0
- package/.agent/pingala.md +47 -0
- package/.agent/roadmap.md +56 -0
- package/.agent/scripts/lattice-extract.py +100 -0
- package/.agent/scripts/sync-agents.sh +82 -0
- package/.agent/scripts/vault-ingest.py +80 -0
- package/.agent/seo-strategy.md +71 -0
- package/.agent/skills/agent-orchestrator/SKILL.md +22 -0
- package/.agent/skills/agent-orchestrator/scripts/sync-agents.sh +61 -0
- package/.agent/skills/knowledge-lattice/SKILL.md +23 -0
- package/.agent/skills/knowledge-lattice/scripts/lattice-extract.py +107 -0
- package/.agent/skills/resource-vault/SKILL.md +30 -0
- package/.agent/skills/resource-vault/scripts/vault-ingest.py +80 -0
- package/.agent/skills/sites-integrity/SKILL.md +28 -0
- package/.agent/skills/stack-auditor/SKILL.md +25 -0
- package/.agent/sources.md +20 -0
- package/.agent/stack-auditor.md +47 -0
- package/.agent/standards.md +36 -0
- package/.agent/strategy.md +65 -0
- package/.agent/vault-schema.md +53 -0
- package/.agent/voice.md +27 -0
- package/.agent/workflows/sync-agents.md +14 -0
- package/.env.example +5 -0
- package/.env.production +3 -0
- package/DISTRIBUTION-PLAN.md +33 -0
- package/HOSTED_SETUP.md +54 -0
- package/LANDING_PAGE_DESIGN.md +46 -0
- package/MANUAL_VERCEL_STEPS.md +39 -0
- package/PRODUCT-ROADMAP.md +241 -0
- package/PROVISIONING_GUIDE.md +39 -0
- package/README.md +38 -0
- package/ROADMAP.md +21 -0
- package/SYNC-ENGINE-SPEC.md +257 -0
- package/build/core/531-protocol.d.ts +26 -0
- package/build/core/531-protocol.js +87 -0
- package/build/core/531-protocol.js.map +1 -0
- package/build/core/531-rule.d.ts +26 -0
- package/build/core/531-rule.js +106 -0
- package/build/core/531-rule.js.map +1 -0
- package/build/core/auth.d.ts +1 -0
- package/build/core/auth.js +24 -0
- package/build/core/auth.js.map +1 -0
- package/build/core/consent-manager.d.ts +17 -0
- package/build/core/consent-manager.js +104 -0
- package/build/core/consent-manager.js.map +1 -0
- package/build/core/csp.d.ts +12 -0
- package/build/core/csp.js +20 -0
- package/build/core/csp.js.map +1 -0
- package/build/core/engagement-analyzer.d.ts +42 -0
- package/build/core/engagement-analyzer.js +71 -0
- package/build/core/engagement-analyzer.js.map +1 -0
- package/build/core/governor.d.ts +106 -0
- package/build/core/governor.js +405 -0
- package/build/core/governor.js.map +1 -0
- package/build/core/life-area-mapper.d.ts +39 -0
- package/build/core/life-area-mapper.js +73 -0
- package/build/core/life-area-mapper.js.map +1 -0
- package/build/core/methodology.d.ts +39 -0
- package/build/core/methodology.js +164 -0
- package/build/core/methodology.js.map +1 -0
- package/build/core/pingala.d.ts +31 -0
- package/build/core/pingala.js +56 -0
- package/build/core/pingala.js.map +1 -0
- package/build/core/sdk-adapter.d.ts +6 -0
- package/build/core/sdk-adapter.js +33 -0
- package/build/core/sdk-adapter.js.map +1 -0
- package/build/cs-agent-core/sdk/index.d.ts +6 -0
- package/build/cs-agent-core/sdk/index.js +18 -0
- package/build/cs-agent-core/sdk/index.js.map +1 -0
- package/build/cs-agent-core/sdk/patterns/index.d.ts +3 -0
- package/build/cs-agent-core/sdk/patterns/index.js +37 -0
- package/build/cs-agent-core/sdk/patterns/index.js.map +1 -0
- package/build/cs-agent-core/sdk/patterns/registry.d.ts +4 -0
- package/build/cs-agent-core/sdk/patterns/registry.js +80 -0
- package/build/cs-agent-core/sdk/patterns/registry.js.map +1 -0
- package/build/cs-agent-core/sdk/telemetry/buffer.d.ts +9 -0
- package/build/cs-agent-core/sdk/telemetry/buffer.js +47 -0
- package/build/cs-agent-core/sdk/telemetry/buffer.js.map +1 -0
- package/build/cs-agent-core/sdk/telemetry/scrubber.d.ts +3 -0
- package/build/cs-agent-core/sdk/telemetry/scrubber.js +13 -0
- package/build/cs-agent-core/sdk/telemetry/scrubber.js.map +1 -0
- package/build/cs-agent-core/sdk/telemetry/types.d.ts +50 -0
- package/build/cs-agent-core/sdk/telemetry/types.js +2 -0
- package/build/cs-agent-core/sdk/telemetry/types.js.map +1 -0
- package/build/cs-agent-core/sdk/types/decision.d.ts +18 -0
- package/build/cs-agent-core/sdk/types/decision.js +2 -0
- package/build/cs-agent-core/sdk/types/decision.js.map +1 -0
- package/build/cs-agent-core/sdk/types/index.d.ts +4 -0
- package/build/cs-agent-core/sdk/types/index.js +5 -0
- package/build/cs-agent-core/sdk/types/index.js.map +1 -0
- package/build/cs-agent-core/sdk/types/pattern.d.ts +17 -0
- package/build/cs-agent-core/sdk/types/pattern.js +2 -0
- package/build/cs-agent-core/sdk/types/pattern.js.map +1 -0
- package/build/cs-agent-core/sdk/types/stack.d.ts +8 -0
- package/build/cs-agent-core/sdk/types/stack.js +2 -0
- package/build/cs-agent-core/sdk/types/stack.js.map +1 -0
- package/build/cs-agent-core/sdk/types/tool.d.ts +9 -0
- package/build/cs-agent-core/sdk/types/tool.js +2 -0
- package/build/cs-agent-core/sdk/types/tool.js.map +1 -0
- package/build/cs-agent-core/sdk/validator/csi.d.ts +2 -0
- package/build/cs-agent-core/sdk/validator/csi.js +24 -0
- package/build/cs-agent-core/sdk/validator/csi.js.map +1 -0
- package/build/cs-agent-core/sdk/validator/index.d.ts +2 -0
- package/build/cs-agent-core/sdk/validator/index.js +3 -0
- package/build/cs-agent-core/sdk/validator/index.js.map +1 -0
- package/build/cs-agent-core/sdk/validator/rules/geometry.d.ts +11 -0
- package/build/cs-agent-core/sdk/validator/rules/geometry.js +22 -0
- package/build/cs-agent-core/sdk/validator/rules/geometry.js.map +1 -0
- package/build/cs-agent-core/sdk/validator/validate.d.ts +2 -0
- package/build/cs-agent-core/sdk/validator/validate.js +46 -0
- package/build/cs-agent-core/sdk/validator/validate.js.map +1 -0
- package/build/index.d.ts +2 -0
- package/build/index.js +444 -0
- package/build/index.js.map +1 -0
- package/build/pingala-mcp/src/core/531-rule.d.ts +26 -0
- package/build/pingala-mcp/src/core/531-rule.js +96 -0
- package/build/pingala-mcp/src/core/531-rule.js.map +1 -0
- package/build/pingala-mcp/src/core/auth.d.ts +1 -0
- package/build/pingala-mcp/src/core/auth.js +15 -0
- package/build/pingala-mcp/src/core/auth.js.map +1 -0
- package/build/pingala-mcp/src/core/consent-manager.d.ts +17 -0
- package/build/pingala-mcp/src/core/consent-manager.js +104 -0
- package/build/pingala-mcp/src/core/consent-manager.js.map +1 -0
- package/build/pingala-mcp/src/core/csp.d.ts +12 -0
- package/build/pingala-mcp/src/core/csp.js +20 -0
- package/build/pingala-mcp/src/core/csp.js.map +1 -0
- package/build/pingala-mcp/src/core/engagement-analyzer.d.ts +42 -0
- package/build/pingala-mcp/src/core/engagement-analyzer.js +71 -0
- package/build/pingala-mcp/src/core/engagement-analyzer.js.map +1 -0
- package/build/pingala-mcp/src/core/governor.d.ts +104 -0
- package/build/pingala-mcp/src/core/governor.js +359 -0
- package/build/pingala-mcp/src/core/governor.js.map +1 -0
- package/build/pingala-mcp/src/core/life-area-mapper.d.ts +39 -0
- package/build/pingala-mcp/src/core/life-area-mapper.js +73 -0
- package/build/pingala-mcp/src/core/life-area-mapper.js.map +1 -0
- package/build/pingala-mcp/src/core/methodology.d.ts +39 -0
- package/build/pingala-mcp/src/core/methodology.js +164 -0
- package/build/pingala-mcp/src/core/methodology.js.map +1 -0
- package/build/pingala-mcp/src/core/pingala.d.ts +25 -0
- package/build/pingala-mcp/src/core/pingala.js +56 -0
- package/build/pingala-mcp/src/core/pingala.js.map +1 -0
- package/build/pingala-mcp/src/core/sdk-adapter.d.ts +6 -0
- package/build/pingala-mcp/src/core/sdk-adapter.js +33 -0
- package/build/pingala-mcp/src/core/sdk-adapter.js.map +1 -0
- package/build/pingala-mcp/src/index.d.ts +1 -0
- package/build/pingala-mcp/src/index.js +221 -0
- package/build/pingala-mcp/src/index.js.map +1 -0
- package/build/pingala-mcp/src/test-l3.d.ts +1 -0
- package/build/pingala-mcp/src/test-l3.js +35 -0
- package/build/pingala-mcp/src/test-l3.js.map +1 -0
- package/build/pingala-mcp/src/tools/audit-workspace.d.ts +16 -0
- package/build/pingala-mcp/src/tools/audit-workspace.js +39 -0
- package/build/pingala-mcp/src/tools/audit-workspace.js.map +1 -0
- package/build/pingala-mcp/src/tools/calculate-csi.d.ts +24 -0
- package/build/pingala-mcp/src/tools/calculate-csi.js +29 -0
- package/build/pingala-mcp/src/tools/calculate-csi.js.map +1 -0
- package/build/pingala-mcp/src/tools/cs-audit.d.ts +54 -0
- package/build/pingala-mcp/src/tools/cs-audit.js +310 -0
- package/build/pingala-mcp/src/tools/cs-audit.js.map +1 -0
- package/build/pingala-mcp/src/tools/get-governance-context.d.ts +11 -0
- package/build/pingala-mcp/src/tools/get-governance-context.js +16 -0
- package/build/pingala-mcp/src/tools/get-governance-context.js.map +1 -0
- package/build/pingala-mcp/src/tools/validate-stack-change.d.ts +41 -0
- package/build/pingala-mcp/src/tools/validate-stack-change.js +35 -0
- package/build/pingala-mcp/src/tools/validate-stack-change.js.map +1 -0
- package/build/sdk/index.d.ts +6 -0
- package/build/sdk/index.js +18 -0
- package/build/sdk/index.js.map +1 -0
- package/build/sdk/patterns/index.d.ts +3 -0
- package/build/sdk/patterns/index.js +37 -0
- package/build/sdk/patterns/index.js.map +1 -0
- package/build/sdk/patterns/registry.d.ts +4 -0
- package/build/sdk/patterns/registry.js +80 -0
- package/build/sdk/patterns/registry.js.map +1 -0
- package/build/sdk/telemetry/buffer.d.ts +9 -0
- package/build/sdk/telemetry/buffer.js +47 -0
- package/build/sdk/telemetry/buffer.js.map +1 -0
- package/build/sdk/telemetry/scrubber.d.ts +3 -0
- package/build/sdk/telemetry/scrubber.js +13 -0
- package/build/sdk/telemetry/scrubber.js.map +1 -0
- package/build/sdk/telemetry/types.d.ts +50 -0
- package/build/sdk/telemetry/types.js +2 -0
- package/build/sdk/telemetry/types.js.map +1 -0
- package/build/sdk/types/decision.d.ts +18 -0
- package/build/sdk/types/decision.js +2 -0
- package/build/sdk/types/decision.js.map +1 -0
- package/build/sdk/types/index.d.ts +4 -0
- package/build/sdk/types/index.js +5 -0
- package/build/sdk/types/index.js.map +1 -0
- package/build/sdk/types/pattern.d.ts +17 -0
- package/build/sdk/types/pattern.js +2 -0
- package/build/sdk/types/pattern.js.map +1 -0
- package/build/sdk/types/stack.d.ts +8 -0
- package/build/sdk/types/stack.js +2 -0
- package/build/sdk/types/stack.js.map +1 -0
- package/build/sdk/types/tool.d.ts +9 -0
- package/build/sdk/types/tool.js +2 -0
- package/build/sdk/types/tool.js.map +1 -0
- package/build/sdk/validator/csi.d.ts +2 -0
- package/build/sdk/validator/csi.js +24 -0
- package/build/sdk/validator/csi.js.map +1 -0
- package/build/sdk/validator/index.d.ts +2 -0
- package/build/sdk/validator/index.js +3 -0
- package/build/sdk/validator/index.js.map +1 -0
- package/build/sdk/validator/rules/geometry.d.ts +11 -0
- package/build/sdk/validator/rules/geometry.js +22 -0
- package/build/sdk/validator/rules/geometry.js.map +1 -0
- package/build/sdk/validator/validate.d.ts +2 -0
- package/build/sdk/validator/validate.js +46 -0
- package/build/sdk/validator/validate.js.map +1 -0
- package/build/src/core/531-rule.d.ts +26 -0
- package/build/src/core/531-rule.js +96 -0
- package/build/src/core/531-rule.js.map +1 -0
- package/build/src/core/auth.d.ts +1 -0
- package/build/src/core/auth.js +15 -0
- package/build/src/core/auth.js.map +1 -0
- package/build/src/core/consent-manager.d.ts +17 -0
- package/build/src/core/consent-manager.js +104 -0
- package/build/src/core/consent-manager.js.map +1 -0
- package/build/src/core/csp.d.ts +12 -0
- package/build/src/core/csp.js +20 -0
- package/build/src/core/csp.js.map +1 -0
- package/build/src/core/engagement-analyzer.d.ts +42 -0
- package/build/src/core/engagement-analyzer.js +71 -0
- package/build/src/core/engagement-analyzer.js.map +1 -0
- package/build/src/core/governor.d.ts +104 -0
- package/build/src/core/governor.js +371 -0
- package/build/src/core/governor.js.map +1 -0
- package/build/src/core/life-area-mapper.d.ts +39 -0
- package/build/src/core/life-area-mapper.js +73 -0
- package/build/src/core/life-area-mapper.js.map +1 -0
- package/build/src/core/methodology.d.ts +39 -0
- package/build/src/core/methodology.js +164 -0
- package/build/src/core/methodology.js.map +1 -0
- package/build/src/core/pingala.d.ts +25 -0
- package/build/src/core/pingala.js +56 -0
- package/build/src/core/pingala.js.map +1 -0
- package/build/src/core/sdk-adapter.d.ts +8 -0
- package/build/src/core/sdk-adapter.js +34 -0
- package/build/src/core/sdk-adapter.js.map +1 -0
- package/build/src/index.d.ts +2 -0
- package/build/src/index.js +333 -0
- package/build/src/index.js.map +1 -0
- package/build/src/test-l3.d.ts +1 -0
- package/build/src/test-l3.js +35 -0
- package/build/src/test-l3.js.map +1 -0
- package/build/src/tools/audit-workspace.d.ts +16 -0
- package/build/src/tools/audit-workspace.js +39 -0
- package/build/src/tools/audit-workspace.js.map +1 -0
- package/build/src/tools/calculate-csi.d.ts +24 -0
- package/build/src/tools/calculate-csi.js +29 -0
- package/build/src/tools/calculate-csi.js.map +1 -0
- package/build/src/tools/cs-audit.d.ts +54 -0
- package/build/src/tools/cs-audit.js +310 -0
- package/build/src/tools/cs-audit.js.map +1 -0
- package/build/src/tools/get-governance-context.d.ts +11 -0
- package/build/src/tools/get-governance-context.js +16 -0
- package/build/src/tools/get-governance-context.js.map +1 -0
- package/build/src/tools/validate-stack-change.d.ts +41 -0
- package/build/src/tools/validate-stack-change.js +35 -0
- package/build/src/tools/validate-stack-change.js.map +1 -0
- package/build/test-l3.d.ts +1 -0
- package/build/test-l3.js +35 -0
- package/build/test-l3.js.map +1 -0
- package/build/tools/analyze-stack.d.ts +40 -0
- package/build/tools/analyze-stack.js +121 -0
- package/build/tools/analyze-stack.js.map +1 -0
- package/build/tools/audit-workspace.d.ts +16 -0
- package/build/tools/audit-workspace.js +39 -0
- package/build/tools/audit-workspace.js.map +1 -0
- package/build/tools/calculate-csi.d.ts +26 -0
- package/build/tools/calculate-csi.js +30 -0
- package/build/tools/calculate-csi.js.map +1 -0
- package/build/tools/cs-audit.d.ts +43 -0
- package/build/tools/cs-audit.js +330 -0
- package/build/tools/cs-audit.js.map +1 -0
- package/build/tools/get-governance-context.d.ts +11 -0
- package/build/tools/get-governance-context.js +61 -0
- package/build/tools/get-governance-context.js.map +1 -0
- package/build/tools/validate-stack-change.d.ts +41 -0
- package/build/tools/validate-stack-change.js +54 -0
- package/build/tools/validate-stack-change.js.map +1 -0
- package/package.json +34 -0
- package/scripts/cloud-bridge.js +62 -0
- package/scripts/generate-token.js +13 -0
- package/src/core/531-rule.ts +148 -0
- package/src/core/auth.ts +42 -0
- package/src/core/consent-manager.ts +134 -0
- package/src/core/csp.ts +40 -0
- package/src/core/engagement-analyzer.ts +122 -0
- package/src/core/governor.ts +522 -0
- package/src/core/life-area-mapper.ts +138 -0
- package/src/core/methodology.ts +256 -0
- package/src/core/pingala.ts +77 -0
- package/src/core/sdk-adapter.ts +52 -0
- package/src/index.ts +562 -0
- package/src/test-l3.ts +45 -0
- package/src/tools/analyze-stack.ts +153 -0
- package/src/tools/audit-workspace.ts +50 -0
- package/src/tools/calculate-csi.ts +38 -0
- package/src/tools/cs-audit.ts +384 -0
- package/src/tools/get-governance-context.ts +69 -0
- package/src/tools/validate-stack-change.ts +71 -0
- package/src/types.d.ts +2 -0
- package/tsconfig.json +40 -0
- package/vercel.json +15 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../sdk/patterns/index.ts"],"names":[],"mappings":"AACA,cAAc,eAAe,CAAC;AAE9B,MAAM,CAAC,MAAM,QAAQ,GAAqB;IACtC;QACI,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,0BAA0B;QAChC,IAAI,EAAE,OAAO;QACb,QAAQ,EAAE,UAAU;QACpB,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACpB,WAAW,EAAE,qEAAqE;QAClF,WAAW,EAAE,CAAC,sDAAsD,EAAE,gBAAgB,CAAC;QACvF,SAAS,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,uDAAuD,EAAE;QAChG,WAAW,EAAE,4CAA4C;KAC5D;IACD;QACI,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,aAAa;QACnB,IAAI,EAAE,YAAY;QAClB,QAAQ,EAAE,UAAU;QACpB,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC;QACrB,WAAW,EAAE,gEAAgE;QAC7E,WAAW,EAAE,CAAC,uBAAuB,CAAC;QACtC,SAAS,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,uDAAuD,EAAE;QAC3F,WAAW,EAAE,mCAAmC;KACnD;IACD;QACI,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,iBAAiB;QACvB,IAAI,EAAE,YAAY;QAClB,QAAQ,EAAE,UAAU;QACpB,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACpB,WAAW,EAAE,0DAA0D;QACvE,WAAW,EAAE,CAAC,sBAAsB,CAAC;QACrC,SAAS,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,oCAAoC,EAAE;QACxE,WAAW,EAAE,8CAA8C;KAC9D;CAEJ,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { FailurePattern } from '../types/pattern.js';
|
|
2
|
+
export declare function syncSignals(signals: any[]): Promise<boolean>;
|
|
3
|
+
export declare function getPatterns(): Promise<FailurePattern[]>;
|
|
4
|
+
export declare function getRegistryMode(): 'Authorized' | 'Public' | 'Disconnected';
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
const REGISTRY_URL = 'https://patterns.consciousstack.com/patterns.json';
|
|
2
|
+
const SIGNAL_URL = 'https://patterns.consciousstack.com/api/signals';
|
|
3
|
+
export async function syncSignals(signals) {
|
|
4
|
+
const apiKey = typeof process !== 'undefined' ? process.env.CSTACK_API_KEY : null;
|
|
5
|
+
if (!apiKey || signals.length === 0)
|
|
6
|
+
return false;
|
|
7
|
+
try {
|
|
8
|
+
const response = await fetch(SIGNAL_URL, {
|
|
9
|
+
method: 'POST',
|
|
10
|
+
headers: {
|
|
11
|
+
'Authorization': `Bearer ${apiKey}`,
|
|
12
|
+
'Content-Type': 'application/json'
|
|
13
|
+
},
|
|
14
|
+
body: JSON.stringify({ signals })
|
|
15
|
+
});
|
|
16
|
+
if (response.ok) {
|
|
17
|
+
console.log(`📡 CSTACK SDK: Successfully synced ${signals.length} signals to the moat.`);
|
|
18
|
+
return true;
|
|
19
|
+
}
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
catch (err) {
|
|
23
|
+
console.warn(`⚠️ CSTACK SDK: Failed to sync signals.`, err);
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
let cachedPatterns = null;
|
|
28
|
+
function mapPattern(raw) {
|
|
29
|
+
return {
|
|
30
|
+
id: raw.id,
|
|
31
|
+
name: raw.name,
|
|
32
|
+
type: raw.type,
|
|
33
|
+
severity: raw.severity,
|
|
34
|
+
csiImpact: raw.csi_impact || [0, 0],
|
|
35
|
+
description: raw.description,
|
|
36
|
+
seedPhrases: raw.seed_phrases || [],
|
|
37
|
+
detection: {
|
|
38
|
+
type: raw.detection?.type || 'heuristic',
|
|
39
|
+
logic: raw.detection?.logic || ''
|
|
40
|
+
},
|
|
41
|
+
remediation: raw.remediation
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
import { PATTERNS } from './index.js';
|
|
45
|
+
export async function getPatterns() {
|
|
46
|
+
if (cachedPatterns)
|
|
47
|
+
return cachedPatterns;
|
|
48
|
+
const apiKey = typeof process !== 'undefined' ? process.env.CSTACK_API_KEY : null;
|
|
49
|
+
try {
|
|
50
|
+
const headers = {
|
|
51
|
+
'Accept': 'application/json'
|
|
52
|
+
};
|
|
53
|
+
if (apiKey) {
|
|
54
|
+
headers['Authorization'] = `Bearer ${apiKey}`;
|
|
55
|
+
}
|
|
56
|
+
const response = await fetch(REGISTRY_URL, { headers });
|
|
57
|
+
if (response.status === 401 || response.status === 403) {
|
|
58
|
+
console.warn(`🗝️ CSTACK SDK: Unauthorized. Running in Local-Only mode. (Check your CSTACK_API_KEY)`);
|
|
59
|
+
return PATTERNS;
|
|
60
|
+
}
|
|
61
|
+
if (!response.ok)
|
|
62
|
+
throw new Error(`Registry fetch failed: ${response.statusText}`);
|
|
63
|
+
const rawPatterns = await response.json();
|
|
64
|
+
cachedPatterns = rawPatterns.map(mapPattern);
|
|
65
|
+
const mode = apiKey ? 'Authorized' : 'Public';
|
|
66
|
+
console.log(`📡 CSTACK SDK: Connected to live registry [${mode}] (${cachedPatterns?.length} patterns loaded).`);
|
|
67
|
+
return cachedPatterns;
|
|
68
|
+
}
|
|
69
|
+
catch (err) {
|
|
70
|
+
console.warn(`⚠️ CSTACK SDK: Falling back to local patterns. Network error or registry unavailable.`);
|
|
71
|
+
return PATTERNS;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
export function getRegistryMode() {
|
|
75
|
+
const apiKey = typeof process !== 'undefined' ? process.env.CSTACK_API_KEY : null;
|
|
76
|
+
if (apiKey)
|
|
77
|
+
return 'Authorized';
|
|
78
|
+
return 'Public';
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../sdk/patterns/registry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Signal, ConsentTier } from './types.js';
|
|
2
|
+
export interface TelemetryConfig {
|
|
3
|
+
consentTier: ConsentTier;
|
|
4
|
+
maxBufferSize?: number;
|
|
5
|
+
}
|
|
6
|
+
export declare function initTelemetry(config: TelemetryConfig): void;
|
|
7
|
+
export declare function recordSignal(signal: Signal): void;
|
|
8
|
+
export declare function getBufferedSignals(): Signal[];
|
|
9
|
+
export declare function clear(): void;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
class TelemetryBuffer {
|
|
2
|
+
signals = [];
|
|
3
|
+
config;
|
|
4
|
+
constructor(config) {
|
|
5
|
+
this.config = {
|
|
6
|
+
maxBufferSize: 100,
|
|
7
|
+
...config
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
push(signal) {
|
|
11
|
+
if (this.config.consentTier === 'observer')
|
|
12
|
+
return;
|
|
13
|
+
if (this.config.consentTier === 'contributor') {
|
|
14
|
+
if (signal.signalType === 'StackMutation' || signal.signalType === 'PatternMatch') {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
this.signals.push(signal);
|
|
19
|
+
if (this.signals.length > (this.config.maxBufferSize || 100)) {
|
|
20
|
+
this.signals.shift();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
getSignals() {
|
|
24
|
+
return [...this.signals];
|
|
25
|
+
}
|
|
26
|
+
clear() {
|
|
27
|
+
this.signals = [];
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
let globalBuffer = null;
|
|
31
|
+
export function initTelemetry(config) {
|
|
32
|
+
globalBuffer = new TelemetryBuffer(config);
|
|
33
|
+
}
|
|
34
|
+
export function recordSignal(signal) {
|
|
35
|
+
if (globalBuffer) {
|
|
36
|
+
globalBuffer.push(signal);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
export function getBufferedSignals() {
|
|
40
|
+
return globalBuffer ? globalBuffer.getSignals() : [];
|
|
41
|
+
}
|
|
42
|
+
export function clear() {
|
|
43
|
+
if (globalBuffer) {
|
|
44
|
+
globalBuffer.clear();
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=buffer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffer.js","sourceRoot":"","sources":["../../../sdk/telemetry/buffer.ts"],"names":[],"mappings":"AAOA,MAAM,eAAe;IACT,OAAO,GAAa,EAAE,CAAC;IACvB,MAAM,CAAkB;IAEhC,YAAY,MAAuB;QAC/B,IAAI,CAAC,MAAM,GAAG;YACV,aAAa,EAAE,GAAG;YAClB,GAAG,MAAM;SACZ,CAAC;IACN,CAAC;IAEM,IAAI,CAAC,MAAc;QACtB,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,KAAK,UAAU;YAAE,OAAO;QAGnD,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,KAAK,aAAa,EAAE,CAAC;YAC5C,IAAI,MAAM,CAAC,UAAU,KAAK,eAAe,IAAI,MAAM,CAAC,UAAU,KAAK,cAAc,EAAE,CAAC;gBAChF,OAAO;YACX,CAAC;QACL,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE1B,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,IAAI,GAAG,CAAC,EAAE,CAAC;YAC3D,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACzB,CAAC;IACL,CAAC;IAEM,UAAU;QACb,OAAO,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAEM,KAAK;QACR,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACtB,CAAC;CACJ;AAED,IAAI,YAAY,GAA2B,IAAI,CAAC;AAEhD,MAAM,UAAU,aAAa,CAAC,MAAuB;IACjD,YAAY,GAAG,IAAI,eAAe,CAAC,MAAM,CAAC,CAAC;AAC/C,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,MAAc;IACvC,IAAI,YAAY,EAAE,CAAC;QACf,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;AACL,CAAC;AAED,MAAM,UAAU,kBAAkB;IAC9B,OAAO,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,KAAK;IACjB,IAAI,YAAY,EAAE,CAAC;QACf,YAAY,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import * as crypto from 'crypto';
|
|
2
|
+
export function hashId(id, salt = '') {
|
|
3
|
+
return crypto.createHash('sha256').update(id + salt).digest('hex');
|
|
4
|
+
}
|
|
5
|
+
export function jitterTimestamp(timestamp) {
|
|
6
|
+
const jitterRangeMap = 300000;
|
|
7
|
+
const jitter = Math.floor(Math.random() * jitterRangeMap * 2) - jitterRangeMap;
|
|
8
|
+
return timestamp + jitter;
|
|
9
|
+
}
|
|
10
|
+
export function scrubToolName(category) {
|
|
11
|
+
return category;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=scrubber.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scrubber.js","sourceRoot":"","sources":["../../../sdk/telemetry/scrubber.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAKjC,MAAM,UAAU,MAAM,CAAC,EAAU,EAAE,OAAe,EAAE;IAChD,OAAO,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AACvE,CAAC;AAKD,MAAM,UAAU,eAAe,CAAC,SAAiB;IAC7C,MAAM,cAAc,GAAG,MAAM,CAAC;IAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,cAAc,GAAG,CAAC,CAAC,GAAG,cAAc,CAAC;IAC/E,OAAO,SAAS,GAAG,MAAM,CAAC;AAC9B,CAAC;AAKD,MAAM,UAAU,aAAa,CAAC,QAAgB;IAG1C,OAAO,QAAQ,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import type { StackRole } from '../types/tool.js';
|
|
2
|
+
export type SignalType = 'StackMutation' | 'GeometryShift' | 'PatternMatch' | 'GovernanceDecision';
|
|
3
|
+
export type ConsentTier = 'observer' | 'contributor' | 'sentinel';
|
|
4
|
+
export interface BaseSignal {
|
|
5
|
+
signalId: string;
|
|
6
|
+
signalType: SignalType;
|
|
7
|
+
timestamp: number;
|
|
8
|
+
operatorHash: string;
|
|
9
|
+
sessionId: string;
|
|
10
|
+
}
|
|
11
|
+
export interface StackMutationSignal extends BaseSignal {
|
|
12
|
+
signalType: 'StackMutation';
|
|
13
|
+
mutationType: 'add' | 'remove' | 'roleChange';
|
|
14
|
+
toolCategory: string;
|
|
15
|
+
previousRole?: StackRole;
|
|
16
|
+
newRole?: StackRole;
|
|
17
|
+
csiDelta: number;
|
|
18
|
+
}
|
|
19
|
+
export interface GeometryShiftSignal extends BaseSignal {
|
|
20
|
+
signalType: 'GeometryShift';
|
|
21
|
+
previousGeometry: {
|
|
22
|
+
anchor: number;
|
|
23
|
+
utility: number;
|
|
24
|
+
periphery: number;
|
|
25
|
+
};
|
|
26
|
+
newGeometry: {
|
|
27
|
+
anchor: number;
|
|
28
|
+
utility: number;
|
|
29
|
+
periphery: number;
|
|
30
|
+
};
|
|
31
|
+
wasValid: boolean;
|
|
32
|
+
isValid: boolean;
|
|
33
|
+
}
|
|
34
|
+
export interface PatternMatchSignal extends BaseSignal {
|
|
35
|
+
signalType: 'PatternMatch';
|
|
36
|
+
patternId: string;
|
|
37
|
+
patternType: 'drift' | 'discipline' | 'structural';
|
|
38
|
+
severity: 'critical' | 'warning' | 'info';
|
|
39
|
+
csiImpact: number;
|
|
40
|
+
}
|
|
41
|
+
export interface GovernanceDecisionSignal extends BaseSignal {
|
|
42
|
+
signalType: 'GovernanceDecision';
|
|
43
|
+
previousStatus?: 'approved' | 'warning' | 'blocked';
|
|
44
|
+
newStatus: 'approved' | 'warning' | 'blocked';
|
|
45
|
+
previousCsi?: number;
|
|
46
|
+
newCsi: number;
|
|
47
|
+
violationCount: number;
|
|
48
|
+
warningCount: number;
|
|
49
|
+
}
|
|
50
|
+
export type Signal = StackMutationSignal | GeometryShiftSignal | PatternMatchSignal | GovernanceDecisionSignal;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../sdk/telemetry/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { FailurePattern } from './pattern.js';
|
|
2
|
+
export type DecisionStatus = 'approved' | 'warning' | 'blocked';
|
|
3
|
+
export interface GovernanceDecision {
|
|
4
|
+
status: DecisionStatus;
|
|
5
|
+
csi: number;
|
|
6
|
+
violations: FailurePattern[];
|
|
7
|
+
warnings: FailurePattern[];
|
|
8
|
+
recommendations: string[];
|
|
9
|
+
reasoning: string;
|
|
10
|
+
}
|
|
11
|
+
export interface CSI {
|
|
12
|
+
score: number;
|
|
13
|
+
components: {
|
|
14
|
+
geometryScore: number;
|
|
15
|
+
patternScore: number;
|
|
16
|
+
balanceScore: number;
|
|
17
|
+
};
|
|
18
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"decision.js","sourceRoot":"","sources":["../../../sdk/types/decision.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../sdk/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,eAAe,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export type PatternType = 'drift' | 'discipline' | 'structural';
|
|
2
|
+
export type Severity = 'critical' | 'warning' | 'info';
|
|
3
|
+
export interface PatternDetection {
|
|
4
|
+
type: 'rule' | 'heuristic';
|
|
5
|
+
logic: string;
|
|
6
|
+
}
|
|
7
|
+
export interface FailurePattern {
|
|
8
|
+
id: string;
|
|
9
|
+
name: string;
|
|
10
|
+
type: PatternType;
|
|
11
|
+
description: string;
|
|
12
|
+
severity: Severity;
|
|
13
|
+
csiImpact: [number, number];
|
|
14
|
+
seedPhrases: string[];
|
|
15
|
+
detection: PatternDetection;
|
|
16
|
+
remediation: string;
|
|
17
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pattern.js","sourceRoot":"","sources":["../../../sdk/types/pattern.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stack.js","sourceRoot":"","sources":["../../../sdk/types/stack.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool.js","sourceRoot":"","sources":["../../../sdk/types/tool.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { checkGeometry } from './rules/geometry.js';
|
|
2
|
+
export function calculateCSI(stack) {
|
|
3
|
+
const geometry = checkGeometry(stack);
|
|
4
|
+
let geometryScore = 0;
|
|
5
|
+
if (geometry.counts.anchor === 1)
|
|
6
|
+
geometryScore += 15;
|
|
7
|
+
if (geometry.counts.utility <= 3 && geometry.counts.utility > 0)
|
|
8
|
+
geometryScore += 15;
|
|
9
|
+
if (geometry.counts.periphery <= 5)
|
|
10
|
+
geometryScore += 10;
|
|
11
|
+
let patternScore = 40;
|
|
12
|
+
if (!geometry.isValid)
|
|
13
|
+
patternScore -= 10;
|
|
14
|
+
const balanceScore = 20;
|
|
15
|
+
return {
|
|
16
|
+
score: geometryScore + patternScore + balanceScore,
|
|
17
|
+
components: {
|
|
18
|
+
geometryScore,
|
|
19
|
+
patternScore,
|
|
20
|
+
balanceScore
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=csi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"csi.js","sourceRoot":"","sources":["../../../sdk/validator/csi.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,MAAM,UAAU,YAAY,CAAC,KAAmB;IAC5C,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;IAGtC,IAAI,aAAa,GAAG,CAAC,CAAC;IACtB,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,aAAa,IAAI,EAAE,CAAC;IACtD,IAAI,QAAQ,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,OAAO,GAAG,CAAC;QAAE,aAAa,IAAI,EAAE,CAAC;IACrF,IAAI,QAAQ,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC;QAAE,aAAa,IAAI,EAAE,CAAC;IAIxD,IAAI,YAAY,GAAG,EAAE,CAAC;IACtB,IAAI,CAAC,QAAQ,CAAC,OAAO;QAAE,YAAY,IAAI,EAAE,CAAC;IAG1C,MAAM,YAAY,GAAG,EAAE,CAAC;IAExB,OAAO;QACH,KAAK,EAAE,aAAa,GAAG,YAAY,GAAG,YAAY;QAClD,UAAU,EAAE;YACR,aAAa;YACb,YAAY;YACZ,YAAY;SACf;KACJ,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../sdk/validator/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,UAAU,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { StackProfile } from '../../types/index.js';
|
|
2
|
+
export interface GeometryCheck {
|
|
3
|
+
isValid: boolean;
|
|
4
|
+
counts: {
|
|
5
|
+
anchor: number;
|
|
6
|
+
utility: number;
|
|
7
|
+
periphery: number;
|
|
8
|
+
};
|
|
9
|
+
violations: string[];
|
|
10
|
+
}
|
|
11
|
+
export declare function checkGeometry(stack: StackProfile): GeometryCheck;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export function checkGeometry(stack) {
|
|
2
|
+
const counts = {
|
|
3
|
+
anchor: stack.tools.filter((t) => t.role === 'anchor').length,
|
|
4
|
+
utility: stack.tools.filter((t) => t.role === 'utility').length,
|
|
5
|
+
periphery: stack.tools.filter((t) => t.role === 'periphery').length,
|
|
6
|
+
};
|
|
7
|
+
const violations = [];
|
|
8
|
+
if (counts.anchor === 0)
|
|
9
|
+
violations.push('No Anchor defined.');
|
|
10
|
+
if (counts.anchor > 1)
|
|
11
|
+
violations.push('Multiple Anchors defined (Duplicate Anchor).');
|
|
12
|
+
if (counts.utility > 3)
|
|
13
|
+
violations.push(`Too many Utilities (${counts.utility}/3).`);
|
|
14
|
+
if (counts.periphery > 5)
|
|
15
|
+
violations.push(`Too many Peripheries (${counts.periphery}/5).`);
|
|
16
|
+
return {
|
|
17
|
+
isValid: violations.length === 0,
|
|
18
|
+
counts,
|
|
19
|
+
violations
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=geometry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"geometry.js","sourceRoot":"","sources":["../../../../sdk/validator/rules/geometry.ts"],"names":[],"mappings":"AAYA,MAAM,UAAU,aAAa,CAAC,KAAmB;IAC7C,MAAM,MAAM,GAAG;QACX,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAO,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,MAAM;QACnE,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAO,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,MAAM;QACrE,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAO,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,MAAM;KAC5E,CAAC;IAEF,MAAM,UAAU,GAAa,EAAE,CAAC;IAEhC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,UAAU,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IAC/D,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC;QAAE,UAAU,CAAC,IAAI,CAAC,8CAA8C,CAAC,CAAC;IACvF,IAAI,MAAM,CAAC,OAAO,GAAG,CAAC;QAAE,UAAU,CAAC,IAAI,CAAC,uBAAuB,MAAM,CAAC,OAAO,MAAM,CAAC,CAAC;IACrF,IAAI,MAAM,CAAC,SAAS,GAAG,CAAC;QAAE,UAAU,CAAC,IAAI,CAAC,yBAAyB,MAAM,CAAC,SAAS,MAAM,CAAC,CAAC;IAE3F,OAAO;QACH,OAAO,EAAE,UAAU,CAAC,MAAM,KAAK,CAAC;QAChC,MAAM;QACN,UAAU;KACb,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import * as crypto from 'crypto';
|
|
2
|
+
import { calculateCSI } from './csi.js';
|
|
3
|
+
import { checkGeometry } from './rules/geometry.js';
|
|
4
|
+
import { getPatterns } from '../patterns/registry.js';
|
|
5
|
+
import { recordSignal } from '../telemetry/buffer.js';
|
|
6
|
+
import { hashId, jitterTimestamp } from '../telemetry/scrubber.js';
|
|
7
|
+
export async function validate(stack) {
|
|
8
|
+
const csi = calculateCSI(stack);
|
|
9
|
+
const geometry = checkGeometry(stack);
|
|
10
|
+
const patterns = await getPatterns();
|
|
11
|
+
const violations = [];
|
|
12
|
+
const warnings = [];
|
|
13
|
+
const recommendations = [];
|
|
14
|
+
if (geometry.counts.anchor === 0) {
|
|
15
|
+
const p = patterns.find(p => p.id === 'SP-001');
|
|
16
|
+
if (p)
|
|
17
|
+
violations.push(p);
|
|
18
|
+
}
|
|
19
|
+
if (!geometry.isValid) {
|
|
20
|
+
const p = patterns.find(p => p.id === 'SP-002');
|
|
21
|
+
if (p)
|
|
22
|
+
violations.push(p);
|
|
23
|
+
recommendations.push(...geometry.violations);
|
|
24
|
+
}
|
|
25
|
+
const status = violations.length > 0 ? 'blocked' : (warnings.length > 0 ? 'warning' : 'approved');
|
|
26
|
+
recordSignal({
|
|
27
|
+
signalId: crypto.randomUUID(),
|
|
28
|
+
signalType: 'GovernanceDecision',
|
|
29
|
+
timestamp: jitterTimestamp(Date.now()),
|
|
30
|
+
operatorHash: hashId(stack.operatorId || 'anonymous'),
|
|
31
|
+
sessionId: 'session-local',
|
|
32
|
+
newStatus: status,
|
|
33
|
+
newCsi: csi.score,
|
|
34
|
+
violationCount: violations.length,
|
|
35
|
+
warningCount: warnings.length
|
|
36
|
+
});
|
|
37
|
+
return {
|
|
38
|
+
status,
|
|
39
|
+
csi: csi.score,
|
|
40
|
+
violations,
|
|
41
|
+
warnings,
|
|
42
|
+
recommendations,
|
|
43
|
+
reasoning: status === 'approved' ? 'Stack adheres to CSP guidelines.' : `Stack drift detected: ${recommendations.join(', ')}`
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=validate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.js","sourceRoot":"","sources":["../../../sdk/validator/validate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAEjC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAEnE,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,KAAmB;IAC9C,MAAM,GAAG,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;IAChC,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;IACtC,MAAM,QAAQ,GAAG,MAAM,WAAW,EAAE,CAAC;IAErC,MAAM,UAAU,GAAqB,EAAE,CAAC;IACxC,MAAM,QAAQ,GAAqB,EAAE,CAAC;IACtC,MAAM,eAAe,GAAa,EAAE,CAAC;IAGrC,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/B,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC;QAChD,IAAI,CAAC;YAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QACpB,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC;QAChD,IAAI,CAAC;YAAE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1B,eAAe,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;IACjD,CAAC;IAED,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IAGlG,YAAY,CAAC;QACT,QAAQ,EAAE,MAAM,CAAC,UAAU,EAAE;QAC7B,UAAU,EAAE,oBAAoB;QAChC,SAAS,EAAE,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QACtC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,UAAU,IAAI,WAAW,CAAC;QACrD,SAAS,EAAE,eAAe;QAC1B,SAAS,EAAE,MAAM;QACjB,MAAM,EAAE,GAAG,CAAC,KAAK;QACjB,cAAc,EAAE,UAAU,CAAC,MAAM;QACjC,YAAY,EAAE,QAAQ,CAAC,MAAM;KAChC,CAAC,CAAC;IAEH,OAAO;QACH,MAAM;QACN,GAAG,EAAE,GAAG,CAAC,KAAK;QACd,UAAU;QACV,QAAQ;QACR,eAAe;QACf,SAAS,EAAE,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,kCAAkC,CAAC,CAAC,CAAC,yBAAyB,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;KAChI,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export interface ToolInstance {
|
|
2
|
+
name: string;
|
|
3
|
+
category: string;
|
|
4
|
+
role: 'Anchor' | 'Active' | 'Supporting' | 'Unknown';
|
|
5
|
+
functionId?: string;
|
|
6
|
+
contexts?: string[];
|
|
7
|
+
isAdapter?: boolean;
|
|
8
|
+
}
|
|
9
|
+
export interface StackConfiguration {
|
|
10
|
+
tools: ToolInstance[];
|
|
11
|
+
}
|
|
12
|
+
export interface ValidationResult {
|
|
13
|
+
isValid: boolean;
|
|
14
|
+
score: number;
|
|
15
|
+
violations: string[];
|
|
16
|
+
recommendations: string[];
|
|
17
|
+
}
|
|
18
|
+
export declare class Rule531 {
|
|
19
|
+
static readonly LIMITS: {
|
|
20
|
+
Anchor: number;
|
|
21
|
+
Active: number;
|
|
22
|
+
Support: number;
|
|
23
|
+
Total: number;
|
|
24
|
+
};
|
|
25
|
+
static validate(config: StackConfiguration): ValidationResult;
|
|
26
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
export class Rule531 {
|
|
2
|
+
static LIMITS = {
|
|
3
|
+
Anchor: 1,
|
|
4
|
+
Active: 3,
|
|
5
|
+
Support: 5,
|
|
6
|
+
Total: 9
|
|
7
|
+
};
|
|
8
|
+
static validate(config) {
|
|
9
|
+
const violations = [];
|
|
10
|
+
const recommendations = [];
|
|
11
|
+
const functionalNodes = {};
|
|
12
|
+
const unclassifiedTools = [];
|
|
13
|
+
config.tools.forEach(t => {
|
|
14
|
+
if (t.functionId) {
|
|
15
|
+
if (!functionalNodes[t.functionId])
|
|
16
|
+
functionalNodes[t.functionId] = [];
|
|
17
|
+
functionalNodes[t.functionId].push(t);
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
unclassifiedTools.push(t);
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
const getRoleForNode = (tools) => {
|
|
24
|
+
if (tools.some(t => t.role === 'Anchor'))
|
|
25
|
+
return 'Anchor';
|
|
26
|
+
if (tools.some(t => t.role === 'Active'))
|
|
27
|
+
return 'Active';
|
|
28
|
+
if (tools.some(t => t.role === 'Supporting'))
|
|
29
|
+
return 'Supporting';
|
|
30
|
+
return 'Unknown';
|
|
31
|
+
};
|
|
32
|
+
const nodeCounts = {
|
|
33
|
+
Anchor: 0,
|
|
34
|
+
Active: 0,
|
|
35
|
+
Supporting: 0,
|
|
36
|
+
Unknown: 0
|
|
37
|
+
};
|
|
38
|
+
Object.entries(functionalNodes).forEach(([id, tools]) => {
|
|
39
|
+
const role = getRoleForNode(tools);
|
|
40
|
+
if (tools.length > 1) {
|
|
41
|
+
const hasAnchor = tools.some(t => t.role === 'Anchor');
|
|
42
|
+
if (!hasAnchor) {
|
|
43
|
+
violations.push(`Sub-stack Violation: Functional Node '${id}' contains ${tools.length} tools but has no designated Anchor.`);
|
|
44
|
+
}
|
|
45
|
+
if (tools.length > this.LIMITS.Total) {
|
|
46
|
+
violations.push(`Sub-stack Congestion: Functional Node '${id}' exceeds the Rule of 9.`);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
if (role === 'Anchor')
|
|
50
|
+
nodeCounts.Anchor++;
|
|
51
|
+
else if (role === 'Active')
|
|
52
|
+
nodeCounts.Active++;
|
|
53
|
+
else if (role === 'Supporting')
|
|
54
|
+
nodeCounts.Supporting++;
|
|
55
|
+
else
|
|
56
|
+
nodeCounts.Unknown++;
|
|
57
|
+
});
|
|
58
|
+
unclassifiedTools.forEach(t => {
|
|
59
|
+
if (t.role === 'Anchor')
|
|
60
|
+
nodeCounts.Anchor++;
|
|
61
|
+
else if (t.role === 'Active')
|
|
62
|
+
nodeCounts.Active++;
|
|
63
|
+
else if (t.role === 'Supporting')
|
|
64
|
+
nodeCounts.Supporting++;
|
|
65
|
+
else
|
|
66
|
+
nodeCounts.Unknown++;
|
|
67
|
+
});
|
|
68
|
+
if (nodeCounts.Anchor > this.LIMITS.Anchor) {
|
|
69
|
+
violations.push(`Protocol Violation: Too many Anchor Nodes (${nodeCounts.Anchor}). Only ${this.LIMITS.Anchor} is allowed in the Core Stack.`);
|
|
70
|
+
}
|
|
71
|
+
else if (nodeCounts.Anchor === 0) {
|
|
72
|
+
recommendations.push("Identify a single 'Anchor' node to serve as your system's center of truth.");
|
|
73
|
+
}
|
|
74
|
+
if (nodeCounts.Active > this.LIMITS.Active) {
|
|
75
|
+
violations.push(`Protocol Violation: Too many Active Nodes (${nodeCounts.Active}). Limit is ${this.LIMITS.Active}. Cluster secondary active tools into sub-stacks.`);
|
|
76
|
+
}
|
|
77
|
+
if (nodeCounts.Supporting > this.LIMITS.Support) {
|
|
78
|
+
violations.push(`Protocol Violation: Too many Supporting Nodes (${nodeCounts.Supporting}). Limit is ${this.LIMITS.Support}.`);
|
|
79
|
+
}
|
|
80
|
+
const totalNodes = nodeCounts.Anchor + nodeCounts.Active + nodeCounts.Supporting;
|
|
81
|
+
if (totalNodes > this.LIMITS.Total) {
|
|
82
|
+
violations.push(`Stack Drift: Total Functional Slots (${totalNodes}) exceeds the Rule of 9. Move non-core functions into sub-stacks of existing nodes.`);
|
|
83
|
+
}
|
|
84
|
+
let score = 100;
|
|
85
|
+
score -= violations.length * 15;
|
|
86
|
+
score -= nodeCounts.Unknown * 5;
|
|
87
|
+
score = Math.max(0, score);
|
|
88
|
+
return {
|
|
89
|
+
isValid: violations.length === 0,
|
|
90
|
+
score,
|
|
91
|
+
violations,
|
|
92
|
+
recommendations
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=531-rule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"531-rule.js","sourceRoot":"","sources":["../../../src/core/531-rule.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const validateToken: (req: any, res: any, next: any) => any;
|