Contract YAML reference
Minimum viable contract:
apiVersion: contract.spendguard.io/v1alpha1kind: Contractmetadata: id: 33333333-3333-4333-8333-333333333333 name: my-contractspec: budgets: - id: 44444444-4444-4444-8444-444444444444 limit_amount_atomic: "1000000000" # $1000 in atomic units currency: USD reservation_ttl_seconds: 600 require_hard_cap: true rules: - id: hard-cap-deny when: budget_id: 44444444-4444-4444-8444-444444444444 claim_amount_atomic_gt: "1000000000" then: decision: STOP reason_code: BUDGET_EXHAUSTED - id: threshold-approval when: budget_id: 44444444-4444-4444-8444-444444444444 claim_amount_atomic_gte: "100000000" then: decision: REQUIRE_APPROVAL reason_code: AMOUNT_OVER_THRESHOLD approver_role: tenant-adminDecision values
Section titled “Decision values”CONTINUE— proceedDEGRADE— apply mutation patch (POC: treated as APPLY_FAILED)SKIP— non-fatal skipSTOP— terminate runREQUIRE_APPROVAL— pause pending operator (POC: terminal)
Condition operators
Section titled “Condition operators”POC supports:
claim_amount_atomic_gt— claim > thresholdclaim_amount_atomic_gte— claim ≥ threshold
CEL predicates land in v1.
See examples for common patterns.