@evolith/core-domain 1.0.0 → 1.0.1
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/dist/domain/services/default-workflow-definition.js +1 -1
- package/dist/domain/services/default-workflow-definition.js.map +1 -1
- package/package.json +2 -1
- package/rulesets/README.es.md +170 -0
- package/rulesets/README.md +170 -0
- package/rulesets/acl/README.es.md +41 -0
- package/rulesets/acl/README.md +41 -0
- package/rulesets/acl/anti-corruption-layer.rules.es.json +99 -0
- package/rulesets/acl/anti-corruption-layer.rules.json +99 -0
- package/rulesets/adr/ADR_COVERAGE.es.md +133 -0
- package/rulesets/adr/ADR_COVERAGE.md +133 -0
- package/rulesets/adr/README.es.md +17 -0
- package/rulesets/adr/README.md +17 -0
- package/rulesets/adr/adr-0002-hexagonal-architecture.rules.json +103 -0
- package/rulesets/adr/adr-0005-cicd-quality-gates.rules.json +102 -0
- package/rulesets/adr/adr-0010-multi-tenancy.rules.json +129 -0
- package/rulesets/adr/adr-0018-testing-pyramid.rules.json +115 -0
- package/rulesets/adr/adr-0032-protocol-selection.rules.json +134 -0
- package/rulesets/adr/adr-0040-multi-runtime.rules.json +131 -0
- package/rulesets/adr/adr-0050-gitflow-branching.rules.json +176 -0
- package/rulesets/adr/generated/adr-0001-monorepo-orchestration-principle.rules.json +29 -0
- package/rulesets/adr/generated/adr-0006-microservices-transition-via-sidecar-pattern.rules.json +29 -0
- package/rulesets/adr/generated/adr-0009-strict-dependency-pinning-and-automated-vulnerability-manage.rules.json +29 -0
- package/rulesets/adr/generated/adr-0011-fault-tolerance-and-resiliency-patterns.rules.json +29 -0
- package/rulesets/adr/generated/adr-0013-cloud-infrastructure-topology-and-disaster-recovery-dr.rules.json +28 -0
- package/rulesets/adr/generated/adr-0014-multi-layer-distributed-caching-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0015-event-driven-architecture-eda-for-intra-domain-communication.rules.json +29 -0
- package/rulesets/adr/generated/adr-0016-immutable-business-audit-trail-and-change-tracking.rules.json +29 -0
- package/rulesets/adr/generated/adr-0017-feature-flagging-strategy-for-progressive-delivery.rules.json +28 -0
- package/rulesets/adr/generated/adr-0019-tactical-design-patterns-for-future-proofing.rules.json +29 -0
- package/rulesets/adr/generated/adr-0020-identity-provider-abstraction-strategy.rules.json +28 -0
- package/rulesets/adr/generated/adr-0024-centralized-configuration-feature-platform.rules.json +28 -0
- package/rulesets/adr/generated/adr-0025-feature-flag-provider-abstraction-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0028-self-hosted-open-source-hybrid-infrastructure.rules.json +29 -0
- package/rulesets/adr/generated/adr-0030-two-tier-distributed-gateway-model.rules.json +28 -0
- package/rulesets/adr/generated/adr-0031-schema-per-bounded-context-and-domain-event-catalog.rules.json +29 -0
- package/rulesets/adr/generated/adr-0033-transactional-outbox-pattern-for-async-messaging.rules.json +28 -0
- package/rulesets/adr/generated/adr-0034-cqrs-pattern-application-matrix.rules.json +29 -0
- package/rulesets/adr/generated/adr-0035-distributed-saga-pattern-implementation-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0036-message-bus-delivery-flow-control-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0037-enterprise-performance-concurrency-chaos-verification-strate.rules.json +28 -0
- package/rulesets/adr/generated/adr-0039-deployment-topology-abstraction-environment-switcher.rules.json +29 -0
- package/rulesets/adr/generated/adr-0041-dual-engine-policy-evaluation-native-opa.rules.json +28 -0
- package/rulesets/adr/generated/adr-0044-configurable-security-persistence-strategy-agnosticism-vs-na.rules.json +29 -0
- package/rulesets/adr/generated/adr-0045-microservice-extraction-readiness-criteria.rules.json +29 -0
- package/rulesets/adr/generated/adr-0046-unified-traceability-via-w3c-tracecontext.rules.json +29 -0
- package/rulesets/adr/generated/adr-0047-progressive-architecture-evolution-framework-modular-monolit.rules.json +29 -0
- package/rulesets/adr/generated/adr-0048-enterprise-taxonomy-standardization-and-reference-layout.rules.json +28 -0
- package/rulesets/adr/generated/adr-0049-naming-semantics-clean-code-policy-e2e-and-global.rules.json +29 -0
- package/rulesets/adr/generated/adr-0051-enterprise-database-engine-selection-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0052-unit-testing-isolation-strategy-mocks-vs-stubs.rules.json +29 -0
- package/rulesets/adr/generated/adr-0053-integration-and-e2e-testing-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0054-database-design-and-normalization-standards.rules.json +29 -0
- package/rulesets/adr/generated/adr-0055-microfrontends-architecture-strategy.rules.json +28 -0
- package/rulesets/adr/generated/adr-0056-enterprise-naming-design-conventions-multi-language-multi-pl.rules.json +29 -0
- package/rulesets/adr/generated/adr-0057-architecture-intelligence-catalog.rules.json +27 -0
- package/rulesets/adr/generated/adr-0058-ai-consumable-architecture-knowledge.rules.json +27 -0
- package/rulesets/adr/generated/adr-0067-modular-monolith-persistence-boundaries.rules.json +28 -0
- package/rulesets/adr/generated/adr-0068-documentation-release-gitflow.rules.json +29 -0
- package/rulesets/adr/generated/adr-0069-ai-agent-context-protocol-integration.rules.json +28 -0
- package/rulesets/adr/generated/adr-0070-lean-root-repository-taxonomy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0071-domain-layer-base-class-and-inheritance-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0072-utc-date-storage-browser-timezone-detection-and-language-res.rules.json +29 -0
- package/rulesets/adr/generated/adr-0073-unified-cli-mcp-output-contract-and-gate-evidence-schema.rules.json +29 -0
- package/rulesets/adr/generated/adr-0074-evolith-core-api-native-exposure-layer.rules.json +29 -0
- package/rulesets/adr/generated/adr-0075-core-api-authentication-strategy.rules.json +28 -0
- package/rulesets/adr/generated/adr-0076-domain-oriented-microservice-architecture-doma.rules.json +28 -0
- package/rulesets/adr/generated/adr-0077-masstransit-v9-commercial-pivot-stay-on-v8-monitor-opentrans.rules.json +28 -0
- package/rulesets/adr/generated/adr-0078-domain-financial-separation-governance.rules.json +29 -0
- package/rulesets/adr/generated/adr-0079-multi-topology-reference-corpus-and-topology-manifest-contra.rules.json +29 -0
- package/rulesets/adr/generated/adr-0080-remote-repository-reference-contract.rules.json +29 -0
- package/rulesets/adr/generated/adr-0081-agentic-ai-sandbox-isolation-boundary.rules.json +29 -0
- package/rulesets/adr/generated/adr-0082-agentic-ai-prompt-context-and-tool-trust-boundary.rules.json +28 -0
- package/rulesets/adr/generated/adr-0083-agentic-ai-action-authorization-and-audit.rules.json +29 -0
- package/rulesets/adr/generated/adr-0084-data-mesh-and-data-as-a-product.rules.json +29 -0
- package/rulesets/adr/generated/adr-0085-agnostic-opa-wasm-distribution-architecture.rules.json +28 -0
- package/rulesets/adr/generated/adr-0086-agentic-ai-telemetry-cost-control-standard.rules.json +27 -0
- package/rulesets/adr/generated/adr-0087-attribute-based-access-control-abac-for-agentic-tool-executi.rules.json +29 -0
- package/rulesets/adr/generated/adr-0088-sovereign-identity-for-agentic-ai.rules.json +29 -0
- package/rulesets/adr/generated/adr-0089-event-driven-agentic-workflow-pattern.rules.json +28 -0
- package/rulesets/adr/generated/adr-0090-rag-knowledge-governance-standard.rules.json +29 -0
- package/rulesets/adr/generated/adr-0091-workload-identity-token-rotation-standard.rules.json +29 -0
- package/rulesets/adr/generated/adr-0092-agent-infinite-loop-prevention-and-circuit-breaker-rules.rules.json +29 -0
- package/rulesets/adr/generated/adr-0093-concurrency-control-and-resource-locking-standard-for-mcp-to.rules.json +29 -0
- package/rulesets/adr/generated/adr-0094-multi-agent-handoff-and-task-delegation-standards.rules.json +29 -0
- package/rulesets/adr/generated/adr-0095-serverless-architecture-governance.rules.json +29 -0
- package/rulesets/adr/generated/adr-0096-edge-computing-architecture-governance.rules.json +29 -0
- package/rulesets/adr/generated/adr-0097-knowledge-lifecycle-governance-standard.rules.json +29 -0
- package/rulesets/adr/generated/adr-0098-rest-uri-versioning-and-deprecation-policy.rules.json +29 -0
- package/rulesets/adr/generated/adr-0099-opa-bundle-distribution-via-s3-minio.rules.json +27 -0
- package/rulesets/adr/generated/adr-ai-augmented-0001-harness-engineering-for-ai-augmented-development.rules.json +29 -0
- package/rulesets/adr/generated/adr-ai-augmented-0002-mcp-integration-protocol-for-agent-tool-invocation.rules.json +29 -0
- package/rulesets/adr/generated/adr-ai-augmented-0003-model-selection-governance-for-ai-augmented-workflows.rules.json +29 -0
- package/rulesets/adr/generated/adr-ai-augmented-0004-agents-md-as-mandatory-repository-artifact.rules.json +29 -0
- package/rulesets/adr/generated/adr-ai-augmented-0005-human-in-the-loop-policy-for-autonomous-agent-operations.rules.json +29 -0
- package/rulesets/adr/generated/adr-android-0042-canonical-android-native-mobile-architecture.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0041-canonical-net-c-backend-architecture.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0060-net-multi-tenancy-dual-layer-strategy-ef-core-sql-server.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0061-transactional-event-lifecycle-in-ef-core.rules.json +28 -0
- package/rulesets/adr/generated/adr-dotnet-0062-net-immutable-audit-trail-via-ddl-triggers-delta-capture.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0063-b2b-request-idempotency-middleware-in-asp-net-core.rules.json +28 -0
- package/rulesets/adr/generated/adr-dotnet-0064-net-request-scope-observability-context-propagation.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0065-net-pii-safe-structured-logging-pipeline-serilog.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0066-net-lightweight-http-idempotency-via-imemorycache-idistribut.rules.json +28 -0
- package/rulesets/adr/generated/adr-dotnet-0069-net-grpc-service-setup-protobuf-contracts.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0070-net-api-endpoint-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-dotnet-0071-net-data-access-strategy-ef-core-as-default-orm-dapper-for-o.rules.json +27 -0
- package/rulesets/adr/generated/adr-dotnet-0072-net-aop-cross-cutting-concern-strategy-dispatchproxy-over-pi.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0003-strict-typescript-standards.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0004-frontend-offline-resilience.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0007-observability-with-opentelemetry-loki-and-jaeger.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0008-progressive-multi-module-evolution-with-api-gateway-and-bff-.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0012-advanced-authorization-rbac-abac-strategy.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0021-high-performance-authentication-graph-compilation.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0022-contextual-authentication-and-pluggable-output-projections.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0023-centralized-authorization-core-strategy.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0026-adaptive-mfa-and-passwordless-platform.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0027-dual-protocol-api-strategy-rest-grpc.rules.json +28 -0
- package/rulesets/adr/generated/adr-nodejs-0029-adoption-of-tactical-ddd-primitives-library.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0038-enterprise-error-handling-result-pattern-strategy.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0043-data-access-and-orm-strategy-for-node-js.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0044-frontend-clean-architecture-layer-boundaries-react.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0045-frontend-state-management-zustand-tanstack-query-dual-strate.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0046-prohibition-of-raw-technical-identifiers-in-user-interfaces.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0047-actionable-user-error-contract-and-correlated-diagnostics.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0048-feature-flag-system-scope-and-structured-criteria-model.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0074-monorepo-orchestration-with-nx.rules.json +29 -0
- package/rulesets/adr/generated/adr-nodejs-0075-application-gateway-bff-with-nestjs.rules.json +29 -0
- package/rulesets/architecture/README.es.md +21 -0
- package/rulesets/architecture/README.md +21 -0
- package/rulesets/architecture/opa/progressive-axis.rego +50 -0
- package/rulesets/cli/README.es.md +17 -0
- package/rulesets/cli/README.md +17 -0
- package/rulesets/cli/core-parity.rules.json +61 -0
- package/rulesets/cli/release-readiness.rules.json +77 -0
- package/rulesets/compliance-baseline/README.es.md +26 -0
- package/rulesets/compliance-baseline/README.md +26 -0
- package/rulesets/compliance-baseline/compliance-baseline.rules.json +81 -0
- package/rulesets/contracts/README.es.md +19 -0
- package/rulesets/contracts/README.md +19 -0
- package/rulesets/contracts/evolith-machine-contracts.json +29 -0
- package/rulesets/contracts/fixtures/gate-evidence.success.json +10 -0
- package/rulesets/contracts/fixtures/output-envelope.success.json +23 -0
- package/rulesets/cross-cutting/README.es.md +14 -0
- package/rulesets/cross-cutting/README.md +14 -0
- package/rulesets/cross-cutting/compliance-baseline.rules.json +81 -0
- package/rulesets/cross-cutting/definition-of-done.rules.json +135 -0
- package/rulesets/cross-cutting/engineering-manifesto.rules.json +145 -0
- package/rulesets/cross-cutting/repository-taxonomy.rules.json +172 -0
- package/rulesets/definition-of-done/README.es.md +26 -0
- package/rulesets/definition-of-done/README.md +26 -0
- package/rulesets/definition-of-done/definition-of-done.rules.json +135 -0
- package/rulesets/engineering-manifesto/README.es.md +26 -0
- package/rulesets/engineering-manifesto/README.md +26 -0
- package/rulesets/engineering-manifesto/engineering-manifesto.rules.json +145 -0
- package/rulesets/evidence/README.es.md +12 -0
- package/rulesets/evidence/README.md +12 -0
- package/rulesets/evidence/evidence-manifest.rules.json +48 -0
- package/rulesets/executive-scorecards/executive-scorecards.rules.es.json +213 -0
- package/rulesets/executive-scorecards/executive-scorecards.rules.json +213 -0
- package/rulesets/governance/README.es.md +13 -0
- package/rulesets/governance/README.md +13 -0
- package/rulesets/governance/abac-mcp-access.rules.es.json +41 -0
- package/rulesets/governance/abac-mcp-access.rules.json +41 -0
- package/rulesets/governance/executive-scorecards.rules.es.json +213 -0
- package/rulesets/governance/executive-scorecards.rules.json +213 -0
- package/rulesets/governance/inheritance.rules.json +115 -0
- package/rulesets/governance/knowledge-intake.rules.json +18 -0
- package/rulesets/governance/open-core-boundary.rules.es.json +148 -0
- package/rulesets/governance/open-core-boundary.rules.json +148 -0
- package/rulesets/governance/satellite-contracts.rules.json +183 -0
- package/rulesets/infrastructure/helm-enforcement.rules.json +21 -0
- package/rulesets/infrastructure/opa/helm-enforcement.rego +25 -0
- package/rulesets/infrastructure/opa/helm-enforcement.test.rego +31 -0
- package/rulesets/infrastructure/opa/opa-sidecar-bundle.rego +115 -0
- package/rulesets/infrastructure/opa/opa-sidecar-bundle.test.rego +66 -0
- package/rulesets/infrastructure/opa-sidecar-bundle.rules.json +18 -0
- package/rulesets/mcp/README.es.md +12 -0
- package/rulesets/mcp/README.md +12 -0
- package/rulesets/mcp/protocol-compliance.rules.json +57 -0
- package/rulesets/observability/README.es.md +12 -0
- package/rulesets/observability/README.md +12 -0
- package/rulesets/observability/telemetry-evidence.rules.json +48 -0
- package/rulesets/opa/README.es.md +22 -0
- package/rulesets/opa/README.md +22 -0
- package/rulesets/opa/abac-mcp-tool-access.rego +122 -0
- package/rulesets/opa/abac-mcp-tool-access.test.rego +33 -0
- package/rulesets/opa/anti-corruption-layer.rego +39 -0
- package/rulesets/opa/anti-corruption-layer.test.rego +118 -0
- package/rulesets/opa/ci-cd.rego +41 -0
- package/rulesets/opa/ci-cd.test.rego +23 -0
- package/rulesets/opa/cicd-quality-gates.rego +29 -0
- package/rulesets/opa/cicd-quality-gates.test.rego +54 -0
- package/rulesets/opa/cli-core-parity.rego +17 -0
- package/rulesets/opa/cli-core-parity.test.rego +39 -0
- package/rulesets/opa/cli-readiness.rego +32 -0
- package/rulesets/opa/cli-readiness.test.rego +23 -0
- package/rulesets/opa/cli-release-readiness.rego +21 -0
- package/rulesets/opa/cli-release-readiness.test.rego +46 -0
- package/rulesets/opa/compliance-baseline.rego +95 -0
- package/rulesets/opa/compliance-baseline.test.rego +89 -0
- package/rulesets/opa/dod.rego +42 -0
- package/rulesets/opa/dod.test.rego +250 -0
- package/rulesets/opa/engineering-manifesto.rego +78 -0
- package/rulesets/opa/engineering-manifesto.test.rego +133 -0
- package/rulesets/opa/evidence.rego +64 -0
- package/rulesets/opa/evidence.test.rego +23 -0
- package/rulesets/opa/executive-scorecards.rego +41 -0
- package/rulesets/opa/executive-scorecards.test.rego +60 -0
- package/rulesets/opa/gitflow-branching.rego +41 -0
- package/rulesets/opa/gitflow-branching.test.rego +60 -0
- package/rulesets/opa/governance.rego +39 -0
- package/rulesets/opa/governance.test.rego +23 -0
- package/rulesets/opa/hexagonal-architecture.rego +33 -0
- package/rulesets/opa/hexagonal-architecture.test.rego +57 -0
- package/rulesets/opa/infrastructure/helm-enforcement.rego +33 -0
- package/rulesets/opa/infrastructure/opa-sidecar-bundle.rego +42 -0
- package/rulesets/opa/knowledge-intake.rego +98 -0
- package/rulesets/opa/knowledge-intake.test.rego +50 -0
- package/rulesets/opa/main.rego +147 -0
- package/rulesets/opa/main_test.rego +149 -0
- package/rulesets/opa/mcp.rego +61 -0
- package/rulesets/opa/mcp.test.rego +27 -0
- package/rulesets/opa/multi-runtime.rego +33 -0
- package/rulesets/opa/multi-runtime.test.rego +53 -0
- package/rulesets/opa/multi-tenancy.rego +33 -0
- package/rulesets/opa/multi-tenancy.test.rego +53 -0
- package/rulesets/opa/open-core-boundary.rego +33 -0
- package/rulesets/opa/open-core-boundary.test.rego +60 -0
- package/rulesets/opa/protocol-selection.rego +29 -0
- package/rulesets/opa/protocol-selection.test.rego +46 -0
- package/rulesets/opa/rbac/gate-role-enforcement.rego +112 -0
- package/rulesets/opa/repository-taxonomy.rego +98 -0
- package/rulesets/opa/repository-taxonomy.test.rego +91 -0
- package/rulesets/opa/satellite-contracts.rego +42 -0
- package/rulesets/opa/satellite-contracts.test.rego +70 -0
- package/rulesets/opa/schemas/abac-mcp-tool-access.input.schema.json +21 -0
- package/rulesets/opa/schemas/anti-corruption-layer.input.schema.json +25 -0
- package/rulesets/opa/schemas/ci-cd.input.schema.json +27 -0
- package/rulesets/opa/schemas/cicd-quality-gates.input.schema.json +33 -0
- package/rulesets/opa/schemas/cli-core-parity.input.schema.json +30 -0
- package/rulesets/opa/schemas/cli-readiness.input.schema.json +28 -0
- package/rulesets/opa/schemas/cli-release-readiness.input.schema.json +26 -0
- package/rulesets/opa/schemas/compliance-baseline.input.schema.json +25 -0
- package/rulesets/opa/schemas/dod.input.schema.json +38 -0
- package/rulesets/opa/schemas/engineering-manifesto.input.schema.json +24 -0
- package/rulesets/opa/schemas/evidence.input.schema.json +35 -0
- package/rulesets/opa/schemas/executive-scorecards.input.schema.json +36 -0
- package/rulesets/opa/schemas/gitflow-branching.input.schema.json +36 -0
- package/rulesets/opa/schemas/governance.input.schema.json +19 -0
- package/rulesets/opa/schemas/hexagonal-architecture.input.schema.json +46 -0
- package/rulesets/opa/schemas/knowledge-intake.input.schema.json +57 -0
- package/rulesets/opa/schemas/mcp.input.schema.json +38 -0
- package/rulesets/opa/schemas/multi-runtime.input.schema.json +27 -0
- package/rulesets/opa/schemas/multi-tenancy.input.schema.json +27 -0
- package/rulesets/opa/schemas/open-core-boundary.input.schema.json +36 -0
- package/rulesets/opa/schemas/protocol-selection.input.schema.json +26 -0
- package/rulesets/opa/schemas/repository-taxonomy.input.schema.json +18 -0
- package/rulesets/opa/schemas/satellite-contracts.input.schema.json +38 -0
- package/rulesets/opa/schemas/taxonomy.input.schema.json +27 -0
- package/rulesets/opa/schemas/testing-pyramid.input.schema.json +42 -0
- package/rulesets/opa/schemas/version-pinning.input.schema.json +39 -0
- package/rulesets/opa/sdlc/coverage.rego +49 -0
- package/rulesets/opa/sdlc/coverage.test.rego +29 -0
- package/rulesets/opa/sdlc/pyramid-distribution.rego +31 -0
- package/rulesets/opa/sdlc/pyramid-distribution.test.rego +33 -0
- package/rulesets/opa/taxonomy.rego +51 -0
- package/rulesets/opa/taxonomy.test.rego +28 -0
- package/rulesets/opa/telemetry-evidence.rego +102 -0
- package/rulesets/opa/testing-pyramid.rego +49 -0
- package/rulesets/opa/testing-pyramid.test.rego +81 -0
- package/rulesets/opa/version-pinning.rego +99 -0
- package/rulesets/opa/version-pinning.test.rego +28 -0
- package/rulesets/phase-gates/README.es.md +28 -0
- package/rulesets/phase-gates/README.md +28 -0
- package/rulesets/phase-gates/phase-gates.rules.json +297 -0
- package/rulesets/quality-thresholds/README.es.md +28 -0
- package/rulesets/quality-thresholds/README.md +28 -0
- package/rulesets/quality-thresholds/quality-thresholds.rules.json +96 -0
- package/rulesets/repository-taxonomy/README.es.md +26 -0
- package/rulesets/repository-taxonomy/README.md +26 -0
- package/rulesets/repository-taxonomy/repository-taxonomy.rules.json +172 -0
- package/rulesets/satellite-contracts/README.es.md +27 -0
- package/rulesets/satellite-contracts/README.md +27 -0
- package/rulesets/satellite-contracts/satellite-contracts.rules.json +183 -0
- package/rulesets/schema/README.es.md +39 -0
- package/rulesets/schema/README.md +39 -0
- package/rulesets/schema/adr.schema.json +138 -0
- package/rulesets/schema/agile-backlog.schema.json +91 -0
- package/rulesets/schema/ballpark-estimation.schema.json +109 -0
- package/rulesets/schema/build-vs-compose.schema.json +98 -0
- package/rulesets/schema/cli-impact-analysis.schema.json +114 -0
- package/rulesets/schema/discovery-canvas.schema.json +92 -0
- package/rulesets/schema/evolith-user-story.schema.json +105 -0
- package/rulesets/schema/evolith-yaml.schema.json +191 -0
- package/rulesets/schema/functional-story.schema.json +111 -0
- package/rulesets/schema/gate-evidence.schema.json +85 -0
- package/rulesets/schema/integration-evidence.schema.json +47 -0
- package/rulesets/schema/knowledge-intake.schema.json +67 -0
- package/rulesets/schema/knowledge-projection.schema.json +24 -0
- package/rulesets/schema/maturity-evidence.schema.json +59 -0
- package/rulesets/schema/observability-validation.schema.json +85 -0
- package/rulesets/schema/on-call-handoff.schema.json +91 -0
- package/rulesets/schema/output-envelope.schema.json +102 -0
- package/rulesets/schema/prd.schema.json +117 -0
- package/rulesets/schema/release-notes.schema.json +138 -0
- package/rulesets/schema/rollback-rehearsal.schema.json +73 -0
- package/rulesets/schema/ruleset-sdlc.schema.json +59 -0
- package/rulesets/schema/ruleset-standard.schema.json +73 -0
- package/rulesets/schema/security-scan-report.schema.json +79 -0
- package/rulesets/schema/source-registry.schema.json +51 -0
- package/rulesets/schema/technical-feasibility.schema.json +66 -0
- package/rulesets/schema/technical-story.schema.json +112 -0
- package/rulesets/schema/test-summary-report.schema.json +158 -0
- package/rulesets/schema/topology-composition.schema.json +43 -0
- package/rulesets/schema/topology-manifest.schema.json +421 -0
- package/rulesets/sdlc/README.es.md +12 -0
- package/rulesets/sdlc/README.md +12 -0
- package/rulesets/sdlc/default-workflow.yaml +73 -0
- package/rulesets/sdlc/dependency-pinning.rules.json +183 -0
- package/rulesets/sdlc/phase-gates.rules.json +297 -0
- package/rulesets/sdlc/quality-thresholds.rules.json +96 -0
- package/rulesets/topologies/README.es.md +42 -0
- package/rulesets/topologies/README.md +42 -0
- package/rulesets/topologies/agentic-ai/README.es.md +142 -0
- package/rulesets/topologies/agentic-ai/README.md +142 -0
- package/rulesets/topologies/agentic-ai/adoption.es.md +37 -0
- package/rulesets/topologies/agentic-ai/adoption.md +37 -0
- package/rulesets/topologies/agentic-ai/agent.config.schema.json +100 -0
- package/rulesets/topologies/agentic-ai/agentic-ai.rego +46 -0
- package/rulesets/topologies/agentic-ai/agentic-ai.rules.json +109 -0
- package/rulesets/topologies/agentic-ai/agentic-ai.test.rego +68 -0
- package/rulesets/topologies/agentic-ai/agentic-ai.wasm +0 -0
- package/rulesets/topologies/agentic-ai/cli/cli-flows.es.md +35 -0
- package/rulesets/topologies/agentic-ai/cli/cli-flows.md +45 -0
- package/rulesets/topologies/agentic-ai/evidence.es.md +25 -0
- package/rulesets/topologies/agentic-ai/evidence.md +25 -0
- package/rulesets/topologies/agentic-ai/evolution.es.md +26 -0
- package/rulesets/topologies/agentic-ai/evolution.md +26 -0
- package/rulesets/topologies/agentic-ai/fixtures/invalid-agent.config.json +48 -0
- package/rulesets/topologies/agentic-ai/fixtures/valid-agent.config.json +48 -0
- package/rulesets/topologies/agentic-ai/maturity.es.md +33 -0
- package/rulesets/topologies/agentic-ai/maturity.md +33 -0
- package/rulesets/topologies/agentic-ai/mcp/mcp-manifest.json +100 -0
- package/rulesets/topologies/agentic-ai/openapi/openapi.yaml +187 -0
- package/rulesets/topologies/agentic-ai/operations.es.md +32 -0
- package/rulesets/topologies/agentic-ai/operations.md +32 -0
- package/rulesets/topologies/agentic-ai/parity-fixtures/compliant.json +18 -0
- package/rulesets/topologies/agentic-ai/parity-fixtures/violation.json +22 -0
- package/rulesets/topologies/agentic-ai/patterns.es.md +32 -0
- package/rulesets/topologies/agentic-ai/patterns.md +32 -0
- package/rulesets/topologies/agentic-ai/resilience.es.md +26 -0
- package/rulesets/topologies/agentic-ai/resilience.md +26 -0
- package/rulesets/topologies/agentic-ai/runbooks.es.md +48 -0
- package/rulesets/topologies/agentic-ai/runbooks.md +48 -0
- package/rulesets/topologies/agentic-ai/security.es.md +26 -0
- package/rulesets/topologies/agentic-ai/security.md +26 -0
- package/rulesets/topologies/agentic-ai/topology.manifest.json +127 -0
- package/rulesets/topologies/data-mesh/README.es.md +69 -0
- package/rulesets/topologies/data-mesh/README.md +69 -0
- package/rulesets/topologies/data-mesh/adoption.es.md +95 -0
- package/rulesets/topologies/data-mesh/adoption.md +95 -0
- package/rulesets/topologies/data-mesh/cli/cli-flows.es.md +41 -0
- package/rulesets/topologies/data-mesh/cli/cli-flows.md +53 -0
- package/rulesets/topologies/data-mesh/data-mesh.rego +11 -0
- package/rulesets/topologies/data-mesh/data-mesh.rules.json +100 -0
- package/rulesets/topologies/data-mesh/data-mesh.test.rego +107 -0
- package/rulesets/topologies/data-mesh/data-mesh.wasm +0 -0
- package/rulesets/topologies/data-mesh/evidence.es.md +111 -0
- package/rulesets/topologies/data-mesh/evidence.md +111 -0
- package/rulesets/topologies/data-mesh/evolution.es.md +67 -0
- package/rulesets/topologies/data-mesh/evolution.md +67 -0
- package/rulesets/topologies/data-mesh/fixtures/invalid.topology.config.json +12 -0
- package/rulesets/topologies/data-mesh/fixtures/valid.topology.config.json +12 -0
- package/rulesets/topologies/data-mesh/maturity.es.md +36 -0
- package/rulesets/topologies/data-mesh/maturity.md +36 -0
- package/rulesets/topologies/data-mesh/mcp/mcp-manifest.json +68 -0
- package/rulesets/topologies/data-mesh/openapi/openapi.yaml +186 -0
- package/rulesets/topologies/data-mesh/operations.es.md +63 -0
- package/rulesets/topologies/data-mesh/operations.md +63 -0
- package/rulesets/topologies/data-mesh/parity-fixtures/compliant.json +18 -0
- package/rulesets/topologies/data-mesh/parity-fixtures/violation.json +21 -0
- package/rulesets/topologies/data-mesh/patterns.es.md +67 -0
- package/rulesets/topologies/data-mesh/patterns.md +67 -0
- package/rulesets/topologies/data-mesh/resilience.es.md +64 -0
- package/rulesets/topologies/data-mesh/resilience.md +64 -0
- package/rulesets/topologies/data-mesh/runbooks.es.md +147 -0
- package/rulesets/topologies/data-mesh/runbooks.md +147 -0
- package/rulesets/topologies/data-mesh/security.es.md +66 -0
- package/rulesets/topologies/data-mesh/security.md +66 -0
- package/rulesets/topologies/data-mesh/topology.config.schema.json +30 -0
- package/rulesets/topologies/data-mesh/topology.manifest.json +107 -0
- package/rulesets/topologies/edge-computing/README.es.md +81 -0
- package/rulesets/topologies/edge-computing/README.md +81 -0
- package/rulesets/topologies/edge-computing/adoption.es.md +268 -0
- package/rulesets/topologies/edge-computing/adoption.md +268 -0
- package/rulesets/topologies/edge-computing/cli/cli-flows.es.md +41 -0
- package/rulesets/topologies/edge-computing/cli/cli-flows.md +53 -0
- package/rulesets/topologies/edge-computing/edge-computing.rego +41 -0
- package/rulesets/topologies/edge-computing/edge-computing.rules.json +50 -0
- package/rulesets/topologies/edge-computing/edge-computing.test.rego +33 -0
- package/rulesets/topologies/edge-computing/edge-computing.wasm +0 -0
- package/rulesets/topologies/edge-computing/evidence.es.md +263 -0
- package/rulesets/topologies/edge-computing/evidence.md +263 -0
- package/rulesets/topologies/edge-computing/evolution.es.md +257 -0
- package/rulesets/topologies/edge-computing/evolution.md +257 -0
- package/rulesets/topologies/edge-computing/fixtures/invalid.topology.config.json +6 -0
- package/rulesets/topologies/edge-computing/fixtures/valid.topology.config.json +6 -0
- package/rulesets/topologies/edge-computing/maturity.es.md +36 -0
- package/rulesets/topologies/edge-computing/maturity.md +36 -0
- package/rulesets/topologies/edge-computing/mcp/mcp-manifest.json +72 -0
- package/rulesets/topologies/edge-computing/openapi/openapi.yaml +187 -0
- package/rulesets/topologies/edge-computing/operations.es.md +148 -0
- package/rulesets/topologies/edge-computing/operations.md +148 -0
- package/rulesets/topologies/edge-computing/parity-fixtures/compliant.json +12 -0
- package/rulesets/topologies/edge-computing/parity-fixtures/violation.json +13 -0
- package/rulesets/topologies/edge-computing/patterns.es.md +291 -0
- package/rulesets/topologies/edge-computing/patterns.md +290 -0
- package/rulesets/topologies/edge-computing/resilience.es.md +232 -0
- package/rulesets/topologies/edge-computing/resilience.md +229 -0
- package/rulesets/topologies/edge-computing/runbooks.es.md +405 -0
- package/rulesets/topologies/edge-computing/runbooks.md +405 -0
- package/rulesets/topologies/edge-computing/security.es.md +218 -0
- package/rulesets/topologies/edge-computing/security.md +218 -0
- package/rulesets/topologies/edge-computing/topology.config.schema.json +13 -0
- package/rulesets/topologies/edge-computing/topology.manifest.json +113 -0
- package/rulesets/topologies/event-driven/README.es.md +71 -0
- package/rulesets/topologies/event-driven/README.md +71 -0
- package/rulesets/topologies/event-driven/adoption.es.md +67 -0
- package/rulesets/topologies/event-driven/adoption.md +67 -0
- package/rulesets/topologies/event-driven/cli/cli-flows.es.md +41 -0
- package/rulesets/topologies/event-driven/cli/cli-flows.md +53 -0
- package/rulesets/topologies/event-driven/event-driven.rego +11 -0
- package/rulesets/topologies/event-driven/event-driven.rules.json +100 -0
- package/rulesets/topologies/event-driven/event-driven.test.rego +107 -0
- package/rulesets/topologies/event-driven/event-driven.wasm +0 -0
- package/rulesets/topologies/event-driven/evidence.es.md +69 -0
- package/rulesets/topologies/event-driven/evidence.md +69 -0
- package/rulesets/topologies/event-driven/evolution.es.md +59 -0
- package/rulesets/topologies/event-driven/evolution.md +59 -0
- package/rulesets/topologies/event-driven/fixtures/invalid.topology.config.json +12 -0
- package/rulesets/topologies/event-driven/fixtures/valid.topology.config.json +12 -0
- package/rulesets/topologies/event-driven/maturity.es.md +36 -0
- package/rulesets/topologies/event-driven/maturity.md +36 -0
- package/rulesets/topologies/event-driven/mcp/mcp-manifest.json +68 -0
- package/rulesets/topologies/event-driven/openapi/openapi.yaml +186 -0
- package/rulesets/topologies/event-driven/operations.es.md +67 -0
- package/rulesets/topologies/event-driven/operations.md +67 -0
- package/rulesets/topologies/event-driven/parity-fixtures/compliant.json +18 -0
- package/rulesets/topologies/event-driven/parity-fixtures/violation.json +21 -0
- package/rulesets/topologies/event-driven/patterns.es.md +68 -0
- package/rulesets/topologies/event-driven/patterns.md +68 -0
- package/rulesets/topologies/event-driven/resilience.es.md +65 -0
- package/rulesets/topologies/event-driven/resilience.md +65 -0
- package/rulesets/topologies/event-driven/runbooks.es.md +79 -0
- package/rulesets/topologies/event-driven/runbooks.md +79 -0
- package/rulesets/topologies/event-driven/security.es.md +59 -0
- package/rulesets/topologies/event-driven/security.md +59 -0
- package/rulesets/topologies/event-driven/topology.config.schema.json +30 -0
- package/rulesets/topologies/event-driven/topology.manifest.json +109 -0
- package/rulesets/topologies/progressive-axis/distributed-modules/distributed-modules.rules.es.json +111 -0
- package/rulesets/topologies/progressive-axis/distributed-modules/distributed-modules.rules.json +111 -0
- package/rulesets/topologies/progressive-axis/microservices/microservices.rules.es.json +106 -0
- package/rulesets/topologies/progressive-axis/microservices/microservices.rules.json +106 -0
- package/rulesets/topologies/progressive-axis/modular-monolith/modular-monolith.rules.es.json +148 -0
- package/rulesets/topologies/progressive-axis/modular-monolith/modular-monolith.rules.json +148 -0
- package/rulesets/topologies/serverless/README.es.md +74 -0
- package/rulesets/topologies/serverless/README.md +74 -0
- package/rulesets/topologies/serverless/adoption.es.md +50 -0
- package/rulesets/topologies/serverless/adoption.md +50 -0
- package/rulesets/topologies/serverless/cli/cli-flows.es.md +41 -0
- package/rulesets/topologies/serverless/cli/cli-flows.md +53 -0
- package/rulesets/topologies/serverless/evidence.es.md +66 -0
- package/rulesets/topologies/serverless/evidence.md +66 -0
- package/rulesets/topologies/serverless/evolution.es.md +36 -0
- package/rulesets/topologies/serverless/evolution.md +36 -0
- package/rulesets/topologies/serverless/fixtures/invalid.topology.config.json +6 -0
- package/rulesets/topologies/serverless/fixtures/valid.topology.config.json +6 -0
- package/rulesets/topologies/serverless/maturity.es.md +36 -0
- package/rulesets/topologies/serverless/maturity.md +36 -0
- package/rulesets/topologies/serverless/mcp/mcp-manifest.json +72 -0
- package/rulesets/topologies/serverless/openapi/openapi.yaml +186 -0
- package/rulesets/topologies/serverless/operations.es.md +36 -0
- package/rulesets/topologies/serverless/operations.md +36 -0
- package/rulesets/topologies/serverless/parity-fixtures/compliant.json +13 -0
- package/rulesets/topologies/serverless/parity-fixtures/violation.json +15 -0
- package/rulesets/topologies/serverless/patterns.es.md +36 -0
- package/rulesets/topologies/serverless/patterns.md +36 -0
- package/rulesets/topologies/serverless/resilience.es.md +36 -0
- package/rulesets/topologies/serverless/resilience.md +36 -0
- package/rulesets/topologies/serverless/runbooks.es.md +68 -0
- package/rulesets/topologies/serverless/runbooks.md +68 -0
- package/rulesets/topologies/serverless/security.es.md +36 -0
- package/rulesets/topologies/serverless/security.md +36 -0
- package/rulesets/topologies/serverless/serverless.rego +32 -0
- package/rulesets/topologies/serverless/serverless.rules.json +33 -0
- package/rulesets/topologies/serverless/serverless.test.rego +28 -0
- package/rulesets/topologies/serverless/serverless.wasm +0 -0
- package/rulesets/topologies/serverless/topology.config.schema.json +28 -0
- package/rulesets/topologies/serverless/topology.manifest.json +114 -0
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
openapi: "3.1.0"
|
|
2
|
+
info:
|
|
3
|
+
title: "Edge Computing Topology — Core API Surface"
|
|
4
|
+
version: "0.1.0"
|
|
5
|
+
description: >
|
|
6
|
+
REST API surface specific to the Edge Computing topology.
|
|
7
|
+
Describes endpoints exposed by the Core API for querying,
|
|
8
|
+
inspecting, and validating Edge Computing topology instances.
|
|
9
|
+
servers:
|
|
10
|
+
- url: "https://api.evolith.dev/v1"
|
|
11
|
+
description: "Evolith Core API (production)"
|
|
12
|
+
paths:
|
|
13
|
+
/topologies/{id}:
|
|
14
|
+
get:
|
|
15
|
+
tags: [Topologies]
|
|
16
|
+
summary: "Retrieve Edge Computing topology information"
|
|
17
|
+
description: >
|
|
18
|
+
Returns the full topology record for Edge Computing, including
|
|
19
|
+
dimension, status, version, governance metadata, and corpus
|
|
20
|
+
artifact references (rulesets, OPA policies, ADRs, guidance).
|
|
21
|
+
operationId: "getEdgeComputingTopology"
|
|
22
|
+
parameters:
|
|
23
|
+
- name: id
|
|
24
|
+
in: path
|
|
25
|
+
required: true
|
|
26
|
+
schema:
|
|
27
|
+
type: string
|
|
28
|
+
pattern: "^edge-computing$"
|
|
29
|
+
example: "edge-computing"
|
|
30
|
+
responses:
|
|
31
|
+
"200":
|
|
32
|
+
description: "Successful response with Edge Computing topology data"
|
|
33
|
+
content:
|
|
34
|
+
application/json:
|
|
35
|
+
schema:
|
|
36
|
+
$ref: "#/components/schemas/EnvelopeTopology"
|
|
37
|
+
"404":
|
|
38
|
+
description: "Topology not found"
|
|
39
|
+
/topologies/{id}/manifest:
|
|
40
|
+
get:
|
|
41
|
+
tags: [Topologies]
|
|
42
|
+
summary: "Get Edge Computing topology manifest"
|
|
43
|
+
description: >
|
|
44
|
+
Returns the full topology manifest for Edge Computing, with
|
|
45
|
+
artifact references, corpus configuration, and business
|
|
46
|
+
boundary declaration.
|
|
47
|
+
operationId: "getEdgeComputingManifest"
|
|
48
|
+
parameters:
|
|
49
|
+
- name: id
|
|
50
|
+
in: path
|
|
51
|
+
required: true
|
|
52
|
+
schema:
|
|
53
|
+
type: string
|
|
54
|
+
pattern: "^edge-computing$"
|
|
55
|
+
responses:
|
|
56
|
+
"200":
|
|
57
|
+
description: "Successful response with Edge Computing manifest"
|
|
58
|
+
content:
|
|
59
|
+
application/json:
|
|
60
|
+
schema:
|
|
61
|
+
$ref: "#/components/schemas/EnvelopeManifest"
|
|
62
|
+
/topologies/{id}/validate:
|
|
63
|
+
post:
|
|
64
|
+
tags: [Topologies]
|
|
65
|
+
summary: "Validate Edge Computing topology rules"
|
|
66
|
+
description: >
|
|
67
|
+
Executes all applicable rulesets and OPA policies for Edge
|
|
68
|
+
Computing against a submitted configuration, returning pass/fail
|
|
69
|
+
per gate.
|
|
70
|
+
operationId: "validateEdgeComputingTopology"
|
|
71
|
+
parameters:
|
|
72
|
+
- name: id
|
|
73
|
+
in: path
|
|
74
|
+
required: true
|
|
75
|
+
schema:
|
|
76
|
+
type: string
|
|
77
|
+
pattern: "^edge-computing$"
|
|
78
|
+
requestBody:
|
|
79
|
+
required: true
|
|
80
|
+
content:
|
|
81
|
+
application/json:
|
|
82
|
+
schema:
|
|
83
|
+
$ref: "#/components/schemas/ValidationRequest"
|
|
84
|
+
responses:
|
|
85
|
+
"200":
|
|
86
|
+
description: "Validation results"
|
|
87
|
+
content:
|
|
88
|
+
application/json:
|
|
89
|
+
schema:
|
|
90
|
+
$ref: "#/components/schemas/EnvelopeValidation"
|
|
91
|
+
components:
|
|
92
|
+
schemas:
|
|
93
|
+
Envelope:
|
|
94
|
+
type: object
|
|
95
|
+
properties:
|
|
96
|
+
success:
|
|
97
|
+
type: boolean
|
|
98
|
+
data: {}
|
|
99
|
+
meta:
|
|
100
|
+
type: object
|
|
101
|
+
properties:
|
|
102
|
+
context:
|
|
103
|
+
type: string
|
|
104
|
+
timing:
|
|
105
|
+
type: number
|
|
106
|
+
schemaVersion:
|
|
107
|
+
type: string
|
|
108
|
+
pattern: "^\\d+\\.\\d+\\.\\d+$"
|
|
109
|
+
required: [context, timing, schemaVersion]
|
|
110
|
+
required: [success, data, meta]
|
|
111
|
+
EnvelopeTopology:
|
|
112
|
+
allOf:
|
|
113
|
+
- $ref: "#/components/schemas/Envelope"
|
|
114
|
+
- type: object
|
|
115
|
+
properties:
|
|
116
|
+
data:
|
|
117
|
+
$ref: "#/components/schemas/TopologyRecord"
|
|
118
|
+
EnvelopeManifest:
|
|
119
|
+
allOf:
|
|
120
|
+
- $ref: "#/components/schemas/Envelope"
|
|
121
|
+
- type: object
|
|
122
|
+
properties:
|
|
123
|
+
data:
|
|
124
|
+
$ref: "#/components/schemas/TopologyManifest"
|
|
125
|
+
EnvelopeValidation:
|
|
126
|
+
allOf:
|
|
127
|
+
- $ref: "#/components/schemas/Envelope"
|
|
128
|
+
- type: object
|
|
129
|
+
properties:
|
|
130
|
+
data:
|
|
131
|
+
$ref: "#/components/schemas/ValidationResult"
|
|
132
|
+
TopologyRecord:
|
|
133
|
+
type: object
|
|
134
|
+
properties:
|
|
135
|
+
id:
|
|
136
|
+
type: string
|
|
137
|
+
example: "edge-computing"
|
|
138
|
+
name:
|
|
139
|
+
type: string
|
|
140
|
+
example: "Edge Computing"
|
|
141
|
+
dimension:
|
|
142
|
+
type: string
|
|
143
|
+
example: "execution"
|
|
144
|
+
status:
|
|
145
|
+
type: string
|
|
146
|
+
enum: [accepted, draft, deprecated]
|
|
147
|
+
version:
|
|
148
|
+
type: string
|
|
149
|
+
example: "0.1.0"
|
|
150
|
+
TopologyManifest:
|
|
151
|
+
type: object
|
|
152
|
+
properties:
|
|
153
|
+
apiVersion:
|
|
154
|
+
type: string
|
|
155
|
+
example: "evolith.dev/topology/v1"
|
|
156
|
+
kind:
|
|
157
|
+
type: string
|
|
158
|
+
example: "TopologyManifest"
|
|
159
|
+
metadata:
|
|
160
|
+
type: object
|
|
161
|
+
spec:
|
|
162
|
+
type: object
|
|
163
|
+
ValidationRequest:
|
|
164
|
+
type: object
|
|
165
|
+
properties:
|
|
166
|
+
config:
|
|
167
|
+
type: object
|
|
168
|
+
description: "Configuration to validate against topology rules"
|
|
169
|
+
required: [config]
|
|
170
|
+
ValidationResult:
|
|
171
|
+
type: object
|
|
172
|
+
properties:
|
|
173
|
+
passed:
|
|
174
|
+
type: boolean
|
|
175
|
+
gates:
|
|
176
|
+
type: array
|
|
177
|
+
items:
|
|
178
|
+
type: object
|
|
179
|
+
properties:
|
|
180
|
+
gate:
|
|
181
|
+
type: string
|
|
182
|
+
passed:
|
|
183
|
+
type: boolean
|
|
184
|
+
evidence:
|
|
185
|
+
type: array
|
|
186
|
+
items:
|
|
187
|
+
type: string
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
# Guía de Operaciones de Computación en el Borde
|
|
2
|
+
|
|
3
|
+
> **Navegación Bilingüe:** [English](./operations.md) | [Español](./operations.es.md)
|
|
4
|
+
|
|
5
|
+
**Propietario:** Ingeniería de Plataforma
|
|
6
|
+
**Topología:** Computación en el Borde
|
|
7
|
+
|
|
8
|
+
## Gestión del Ciclo de Vida de Nodos
|
|
9
|
+
|
|
10
|
+
Los nodos del borde siguen un ciclo de vida definido: aprovisionamiento, registro, activación, monitoreo, mantenimiento y baja.
|
|
11
|
+
|
|
12
|
+
### Aprovisionamiento
|
|
13
|
+
|
|
14
|
+
```bash
|
|
15
|
+
# Registrar un nuevo nodo del borde
|
|
16
|
+
edge-cli node register \
|
|
17
|
+
--node-id edge-node-01 \
|
|
18
|
+
--region us-west-2 \
|
|
19
|
+
--zone us-west-2a \
|
|
20
|
+
--role compute \
|
|
21
|
+
--capacity "cpu=4,memory=8Gi,storage=50Gi"
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
### Monitoreo de Salud
|
|
25
|
+
|
|
26
|
+
Cada nodo reporta métricas de salud cada 15 segundos:
|
|
27
|
+
|
|
28
|
+
| Métrica | Umbral | Acción al Exceder |
|
|
29
|
+
|---------|--------|-------------------|
|
|
30
|
+
| Latencia al origen | > 200ms | Activar conmutación por error |
|
|
31
|
+
| Utilización de CPU | > 85% | Reducir cargas no críticas |
|
|
32
|
+
| Uso de memoria | > 90% | Expulsar caché de menor uso |
|
|
33
|
+
| Uso de disco | > 80% | Purgar contenido obsoleto |
|
|
34
|
+
| Retraso de sincronización | > 30s | Escalar a operaciones |
|
|
35
|
+
|
|
36
|
+
## Monitoreo de Sincronización de Contenido (Ref: EC-R01)
|
|
37
|
+
|
|
38
|
+
La estrategia de sincronización garantiza la consistencia del contenido en toda la flota del borde.
|
|
39
|
+
|
|
40
|
+
### Panel de Salud de Sincronización
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
# Verificar estado de sincronización en todos los nodos
|
|
44
|
+
edge-cli sync status --fleet-wide --format table
|
|
45
|
+
|
|
46
|
+
# Salida:
|
|
47
|
+
# NODE LAST_SYNC LAG STATUS
|
|
48
|
+
# edge-node-01 2026-06-23 2s healthy
|
|
49
|
+
# edge-node-02 2026-06-23 45s degraded
|
|
50
|
+
# edge-node-03 2026-06-22 4h offline
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
### Estrategias de Sincronización
|
|
54
|
+
|
|
55
|
+
| Estrategia | Caso de Uso | Consistencia | Rendimiento |
|
|
56
|
+
|------------|-------------|--------------|-------------|
|
|
57
|
+
| Basada en envío | Activos estáticos | Fuerte | Alto ancho de banda |
|
|
58
|
+
| Basada en solicitud | Contenido dinámico | Eventual | Bajo demanda |
|
|
59
|
+
| Híbrida | Cargas de trabajo mixtas | Ajustable | Equilibrado |
|
|
60
|
+
|
|
61
|
+
## Medición de Latencia (Presupuesto de 200ms)
|
|
62
|
+
|
|
63
|
+
La latencia de extremo a extremo se mende desde la solicitud del cliente hasta la entrega de la respuesta.
|
|
64
|
+
|
|
65
|
+
### Puntos de Medición
|
|
66
|
+
|
|
67
|
+
1. **Cliente → Nodo del borde**: Resolución DNS +握手 TCP + TLS
|
|
68
|
+
2. **Procesamiento del borde**: Tiempo de ejecución de la función
|
|
69
|
+
3. **Borde → Origen** (en caso de fallo): Penalización por fallo de caché
|
|
70
|
+
4. **Entrega de respuesta**: Serialización + transferencia
|
|
71
|
+
|
|
72
|
+
### Desglose del Presupuesto de Latencia
|
|
73
|
+
|
|
74
|
+
| Segmento | Presupuesto | Actual | Estado |
|
|
75
|
+
|----------|-------------|--------|--------|
|
|
76
|
+
| Resolución DNS | 20ms | 12ms | [PASS] |
|
|
77
|
+
| Handshake TLS | 40ms | 35ms | [PASS] |
|
|
78
|
+
| Procesamiento del borde | 50ms | 42ms | [PASS] |
|
|
79
|
+
| Fallo de caché (p95) | 80ms | 78ms | [PASS] |
|
|
80
|
+
| Sobrecarga de transferencia | 10ms | 8ms | [PASS] |
|
|
81
|
+
| **Total** | **200ms** | **175ms** | **[PASS]** |
|
|
82
|
+
|
|
83
|
+
### Reglas de Alerta
|
|
84
|
+
|
|
85
|
+
```yaml
|
|
86
|
+
alerts:
|
|
87
|
+
- name: edge-latency-p99
|
|
88
|
+
condition: latency_p99 > 200ms
|
|
89
|
+
severity: critical
|
|
90
|
+
action: page-oncall
|
|
91
|
+
- name: edge-latency-p95
|
|
92
|
+
condition: latency_p95 > 180ms
|
|
93
|
+
severity: warning
|
|
94
|
+
action: notify-slack
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
## Operaciones sin Conexión (Ref: EC-R02)
|
|
98
|
+
|
|
99
|
+
Los nodos del borde deben continuar sirviendo contenido en caché cuando se desconectan del origen.
|
|
100
|
+
|
|
101
|
+
### Matriz de Capacidades sin Conexión
|
|
102
|
+
|
|
103
|
+
| Capacidad | Disponible sin Conexión | Sincronización Requerida |
|
|
104
|
+
|-----------|-------------------------|--------------------------|
|
|
105
|
+
| Lectura de contenido en caché | Sí | No |
|
|
106
|
+
| Servir activos estáticos | Sí | No |
|
|
107
|
+
| Ejecutar funciones del borde | Sí (en caché) | Al reconectar |
|
|
108
|
+
| Operaciones de escritura | En cola local | Sincronización en segundo plano |
|
|
109
|
+
| Autenticación | Tokens en caché | Actualizar al reconectar |
|
|
110
|
+
|
|
111
|
+
### Detección sin Conexión
|
|
112
|
+
|
|
113
|
+
```bash
|
|
114
|
+
# Monitorear conectividad con el origen
|
|
115
|
+
edge-cli connectivity monitor \
|
|
116
|
+
--interval 5s \
|
|
117
|
+
--threshold 3 failures \
|
|
118
|
+
--action enter-offline-mode
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
## Gestión de Flota
|
|
122
|
+
|
|
123
|
+
### Actualizaciones Escalonadas
|
|
124
|
+
|
|
125
|
+
```bash
|
|
126
|
+
# Actualizar flota en incrementos del 10%
|
|
127
|
+
edge-cli fleet update \
|
|
128
|
+
--image edge-runtime:2.4.1 \
|
|
129
|
+
--strategy rolling \
|
|
130
|
+
--batch-size 10% \
|
|
131
|
+
--pause-on-failure-rate 5%
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### Planificación de Capacidad
|
|
135
|
+
|
|
136
|
+
```bash
|
|
137
|
+
# Ver resumen de capacidad de la flota
|
|
138
|
+
edge-cli fleet capacity --format json
|
|
139
|
+
|
|
140
|
+
# Métricas clave:
|
|
141
|
+
# - Nodos totales: 24
|
|
142
|
+
# - Capacidad de cómputo activa: 96 vCPUs
|
|
143
|
+
# - Capacidad de almacenamiento: 1.2Ti
|
|
144
|
+
# - Utilización actual: 62%
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
---
|
|
148
|
+
[Volver al Perfil de Computación en el Borde](./README.es.md)
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
# Edge Computing — Operations Guide
|
|
2
|
+
|
|
3
|
+
> **Bilingual Navigation:** [English](./operations.md) | [Español](./operations.es.md)
|
|
4
|
+
|
|
5
|
+
**Owner:** Platform Engineering
|
|
6
|
+
**Topology:** Edge Computing
|
|
7
|
+
|
|
8
|
+
## Node Lifecycle Management
|
|
9
|
+
|
|
10
|
+
Edge nodes follow a defined lifecycle: provisioning, registration, activation, monitoring, maintenance, and decommissioning.
|
|
11
|
+
|
|
12
|
+
### Provisioning
|
|
13
|
+
|
|
14
|
+
```bash
|
|
15
|
+
# Register a new edge node
|
|
16
|
+
edge-cli node register \
|
|
17
|
+
--node-id edge-node-01 \
|
|
18
|
+
--region us-west-2 \
|
|
19
|
+
--zone us-west-2a \
|
|
20
|
+
--role compute \
|
|
21
|
+
--capacity "cpu=4,memory=8Gi,storage=50Gi"
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
### Health Monitoring
|
|
25
|
+
|
|
26
|
+
Each node reports health metrics every 15 seconds:
|
|
27
|
+
|
|
28
|
+
| Metric | Threshold | Action on Breach |
|
|
29
|
+
|--------|-----------|------------------|
|
|
30
|
+
| Latency to origin | > 200ms | Trigger failover |
|
|
31
|
+
| CPU utilization | > 85% | Shed non-critical workloads |
|
|
32
|
+
| Memory usage | > 90% | Evict least-recently-used cache |
|
|
33
|
+
| Disk usage | > 80% | Purge stale content |
|
|
34
|
+
| Sync lag | > 30s | Escalate to operations |
|
|
35
|
+
|
|
36
|
+
## Content Sync Monitoring (Ref: EC-R01)
|
|
37
|
+
|
|
38
|
+
The sync strategy ensures content consistency across the edge fleet.
|
|
39
|
+
|
|
40
|
+
### Sync Health Dashboard
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
# Check sync status across all nodes
|
|
44
|
+
edge-cli sync status --fleet-wide --format table
|
|
45
|
+
|
|
46
|
+
# Output:
|
|
47
|
+
# NODE LAST_SYNC LAG STATUS
|
|
48
|
+
# edge-node-01 2026-06-23 2s healthy
|
|
49
|
+
# edge-node-02 2026-06-23 45s degraded
|
|
50
|
+
# edge-node-03 2026-06-22 4h offline
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
### Sync Strategies
|
|
54
|
+
|
|
55
|
+
| Strategy | Use Case | Consistency | Performance |
|
|
56
|
+
|----------|----------|-------------|-------------|
|
|
57
|
+
| Push-based | Static assets | Strong | High bandwidth |
|
|
58
|
+
| Pull-based | Dynamic content | Eventual | On-demand |
|
|
59
|
+
| Hybrid | Mixed workloads | Tunable | Balanced |
|
|
60
|
+
|
|
61
|
+
## Latency Measurement (200ms Budget)
|
|
62
|
+
|
|
63
|
+
End-to-end latency is measured from client request to response delivery.
|
|
64
|
+
|
|
65
|
+
### Measurement Points
|
|
66
|
+
|
|
67
|
+
1. **Client → Edge Node**: DNS resolution + TCP handshake + TLS
|
|
68
|
+
2. **Edge Processing**: Function execution time
|
|
69
|
+
3. **Edge → Origin** (on miss): Cache miss penalty
|
|
70
|
+
4. **Response Delivery**: Serialization + transfer
|
|
71
|
+
|
|
72
|
+
### Latency Budget Breakdown
|
|
73
|
+
|
|
74
|
+
| Segment | Budget | Current | Status |
|
|
75
|
+
|---------|--------|---------|--------|
|
|
76
|
+
| DNS resolution | 20ms | 12ms | [PASS] |
|
|
77
|
+
| TLS handshake | 40ms | 35ms | [PASS] |
|
|
78
|
+
| Edge processing | 50ms | 42ms | [PASS] |
|
|
79
|
+
| Cache miss (p95) | 80ms | 78ms | [PASS] |
|
|
80
|
+
| Transfer overhead | 10ms | 8ms | [PASS] |
|
|
81
|
+
| **Total** | **200ms** | **175ms** | **[PASS]** |
|
|
82
|
+
|
|
83
|
+
### Alerting Rules
|
|
84
|
+
|
|
85
|
+
```yaml
|
|
86
|
+
alerts:
|
|
87
|
+
- name: edge-latency-p99
|
|
88
|
+
condition: latency_p99 > 200ms
|
|
89
|
+
severity: critical
|
|
90
|
+
action: page-oncall
|
|
91
|
+
- name: edge-latency-p95
|
|
92
|
+
condition: latency_p95 > 180ms
|
|
93
|
+
severity: warning
|
|
94
|
+
action: notify-slack
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
## Offline Operations (Ref: EC-R02)
|
|
98
|
+
|
|
99
|
+
Edge nodes must continue serving cached content when disconnected from origin.
|
|
100
|
+
|
|
101
|
+
### Offline Capability Matrix
|
|
102
|
+
|
|
103
|
+
| Capability | Available Offline | Sync Required |
|
|
104
|
+
|------------|-------------------|---------------|
|
|
105
|
+
| Read cached content | Yes | No |
|
|
106
|
+
| Serve static assets | Yes | No |
|
|
107
|
+
| Execute edge functions | Yes (cached) | On reconnect |
|
|
108
|
+
| Write operations | Queued locally | Background sync |
|
|
109
|
+
| Authentication | Cached tokens | Refresh on reconnect |
|
|
110
|
+
|
|
111
|
+
### Offline Detection
|
|
112
|
+
|
|
113
|
+
```bash
|
|
114
|
+
# Monitor origin connectivity
|
|
115
|
+
edge-cli connectivity monitor \
|
|
116
|
+
--interval 5s \
|
|
117
|
+
--threshold 3 failures \
|
|
118
|
+
--action enter-offline-mode
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
## Fleet Management
|
|
122
|
+
|
|
123
|
+
### Rolling Updates
|
|
124
|
+
|
|
125
|
+
```bash
|
|
126
|
+
# Update fleet in 10% increments
|
|
127
|
+
edge-cli fleet update \
|
|
128
|
+
--image edge-runtime:2.4.1 \
|
|
129
|
+
--strategy rolling \
|
|
130
|
+
--batch-size 10% \
|
|
131
|
+
--pause-on-failure-rate 5%
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### Capacity Planning
|
|
135
|
+
|
|
136
|
+
```bash
|
|
137
|
+
# View fleet capacity summary
|
|
138
|
+
edge-cli fleet capacity --format json
|
|
139
|
+
|
|
140
|
+
# Key metrics:
|
|
141
|
+
# - Total nodes: 24
|
|
142
|
+
# - Active compute capacity: 96 vCPUs
|
|
143
|
+
# - Storage capacity: 1.2Ti
|
|
144
|
+
# - Current utilization: 62%
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
---
|
|
148
|
+
[Back to Edge Computing Profile](./README.md)
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
{
|
|
2
|
+
"input": {
|
|
3
|
+
"topology": "edge-computing",
|
|
4
|
+
"config": {
|
|
5
|
+
"networkSecurity": { "mtlsEnabled": true },
|
|
6
|
+
"edgeIsolation": true,
|
|
7
|
+
"conflictResolution": "last-write-wins"
|
|
8
|
+
}
|
|
9
|
+
},
|
|
10
|
+
"expectedNative": [
|
|
11
|
+
{ "ruleId": "EC-R01", "severity": "error", "file": null }
|
|
12
|
+
]
|
|
13
|
+
}
|