@usesigil/kit 0.15.0 → 0.17.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +56 -0
- package/dist/advanced-analytics.d.ts +3 -2
- package/dist/advanced-analytics.d.ts.map +1 -1
- package/dist/advanced-analytics.js +9 -42
- package/dist/advanced-analytics.js.map +1 -1
- package/dist/agent-bootstrap.d.ts +117 -0
- package/dist/agent-bootstrap.d.ts.map +1 -0
- package/dist/agent-bootstrap.js +211 -0
- package/dist/agent-bootstrap.js.map +1 -0
- package/dist/agent-errors.d.ts +20 -4
- package/dist/agent-errors.d.ts.map +1 -1
- package/dist/agent-errors.js +947 -377
- package/dist/agent-errors.js.map +1 -1
- package/dist/audit-log.d.ts +101 -0
- package/dist/audit-log.d.ts.map +1 -0
- package/dist/audit-log.js +145 -0
- package/dist/audit-log.js.map +1 -0
- package/dist/build-unsigned.d.ts +152 -0
- package/dist/build-unsigned.d.ts.map +1 -0
- package/dist/build-unsigned.js +152 -0
- package/dist/build-unsigned.js.map +1 -0
- package/dist/caip2-network.d.ts +171 -0
- package/dist/caip2-network.d.ts.map +1 -0
- package/dist/caip2-network.js +202 -0
- package/dist/caip2-network.js.map +1 -0
- package/dist/canonical-encode.d.ts +59 -0
- package/dist/canonical-encode.d.ts.map +1 -0
- package/dist/canonical-encode.js +141 -0
- package/dist/canonical-encode.js.map +1 -0
- package/dist/cosign-helper.d.ts +264 -0
- package/dist/cosign-helper.d.ts.map +1 -0
- package/dist/cosign-helper.js +147 -0
- package/dist/cosign-helper.js.map +1 -0
- package/dist/create-vault.d.ts +102 -1
- package/dist/create-vault.d.ts.map +1 -1
- package/dist/create-vault.js +108 -9
- package/dist/create-vault.js.map +1 -1
- package/dist/dashboard/close-vault.d.ts +110 -0
- package/dist/dashboard/close-vault.d.ts.map +1 -0
- package/dist/dashboard/close-vault.js +165 -0
- package/dist/dashboard/close-vault.js.map +1 -0
- package/dist/dashboard/errors.d.ts +37 -0
- package/dist/dashboard/errors.d.ts.map +1 -1
- package/dist/dashboard/errors.js +81 -1
- package/dist/dashboard/errors.js.map +1 -1
- package/dist/dashboard/from-json.d.ts.map +1 -1
- package/dist/dashboard/from-json.js +1 -2
- package/dist/dashboard/from-json.js.map +1 -1
- package/dist/dashboard/index.d.ts +204 -31
- package/dist/dashboard/index.d.ts.map +1 -1
- package/dist/dashboard/index.js +290 -49
- package/dist/dashboard/index.js.map +1 -1
- package/dist/dashboard/mutations.d.ts +160 -10
- package/dist/dashboard/mutations.d.ts.map +1 -1
- package/dist/dashboard/mutations.js +584 -66
- package/dist/dashboard/mutations.js.map +1 -1
- package/dist/dashboard/post-assertion-validation.d.ts +88 -0
- package/dist/dashboard/post-assertion-validation.d.ts.map +1 -0
- package/dist/dashboard/post-assertion-validation.js +312 -0
- package/dist/dashboard/post-assertion-validation.js.map +1 -0
- package/dist/dashboard/reads.d.ts +92 -1
- package/dist/dashboard/reads.d.ts.map +1 -1
- package/dist/dashboard/reads.js +244 -26
- package/dist/dashboard/reads.js.map +1 -1
- package/dist/dashboard/types.d.ts +172 -21
- package/dist/dashboard/types.d.ts.map +1 -1
- package/dist/errors/agent-errors.generated.d.ts +21 -0
- package/dist/errors/agent-errors.generated.d.ts.map +1 -0
- package/dist/errors/agent-errors.generated.js +133 -0
- package/dist/errors/agent-errors.generated.js.map +1 -0
- package/dist/errors/codes.d.ts +21 -2
- package/dist/errors/codes.d.ts.map +1 -1
- package/dist/errors/codes.js +20 -1
- package/dist/errors/codes.js.map +1 -1
- package/dist/errors/context.d.ts +9 -1
- package/dist/errors/context.d.ts.map +1 -1
- package/dist/event-analytics.d.ts +1 -3
- package/dist/event-analytics.d.ts.map +1 -1
- package/dist/event-analytics.js +28 -81
- package/dist/event-analytics.js.map +1 -1
- package/dist/events.d.ts.map +1 -1
- package/dist/events.js +23 -13
- package/dist/events.js.map +1 -1
- package/dist/generated/accounts/agentSpendOverlay.d.ts +60 -0
- package/dist/generated/accounts/agentSpendOverlay.d.ts.map +1 -1
- package/dist/generated/accounts/agentSpendOverlay.js +6 -2
- package/dist/generated/accounts/agentSpendOverlay.js.map +1 -1
- package/dist/generated/accounts/agentVault.d.ts +168 -4
- package/dist/generated/accounts/agentVault.d.ts.map +1 -1
- package/dist/generated/accounts/agentVault.js +11 -3
- package/dist/generated/accounts/agentVault.js.map +1 -1
- package/dist/generated/accounts/auditLogRejected.d.ts +66 -0
- package/dist/generated/accounts/auditLogRejected.d.ts.map +1 -0
- package/dist/generated/accounts/auditLogRejected.js +68 -0
- package/dist/generated/accounts/auditLogRejected.js.map +1 -0
- package/dist/generated/accounts/auditLogSuccess.d.ts +78 -0
- package/dist/generated/accounts/auditLogSuccess.d.ts.map +1 -0
- package/dist/generated/accounts/auditLogSuccess.js +68 -0
- package/dist/generated/accounts/auditLogSuccess.js.map +1 -0
- package/dist/generated/accounts/index.d.ts +4 -4
- package/dist/generated/accounts/index.d.ts.map +1 -1
- package/dist/generated/accounts/index.js +4 -4
- package/dist/generated/accounts/index.js.map +1 -1
- package/dist/generated/accounts/pendingAgentGrant.d.ts +199 -0
- package/dist/generated/accounts/pendingAgentGrant.d.ts.map +1 -0
- package/dist/generated/accounts/pendingAgentGrant.js +75 -0
- package/dist/generated/accounts/pendingAgentGrant.js.map +1 -0
- package/dist/generated/accounts/pendingAgentPermissionsUpdate.d.ts +76 -0
- package/dist/generated/accounts/pendingAgentPermissionsUpdate.d.ts.map +1 -1
- package/dist/generated/accounts/pendingAgentPermissionsUpdate.js +9 -1
- package/dist/generated/accounts/pendingAgentPermissionsUpdate.js.map +1 -1
- package/dist/generated/accounts/pendingOwnershipTransfer.d.ts +131 -0
- package/dist/generated/accounts/pendingOwnershipTransfer.d.ts.map +1 -0
- package/dist/generated/accounts/pendingOwnershipTransfer.js +76 -0
- package/dist/generated/accounts/pendingOwnershipTransfer.js.map +1 -0
- package/dist/generated/accounts/pendingPolicyUpdate.d.ts +220 -4
- package/dist/generated/accounts/pendingPolicyUpdate.d.ts.map +1 -1
- package/dist/generated/accounts/pendingPolicyUpdate.js +25 -5
- package/dist/generated/accounts/pendingPolicyUpdate.js.map +1 -1
- package/dist/generated/accounts/policyConfig.d.ts +495 -34
- package/dist/generated/accounts/policyConfig.d.ts.map +1 -1
- package/dist/generated/accounts/policyConfig.js +34 -7
- package/dist/generated/accounts/policyConfig.js.map +1 -1
- package/dist/generated/accounts/postExecutionAssertions.d.ts +2 -2
- package/dist/generated/accounts/postExecutionAssertions.d.ts.map +1 -1
- package/dist/generated/accounts/postExecutionAssertions.js +3 -3
- package/dist/generated/accounts/sessionAuthority.d.ts +154 -12
- package/dist/generated/accounts/sessionAuthority.d.ts.map +1 -1
- package/dist/generated/accounts/sessionAuthority.js +12 -10
- package/dist/generated/accounts/sessionAuthority.js.map +1 -1
- package/dist/generated/accounts/spendTracker.d.ts +83 -3
- package/dist/generated/accounts/spendTracker.d.ts.map +1 -1
- package/dist/generated/accounts/spendTracker.js +14 -2
- package/dist/generated/accounts/spendTracker.js.map +1 -1
- package/dist/generated/errors/sigil.d.ts +160 -100
- package/dist/generated/errors/sigil.d.ts.map +1 -1
- package/dist/generated/errors/sigil.js +214 -124
- package/dist/generated/errors/sigil.js.map +1 -1
- package/dist/generated/event-discriminators.d.ts.map +1 -1
- package/dist/generated/event-discriminators.js +11 -13
- package/dist/generated/event-discriminators.js.map +1 -1
- package/dist/generated/instructions/acceptOwnershipTransfer.d.ts +142 -0
- package/dist/generated/instructions/acceptOwnershipTransfer.d.ts.map +1 -0
- package/dist/generated/instructions/acceptOwnershipTransfer.js +171 -0
- package/dist/generated/instructions/acceptOwnershipTransfer.js.map +1 -0
- package/dist/generated/instructions/acceptOwnershipTransferMultisig.d.ts +142 -0
- package/dist/generated/instructions/acceptOwnershipTransferMultisig.d.ts.map +1 -0
- package/dist/generated/instructions/acceptOwnershipTransferMultisig.js +171 -0
- package/dist/generated/instructions/acceptOwnershipTransferMultisig.js.map +1 -0
- package/dist/generated/instructions/applyAgentGrant.d.ts +100 -0
- package/dist/generated/instructions/applyAgentGrant.d.ts.map +1 -0
- package/dist/generated/instructions/{applyConstraintsUpdate.js → applyAgentGrant.js} +66 -42
- package/dist/generated/instructions/applyAgentGrant.js.map +1 -0
- package/dist/generated/instructions/applyAgentPermissionsUpdate.d.ts +31 -8
- package/dist/generated/instructions/applyAgentPermissionsUpdate.d.ts.map +1 -1
- package/dist/generated/instructions/applyAgentPermissionsUpdate.js +38 -2
- package/dist/generated/instructions/applyAgentPermissionsUpdate.js.map +1 -1
- package/dist/generated/instructions/applyPendingPolicy.d.ts +18 -7
- package/dist/generated/instructions/applyPendingPolicy.d.ts.map +1 -1
- package/dist/generated/instructions/applyPendingPolicy.js +38 -2
- package/dist/generated/instructions/applyPendingPolicy.js.map +1 -1
- package/dist/generated/instructions/cancelAgentGrant.d.ts +106 -0
- package/dist/generated/instructions/cancelAgentGrant.d.ts.map +1 -0
- package/dist/generated/instructions/{allocatePendingConstraintsPda.js → cancelAgentGrant.js} +54 -42
- package/dist/generated/instructions/cancelAgentGrant.js.map +1 -0
- package/dist/generated/instructions/cancelOwnershipTransfer.d.ts +121 -0
- package/dist/generated/instructions/cancelOwnershipTransfer.d.ts.map +1 -0
- package/dist/generated/instructions/{queueCloseConstraints.js → cancelOwnershipTransfer.js} +58 -44
- package/dist/generated/instructions/cancelOwnershipTransfer.js.map +1 -0
- package/dist/generated/instructions/closePostAssertions.d.ts +6 -1
- package/dist/generated/instructions/closePostAssertions.d.ts.map +1 -1
- package/dist/generated/instructions/closePostAssertions.js +11 -3
- package/dist/generated/instructions/closePostAssertions.js.map +1 -1
- package/dist/generated/instructions/closeVault.d.ts +40 -8
- package/dist/generated/instructions/closeVault.d.ts.map +1 -1
- package/dist/generated/instructions/closeVault.js +40 -2
- package/dist/generated/instructions/closeVault.js.map +1 -1
- package/dist/generated/instructions/createPostAssertions.d.ts +4 -0
- package/dist/generated/instructions/createPostAssertions.d.ts.map +1 -1
- package/dist/generated/instructions/createPostAssertions.js +2 -0
- package/dist/generated/instructions/createPostAssertions.js.map +1 -1
- package/dist/generated/instructions/depositFunds.d.ts +21 -10
- package/dist/generated/instructions/depositFunds.d.ts.map +1 -1
- package/dist/generated/instructions/depositFunds.js +37 -2
- package/dist/generated/instructions/depositFunds.js.map +1 -1
- package/dist/generated/instructions/finalizeSession.d.ts +49 -7
- package/dist/generated/instructions/finalizeSession.d.ts.map +1 -1
- package/dist/generated/instructions/finalizeSession.js +59 -2
- package/dist/generated/instructions/finalizeSession.js.map +1 -1
- package/dist/generated/instructions/freezeVault.d.ts +39 -5
- package/dist/generated/instructions/freezeVault.d.ts.map +1 -1
- package/dist/generated/instructions/freezeVault.js +77 -5
- package/dist/generated/instructions/freezeVault.js.map +1 -1
- package/dist/generated/instructions/index.d.ts +10 -14
- package/dist/generated/instructions/index.d.ts.map +1 -1
- package/dist/generated/instructions/index.js +10 -14
- package/dist/generated/instructions/index.js.map +1 -1
- package/dist/generated/instructions/initializeVault.d.ts +79 -13
- package/dist/generated/instructions/initializeVault.d.ts.map +1 -1
- package/dist/generated/instructions/initializeVault.js +57 -5
- package/dist/generated/instructions/initializeVault.js.map +1 -1
- package/dist/generated/instructions/initiateOwnershipTransfer.d.ts +106 -0
- package/dist/generated/instructions/initiateOwnershipTransfer.d.ts.map +1 -0
- package/dist/generated/instructions/initiateOwnershipTransfer.js +181 -0
- package/dist/generated/instructions/initiateOwnershipTransfer.js.map +1 -0
- package/dist/generated/instructions/pauseAgent.d.ts +49 -5
- package/dist/generated/instructions/pauseAgent.d.ts.map +1 -1
- package/dist/generated/instructions/pauseAgent.js +80 -5
- package/dist/generated/instructions/pauseAgent.js.map +1 -1
- package/dist/generated/instructions/promoteGraylistDestination.d.ts +56 -0
- package/dist/generated/instructions/promoteGraylistDestination.d.ts.map +1 -0
- package/dist/generated/instructions/{createInstructionConstraints.js → promoteGraylistDestination.js} +23 -40
- package/dist/generated/instructions/promoteGraylistDestination.js.map +1 -0
- package/dist/generated/instructions/queueAgentGrant.d.ts +113 -0
- package/dist/generated/instructions/queueAgentGrant.d.ts.map +1 -0
- package/dist/generated/instructions/queueAgentGrant.js +181 -0
- package/dist/generated/instructions/queueAgentGrant.js.map +1 -0
- package/dist/generated/instructions/queueAgentPermissionsUpdate.d.ts +8 -0
- package/dist/generated/instructions/queueAgentPermissionsUpdate.d.ts.map +1 -1
- package/dist/generated/instructions/queueAgentPermissionsUpdate.js +4 -0
- package/dist/generated/instructions/queueAgentPermissionsUpdate.js.map +1 -1
- package/dist/generated/instructions/queuePolicyUpdate.d.ts +40 -8
- package/dist/generated/instructions/queuePolicyUpdate.d.ts.map +1 -1
- package/dist/generated/instructions/queuePolicyUpdate.js +21 -5
- package/dist/generated/instructions/queuePolicyUpdate.js.map +1 -1
- package/dist/generated/instructions/reactivateVault.d.ts +71 -5
- package/dist/generated/instructions/reactivateVault.d.ts.map +1 -1
- package/dist/generated/instructions/reactivateVault.js +80 -5
- package/dist/generated/instructions/reactivateVault.js.map +1 -1
- package/dist/generated/instructions/recordAgentViolation.d.ts +89 -0
- package/dist/generated/instructions/recordAgentViolation.d.ts.map +1 -0
- package/dist/generated/instructions/recordAgentViolation.js +152 -0
- package/dist/generated/instructions/recordAgentViolation.js.map +1 -0
- package/dist/generated/instructions/registerAgent.d.ts +84 -6
- package/dist/generated/instructions/registerAgent.d.ts.map +1 -1
- package/dist/generated/instructions/registerAgent.js +81 -4
- package/dist/generated/instructions/registerAgent.js.map +1 -1
- package/dist/generated/instructions/revokeAgent.d.ts +49 -6
- package/dist/generated/instructions/revokeAgent.d.ts.map +1 -1
- package/dist/generated/instructions/revokeAgent.js +81 -4
- package/dist/generated/instructions/revokeAgent.js.map +1 -1
- package/dist/generated/instructions/setObserveOnly.d.ts +56 -0
- package/dist/generated/instructions/setObserveOnly.d.ts.map +1 -0
- package/dist/generated/instructions/setObserveOnly.js +111 -0
- package/dist/generated/instructions/setObserveOnly.js.map +1 -0
- package/dist/generated/instructions/unpauseAgent.d.ts +46 -5
- package/dist/generated/instructions/unpauseAgent.d.ts.map +1 -1
- package/dist/generated/instructions/unpauseAgent.js +80 -5
- package/dist/generated/instructions/unpauseAgent.js.map +1 -1
- package/dist/generated/instructions/validateAndAuthorize.d.ts +29 -0
- package/dist/generated/instructions/validateAndAuthorize.d.ts.map +1 -1
- package/dist/generated/instructions/validateAndAuthorize.js +4 -0
- package/dist/generated/instructions/validateAndAuthorize.js.map +1 -1
- package/dist/generated/instructions/withdrawFunds.d.ts +53 -11
- package/dist/generated/instructions/withdrawFunds.d.ts.map +1 -1
- package/dist/generated/instructions/withdrawFunds.js +51 -2
- package/dist/generated/instructions/withdrawFunds.js.map +1 -1
- package/dist/generated/programs/sigil.d.ts +79 -95
- package/dist/generated/programs/sigil.d.ts.map +1 -1
- package/dist/generated/programs/sigil.js +139 -187
- package/dist/generated/programs/sigil.js.map +1 -1
- package/dist/generated/types/actionAuthorized.d.ts +0 -2
- package/dist/generated/types/actionAuthorized.d.ts.map +1 -1
- package/dist/generated/types/actionAuthorized.js +0 -2
- package/dist/generated/types/actionAuthorized.js.map +1 -1
- package/dist/generated/types/agentAutoRevoked.d.ts +31 -0
- package/dist/generated/types/agentAutoRevoked.d.ts.map +1 -0
- package/dist/generated/types/{pdaAllocated.js → agentAutoRevoked.js} +12 -10
- package/dist/generated/types/agentAutoRevoked.js.map +1 -0
- package/dist/generated/types/agentEntry.d.ts +48 -0
- package/dist/generated/types/agentEntry.d.ts.map +1 -1
- package/dist/generated/types/agentEntry.js +4 -2
- package/dist/generated/types/agentEntry.js.map +1 -1
- package/dist/generated/types/agentGrantApplied.d.ts +38 -0
- package/dist/generated/types/agentGrantApplied.d.ts.map +1 -0
- package/dist/generated/types/agentGrantApplied.js +34 -0
- package/dist/generated/types/agentGrantApplied.js.map +1 -0
- package/dist/generated/types/agentGrantCancelled.d.ts +33 -0
- package/dist/generated/types/agentGrantCancelled.d.ts.map +1 -0
- package/dist/generated/types/agentGrantCancelled.js +28 -0
- package/dist/generated/types/agentGrantCancelled.js.map +1 -0
- package/dist/generated/types/agentGrantQueued.d.ts +38 -0
- package/dist/generated/types/agentGrantQueued.d.ts.map +1 -0
- package/dist/generated/types/agentGrantQueued.js +32 -0
- package/dist/generated/types/agentGrantQueued.js.map +1 -0
- package/dist/generated/types/auditEntry.d.ts +120 -0
- package/dist/generated/types/auditEntry.d.ts.map +1 -0
- package/dist/generated/types/auditEntry.js +34 -0
- package/dist/generated/types/auditEntry.js.map +1 -0
- package/dist/generated/types/destinationGraylistEntry.d.ts +32 -0
- package/dist/generated/types/destinationGraylistEntry.d.ts.map +1 -0
- package/dist/generated/types/destinationGraylistEntry.js +24 -0
- package/dist/generated/types/destinationGraylistEntry.js.map +1 -0
- package/dist/generated/types/graylistEntered.d.ts +31 -0
- package/dist/generated/types/graylistEntered.d.ts.map +1 -0
- package/dist/generated/types/graylistEntered.js +30 -0
- package/dist/generated/types/graylistEntered.js.map +1 -0
- package/dist/generated/types/graylistPromoted.d.ts +29 -0
- package/dist/generated/types/graylistPromoted.d.ts.map +1 -0
- package/dist/generated/types/graylistPromoted.js +28 -0
- package/dist/generated/types/graylistPromoted.js.map +1 -0
- package/dist/generated/types/index.d.ts +13 -21
- package/dist/generated/types/index.d.ts.map +1 -1
- package/dist/generated/types/index.js +13 -21
- package/dist/generated/types/index.js.map +1 -1
- package/dist/generated/types/observeOnlyChanged.d.ts +33 -0
- package/dist/generated/types/observeOnlyChanged.d.ts.map +1 -0
- package/dist/generated/types/observeOnlyChanged.js +32 -0
- package/dist/generated/types/observeOnlyChanged.js.map +1 -0
- package/dist/generated/types/ownershipTransferAccepted.d.ts +32 -0
- package/dist/generated/types/ownershipTransferAccepted.d.ts.map +1 -0
- package/dist/generated/types/ownershipTransferAccepted.js +30 -0
- package/dist/generated/types/ownershipTransferAccepted.js.map +1 -0
- package/dist/generated/types/ownershipTransferCancelled.d.ts +29 -0
- package/dist/generated/types/ownershipTransferCancelled.d.ts.map +1 -0
- package/dist/generated/types/ownershipTransferCancelled.js +28 -0
- package/dist/generated/types/ownershipTransferCancelled.js.map +1 -0
- package/dist/generated/types/ownershipTransferInitiated.d.ts +33 -0
- package/dist/generated/types/ownershipTransferInitiated.d.ts.map +1 -0
- package/dist/generated/types/ownershipTransferInitiated.js +30 -0
- package/dist/generated/types/ownershipTransferInitiated.js.map +1 -0
- package/dist/generated/types/perRecipientCounter.d.ts +61 -0
- package/dist/generated/types/perRecipientCounter.d.ts.map +1 -0
- package/dist/generated/types/perRecipientCounter.js +26 -0
- package/dist/generated/types/perRecipientCounter.js.map +1 -0
- package/dist/generated/types/postAssertionEntry.d.ts +14 -7
- package/dist/generated/types/postAssertionEntry.d.ts.map +1 -1
- package/dist/generated/types/postAssertionEntry.js +5 -7
- package/dist/generated/types/postAssertionEntry.js.map +1 -1
- package/dist/generated/types/postAssertionEntryZC.d.ts +53 -22
- package/dist/generated/types/postAssertionEntryZC.d.ts.map +1 -1
- package/dist/generated/types/postAssertionEntryZC.js +4 -6
- package/dist/generated/types/postAssertionEntryZC.js.map +1 -1
- package/dist/generated/types/sessionFinalized.d.ts +0 -4
- package/dist/generated/types/sessionFinalized.d.ts.map +1 -1
- package/dist/generated/types/sessionFinalized.js +0 -2
- package/dist/generated/types/sessionFinalized.js.map +1 -1
- package/dist/generated/types/vaultFrozen.d.ts +26 -0
- package/dist/generated/types/vaultFrozen.d.ts.map +1 -1
- package/dist/generated/types/vaultFrozen.js +5 -1
- package/dist/generated/types/vaultFrozen.js.map +1 -1
- package/dist/index.d.ts +35 -6
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +81 -7
- package/dist/index.js.map +1 -1
- package/dist/inscribe.d.ts +0 -4
- package/dist/inscribe.d.ts.map +1 -1
- package/dist/inscribe.js +0 -1
- package/dist/inscribe.js.map +1 -1
- package/dist/inspector.d.ts +0 -23
- package/dist/inspector.d.ts.map +1 -1
- package/dist/inspector.js +0 -52
- package/dist/inspector.js.map +1 -1
- package/dist/kit-adapter.d.ts +1 -1
- package/dist/kit-adapter.d.ts.map +1 -1
- package/dist/kit-adapter.js +1 -1
- package/dist/kit-adapter.js.map +1 -1
- package/dist/logger.d.ts +48 -0
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +36 -0
- package/dist/logger.js.map +1 -1
- package/dist/multisig-detection.d.ts +83 -0
- package/dist/multisig-detection.d.ts.map +1 -0
- package/dist/multisig-detection.js +128 -0
- package/dist/multisig-detection.js.map +1 -0
- package/dist/owner-transaction.d.ts +8 -0
- package/dist/owner-transaction.d.ts.map +1 -1
- package/dist/owner-transaction.js +1 -0
- package/dist/owner-transaction.js.map +1 -1
- package/dist/ownership-transfer.d.ts +79 -0
- package/dist/ownership-transfer.d.ts.map +1 -0
- package/dist/ownership-transfer.js +66 -0
- package/dist/ownership-transfer.js.map +1 -0
- package/dist/policy/compute-cosign-digest.d.ts +193 -0
- package/dist/policy/compute-cosign-digest.d.ts.map +1 -0
- package/dist/policy/compute-cosign-digest.js +318 -0
- package/dist/policy/compute-cosign-digest.js.map +1 -0
- package/dist/policy/compute-policy-preview-digest.d.ts +258 -0
- package/dist/policy/compute-policy-preview-digest.d.ts.map +1 -0
- package/dist/policy/compute-policy-preview-digest.js +351 -0
- package/dist/policy/compute-policy-preview-digest.js.map +1 -0
- package/dist/policy-attestation.d.ts +51 -0
- package/dist/policy-attestation.d.ts.map +1 -0
- package/dist/policy-attestation.js +43 -0
- package/dist/policy-attestation.js.map +1 -0
- package/dist/presets.d.ts +1 -7
- package/dist/presets.d.ts.map +1 -1
- package/dist/presets.js +0 -5
- package/dist/presets.js.map +1 -1
- package/dist/preview-create-vault.d.ts +280 -0
- package/dist/preview-create-vault.d.ts.map +1 -0
- package/dist/preview-create-vault.js +498 -0
- package/dist/preview-create-vault.js.map +1 -0
- package/dist/resolve-accounts.d.ts +75 -10
- package/dist/resolve-accounts.d.ts.map +1 -1
- package/dist/resolve-accounts.js +68 -32
- package/dist/resolve-accounts.js.map +1 -1
- package/dist/rpc-helpers.d.ts +29 -3
- package/dist/rpc-helpers.d.ts.map +1 -1
- package/dist/rpc-helpers.js +51 -12
- package/dist/rpc-helpers.js.map +1 -1
- package/dist/seal/intent-digest.d.ts +195 -0
- package/dist/seal/intent-digest.d.ts.map +1 -0
- package/dist/seal/intent-digest.js +372 -0
- package/dist/seal/intent-digest.js.map +1 -0
- package/dist/seal.d.ts +166 -3
- package/dist/seal.d.ts.map +1 -1
- package/dist/seal.js +428 -8
- package/dist/seal.js.map +1 -1
- package/dist/security-analytics.d.ts +3 -3
- package/dist/security-analytics.d.ts.map +1 -1
- package/dist/security-analytics.js +13 -128
- package/dist/security-analytics.js.map +1 -1
- package/dist/session-mint.d.ts +72 -0
- package/dist/session-mint.d.ts.map +1 -0
- package/dist/session-mint.js +59 -0
- package/dist/session-mint.js.map +1 -0
- package/dist/sigil.d.ts +0 -4
- package/dist/sigil.d.ts.map +1 -1
- package/dist/simulation.d.ts +19 -0
- package/dist/simulation.d.ts.map +1 -1
- package/dist/simulation.js +211 -138
- package/dist/simulation.js.map +1 -1
- package/dist/squads-detection.d.ts +135 -0
- package/dist/squads-detection.d.ts.map +1 -0
- package/dist/squads-detection.js +124 -0
- package/dist/squads-detection.js.map +1 -0
- package/dist/state-resolver.d.ts +0 -16
- package/dist/state-resolver.d.ts.map +1 -1
- package/dist/state-resolver.js +162 -97
- package/dist/state-resolver.js.map +1 -1
- package/dist/testing/devnet.d.ts +40 -1
- package/dist/testing/devnet.d.ts.map +1 -1
- package/dist/testing/devnet.js +333 -45
- package/dist/testing/devnet.js.map +1 -1
- package/dist/testing/errors/expect.d.ts +137 -0
- package/dist/testing/errors/expect.d.ts.map +1 -0
- package/dist/testing/errors/expect.js +372 -0
- package/dist/testing/errors/expect.js.map +1 -0
- package/dist/testing/errors/index.d.ts +3 -0
- package/dist/testing/errors/index.d.ts.map +1 -0
- package/dist/testing/errors/index.js +8 -0
- package/dist/testing/errors/index.js.map +1 -0
- package/dist/testing/errors/names.generated.d.ts +211 -0
- package/dist/testing/errors/names.generated.d.ts.map +1 -0
- package/dist/testing/errors/names.generated.js +206 -0
- package/dist/testing/errors/names.generated.js.map +1 -0
- package/dist/testing/index.d.ts +1 -0
- package/dist/testing/index.d.ts.map +1 -1
- package/dist/testing/index.js +8 -0
- package/dist/testing/index.js.map +1 -1
- package/dist/testing/mock-rpc.d.ts +16 -0
- package/dist/testing/mock-rpc.d.ts.map +1 -1
- package/dist/testing/mock-rpc.js +27 -0
- package/dist/testing/mock-rpc.js.map +1 -1
- package/dist/testing/mock-state.d.ts +2 -0
- package/dist/testing/mock-state.d.ts.map +1 -1
- package/dist/testing/mock-state.js +45 -6
- package/dist/testing/mock-state.js.map +1 -1
- package/dist/types.d.ts +5 -15
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +11 -69
- package/dist/types.js.map +1 -1
- package/dist/vault-analytics.d.ts +0 -2
- package/dist/vault-analytics.d.ts.map +1 -1
- package/dist/vault-analytics.js +1 -9
- package/dist/vault-analytics.js.map +1 -1
- package/package.json +12 -5
- package/dist/dashboard/constraint-reads.d.ts +0 -50
- package/dist/dashboard/constraint-reads.d.ts.map +0 -1
- package/dist/dashboard/constraint-reads.js +0 -119
- package/dist/dashboard/constraint-reads.js.map +0 -1
- package/dist/generated/accounts/escrowDeposit.d.ts +0 -50
- package/dist/generated/accounts/escrowDeposit.d.ts.map +0 -1
- package/dist/generated/accounts/escrowDeposit.js +0 -76
- package/dist/generated/accounts/escrowDeposit.js.map +0 -1
- package/dist/generated/accounts/instructionConstraints.d.ts +0 -46
- package/dist/generated/accounts/instructionConstraints.d.ts.map +0 -1
- package/dist/generated/accounts/instructionConstraints.js +0 -73
- package/dist/generated/accounts/instructionConstraints.js.map +0 -1
- package/dist/generated/accounts/pendingCloseConstraints.d.ts +0 -37
- package/dist/generated/accounts/pendingCloseConstraints.d.ts.map +0 -1
- package/dist/generated/accounts/pendingCloseConstraints.js +0 -66
- package/dist/generated/accounts/pendingCloseConstraints.js.map +0 -1
- package/dist/generated/accounts/pendingConstraintsUpdate.d.ts +0 -62
- package/dist/generated/accounts/pendingConstraintsUpdate.d.ts.map +0 -1
- package/dist/generated/accounts/pendingConstraintsUpdate.js +0 -75
- package/dist/generated/accounts/pendingConstraintsUpdate.js.map +0 -1
- package/dist/generated/instructions/allocateConstraintsPda.d.ts +0 -62
- package/dist/generated/instructions/allocateConstraintsPda.d.ts.map +0 -1
- package/dist/generated/instructions/allocateConstraintsPda.js +0 -134
- package/dist/generated/instructions/allocateConstraintsPda.js.map +0 -1
- package/dist/generated/instructions/allocatePendingConstraintsPda.d.ts +0 -66
- package/dist/generated/instructions/allocatePendingConstraintsPda.d.ts.map +0 -1
- package/dist/generated/instructions/allocatePendingConstraintsPda.js.map +0 -1
- package/dist/generated/instructions/applyCloseConstraints.d.ts +0 -59
- package/dist/generated/instructions/applyCloseConstraints.d.ts.map +0 -1
- package/dist/generated/instructions/applyCloseConstraints.js +0 -143
- package/dist/generated/instructions/applyCloseConstraints.js.map +0 -1
- package/dist/generated/instructions/applyConstraintsUpdate.d.ts +0 -62
- package/dist/generated/instructions/applyConstraintsUpdate.d.ts.map +0 -1
- package/dist/generated/instructions/applyConstraintsUpdate.js.map +0 -1
- package/dist/generated/instructions/cancelCloseConstraints.d.ts +0 -51
- package/dist/generated/instructions/cancelCloseConstraints.d.ts.map +0 -1
- package/dist/generated/instructions/cancelCloseConstraints.js +0 -115
- package/dist/generated/instructions/cancelCloseConstraints.js.map +0 -1
- package/dist/generated/instructions/cancelConstraintsUpdate.d.ts +0 -51
- package/dist/generated/instructions/cancelConstraintsUpdate.d.ts.map +0 -1
- package/dist/generated/instructions/cancelConstraintsUpdate.js +0 -115
- package/dist/generated/instructions/cancelConstraintsUpdate.js.map +0 -1
- package/dist/generated/instructions/closeSettledEscrow.d.ts +0 -72
- package/dist/generated/instructions/closeSettledEscrow.d.ts.map +0 -1
- package/dist/generated/instructions/closeSettledEscrow.js +0 -127
- package/dist/generated/instructions/closeSettledEscrow.js.map +0 -1
- package/dist/generated/instructions/createEscrow.d.ts +0 -131
- package/dist/generated/instructions/createEscrow.d.ts.map +0 -1
- package/dist/generated/instructions/createEscrow.js +0 -272
- package/dist/generated/instructions/createEscrow.js.map +0 -1
- package/dist/generated/instructions/createInstructionConstraints.d.ts +0 -68
- package/dist/generated/instructions/createInstructionConstraints.d.ts.map +0 -1
- package/dist/generated/instructions/createInstructionConstraints.js.map +0 -1
- package/dist/generated/instructions/extendPda.d.ts +0 -52
- package/dist/generated/instructions/extendPda.d.ts.map +0 -1
- package/dist/generated/instructions/extendPda.js +0 -86
- package/dist/generated/instructions/extendPda.js.map +0 -1
- package/dist/generated/instructions/queueCloseConstraints.d.ts +0 -66
- package/dist/generated/instructions/queueCloseConstraints.d.ts.map +0 -1
- package/dist/generated/instructions/queueCloseConstraints.js.map +0 -1
- package/dist/generated/instructions/queueConstraintsUpdate.d.ts +0 -75
- package/dist/generated/instructions/queueConstraintsUpdate.d.ts.map +0 -1
- package/dist/generated/instructions/queueConstraintsUpdate.js +0 -154
- package/dist/generated/instructions/queueConstraintsUpdate.js.map +0 -1
- package/dist/generated/instructions/refundEscrow.d.ts +0 -74
- package/dist/generated/instructions/refundEscrow.d.ts.map +0 -1
- package/dist/generated/instructions/refundEscrow.js +0 -142
- package/dist/generated/instructions/refundEscrow.js.map +0 -1
- package/dist/generated/instructions/settleEscrow.d.ts +0 -80
- package/dist/generated/instructions/settleEscrow.d.ts.map +0 -1
- package/dist/generated/instructions/settleEscrow.js +0 -173
- package/dist/generated/instructions/settleEscrow.js.map +0 -1
- package/dist/generated/types/accountConstraint.d.ts +0 -18
- package/dist/generated/types/accountConstraint.d.ts.map +0 -1
- package/dist/generated/types/accountConstraint.js +0 -24
- package/dist/generated/types/accountConstraint.js.map +0 -1
- package/dist/generated/types/accountConstraintZC.d.ts +0 -18
- package/dist/generated/types/accountConstraintZC.d.ts.map +0 -1
- package/dist/generated/types/accountConstraintZC.js +0 -26
- package/dist/generated/types/accountConstraintZC.js.map +0 -1
- package/dist/generated/types/closeConstraintsApplied.d.ts +0 -20
- package/dist/generated/types/closeConstraintsApplied.d.ts.map +0 -1
- package/dist/generated/types/closeConstraintsApplied.js +0 -24
- package/dist/generated/types/closeConstraintsApplied.js.map +0 -1
- package/dist/generated/types/closeConstraintsCancelled.d.ts +0 -16
- package/dist/generated/types/closeConstraintsCancelled.d.ts.map +0 -1
- package/dist/generated/types/closeConstraintsCancelled.js +0 -18
- package/dist/generated/types/closeConstraintsCancelled.js.map +0 -1
- package/dist/generated/types/closeConstraintsQueued.d.ts +0 -20
- package/dist/generated/types/closeConstraintsQueued.d.ts.map +0 -1
- package/dist/generated/types/closeConstraintsQueued.js +0 -24
- package/dist/generated/types/closeConstraintsQueued.js.map +0 -1
- package/dist/generated/types/constraintEntry.d.ts +0 -39
- package/dist/generated/types/constraintEntry.d.ts.map +0 -1
- package/dist/generated/types/constraintEntry.js +0 -31
- package/dist/generated/types/constraintEntry.js.map +0 -1
- package/dist/generated/types/constraintEntryZC.d.ts +0 -68
- package/dist/generated/types/constraintEntryZC.d.ts.map +0 -1
- package/dist/generated/types/constraintEntryZC.js +0 -49
- package/dist/generated/types/constraintEntryZC.js.map +0 -1
- package/dist/generated/types/constraintOperator.d.ts +0 -22
- package/dist/generated/types/constraintOperator.d.ts.map +0 -1
- package/dist/generated/types/constraintOperator.js +0 -28
- package/dist/generated/types/constraintOperator.js.map +0 -1
- package/dist/generated/types/constraintsChangeApplied.d.ts +0 -30
- package/dist/generated/types/constraintsChangeApplied.d.ts.map +0 -1
- package/dist/generated/types/constraintsChangeApplied.js +0 -32
- package/dist/generated/types/constraintsChangeApplied.js.map +0 -1
- package/dist/generated/types/constraintsChangeCancelled.d.ts +0 -16
- package/dist/generated/types/constraintsChangeCancelled.d.ts.map +0 -1
- package/dist/generated/types/constraintsChangeCancelled.js +0 -18
- package/dist/generated/types/constraintsChangeCancelled.js.map +0 -1
- package/dist/generated/types/constraintsChangeQueued.d.ts +0 -30
- package/dist/generated/types/constraintsChangeQueued.d.ts.map +0 -1
- package/dist/generated/types/constraintsChangeQueued.js +0 -32
- package/dist/generated/types/constraintsChangeQueued.js.map +0 -1
- package/dist/generated/types/dataConstraint.d.ts +0 -23
- package/dist/generated/types/dataConstraint.d.ts.map +0 -1
- package/dist/generated/types/dataConstraint.js +0 -27
- package/dist/generated/types/dataConstraint.js.map +0 -1
- package/dist/generated/types/dataConstraintZC.d.ts +0 -20
- package/dist/generated/types/dataConstraintZC.d.ts.map +0 -1
- package/dist/generated/types/dataConstraintZC.js +0 -30
- package/dist/generated/types/dataConstraintZC.js.map +0 -1
- package/dist/generated/types/discriminatorFormat.d.ts +0 -25
- package/dist/generated/types/discriminatorFormat.d.ts.map +0 -1
- package/dist/generated/types/discriminatorFormat.js +0 -31
- package/dist/generated/types/discriminatorFormat.js.map +0 -1
- package/dist/generated/types/escrowCreated.d.ts +0 -30
- package/dist/generated/types/escrowCreated.d.ts.map +0 -1
- package/dist/generated/types/escrowCreated.js +0 -34
- package/dist/generated/types/escrowCreated.js.map +0 -1
- package/dist/generated/types/escrowRefunded.d.ts +0 -26
- package/dist/generated/types/escrowRefunded.d.ts.map +0 -1
- package/dist/generated/types/escrowRefunded.js +0 -30
- package/dist/generated/types/escrowRefunded.js.map +0 -1
- package/dist/generated/types/escrowSettled.d.ts +0 -26
- package/dist/generated/types/escrowSettled.d.ts.map +0 -1
- package/dist/generated/types/escrowSettled.js +0 -30
- package/dist/generated/types/escrowSettled.js.map +0 -1
- package/dist/generated/types/escrowStatus.d.ts +0 -18
- package/dist/generated/types/escrowStatus.d.ts.map +0 -1
- package/dist/generated/types/escrowStatus.js +0 -24
- package/dist/generated/types/escrowStatus.js.map +0 -1
- package/dist/generated/types/instructionConstraintsCreated.d.ts +0 -34
- package/dist/generated/types/instructionConstraintsCreated.d.ts.map +0 -1
- package/dist/generated/types/instructionConstraintsCreated.js +0 -36
- package/dist/generated/types/instructionConstraintsCreated.js.map +0 -1
- package/dist/generated/types/pdaAllocated.d.ts +0 -24
- package/dist/generated/types/pdaAllocated.d.ts.map +0 -1
- package/dist/generated/types/pdaAllocated.js.map +0 -1
- package/dist/generated/types/pdaExtended.d.ts +0 -24
- package/dist/generated/types/pdaExtended.d.ts.map +0 -1
- package/dist/generated/types/pdaExtended.js +0 -28
- package/dist/generated/types/pdaExtended.js.map +0 -1
- package/dist/integrations/protocol-handler.d.ts +0 -59
- package/dist/integrations/protocol-handler.d.ts.map +0 -1
- package/dist/integrations/protocol-handler.js +0 -9
- package/dist/integrations/protocol-handler.js.map +0 -1
|
@@ -5,7 +5,8 @@
|
|
|
5
5
|
*
|
|
6
6
|
* @see https://github.com/codama-idl/codama
|
|
7
7
|
*/
|
|
8
|
-
import { assertAccountExists, assertAccountsExist, combineCodec, decodeAccount, fetchEncodedAccount, fetchEncodedAccounts, fixDecoderSize, fixEncoderSize, getAddressDecoder, getAddressEncoder, getArrayDecoder, getArrayEncoder, getBooleanDecoder, getBooleanEncoder, getBytesDecoder, getBytesEncoder, getStructDecoder, getStructEncoder, getU16Decoder, getU16Encoder, getU64Decoder, getU64Encoder, getU8Decoder, getU8Encoder, transformEncoder, } from "@solana/kit";
|
|
8
|
+
import { assertAccountExists, assertAccountsExist, combineCodec, decodeAccount, fetchEncodedAccount, fetchEncodedAccounts, fixDecoderSize, fixEncoderSize, getAddressDecoder, getAddressEncoder, getArrayDecoder, getArrayEncoder, getBooleanDecoder, getBooleanEncoder, getBytesDecoder, getBytesEncoder, getStructDecoder, getStructEncoder, getU16Decoder, getU16Encoder, getU32Decoder, getU32Encoder, getU64Decoder, getU64Encoder, getU8Decoder, getU8Encoder, transformEncoder, } from "@solana/kit";
|
|
9
|
+
import { getDestinationGraylistEntryDecoder, getDestinationGraylistEntryEncoder, } from "../types/index.js";
|
|
9
10
|
export const POLICY_CONFIG_DISCRIMINATOR = new Uint8Array([
|
|
10
11
|
219, 7, 79, 84, 175, 51, 148, 146,
|
|
11
12
|
]);
|
|
@@ -21,19 +22,32 @@ export function getPolicyConfigEncoder() {
|
|
|
21
22
|
["maxTransactionSizeUsd", getU64Encoder()],
|
|
22
23
|
["protocolMode", getU8Encoder()],
|
|
23
24
|
["protocols", getArrayEncoder(getAddressEncoder())],
|
|
24
|
-
["maxLeverageBps", getU16Encoder()],
|
|
25
25
|
["developerFeeRate", getU16Encoder()],
|
|
26
26
|
["maxSlippageBps", getU16Encoder()],
|
|
27
27
|
["timelockDuration", getU64Encoder()],
|
|
28
28
|
["allowedDestinations", getArrayEncoder(getAddressEncoder())],
|
|
29
|
-
["hasConstraints", getBooleanEncoder()],
|
|
30
29
|
["hasPendingPolicy", getBooleanEncoder()],
|
|
31
30
|
["hasProtocolCaps", getBooleanEncoder()],
|
|
32
31
|
["protocolCaps", getArrayEncoder(getU64Encoder())],
|
|
33
|
-
["
|
|
32
|
+
["sessionExpirySeconds", getU64Encoder()],
|
|
34
33
|
["bump", getU8Encoder()],
|
|
35
34
|
["policyVersion", getU64Encoder()],
|
|
36
35
|
["hasPostAssertions", getU8Encoder()],
|
|
36
|
+
["destinationMode", getU8Encoder()],
|
|
37
|
+
["policyPreviewDigest", fixEncoderSize(getBytesEncoder(), 32)],
|
|
38
|
+
["createdAtSlot", getU64Encoder()],
|
|
39
|
+
["operatingHours", getU32Encoder()],
|
|
40
|
+
[
|
|
41
|
+
"destinationGraylist",
|
|
42
|
+
getArrayEncoder(getDestinationGraylistEntryEncoder()),
|
|
43
|
+
],
|
|
44
|
+
["autoPromoteGrays", getBooleanEncoder()],
|
|
45
|
+
["autoRevokeThreshold", getU8Encoder()],
|
|
46
|
+
["stableBalanceFloor", getU64Encoder()],
|
|
47
|
+
["perRecipientDailyCapUsd", getU64Encoder()],
|
|
48
|
+
["cosignRequired", getBooleanEncoder()],
|
|
49
|
+
["cosignSessionPubkey", getAddressEncoder()],
|
|
50
|
+
["operatorGrantDelaySeconds", getU64Encoder()],
|
|
37
51
|
]), (value) => ({ ...value, discriminator: POLICY_CONFIG_DISCRIMINATOR }));
|
|
38
52
|
}
|
|
39
53
|
/** Gets the decoder for {@link PolicyConfig} account data. */
|
|
@@ -45,19 +59,32 @@ export function getPolicyConfigDecoder() {
|
|
|
45
59
|
["maxTransactionSizeUsd", getU64Decoder()],
|
|
46
60
|
["protocolMode", getU8Decoder()],
|
|
47
61
|
["protocols", getArrayDecoder(getAddressDecoder())],
|
|
48
|
-
["maxLeverageBps", getU16Decoder()],
|
|
49
62
|
["developerFeeRate", getU16Decoder()],
|
|
50
63
|
["maxSlippageBps", getU16Decoder()],
|
|
51
64
|
["timelockDuration", getU64Decoder()],
|
|
52
65
|
["allowedDestinations", getArrayDecoder(getAddressDecoder())],
|
|
53
|
-
["hasConstraints", getBooleanDecoder()],
|
|
54
66
|
["hasPendingPolicy", getBooleanDecoder()],
|
|
55
67
|
["hasProtocolCaps", getBooleanDecoder()],
|
|
56
68
|
["protocolCaps", getArrayDecoder(getU64Decoder())],
|
|
57
|
-
["
|
|
69
|
+
["sessionExpirySeconds", getU64Decoder()],
|
|
58
70
|
["bump", getU8Decoder()],
|
|
59
71
|
["policyVersion", getU64Decoder()],
|
|
60
72
|
["hasPostAssertions", getU8Decoder()],
|
|
73
|
+
["destinationMode", getU8Decoder()],
|
|
74
|
+
["policyPreviewDigest", fixDecoderSize(getBytesDecoder(), 32)],
|
|
75
|
+
["createdAtSlot", getU64Decoder()],
|
|
76
|
+
["operatingHours", getU32Decoder()],
|
|
77
|
+
[
|
|
78
|
+
"destinationGraylist",
|
|
79
|
+
getArrayDecoder(getDestinationGraylistEntryDecoder()),
|
|
80
|
+
],
|
|
81
|
+
["autoPromoteGrays", getBooleanDecoder()],
|
|
82
|
+
["autoRevokeThreshold", getU8Decoder()],
|
|
83
|
+
["stableBalanceFloor", getU64Decoder()],
|
|
84
|
+
["perRecipientDailyCapUsd", getU64Decoder()],
|
|
85
|
+
["cosignRequired", getBooleanDecoder()],
|
|
86
|
+
["cosignSessionPubkey", getAddressDecoder()],
|
|
87
|
+
["operatorGrantDelaySeconds", getU64Decoder()],
|
|
61
88
|
]);
|
|
62
89
|
}
|
|
63
90
|
/** Gets the codec for {@link PolicyConfig} account data. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"policyConfig.js","sourceRoot":"","sources":["../../../src/generated/accounts/policyConfig.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EACL,mBAAmB,EACnB,mBAAmB,EACnB,YAAY,EACZ,aAAa,EACb,mBAAmB,EACnB,oBAAoB,EACpB,cAAc,EACd,cAAc,EACd,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,aAAa,EACb,aAAa,EACb,aAAa,EACb,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,gBAAgB,GAYjB,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"policyConfig.js","sourceRoot":"","sources":["../../../src/generated/accounts/policyConfig.ts"],"names":[],"mappings":"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"}
|
|
@@ -15,7 +15,7 @@ export type PostExecutionAssertions = {
|
|
|
15
15
|
vault: ReadonlyUint8Array;
|
|
16
16
|
/** Assertion entries (fixed-size array, up to MAX_POST_ASSERTION_ENTRIES). */
|
|
17
17
|
entries: Array<PostAssertionEntryZC>;
|
|
18
|
-
/** Number of active entries (0..=
|
|
18
|
+
/** Number of active entries (0..=MAX_POST_ASSERTION_ENTRIES). */
|
|
19
19
|
entryCount: number;
|
|
20
20
|
/** PDA bump seed. */
|
|
21
21
|
bump: number;
|
|
@@ -27,7 +27,7 @@ export type PostExecutionAssertionsArgs = {
|
|
|
27
27
|
vault: ReadonlyUint8Array;
|
|
28
28
|
/** Assertion entries (fixed-size array, up to MAX_POST_ASSERTION_ENTRIES). */
|
|
29
29
|
entries: Array<PostAssertionEntryZCArgs>;
|
|
30
|
-
/** Number of active entries (0..=
|
|
30
|
+
/** Number of active entries (0..=MAX_POST_ASSERTION_ENTRIES). */
|
|
31
31
|
entryCount: number;
|
|
32
32
|
/** PDA bump seed. */
|
|
33
33
|
bump: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postExecutionAssertions.d.ts","sourceRoot":"","sources":["../../../src/generated/accounts/postExecutionAssertions.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAKL,mBAAmB,EACnB,oBAAoB,EAYpB,KAAK,OAAO,EACZ,KAAK,OAAO,EACZ,KAAK,cAAc,EACnB,KAAK,kBAAkB,EACvB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,KAAK,mBAAmB,EACxB,KAAK,kBAAkB,EACxB,MAAM,aAAa,CAAC;AACrB,OAAO,EAGL,KAAK,oBAAoB,EACzB,KAAK,wBAAwB,EAC9B,MAAM,mBAAmB,CAAC;AAE3B,eAAO,MAAM,uCAAuC,yBAElD,CAAC;AAEH,wBAAgB,4CAA4C,oCAI3D;AAED,MAAM,MAAM,uBAAuB,GAAG;IACpC,aAAa,EAAE,kBAAkB,CAAC;IAClC,+CAA+C;IAC/C,KAAK,EAAE,kBAAkB,CAAC;IAC1B,8EAA8E;IAC9E,OAAO,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACrC,
|
|
1
|
+
{"version":3,"file":"postExecutionAssertions.d.ts","sourceRoot":"","sources":["../../../src/generated/accounts/postExecutionAssertions.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAKL,mBAAmB,EACnB,oBAAoB,EAYpB,KAAK,OAAO,EACZ,KAAK,OAAO,EACZ,KAAK,cAAc,EACnB,KAAK,kBAAkB,EACvB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,KAAK,mBAAmB,EACxB,KAAK,kBAAkB,EACxB,MAAM,aAAa,CAAC;AACrB,OAAO,EAGL,KAAK,oBAAoB,EACzB,KAAK,wBAAwB,EAC9B,MAAM,mBAAmB,CAAC;AAE3B,eAAO,MAAM,uCAAuC,yBAElD,CAAC;AAEH,wBAAgB,4CAA4C,oCAI3D;AAED,MAAM,MAAM,uBAAuB,GAAG;IACpC,aAAa,EAAE,kBAAkB,CAAC;IAClC,+CAA+C;IAC/C,KAAK,EAAE,kBAAkB,CAAC;IAC1B,8EAA8E;IAC9E,OAAO,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACrC,iEAAiE;IACjE,UAAU,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,+BAA+B;IAC/B,OAAO,EAAE,kBAAkB,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,2BAA2B,GAAG;IACxC,+CAA+C;IAC/C,KAAK,EAAE,kBAAkB,CAAC;IAC1B,8EAA8E;IAC9E,OAAO,EAAE,KAAK,CAAC,wBAAwB,CAAC,CAAC;IACzC,iEAAiE;IACjE,UAAU,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,+BAA+B;IAC/B,OAAO,EAAE,kBAAkB,CAAC;CAC7B,CAAC;AAEF,6EAA6E;AAC7E,wBAAgB,iCAAiC,IAAI,gBAAgB,CAAC,2BAA2B,CAAC,CAkBjG;AAED,yEAAyE;AACzE,wBAAgB,iCAAiC,IAAI,gBAAgB,CAAC,uBAAuB,CAAC,CAS7F;AAED,uEAAuE;AACvE,wBAAgB,+BAA+B,IAAI,cAAc,CAC/D,2BAA2B,EAC3B,uBAAuB,CACxB,CAKA;AAED,wBAAgB,6BAA6B,CAAC,QAAQ,SAAS,MAAM,GAAG,MAAM,EAC5E,cAAc,EAAE,cAAc,CAAC,QAAQ,CAAC,GACvC,OAAO,CAAC,uBAAuB,EAAE,QAAQ,CAAC,CAAC;AAC9C,wBAAgB,6BAA6B,CAAC,QAAQ,SAAS,MAAM,GAAG,MAAM,EAC5E,cAAc,EAAE,mBAAmB,CAAC,QAAQ,CAAC,GAC5C,YAAY,CAAC,uBAAuB,EAAE,QAAQ,CAAC,CAAC;AAYnD,wBAAsB,4BAA4B,CAChD,QAAQ,SAAS,MAAM,GAAG,MAAM,EAEhC,GAAG,EAAE,UAAU,CAAC,OAAO,mBAAmB,CAAC,CAAC,CAAC,CAAC,EAC9C,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,EAC1B,MAAM,CAAC,EAAE,kBAAkB,GAC1B,OAAO,CAAC,OAAO,CAAC,uBAAuB,EAAE,QAAQ,CAAC,CAAC,CAQrD;AAED,wBAAsB,iCAAiC,CACrD,QAAQ,SAAS,MAAM,GAAG,MAAM,EAEhC,GAAG,EAAE,UAAU,CAAC,OAAO,mBAAmB,CAAC,CAAC,CAAC,CAAC,EAC9C,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,EAC1B,MAAM,CAAC,EAAE,kBAAkB,GAC1B,OAAO,CAAC,YAAY,CAAC,uBAAuB,EAAE,QAAQ,CAAC,CAAC,CAG1D;AAED,wBAAsB,+BAA+B,CACnD,GAAG,EAAE,UAAU,CAAC,OAAO,oBAAoB,CAAC,CAAC,CAAC,CAAC,EAC/C,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,EACzB,MAAM,CAAC,EAAE,mBAAmB,GAC3B,OAAO,CAAC,OAAO,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAQ7C;AAED,wBAAsB,oCAAoC,CACxD,GAAG,EAAE,UAAU,CAAC,OAAO,oBAAoB,CAAC,CAAC,CAAC,CAAC,EAC/C,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,EACzB,MAAM,CAAC,EAAE,mBAAmB,GAC3B,OAAO,CAAC,YAAY,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAKlD;AAED,wBAAgB,8BAA8B,IAAI,MAAM,CAEvD"}
|
|
@@ -20,7 +20,7 @@ export function getPostExecutionAssertionsEncoder() {
|
|
|
20
20
|
["vault", fixEncoderSize(getBytesEncoder(), 32)],
|
|
21
21
|
[
|
|
22
22
|
"entries",
|
|
23
|
-
getArrayEncoder(getPostAssertionEntryZCEncoder(), { size:
|
|
23
|
+
getArrayEncoder(getPostAssertionEntryZCEncoder(), { size: 8 }),
|
|
24
24
|
],
|
|
25
25
|
["entryCount", getU8Encoder()],
|
|
26
26
|
["bump", getU8Encoder()],
|
|
@@ -35,7 +35,7 @@ export function getPostExecutionAssertionsDecoder() {
|
|
|
35
35
|
return getStructDecoder([
|
|
36
36
|
["discriminator", fixDecoderSize(getBytesDecoder(), 8)],
|
|
37
37
|
["vault", fixDecoderSize(getBytesDecoder(), 32)],
|
|
38
|
-
["entries", getArrayDecoder(getPostAssertionEntryZCDecoder(), { size:
|
|
38
|
+
["entries", getArrayDecoder(getPostAssertionEntryZCDecoder(), { size: 8 })],
|
|
39
39
|
["entryCount", getU8Decoder()],
|
|
40
40
|
["bump", getU8Decoder()],
|
|
41
41
|
["padding", fixDecoderSize(getBytesDecoder(), 6)],
|
|
@@ -67,6 +67,6 @@ export async function fetchAllMaybePostExecutionAssertions(rpc, addresses, confi
|
|
|
67
67
|
return maybeAccounts.map((maybeAccount) => decodePostExecutionAssertions(maybeAccount));
|
|
68
68
|
}
|
|
69
69
|
export function getPostExecutionAssertionsSize() {
|
|
70
|
-
return
|
|
70
|
+
return 672;
|
|
71
71
|
}
|
|
72
72
|
//# sourceMappingURL=postExecutionAssertions.js.map
|
|
@@ -21,12 +21,14 @@ export type SessionAuthority = {
|
|
|
21
21
|
authorizedToken: Address;
|
|
22
22
|
authorizedProtocol: Address;
|
|
23
23
|
/**
|
|
24
|
-
*
|
|
25
|
-
*
|
|
24
|
+
* Wall-clock expiry: session is valid until this `Clock::unix_timestamp`.
|
|
25
|
+
*
|
|
26
|
+
* **Why timestamp, not slot:** Solana slot times vary 400ms-1.5s under
|
|
27
|
+
* congestion. Slot-based expiry produced a 3.75x variance window between
|
|
28
|
+
* the documented and worst-case session lifetime — see audit F5-H1.
|
|
29
|
+
* Wall-clock enforcement is congestion-immune.
|
|
26
30
|
*/
|
|
27
|
-
|
|
28
|
-
/** Slot-based expiry: session is valid until this slot */
|
|
29
|
-
expiresAtSlot: bigint;
|
|
31
|
+
expiresAtTimestamp: bigint;
|
|
30
32
|
/** Whether token delegation was set up (approve CPI) */
|
|
31
33
|
delegated: boolean;
|
|
32
34
|
/**
|
|
@@ -58,14 +60,83 @@ export type SessionAuthority = {
|
|
|
58
60
|
* Phase B2: Snapshots of target account bytes captured in validate_and_authorize
|
|
59
61
|
* before DeFi instruction executes. Index i corresponds to PostAssertionEntry i.
|
|
60
62
|
* Used by delta assertion modes (1=MaxDecrease, 2=MaxIncrease, 3=NoChange).
|
|
63
|
+
*
|
|
64
|
+
* Phase 6 grow: array length 4 → 8 to match MAX_POST_ASSERTION_ENTRIES.
|
|
65
|
+
* Adds 128 bytes (4 × 32) to SessionAuthority.
|
|
66
|
+
*
|
|
67
|
+
* **Phase 6 R-1 MintDeltaCap reuse:** for mode-4 entries, the snapshot
|
|
68
|
+
* stores `pre_sum: u64 LE` in bytes [0..8] of the 32-byte slot. Remaining
|
|
69
|
+
* 24 bytes are zero-padded. `snapshot_lens[i]` is set to 8 (the u64
|
|
70
|
+
* width) so finalize can distinguish a captured R-1 snapshot from an
|
|
71
|
+
* uncaptured slot.
|
|
61
72
|
*/
|
|
62
73
|
assertionSnapshots: Array<ReadonlyUint8Array>;
|
|
63
74
|
/**
|
|
64
75
|
* Phase B2: Actual value_len captured for each snapshot.
|
|
65
76
|
* 0 = no snapshot captured (mode 0 entries). Non-zero = snapshot was captured.
|
|
66
|
-
* finalize_session cross-checks snapshot_lens[i] == entry.value_len
|
|
77
|
+
* finalize_session cross-checks snapshot_lens[i] == entry.value_len for
|
|
78
|
+
* modes 1..3. For mode 4 (R-1 MintDeltaCap) the field is set to 8 and
|
|
79
|
+
* finalize asserts snapshot_lens[i] == 8 before re-summing.
|
|
80
|
+
*
|
|
81
|
+
* Phase 6 grow: array length 4 → 8. Adds 4 bytes.
|
|
67
82
|
*/
|
|
68
83
|
snapshotLens: ReadonlyUint8Array;
|
|
84
|
+
/**
|
|
85
|
+
* AC-10 (Phase 4) — monotonic session nonce closing durable-nonce replay
|
|
86
|
+
* (per Audit #1 C-1).
|
|
87
|
+
*
|
|
88
|
+
* **Semantics**
|
|
89
|
+
* - New session: `init` zero-initializes the account, so the field starts
|
|
90
|
+
* at 0. `validate_and_authorize` accepts `expected_nonce` and requires
|
|
91
|
+
* it to equal `self.nonce` at entry — a fresh session therefore demands
|
|
92
|
+
* `expected_nonce = 0` from the caller.
|
|
93
|
+
* - `finalize_session` increments `self.nonce` by 1 on every successful
|
|
94
|
+
* finalize (including the expired-cleanup path — see finalize_session.rs
|
|
95
|
+
* for the atomicity argument). The increment is atomic with the
|
|
96
|
+
* account-close: if finalize errors, the close is rolled back by the
|
|
97
|
+
* runtime and the persisted nonce stays at the pre-increment value, so
|
|
98
|
+
* a partial-fail does NOT permanent-increment the nonce.
|
|
99
|
+
* - Because `validate_and_authorize` uses `init` (not `init_if_needed`),
|
|
100
|
+
* the (vault, agent, mint) session PDA is closed at finalize and the
|
|
101
|
+
* next validate creates a fresh account starting at nonce=0. The nonce
|
|
102
|
+
* field therefore functions as an in-session counter and is checked
|
|
103
|
+
* against `expected_nonce` ONLY when the SessionAuthority account is
|
|
104
|
+
* not closed between validates — currently a no-op in the steady-state
|
|
105
|
+
* flow, present so Phase 8 ownership-transfer replay protection (M-5)
|
|
106
|
+
* can extend the same field without a state-shape migration.
|
|
107
|
+
*
|
|
108
|
+
* **Phase 8 extension contract:** the ownership-transfer flow (M-5) will
|
|
109
|
+
* reuse this field as a per-vault monotonic counter scoped to the
|
|
110
|
+
* session PDA, preserving the existing finalize-time increment semantics.
|
|
111
|
+
* Adding seeds / scope is additive; the on-chain field stays a `u64`.
|
|
112
|
+
*
|
|
113
|
+
* **Why NOT in TA-19 canonical digest:** SessionAuthority is per-session
|
|
114
|
+
* ephemeral state, not policy-owned. Including the nonce in the policy
|
|
115
|
+
* digest would require digest recomputation on every successful seal,
|
|
116
|
+
* which collapses the queue/apply timelock semantics. The nonce is
|
|
117
|
+
* orthogonal to the policy_preview_digest binding.
|
|
118
|
+
*
|
|
119
|
+
* **APPEND-ONLY**: new field at the END of SessionAuthority. SIZE grows
|
|
120
|
+
* by 8 bytes (375 → 383). Pre-existing accounts at the prior layout are
|
|
121
|
+
* not migrated (the program close+init cycle naturally retires them at
|
|
122
|
+
* the next finalize), so this is safe under a V2 program ID redeploy.
|
|
123
|
+
*/
|
|
124
|
+
nonce: bigint;
|
|
125
|
+
/**
|
|
126
|
+
* F-Q8 — the vault stablecoin ATA pinned at validate for the
|
|
127
|
+
* non-stablecoin-input outcome check. finalize_session asserts the
|
|
128
|
+
* account it measures has THIS exact pubkey, so a compromised agent
|
|
129
|
+
* cannot substitute a different vault-owned stablecoin ATA (whose
|
|
130
|
+
* owner+mint also pass) to spoof the `current > before` return check.
|
|
131
|
+
* Set to output_stablecoin_account.key() on the non-stablecoin-input
|
|
132
|
+
* spending path; Pubkey::default() otherwise (stablecoin-input uses
|
|
133
|
+
* vault_token_account, already pinned via delegation_token_account).
|
|
134
|
+
*
|
|
135
|
+
* **APPEND-ONLY**: new field at the END of SessionAuthority. SIZE grows
|
|
136
|
+
* by 32 bytes (515 → 547). Sessions are init/close per cycle, so no
|
|
137
|
+
* migration is required.
|
|
138
|
+
*/
|
|
139
|
+
outputStablecoinAccount: Address;
|
|
69
140
|
};
|
|
70
141
|
export type SessionAuthorityArgs = {
|
|
71
142
|
/** Associated vault */
|
|
@@ -79,12 +150,14 @@ export type SessionAuthorityArgs = {
|
|
|
79
150
|
authorizedToken: Address;
|
|
80
151
|
authorizedProtocol: Address;
|
|
81
152
|
/**
|
|
82
|
-
*
|
|
83
|
-
*
|
|
153
|
+
* Wall-clock expiry: session is valid until this `Clock::unix_timestamp`.
|
|
154
|
+
*
|
|
155
|
+
* **Why timestamp, not slot:** Solana slot times vary 400ms-1.5s under
|
|
156
|
+
* congestion. Slot-based expiry produced a 3.75x variance window between
|
|
157
|
+
* the documented and worst-case session lifetime — see audit F5-H1.
|
|
158
|
+
* Wall-clock enforcement is congestion-immune.
|
|
84
159
|
*/
|
|
85
|
-
|
|
86
|
-
/** Slot-based expiry: session is valid until this slot */
|
|
87
|
-
expiresAtSlot: number | bigint;
|
|
160
|
+
expiresAtTimestamp: number | bigint;
|
|
88
161
|
/** Whether token delegation was set up (approve CPI) */
|
|
89
162
|
delegated: boolean;
|
|
90
163
|
/**
|
|
@@ -116,14 +189,83 @@ export type SessionAuthorityArgs = {
|
|
|
116
189
|
* Phase B2: Snapshots of target account bytes captured in validate_and_authorize
|
|
117
190
|
* before DeFi instruction executes. Index i corresponds to PostAssertionEntry i.
|
|
118
191
|
* Used by delta assertion modes (1=MaxDecrease, 2=MaxIncrease, 3=NoChange).
|
|
192
|
+
*
|
|
193
|
+
* Phase 6 grow: array length 4 → 8 to match MAX_POST_ASSERTION_ENTRIES.
|
|
194
|
+
* Adds 128 bytes (4 × 32) to SessionAuthority.
|
|
195
|
+
*
|
|
196
|
+
* **Phase 6 R-1 MintDeltaCap reuse:** for mode-4 entries, the snapshot
|
|
197
|
+
* stores `pre_sum: u64 LE` in bytes [0..8] of the 32-byte slot. Remaining
|
|
198
|
+
* 24 bytes are zero-padded. `snapshot_lens[i]` is set to 8 (the u64
|
|
199
|
+
* width) so finalize can distinguish a captured R-1 snapshot from an
|
|
200
|
+
* uncaptured slot.
|
|
119
201
|
*/
|
|
120
202
|
assertionSnapshots: Array<ReadonlyUint8Array>;
|
|
121
203
|
/**
|
|
122
204
|
* Phase B2: Actual value_len captured for each snapshot.
|
|
123
205
|
* 0 = no snapshot captured (mode 0 entries). Non-zero = snapshot was captured.
|
|
124
|
-
* finalize_session cross-checks snapshot_lens[i] == entry.value_len
|
|
206
|
+
* finalize_session cross-checks snapshot_lens[i] == entry.value_len for
|
|
207
|
+
* modes 1..3. For mode 4 (R-1 MintDeltaCap) the field is set to 8 and
|
|
208
|
+
* finalize asserts snapshot_lens[i] == 8 before re-summing.
|
|
209
|
+
*
|
|
210
|
+
* Phase 6 grow: array length 4 → 8. Adds 4 bytes.
|
|
125
211
|
*/
|
|
126
212
|
snapshotLens: ReadonlyUint8Array;
|
|
213
|
+
/**
|
|
214
|
+
* AC-10 (Phase 4) — monotonic session nonce closing durable-nonce replay
|
|
215
|
+
* (per Audit #1 C-1).
|
|
216
|
+
*
|
|
217
|
+
* **Semantics**
|
|
218
|
+
* - New session: `init` zero-initializes the account, so the field starts
|
|
219
|
+
* at 0. `validate_and_authorize` accepts `expected_nonce` and requires
|
|
220
|
+
* it to equal `self.nonce` at entry — a fresh session therefore demands
|
|
221
|
+
* `expected_nonce = 0` from the caller.
|
|
222
|
+
* - `finalize_session` increments `self.nonce` by 1 on every successful
|
|
223
|
+
* finalize (including the expired-cleanup path — see finalize_session.rs
|
|
224
|
+
* for the atomicity argument). The increment is atomic with the
|
|
225
|
+
* account-close: if finalize errors, the close is rolled back by the
|
|
226
|
+
* runtime and the persisted nonce stays at the pre-increment value, so
|
|
227
|
+
* a partial-fail does NOT permanent-increment the nonce.
|
|
228
|
+
* - Because `validate_and_authorize` uses `init` (not `init_if_needed`),
|
|
229
|
+
* the (vault, agent, mint) session PDA is closed at finalize and the
|
|
230
|
+
* next validate creates a fresh account starting at nonce=0. The nonce
|
|
231
|
+
* field therefore functions as an in-session counter and is checked
|
|
232
|
+
* against `expected_nonce` ONLY when the SessionAuthority account is
|
|
233
|
+
* not closed between validates — currently a no-op in the steady-state
|
|
234
|
+
* flow, present so Phase 8 ownership-transfer replay protection (M-5)
|
|
235
|
+
* can extend the same field without a state-shape migration.
|
|
236
|
+
*
|
|
237
|
+
* **Phase 8 extension contract:** the ownership-transfer flow (M-5) will
|
|
238
|
+
* reuse this field as a per-vault monotonic counter scoped to the
|
|
239
|
+
* session PDA, preserving the existing finalize-time increment semantics.
|
|
240
|
+
* Adding seeds / scope is additive; the on-chain field stays a `u64`.
|
|
241
|
+
*
|
|
242
|
+
* **Why NOT in TA-19 canonical digest:** SessionAuthority is per-session
|
|
243
|
+
* ephemeral state, not policy-owned. Including the nonce in the policy
|
|
244
|
+
* digest would require digest recomputation on every successful seal,
|
|
245
|
+
* which collapses the queue/apply timelock semantics. The nonce is
|
|
246
|
+
* orthogonal to the policy_preview_digest binding.
|
|
247
|
+
*
|
|
248
|
+
* **APPEND-ONLY**: new field at the END of SessionAuthority. SIZE grows
|
|
249
|
+
* by 8 bytes (375 → 383). Pre-existing accounts at the prior layout are
|
|
250
|
+
* not migrated (the program close+init cycle naturally retires them at
|
|
251
|
+
* the next finalize), so this is safe under a V2 program ID redeploy.
|
|
252
|
+
*/
|
|
253
|
+
nonce: number | bigint;
|
|
254
|
+
/**
|
|
255
|
+
* F-Q8 — the vault stablecoin ATA pinned at validate for the
|
|
256
|
+
* non-stablecoin-input outcome check. finalize_session asserts the
|
|
257
|
+
* account it measures has THIS exact pubkey, so a compromised agent
|
|
258
|
+
* cannot substitute a different vault-owned stablecoin ATA (whose
|
|
259
|
+
* owner+mint also pass) to spoof the `current > before` return check.
|
|
260
|
+
* Set to output_stablecoin_account.key() on the non-stablecoin-input
|
|
261
|
+
* spending path; Pubkey::default() otherwise (stablecoin-input uses
|
|
262
|
+
* vault_token_account, already pinned via delegation_token_account).
|
|
263
|
+
*
|
|
264
|
+
* **APPEND-ONLY**: new field at the END of SessionAuthority. SIZE grows
|
|
265
|
+
* by 32 bytes (515 → 547). Sessions are init/close per cycle, so no
|
|
266
|
+
* migration is required.
|
|
267
|
+
*/
|
|
268
|
+
outputStablecoinAccount: Address;
|
|
127
269
|
};
|
|
128
270
|
/** Gets the encoder for {@link SessionAuthorityArgs} account data. */
|
|
129
271
|
export declare function getSessionAuthorityEncoder(): FixedSizeEncoder<SessionAuthorityArgs>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sessionAuthority.d.ts","sourceRoot":"","sources":["../../../src/generated/accounts/sessionAuthority.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAKL,mBAAmB,EACnB,oBAAoB,
|
|
1
|
+
{"version":3,"file":"sessionAuthority.d.ts","sourceRoot":"","sources":["../../../src/generated/accounts/sessionAuthority.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
*
|
|
6
6
|
* @see https://github.com/codama-idl/codama
|
|
7
7
|
*/
|
|
8
|
-
import { assertAccountExists, assertAccountsExist, combineCodec, decodeAccount, fetchEncodedAccount, fetchEncodedAccounts, fixDecoderSize, fixEncoderSize, getAddressDecoder, getAddressEncoder, getArrayDecoder, getArrayEncoder, getBooleanDecoder, getBooleanEncoder, getBytesDecoder, getBytesEncoder, getStructDecoder, getStructEncoder, getU64Decoder, getU64Encoder, getU8Decoder, getU8Encoder, transformEncoder, } from "@solana/kit";
|
|
8
|
+
import { assertAccountExists, assertAccountsExist, combineCodec, decodeAccount, fetchEncodedAccount, fetchEncodedAccounts, fixDecoderSize, fixEncoderSize, getAddressDecoder, getAddressEncoder, getArrayDecoder, getArrayEncoder, getBooleanDecoder, getBooleanEncoder, getBytesDecoder, getBytesEncoder, getI64Decoder, getI64Encoder, getStructDecoder, getStructEncoder, getU64Decoder, getU64Encoder, getU8Decoder, getU8Encoder, transformEncoder, } from "@solana/kit";
|
|
9
9
|
export const SESSION_AUTHORITY_DISCRIMINATOR = new Uint8Array([
|
|
10
10
|
48, 9, 30, 120, 134, 35, 172, 170,
|
|
11
11
|
]);
|
|
@@ -22,8 +22,7 @@ export function getSessionAuthorityEncoder() {
|
|
|
22
22
|
["authorizedAmount", getU64Encoder()],
|
|
23
23
|
["authorizedToken", getAddressEncoder()],
|
|
24
24
|
["authorizedProtocol", getAddressEncoder()],
|
|
25
|
-
["
|
|
26
|
-
["expiresAtSlot", getU64Encoder()],
|
|
25
|
+
["expiresAtTimestamp", getI64Encoder()],
|
|
27
26
|
["delegated", getBooleanEncoder()],
|
|
28
27
|
["delegationTokenAccount", getAddressEncoder()],
|
|
29
28
|
["protocolFee", getU64Encoder()],
|
|
@@ -33,9 +32,11 @@ export function getSessionAuthorityEncoder() {
|
|
|
33
32
|
["bump", getU8Encoder()],
|
|
34
33
|
[
|
|
35
34
|
"assertionSnapshots",
|
|
36
|
-
getArrayEncoder(fixEncoderSize(getBytesEncoder(), 32), { size:
|
|
35
|
+
getArrayEncoder(fixEncoderSize(getBytesEncoder(), 32), { size: 8 }),
|
|
37
36
|
],
|
|
38
|
-
["snapshotLens", fixEncoderSize(getBytesEncoder(),
|
|
37
|
+
["snapshotLens", fixEncoderSize(getBytesEncoder(), 8)],
|
|
38
|
+
["nonce", getU64Encoder()],
|
|
39
|
+
["outputStablecoinAccount", getAddressEncoder()],
|
|
39
40
|
]), (value) => ({ ...value, discriminator: SESSION_AUTHORITY_DISCRIMINATOR }));
|
|
40
41
|
}
|
|
41
42
|
/** Gets the decoder for {@link SessionAuthority} account data. */
|
|
@@ -48,8 +49,7 @@ export function getSessionAuthorityDecoder() {
|
|
|
48
49
|
["authorizedAmount", getU64Decoder()],
|
|
49
50
|
["authorizedToken", getAddressDecoder()],
|
|
50
51
|
["authorizedProtocol", getAddressDecoder()],
|
|
51
|
-
["
|
|
52
|
-
["expiresAtSlot", getU64Decoder()],
|
|
52
|
+
["expiresAtTimestamp", getI64Decoder()],
|
|
53
53
|
["delegated", getBooleanDecoder()],
|
|
54
54
|
["delegationTokenAccount", getAddressDecoder()],
|
|
55
55
|
["protocolFee", getU64Decoder()],
|
|
@@ -59,9 +59,11 @@ export function getSessionAuthorityDecoder() {
|
|
|
59
59
|
["bump", getU8Decoder()],
|
|
60
60
|
[
|
|
61
61
|
"assertionSnapshots",
|
|
62
|
-
getArrayDecoder(fixDecoderSize(getBytesDecoder(), 32), { size:
|
|
62
|
+
getArrayDecoder(fixDecoderSize(getBytesDecoder(), 32), { size: 8 }),
|
|
63
63
|
],
|
|
64
|
-
["snapshotLens", fixDecoderSize(getBytesDecoder(),
|
|
64
|
+
["snapshotLens", fixDecoderSize(getBytesDecoder(), 8)],
|
|
65
|
+
["nonce", getU64Decoder()],
|
|
66
|
+
["outputStablecoinAccount", getAddressDecoder()],
|
|
65
67
|
]);
|
|
66
68
|
}
|
|
67
69
|
/** Gets the codec for {@link SessionAuthority} account data. */
|
|
@@ -90,6 +92,6 @@ export async function fetchAllMaybeSessionAuthority(rpc, addresses, config) {
|
|
|
90
92
|
return maybeAccounts.map((maybeAccount) => decodeSessionAuthority(maybeAccount));
|
|
91
93
|
}
|
|
92
94
|
export function getSessionAuthoritySize() {
|
|
93
|
-
return
|
|
95
|
+
return 547;
|
|
94
96
|
}
|
|
95
97
|
//# sourceMappingURL=sessionAuthority.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sessionAuthority.js","sourceRoot":"","sources":["../../../src/generated/accounts/sessionAuthority.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EACL,mBAAmB,EACnB,mBAAmB,EACnB,YAAY,EACZ,aAAa,EACb,mBAAmB,EACnB,oBAAoB,EACpB,cAAc,EACd,cAAc,EACd,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,aAAa,EACb,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,gBAAgB,GAYjB,MAAM,aAAa,CAAC;AAErB,MAAM,CAAC,MAAM,+BAA+B,GAAG,IAAI,UAAU,CAAC;IAC5D,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG;CAClC,CAAC,CAAC;AAEH,MAAM,UAAU,qCAAqC;IACnD,OAAO,cAAc,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAChD,+BAA+B,CAChC,CAAC;AACJ,CAAC;
|
|
1
|
+
{"version":3,"file":"sessionAuthority.js","sourceRoot":"","sources":["../../../src/generated/accounts/sessionAuthority.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
* @see https://github.com/codama-idl/codama
|
|
7
7
|
*/
|
|
8
8
|
import { fetchEncodedAccount, fetchEncodedAccounts, type Account, type Address, type EncodedAccount, type FetchAccountConfig, type FetchAccountsConfig, type FixedSizeCodec, type FixedSizeDecoder, type FixedSizeEncoder, type MaybeAccount, type MaybeEncodedAccount, type ReadonlyUint8Array } from "@solana/kit";
|
|
9
|
-
import { type EpochBucket, type EpochBucketArgs, type ProtocolSpendCounter, type ProtocolSpendCounterArgs } from "../types/index.js";
|
|
9
|
+
import { type EpochBucket, type EpochBucketArgs, type PerRecipientCounter, type PerRecipientCounterArgs, type ProtocolSpendCounter, type ProtocolSpendCounterArgs } from "../types/index.js";
|
|
10
10
|
export declare const SPEND_TRACKER_DISCRIMINATOR: Uint8Array<ArrayBuffer>;
|
|
11
11
|
export declare function getSpendTrackerDiscriminatorBytes(): ReadonlyUint8Array<ArrayBuffer>;
|
|
12
12
|
export type SpendTracker = {
|
|
@@ -15,7 +15,26 @@ export type SpendTracker = {
|
|
|
15
15
|
vault: Address;
|
|
16
16
|
/** 144 epoch buckets for rolling 24h spend tracking */
|
|
17
17
|
buckets: Array<EpochBucket>;
|
|
18
|
-
/**
|
|
18
|
+
/**
|
|
19
|
+
* Per-protocol rolling 24h counters. Enforcement wired in
|
|
20
|
+
* `finalize_session.rs` — search for "TA-13 (Phase 5 ratification)"
|
|
21
|
+
* (two sites: the stablecoin-input branch around line 314 and the
|
|
22
|
+
* non-stablecoin-input branch around line 408). See
|
|
23
|
+
* `policy.protocol_caps` for the cap values and
|
|
24
|
+
* `PolicyConfig::get_protocol_cap` for the lookup logic. Per-protocol
|
|
25
|
+
* entries are populated by `record_protocol_spend()` when
|
|
26
|
+
* `policy.has_protocol_caps == true`.
|
|
27
|
+
*
|
|
28
|
+
* TA-13 ratification (Phase 5): the prior doc-comment claimed
|
|
29
|
+
* "zeroed, no enforcement yet" — this was stale. The enforcement
|
|
30
|
+
* has lived in `finalize_session` since Phase 2; this comment was
|
|
31
|
+
* the only artifact suggesting otherwise. Phase 5 ratifies the
|
|
32
|
+
* existing require! with the dedicated `ErrDailyCapExceeded` (6086)
|
|
33
|
+
* error code so off-chain monitors can disambiguate the "rolling
|
|
34
|
+
* 24h cap hit" semantic from the legacy "slot allocation exhausted"
|
|
35
|
+
* path (which still returns `ProtocolCapExceeded` from inside
|
|
36
|
+
* `record_protocol_spend`).
|
|
37
|
+
*/
|
|
19
38
|
protocolCounters: Array<ProtocolSpendCounter>;
|
|
20
39
|
/**
|
|
21
40
|
* Epoch of most recent record_spend() call. Enables early exit in get_rolling_24h_usd().
|
|
@@ -26,13 +45,53 @@ export type SpendTracker = {
|
|
|
26
45
|
bump: number;
|
|
27
46
|
/** Padding for 8-byte alignment */
|
|
28
47
|
padding: ReadonlyUint8Array;
|
|
48
|
+
/**
|
|
49
|
+
* TA-14 (Phase 5 post-exec invariant #2): per-recipient rolling 24h
|
|
50
|
+
* outflow counters. Bounded to `MAX_PER_RECIPIENT_ENTRIES` (10)
|
|
51
|
+
* entries — Vec NOT permitted in zero-copy account per F-14.
|
|
52
|
+
* 10 × 48 = 480 bytes. Each entry tracks one recipient pubkey
|
|
53
|
+
* (resolved from the SPL TokenAccount.owner field — NOT the ATA
|
|
54
|
+
* pubkey) and their rolling-24h outflow USD total.
|
|
55
|
+
*/
|
|
56
|
+
perRecipient: Array<PerRecipientCounter>;
|
|
57
|
+
/**
|
|
58
|
+
* TA-14 (Phase 5): how many `per_recipient` slots are currently
|
|
59
|
+
* active. New entries occupy `per_recipient[per_recipient_count]`
|
|
60
|
+
* then this counter increments. Eviction is AGE-BASED only — slots
|
|
61
|
+
* whose 24h window has elapsed are eligible; LRU/churn-eviction is
|
|
62
|
+
* EXPLICITLY REJECTED per §RP requirement (prevents an attacker
|
|
63
|
+
* recycling slots by paying many distinct recipients to bypass
|
|
64
|
+
* the cap).
|
|
65
|
+
*/
|
|
66
|
+
perRecipientCount: number;
|
|
67
|
+
/** Padding for 8-byte alignment after the new u8 counter. */
|
|
68
|
+
paddingRecipient: ReadonlyUint8Array;
|
|
29
69
|
};
|
|
30
70
|
export type SpendTrackerArgs = {
|
|
31
71
|
/** Associated vault pubkey */
|
|
32
72
|
vault: Address;
|
|
33
73
|
/** 144 epoch buckets for rolling 24h spend tracking */
|
|
34
74
|
buckets: Array<EpochBucketArgs>;
|
|
35
|
-
/**
|
|
75
|
+
/**
|
|
76
|
+
* Per-protocol rolling 24h counters. Enforcement wired in
|
|
77
|
+
* `finalize_session.rs` — search for "TA-13 (Phase 5 ratification)"
|
|
78
|
+
* (two sites: the stablecoin-input branch around line 314 and the
|
|
79
|
+
* non-stablecoin-input branch around line 408). See
|
|
80
|
+
* `policy.protocol_caps` for the cap values and
|
|
81
|
+
* `PolicyConfig::get_protocol_cap` for the lookup logic. Per-protocol
|
|
82
|
+
* entries are populated by `record_protocol_spend()` when
|
|
83
|
+
* `policy.has_protocol_caps == true`.
|
|
84
|
+
*
|
|
85
|
+
* TA-13 ratification (Phase 5): the prior doc-comment claimed
|
|
86
|
+
* "zeroed, no enforcement yet" — this was stale. The enforcement
|
|
87
|
+
* has lived in `finalize_session` since Phase 2; this comment was
|
|
88
|
+
* the only artifact suggesting otherwise. Phase 5 ratifies the
|
|
89
|
+
* existing require! with the dedicated `ErrDailyCapExceeded` (6086)
|
|
90
|
+
* error code so off-chain monitors can disambiguate the "rolling
|
|
91
|
+
* 24h cap hit" semantic from the legacy "slot allocation exhausted"
|
|
92
|
+
* path (which still returns `ProtocolCapExceeded` from inside
|
|
93
|
+
* `record_protocol_spend`).
|
|
94
|
+
*/
|
|
36
95
|
protocolCounters: Array<ProtocolSpendCounterArgs>;
|
|
37
96
|
/**
|
|
38
97
|
* Epoch of most recent record_spend() call. Enables early exit in get_rolling_24h_usd().
|
|
@@ -43,6 +102,27 @@ export type SpendTrackerArgs = {
|
|
|
43
102
|
bump: number;
|
|
44
103
|
/** Padding for 8-byte alignment */
|
|
45
104
|
padding: ReadonlyUint8Array;
|
|
105
|
+
/**
|
|
106
|
+
* TA-14 (Phase 5 post-exec invariant #2): per-recipient rolling 24h
|
|
107
|
+
* outflow counters. Bounded to `MAX_PER_RECIPIENT_ENTRIES` (10)
|
|
108
|
+
* entries — Vec NOT permitted in zero-copy account per F-14.
|
|
109
|
+
* 10 × 48 = 480 bytes. Each entry tracks one recipient pubkey
|
|
110
|
+
* (resolved from the SPL TokenAccount.owner field — NOT the ATA
|
|
111
|
+
* pubkey) and their rolling-24h outflow USD total.
|
|
112
|
+
*/
|
|
113
|
+
perRecipient: Array<PerRecipientCounterArgs>;
|
|
114
|
+
/**
|
|
115
|
+
* TA-14 (Phase 5): how many `per_recipient` slots are currently
|
|
116
|
+
* active. New entries occupy `per_recipient[per_recipient_count]`
|
|
117
|
+
* then this counter increments. Eviction is AGE-BASED only — slots
|
|
118
|
+
* whose 24h window has elapsed are eligible; LRU/churn-eviction is
|
|
119
|
+
* EXPLICITLY REJECTED per §RP requirement (prevents an attacker
|
|
120
|
+
* recycling slots by paying many distinct recipients to bypass
|
|
121
|
+
* the cap).
|
|
122
|
+
*/
|
|
123
|
+
perRecipientCount: number;
|
|
124
|
+
/** Padding for 8-byte alignment after the new u8 counter. */
|
|
125
|
+
paddingRecipient: ReadonlyUint8Array;
|
|
46
126
|
};
|
|
47
127
|
/** Gets the encoder for {@link SpendTrackerArgs} account data. */
|
|
48
128
|
export declare function getSpendTrackerEncoder(): FixedSizeEncoder<SpendTrackerArgs>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spendTracker.d.ts","sourceRoot":"","sources":["../../../src/generated/accounts/spendTracker.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAKL,mBAAmB,EACnB,oBAAoB,EAgBpB,KAAK,OAAO,EACZ,KAAK,OAAO,EACZ,KAAK,cAAc,EACnB,KAAK,kBAAkB,EACvB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,KAAK,mBAAmB,EACxB,KAAK,kBAAkB,EACxB,MAAM,aAAa,CAAC;AACrB,OAAO,
|
|
1
|
+
{"version":3,"file":"spendTracker.d.ts","sourceRoot":"","sources":["../../../src/generated/accounts/spendTracker.ts"],"names":[],"mappings":"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"}
|