@usesigil/kit 0.1.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/LICENSE +191 -0
- package/README.md +190 -0
- package/dist/advanced-analytics.d.ts +118 -0
- package/dist/advanced-analytics.d.ts.map +1 -0
- package/dist/advanced-analytics.js +341 -0
- package/dist/advanced-analytics.js.map +1 -0
- package/dist/agent-analytics.d.ts +76 -0
- package/dist/agent-analytics.d.ts.map +1 -0
- package/dist/agent-analytics.js +179 -0
- package/dist/agent-analytics.js.map +1 -0
- package/dist/agent-errors.d.ts +151 -0
- package/dist/agent-errors.d.ts.map +1 -0
- package/dist/agent-errors.js +2001 -0
- package/dist/agent-errors.js.map +1 -0
- package/dist/alt-config.d.ts +43 -0
- package/dist/alt-config.d.ts.map +1 -0
- package/dist/alt-config.js +78 -0
- package/dist/alt-config.js.map +1 -0
- package/dist/alt-loader.d.ts +47 -0
- package/dist/alt-loader.d.ts.map +1 -0
- package/dist/alt-loader.js +143 -0
- package/dist/alt-loader.js.map +1 -0
- package/dist/balance-tracker.d.ts +87 -0
- package/dist/balance-tracker.d.ts.map +1 -0
- package/dist/balance-tracker.js +181 -0
- package/dist/balance-tracker.js.map +1 -0
- package/dist/composer.d.ts +56 -0
- package/dist/composer.d.ts.map +1 -0
- package/dist/composer.js +77 -0
- package/dist/composer.js.map +1 -0
- package/dist/core/engine.d.ts +17 -0
- package/dist/core/engine.d.ts.map +1 -0
- package/dist/core/engine.js +177 -0
- package/dist/core/engine.js.map +1 -0
- package/dist/core/errors.d.ts +24 -0
- package/dist/core/errors.d.ts.map +1 -0
- package/dist/core/errors.js +16 -0
- package/dist/core/errors.js.map +1 -0
- package/dist/core/index.d.ts +9 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +10 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/policies.d.ts +75 -0
- package/dist/core/policies.d.ts.map +1 -0
- package/dist/core/policies.js +126 -0
- package/dist/core/policies.js.map +1 -0
- package/dist/core/registry.d.ts +29 -0
- package/dist/core/registry.d.ts.map +1 -0
- package/dist/core/registry.js +125 -0
- package/dist/core/registry.js.map +1 -0
- package/dist/core/state.d.ts +71 -0
- package/dist/core/state.d.ts.map +1 -0
- package/dist/core/state.js +169 -0
- package/dist/core/state.js.map +1 -0
- package/dist/create-vault.d.ts +58 -0
- package/dist/create-vault.d.ts.map +1 -0
- package/dist/create-vault.js +90 -0
- package/dist/create-vault.js.map +1 -0
- package/dist/custody-adapter.d.ts +54 -0
- package/dist/custody-adapter.d.ts.map +1 -0
- package/dist/custody-adapter.js +45 -0
- package/dist/custody-adapter.js.map +1 -0
- package/dist/event-analytics.d.ts +45 -0
- package/dist/event-analytics.d.ts.map +1 -0
- package/dist/event-analytics.js +277 -0
- package/dist/event-analytics.js.map +1 -0
- package/dist/events.d.ts +56 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +151 -0
- package/dist/events.js.map +1 -0
- package/dist/formatting.d.ts +103 -0
- package/dist/formatting.d.ts.map +1 -0
- package/dist/formatting.js +244 -0
- package/dist/formatting.js.map +1 -0
- package/dist/generated/accounts/agentSpendOverlay.d.ts +54 -0
- package/dist/generated/accounts/agentSpendOverlay.d.ts.map +1 -0
- package/dist/generated/accounts/agentSpendOverlay.js +74 -0
- package/dist/generated/accounts/agentSpendOverlay.js.map +1 -0
- package/dist/generated/accounts/agentVault.d.ts +95 -0
- package/dist/generated/accounts/agentVault.d.ts.map +1 -0
- package/dist/generated/accounts/agentVault.js +83 -0
- package/dist/generated/accounts/agentVault.js.map +1 -0
- package/dist/generated/accounts/escrowDeposit.d.ts +50 -0
- package/dist/generated/accounts/escrowDeposit.d.ts.map +1 -0
- package/dist/generated/accounts/escrowDeposit.js +76 -0
- package/dist/generated/accounts/escrowDeposit.js.map +1 -0
- package/dist/generated/accounts/index.d.ts +17 -0
- package/dist/generated/accounts/index.d.ts.map +1 -0
- package/dist/generated/accounts/index.js +17 -0
- package/dist/generated/accounts/index.js.map +1 -0
- package/dist/generated/accounts/instructionConstraints.d.ts +37 -0
- package/dist/generated/accounts/instructionConstraints.d.ts.map +1 -0
- package/dist/generated/accounts/instructionConstraints.js +64 -0
- package/dist/generated/accounts/instructionConstraints.js.map +1 -0
- package/dist/generated/accounts/pendingConstraintsUpdate.d.ts +53 -0
- package/dist/generated/accounts/pendingConstraintsUpdate.d.ts.map +1 -0
- package/dist/generated/accounts/pendingConstraintsUpdate.js +68 -0
- package/dist/generated/accounts/pendingConstraintsUpdate.js.map +1 -0
- package/dist/generated/accounts/pendingPolicyUpdate.d.ts +72 -0
- package/dist/generated/accounts/pendingPolicyUpdate.d.ts.map +1 -0
- package/dist/generated/accounts/pendingPolicyUpdate.js +97 -0
- package/dist/generated/accounts/pendingPolicyUpdate.js.map +1 -0
- package/dist/generated/accounts/policyConfig.d.ts +180 -0
- package/dist/generated/accounts/policyConfig.d.ts.map +1 -0
- package/dist/generated/accounts/policyConfig.js +88 -0
- package/dist/generated/accounts/policyConfig.js.map +1 -0
- package/dist/generated/accounts/sessionAuthority.d.ts +104 -0
- package/dist/generated/accounts/sessionAuthority.d.ts.map +1 -0
- package/dist/generated/accounts/sessionAuthority.js +86 -0
- package/dist/generated/accounts/sessionAuthority.js.map +1 -0
- package/dist/generated/accounts/spendTracker.d.ts +60 -0
- package/dist/generated/accounts/spendTracker.d.ts.map +1 -0
- package/dist/generated/accounts/spendTracker.js +74 -0
- package/dist/generated/accounts/spendTracker.js.map +1 -0
- package/dist/generated/errors/index.d.ts +9 -0
- package/dist/generated/errors/index.d.ts.map +1 -0
- package/dist/generated/errors/index.js +9 -0
- package/dist/generated/errors/index.js.map +1 -0
- package/dist/generated/errors/sigil.d.ts +162 -0
- package/dist/generated/errors/sigil.d.ts.map +1 -0
- package/dist/generated/errors/sigil.js +237 -0
- package/dist/generated/errors/sigil.js.map +1 -0
- package/dist/generated/event-discriminators.d.ts +2 -0
- package/dist/generated/event-discriminators.d.ts.map +1 -0
- package/dist/generated/event-discriminators.js +39 -0
- package/dist/generated/event-discriminators.js.map +1 -0
- package/dist/generated/index.d.ts +13 -0
- package/dist/generated/index.d.ts.map +1 -0
- package/dist/generated/index.js +13 -0
- package/dist/generated/index.js.map +1 -0
- package/dist/generated/instructions/agentTransfer.d.ts +109 -0
- package/dist/generated/instructions/agentTransfer.d.ts.map +1 -0
- package/dist/generated/instructions/agentTransfer.js +211 -0
- package/dist/generated/instructions/agentTransfer.js.map +1 -0
- package/dist/generated/instructions/applyConstraintsUpdate.d.ts +55 -0
- package/dist/generated/instructions/applyConstraintsUpdate.d.ts.map +1 -0
- package/dist/generated/instructions/applyConstraintsUpdate.js +129 -0
- package/dist/generated/instructions/applyConstraintsUpdate.js.map +1 -0
- package/dist/generated/instructions/applyPendingPolicy.d.ts +55 -0
- package/dist/generated/instructions/applyPendingPolicy.d.ts.map +1 -0
- package/dist/generated/instructions/applyPendingPolicy.js +122 -0
- package/dist/generated/instructions/applyPendingPolicy.js.map +1 -0
- package/dist/generated/instructions/cancelConstraintsUpdate.d.ts +51 -0
- package/dist/generated/instructions/cancelConstraintsUpdate.d.ts.map +1 -0
- package/dist/generated/instructions/cancelConstraintsUpdate.js +115 -0
- package/dist/generated/instructions/cancelConstraintsUpdate.js.map +1 -0
- package/dist/generated/instructions/cancelPendingPolicy.d.ts +55 -0
- package/dist/generated/instructions/cancelPendingPolicy.d.ts.map +1 -0
- package/dist/generated/instructions/cancelPendingPolicy.js +122 -0
- package/dist/generated/instructions/cancelPendingPolicy.js.map +1 -0
- package/dist/generated/instructions/closeInstructionConstraints.d.ts +55 -0
- package/dist/generated/instructions/closeInstructionConstraints.d.ts.map +1 -0
- package/dist/generated/instructions/closeInstructionConstraints.js +120 -0
- package/dist/generated/instructions/closeInstructionConstraints.js.map +1 -0
- package/dist/generated/instructions/closeSettledEscrow.d.ts +72 -0
- package/dist/generated/instructions/closeSettledEscrow.d.ts.map +1 -0
- package/dist/generated/instructions/closeSettledEscrow.js +127 -0
- package/dist/generated/instructions/closeSettledEscrow.js.map +1 -0
- package/dist/generated/instructions/closeVault.d.ts +69 -0
- package/dist/generated/instructions/closeVault.d.ts.map +1 -0
- package/dist/generated/instructions/closeVault.js +142 -0
- package/dist/generated/instructions/closeVault.js.map +1 -0
- package/dist/generated/instructions/createEscrow.d.ts +131 -0
- package/dist/generated/instructions/createEscrow.d.ts.map +1 -0
- package/dist/generated/instructions/createEscrow.js +272 -0
- package/dist/generated/instructions/createEscrow.js.map +1 -0
- package/dist/generated/instructions/createInstructionConstraints.d.ts +69 -0
- package/dist/generated/instructions/createInstructionConstraints.d.ts.map +1 -0
- package/dist/generated/instructions/createInstructionConstraints.js +145 -0
- package/dist/generated/instructions/createInstructionConstraints.js.map +1 -0
- package/dist/generated/instructions/depositFunds.d.ts +82 -0
- package/dist/generated/instructions/depositFunds.d.ts.map +1 -0
- package/dist/generated/instructions/depositFunds.js +198 -0
- package/dist/generated/instructions/depositFunds.js.map +1 -0
- package/dist/generated/instructions/finalizeSession.d.ts +126 -0
- package/dist/generated/instructions/finalizeSession.d.ts.map +1 -0
- package/dist/generated/instructions/finalizeSession.js +218 -0
- package/dist/generated/instructions/finalizeSession.js.map +1 -0
- package/dist/generated/instructions/freezeVault.d.ts +40 -0
- package/dist/generated/instructions/freezeVault.d.ts.map +1 -0
- package/dist/generated/instructions/freezeVault.js +66 -0
- package/dist/generated/instructions/freezeVault.js.map +1 -0
- package/dist/generated/instructions/index.d.ts +37 -0
- package/dist/generated/instructions/index.d.ts.map +1 -0
- package/dist/generated/instructions/index.js +37 -0
- package/dist/generated/instructions/index.js.map +1 -0
- package/dist/generated/instructions/initializeVault.d.ts +122 -0
- package/dist/generated/instructions/initializeVault.d.ts.map +1 -0
- package/dist/generated/instructions/initializeVault.js +187 -0
- package/dist/generated/instructions/initializeVault.js.map +1 -0
- package/dist/generated/instructions/pauseAgent.d.ts +44 -0
- package/dist/generated/instructions/pauseAgent.d.ts.map +1 -0
- package/dist/generated/instructions/pauseAgent.js +72 -0
- package/dist/generated/instructions/pauseAgent.js.map +1 -0
- package/dist/generated/instructions/queueConstraintsUpdate.d.ts +73 -0
- package/dist/generated/instructions/queueConstraintsUpdate.d.ts.map +1 -0
- package/dist/generated/instructions/queueConstraintsUpdate.js +168 -0
- package/dist/generated/instructions/queueConstraintsUpdate.js.map +1 -0
- package/dist/generated/instructions/queuePolicyUpdate.d.ts +116 -0
- package/dist/generated/instructions/queuePolicyUpdate.d.ts.map +1 -0
- package/dist/generated/instructions/queuePolicyUpdate.js +173 -0
- package/dist/generated/instructions/queuePolicyUpdate.js.map +1 -0
- package/dist/generated/instructions/reactivateVault.d.ts +47 -0
- package/dist/generated/instructions/reactivateVault.d.ts.map +1 -0
- package/dist/generated/instructions/reactivateVault.js +74 -0
- package/dist/generated/instructions/reactivateVault.js.map +1 -0
- package/dist/generated/instructions/refundEscrow.d.ts +74 -0
- package/dist/generated/instructions/refundEscrow.d.ts.map +1 -0
- package/dist/generated/instructions/refundEscrow.js +142 -0
- package/dist/generated/instructions/refundEscrow.js.map +1 -0
- package/dist/generated/instructions/registerAgent.d.ts +55 -0
- package/dist/generated/instructions/registerAgent.d.ts.map +1 -0
- package/dist/generated/instructions/registerAgent.js +85 -0
- package/dist/generated/instructions/registerAgent.js.map +1 -0
- package/dist/generated/instructions/revokeAgent.d.ts +49 -0
- package/dist/generated/instructions/revokeAgent.d.ts.map +1 -0
- package/dist/generated/instructions/revokeAgent.js +81 -0
- package/dist/generated/instructions/revokeAgent.js.map +1 -0
- package/dist/generated/instructions/settleEscrow.d.ts +80 -0
- package/dist/generated/instructions/settleEscrow.d.ts.map +1 -0
- package/dist/generated/instructions/settleEscrow.js +173 -0
- package/dist/generated/instructions/settleEscrow.js.map +1 -0
- package/dist/generated/instructions/syncPositions.d.ts +44 -0
- package/dist/generated/instructions/syncPositions.d.ts.map +1 -0
- package/dist/generated/instructions/syncPositions.js +72 -0
- package/dist/generated/instructions/syncPositions.js.map +1 -0
- package/dist/generated/instructions/unpauseAgent.d.ts +44 -0
- package/dist/generated/instructions/unpauseAgent.d.ts.map +1 -0
- package/dist/generated/instructions/unpauseAgent.js +72 -0
- package/dist/generated/instructions/unpauseAgent.js.map +1 -0
- package/dist/generated/instructions/updateAgentPermissions.d.ts +68 -0
- package/dist/generated/instructions/updateAgentPermissions.d.ts.map +1 -0
- package/dist/generated/instructions/updateAgentPermissions.js +139 -0
- package/dist/generated/instructions/updateAgentPermissions.js.map +1 -0
- package/dist/generated/instructions/updateInstructionConstraints.d.ts +65 -0
- package/dist/generated/instructions/updateInstructionConstraints.d.ts.map +1 -0
- package/dist/generated/instructions/updateInstructionConstraints.js +131 -0
- package/dist/generated/instructions/updateInstructionConstraints.js.map +1 -0
- package/dist/generated/instructions/updatePolicy.d.ts +108 -0
- package/dist/generated/instructions/updatePolicy.d.ts.map +1 -0
- package/dist/generated/instructions/updatePolicy.js +143 -0
- package/dist/generated/instructions/updatePolicy.js.map +1 -0
- package/dist/generated/instructions/validateAndAuthorize.d.ts +171 -0
- package/dist/generated/instructions/validateAndAuthorize.d.ts.map +1 -0
- package/dist/generated/instructions/validateAndAuthorize.js +271 -0
- package/dist/generated/instructions/validateAndAuthorize.js.map +1 -0
- package/dist/generated/instructions/withdrawFunds.d.ts +74 -0
- package/dist/generated/instructions/withdrawFunds.d.ts.map +1 -0
- package/dist/generated/instructions/withdrawFunds.js +166 -0
- package/dist/generated/instructions/withdrawFunds.js.map +1 -0
- package/dist/generated/programs/index.d.ts +9 -0
- package/dist/generated/programs/index.d.ts.map +1 -0
- package/dist/generated/programs/index.js +9 -0
- package/dist/generated/programs/index.js.map +1 -0
- package/dist/generated/programs/sigil.d.ts +173 -0
- package/dist/generated/programs/sigil.d.ts.map +1 -0
- package/dist/generated/programs/sigil.js +443 -0
- package/dist/generated/programs/sigil.js.map +1 -0
- package/dist/generated/types/accountConstraint.d.ts +18 -0
- package/dist/generated/types/accountConstraint.d.ts.map +1 -0
- package/dist/generated/types/accountConstraint.js +24 -0
- package/dist/generated/types/accountConstraint.js.map +1 -0
- package/dist/generated/types/actionAuthorized.d.ts +39 -0
- package/dist/generated/types/actionAuthorized.d.ts.map +1 -0
- package/dist/generated/types/actionAuthorized.js +43 -0
- package/dist/generated/types/actionAuthorized.js.map +1 -0
- package/dist/generated/types/actionType.d.ts +37 -0
- package/dist/generated/types/actionType.d.ts.map +1 -0
- package/dist/generated/types/actionType.js +43 -0
- package/dist/generated/types/actionType.js.map +1 -0
- package/dist/generated/types/agentContributionEntry.d.ts +49 -0
- package/dist/generated/types/agentContributionEntry.d.ts.map +1 -0
- package/dist/generated/types/agentContributionEntry.js +26 -0
- package/dist/generated/types/agentContributionEntry.js.map +1 -0
- package/dist/generated/types/agentEntry.d.ts +24 -0
- package/dist/generated/types/agentEntry.d.ts.map +1 -0
- package/dist/generated/types/agentEntry.js +28 -0
- package/dist/generated/types/agentEntry.js.map +1 -0
- package/dist/generated/types/agentPausedEvent.d.ts +22 -0
- package/dist/generated/types/agentPausedEvent.d.ts.map +1 -0
- package/dist/generated/types/agentPausedEvent.js +26 -0
- package/dist/generated/types/agentPausedEvent.js.map +1 -0
- package/dist/generated/types/agentPermissionsUpdated.d.ts +24 -0
- package/dist/generated/types/agentPermissionsUpdated.d.ts.map +1 -0
- package/dist/generated/types/agentPermissionsUpdated.js +28 -0
- package/dist/generated/types/agentPermissionsUpdated.js.map +1 -0
- package/dist/generated/types/agentRegistered.d.ts +26 -0
- package/dist/generated/types/agentRegistered.d.ts.map +1 -0
- package/dist/generated/types/agentRegistered.js +30 -0
- package/dist/generated/types/agentRegistered.js.map +1 -0
- package/dist/generated/types/agentRevoked.d.ts +24 -0
- package/dist/generated/types/agentRevoked.d.ts.map +1 -0
- package/dist/generated/types/agentRevoked.js +28 -0
- package/dist/generated/types/agentRevoked.js.map +1 -0
- package/dist/generated/types/agentSpendLimitChecked.d.ts +28 -0
- package/dist/generated/types/agentSpendLimitChecked.d.ts.map +1 -0
- package/dist/generated/types/agentSpendLimitChecked.js +32 -0
- package/dist/generated/types/agentSpendLimitChecked.js.map +1 -0
- package/dist/generated/types/agentTransferExecuted.d.ts +24 -0
- package/dist/generated/types/agentTransferExecuted.d.ts.map +1 -0
- package/dist/generated/types/agentTransferExecuted.js +28 -0
- package/dist/generated/types/agentTransferExecuted.js.map +1 -0
- package/dist/generated/types/agentUnpausedEvent.d.ts +22 -0
- package/dist/generated/types/agentUnpausedEvent.d.ts.map +1 -0
- package/dist/generated/types/agentUnpausedEvent.js +26 -0
- package/dist/generated/types/agentUnpausedEvent.js.map +1 -0
- package/dist/generated/types/constraintEntry.d.ts +23 -0
- package/dist/generated/types/constraintEntry.d.ts.map +1 -0
- package/dist/generated/types/constraintEntry.js +27 -0
- package/dist/generated/types/constraintEntry.js.map +1 -0
- package/dist/generated/types/constraintOperator.d.ts +22 -0
- package/dist/generated/types/constraintOperator.d.ts.map +1 -0
- package/dist/generated/types/constraintOperator.js +28 -0
- package/dist/generated/types/constraintOperator.js.map +1 -0
- package/dist/generated/types/constraintsChangeApplied.d.ts +20 -0
- package/dist/generated/types/constraintsChangeApplied.d.ts.map +1 -0
- package/dist/generated/types/constraintsChangeApplied.js +24 -0
- package/dist/generated/types/constraintsChangeApplied.js.map +1 -0
- package/dist/generated/types/constraintsChangeCancelled.d.ts +16 -0
- package/dist/generated/types/constraintsChangeCancelled.d.ts.map +1 -0
- package/dist/generated/types/constraintsChangeCancelled.js +18 -0
- package/dist/generated/types/constraintsChangeCancelled.js.map +1 -0
- package/dist/generated/types/constraintsChangeQueued.d.ts +20 -0
- package/dist/generated/types/constraintsChangeQueued.d.ts.map +1 -0
- package/dist/generated/types/constraintsChangeQueued.js +24 -0
- package/dist/generated/types/constraintsChangeQueued.js.map +1 -0
- package/dist/generated/types/dataConstraint.d.ts +23 -0
- package/dist/generated/types/dataConstraint.d.ts.map +1 -0
- package/dist/generated/types/dataConstraint.js +27 -0
- package/dist/generated/types/dataConstraint.js.map +1 -0
- package/dist/generated/types/delegationRevoked.d.ts +22 -0
- package/dist/generated/types/delegationRevoked.d.ts.map +1 -0
- package/dist/generated/types/delegationRevoked.js +26 -0
- package/dist/generated/types/delegationRevoked.js.map +1 -0
- package/dist/generated/types/epochBucket.d.ts +28 -0
- package/dist/generated/types/epochBucket.d.ts.map +1 -0
- package/dist/generated/types/epochBucket.js +24 -0
- package/dist/generated/types/epochBucket.js.map +1 -0
- package/dist/generated/types/escrowCreated.d.ts +30 -0
- package/dist/generated/types/escrowCreated.d.ts.map +1 -0
- package/dist/generated/types/escrowCreated.js +34 -0
- package/dist/generated/types/escrowCreated.js.map +1 -0
- package/dist/generated/types/escrowRefunded.d.ts +26 -0
- package/dist/generated/types/escrowRefunded.d.ts.map +1 -0
- package/dist/generated/types/escrowRefunded.js +30 -0
- package/dist/generated/types/escrowRefunded.js.map +1 -0
- package/dist/generated/types/escrowSettled.d.ts +26 -0
- package/dist/generated/types/escrowSettled.d.ts.map +1 -0
- package/dist/generated/types/escrowSettled.js +30 -0
- package/dist/generated/types/escrowSettled.js.map +1 -0
- package/dist/generated/types/escrowStatus.d.ts +18 -0
- package/dist/generated/types/escrowStatus.d.ts.map +1 -0
- package/dist/generated/types/escrowStatus.js +24 -0
- package/dist/generated/types/escrowStatus.js.map +1 -0
- package/dist/generated/types/feesCollected.d.ts +38 -0
- package/dist/generated/types/feesCollected.d.ts.map +1 -0
- package/dist/generated/types/feesCollected.js +42 -0
- package/dist/generated/types/feesCollected.js.map +1 -0
- package/dist/generated/types/fundsDeposited.d.ts +24 -0
- package/dist/generated/types/fundsDeposited.d.ts.map +1 -0
- package/dist/generated/types/fundsDeposited.js +28 -0
- package/dist/generated/types/fundsDeposited.js.map +1 -0
- package/dist/generated/types/fundsWithdrawn.d.ts +26 -0
- package/dist/generated/types/fundsWithdrawn.d.ts.map +1 -0
- package/dist/generated/types/fundsWithdrawn.js +30 -0
- package/dist/generated/types/fundsWithdrawn.js.map +1 -0
- package/dist/generated/types/index.d.ts +50 -0
- package/dist/generated/types/index.d.ts.map +1 -0
- package/dist/generated/types/index.js +50 -0
- package/dist/generated/types/index.js.map +1 -0
- package/dist/generated/types/instructionConstraintsClosed.d.ts +20 -0
- package/dist/generated/types/instructionConstraintsClosed.d.ts.map +1 -0
- package/dist/generated/types/instructionConstraintsClosed.js +24 -0
- package/dist/generated/types/instructionConstraintsClosed.js.map +1 -0
- package/dist/generated/types/instructionConstraintsCreated.d.ts +24 -0
- package/dist/generated/types/instructionConstraintsCreated.d.ts.map +1 -0
- package/dist/generated/types/instructionConstraintsCreated.js +28 -0
- package/dist/generated/types/instructionConstraintsCreated.js.map +1 -0
- package/dist/generated/types/instructionConstraintsUpdated.d.ts +24 -0
- package/dist/generated/types/instructionConstraintsUpdated.d.ts.map +1 -0
- package/dist/generated/types/instructionConstraintsUpdated.js +28 -0
- package/dist/generated/types/instructionConstraintsUpdated.js.map +1 -0
- package/dist/generated/types/policyChangeApplied.d.ts +20 -0
- package/dist/generated/types/policyChangeApplied.d.ts.map +1 -0
- package/dist/generated/types/policyChangeApplied.js +24 -0
- package/dist/generated/types/policyChangeApplied.js.map +1 -0
- package/dist/generated/types/policyChangeCancelled.d.ts +16 -0
- package/dist/generated/types/policyChangeCancelled.d.ts.map +1 -0
- package/dist/generated/types/policyChangeCancelled.js +18 -0
- package/dist/generated/types/policyChangeCancelled.js.map +1 -0
- package/dist/generated/types/policyChangeQueued.d.ts +20 -0
- package/dist/generated/types/policyChangeQueued.d.ts.map +1 -0
- package/dist/generated/types/policyChangeQueued.js +24 -0
- package/dist/generated/types/policyChangeQueued.js.map +1 -0
- package/dist/generated/types/policyUpdated.d.ts +34 -0
- package/dist/generated/types/policyUpdated.d.ts.map +1 -0
- package/dist/generated/types/policyUpdated.js +38 -0
- package/dist/generated/types/policyUpdated.js.map +1 -0
- package/dist/generated/types/positionsSynced.d.ts +24 -0
- package/dist/generated/types/positionsSynced.d.ts.map +1 -0
- package/dist/generated/types/positionsSynced.js +28 -0
- package/dist/generated/types/positionsSynced.js.map +1 -0
- package/dist/generated/types/protocolSpendCounter.d.ts +33 -0
- package/dist/generated/types/protocolSpendCounter.d.ts.map +1 -0
- package/dist/generated/types/protocolSpendCounter.js +26 -0
- package/dist/generated/types/protocolSpendCounter.js.map +1 -0
- package/dist/generated/types/sessionFinalized.d.ts +32 -0
- package/dist/generated/types/sessionFinalized.d.ts.map +1 -0
- package/dist/generated/types/sessionFinalized.js +36 -0
- package/dist/generated/types/sessionFinalized.js.map +1 -0
- package/dist/generated/types/vaultClosed.d.ts +22 -0
- package/dist/generated/types/vaultClosed.d.ts.map +1 -0
- package/dist/generated/types/vaultClosed.js +26 -0
- package/dist/generated/types/vaultClosed.js.map +1 -0
- package/dist/generated/types/vaultCreated.d.ts +24 -0
- package/dist/generated/types/vaultCreated.d.ts.map +1 -0
- package/dist/generated/types/vaultCreated.js +28 -0
- package/dist/generated/types/vaultCreated.js.map +1 -0
- package/dist/generated/types/vaultFrozen.d.ts +24 -0
- package/dist/generated/types/vaultFrozen.d.ts.map +1 -0
- package/dist/generated/types/vaultFrozen.js +28 -0
- package/dist/generated/types/vaultFrozen.js.map +1 -0
- package/dist/generated/types/vaultReactivated.d.ts +24 -0
- package/dist/generated/types/vaultReactivated.d.ts.map +1 -0
- package/dist/generated/types/vaultReactivated.js +28 -0
- package/dist/generated/types/vaultReactivated.js.map +1 -0
- package/dist/generated/types/vaultStatus.d.ts +19 -0
- package/dist/generated/types/vaultStatus.d.ts.map +1 -0
- package/dist/generated/types/vaultStatus.js +25 -0
- package/dist/generated/types/vaultStatus.js.map +1 -0
- package/dist/index.d.ts +74 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +113 -0
- package/dist/index.js.map +1 -0
- package/dist/inscribe.d.ts +134 -0
- package/dist/inscribe.d.ts.map +1 -0
- package/dist/inscribe.js +149 -0
- package/dist/inscribe.js.map +1 -0
- package/dist/inspector.d.ts +85 -0
- package/dist/inspector.d.ts.map +1 -0
- package/dist/inspector.js +188 -0
- package/dist/inspector.js.map +1 -0
- package/dist/math-utils.d.ts +15 -0
- package/dist/math-utils.d.ts.map +1 -0
- package/dist/math-utils.js +29 -0
- package/dist/math-utils.js.map +1 -0
- package/dist/owner-transaction.d.ts +42 -0
- package/dist/owner-transaction.d.ts.map +1 -0
- package/dist/owner-transaction.js +71 -0
- package/dist/owner-transaction.js.map +1 -0
- package/dist/policies.d.ts +70 -0
- package/dist/policies.d.ts.map +1 -0
- package/dist/policies.js +87 -0
- package/dist/policies.js.map +1 -0
- package/dist/portfolio-analytics.d.ts +82 -0
- package/dist/portfolio-analytics.d.ts.map +1 -0
- package/dist/portfolio-analytics.js +232 -0
- package/dist/portfolio-analytics.js.map +1 -0
- package/dist/presets.d.ts +108 -0
- package/dist/presets.d.ts.map +1 -0
- package/dist/presets.js +110 -0
- package/dist/presets.js.map +1 -0
- package/dist/priority-fees.d.ts +49 -0
- package/dist/priority-fees.d.ts.map +1 -0
- package/dist/priority-fees.js +175 -0
- package/dist/priority-fees.js.map +1 -0
- package/dist/protocol-analytics.d.ts +35 -0
- package/dist/protocol-analytics.d.ts.map +1 -0
- package/dist/protocol-analytics.js +64 -0
- package/dist/protocol-analytics.js.map +1 -0
- package/dist/protocol-names.d.ts +9 -0
- package/dist/protocol-names.d.ts.map +1 -0
- package/dist/protocol-names.js +18 -0
- package/dist/protocol-names.js.map +1 -0
- package/dist/protocol-resolver.d.ts +54 -0
- package/dist/protocol-resolver.d.ts.map +1 -0
- package/dist/protocol-resolver.js +123 -0
- package/dist/protocol-resolver.js.map +1 -0
- package/dist/resolve-accounts.d.ts +38 -0
- package/dist/resolve-accounts.d.ts.map +1 -0
- package/dist/resolve-accounts.js +120 -0
- package/dist/resolve-accounts.js.map +1 -0
- package/dist/rpc-helpers.d.ts +50 -0
- package/dist/rpc-helpers.d.ts.map +1 -0
- package/dist/rpc-helpers.js +119 -0
- package/dist/rpc-helpers.js.map +1 -0
- package/dist/seal.d.ts +211 -0
- package/dist/seal.d.ts.map +1 -0
- package/dist/seal.js +569 -0
- package/dist/seal.js.map +1 -0
- package/dist/security-analytics.d.ts +85 -0
- package/dist/security-analytics.d.ts.map +1 -0
- package/dist/security-analytics.js +510 -0
- package/dist/security-analytics.js.map +1 -0
- package/dist/shield.d.ts +235 -0
- package/dist/shield.d.ts.map +1 -0
- package/dist/shield.js +701 -0
- package/dist/shield.js.map +1 -0
- package/dist/simulation.d.ts +111 -0
- package/dist/simulation.d.ts.map +1 -0
- package/dist/simulation.js +514 -0
- package/dist/simulation.js.map +1 -0
- package/dist/spending-analytics.d.ts +91 -0
- package/dist/spending-analytics.d.ts.map +1 -0
- package/dist/spending-analytics.js +217 -0
- package/dist/spending-analytics.js.map +1 -0
- package/dist/state-resolver.d.ts +173 -0
- package/dist/state-resolver.d.ts.map +1 -0
- package/dist/state-resolver.js +660 -0
- package/dist/state-resolver.js.map +1 -0
- package/dist/tee/cache.d.ts +28 -0
- package/dist/tee/cache.d.ts.map +1 -0
- package/dist/tee/cache.js +75 -0
- package/dist/tee/cache.js.map +1 -0
- package/dist/tee/index.d.ts +9 -0
- package/dist/tee/index.d.ts.map +1 -0
- package/dist/tee/index.js +9 -0
- package/dist/tee/index.js.map +1 -0
- package/dist/tee/nitro-root.d.ts +11 -0
- package/dist/tee/nitro-root.d.ts.map +1 -0
- package/dist/tee/nitro-root.js +24 -0
- package/dist/tee/nitro-root.js.map +1 -0
- package/dist/tee/providers/crossmint.d.ts +12 -0
- package/dist/tee/providers/crossmint.d.ts.map +1 -0
- package/dist/tee/providers/crossmint.js +73 -0
- package/dist/tee/providers/crossmint.js.map +1 -0
- package/dist/tee/providers/privy.d.ts +12 -0
- package/dist/tee/providers/privy.d.ts.map +1 -0
- package/dist/tee/providers/privy.js +73 -0
- package/dist/tee/providers/privy.js.map +1 -0
- package/dist/tee/providers/turnkey.d.ts +34 -0
- package/dist/tee/providers/turnkey.d.ts.map +1 -0
- package/dist/tee/providers/turnkey.js +401 -0
- package/dist/tee/providers/turnkey.js.map +1 -0
- package/dist/tee/types.d.ts +124 -0
- package/dist/tee/types.d.ts.map +1 -0
- package/dist/tee/types.js +51 -0
- package/dist/tee/types.js.map +1 -0
- package/dist/tee/verify.d.ts +34 -0
- package/dist/tee/verify.d.ts.map +1 -0
- package/dist/tee/verify.js +177 -0
- package/dist/tee/verify.js.map +1 -0
- package/dist/tee/wallet-types.d.ts +61 -0
- package/dist/tee/wallet-types.d.ts.map +1 -0
- package/dist/tee/wallet-types.js +42 -0
- package/dist/tee/wallet-types.js.map +1 -0
- package/dist/testing/devnet.d.ts +64 -0
- package/dist/testing/devnet.d.ts.map +1 -0
- package/dist/testing/devnet.js +222 -0
- package/dist/testing/devnet.js.map +1 -0
- package/dist/testing/index.d.ts +3 -0
- package/dist/testing/index.d.ts.map +1 -0
- package/dist/testing/index.js +9 -0
- package/dist/testing/index.js.map +1 -0
- package/dist/testing/mock-rpc.d.ts +31 -0
- package/dist/testing/mock-rpc.d.ts.map +1 -0
- package/dist/testing/mock-rpc.js +50 -0
- package/dist/testing/mock-rpc.js.map +1 -0
- package/dist/testing/mock-state.d.ts +35 -0
- package/dist/testing/mock-state.d.ts.map +1 -0
- package/dist/testing/mock-state.js +86 -0
- package/dist/testing/mock-state.js.map +1 -0
- package/dist/tokens.d.ts +35 -0
- package/dist/tokens.d.ts.map +1 -0
- package/dist/tokens.js +157 -0
- package/dist/tokens.js.map +1 -0
- package/dist/transaction-executor.d.ts +116 -0
- package/dist/transaction-executor.d.ts.map +1 -0
- package/dist/transaction-executor.js +165 -0
- package/dist/transaction-executor.js.map +1 -0
- package/dist/types.d.ts +102 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +216 -0
- package/dist/types.js.map +1 -0
- package/dist/vault-analytics.d.ts +83 -0
- package/dist/vault-analytics.d.ts.map +1 -0
- package/dist/vault-analytics.js +175 -0
- package/dist/vault-analytics.js.map +1 -0
- package/dist/velocity-tracker.d.ts +79 -0
- package/dist/velocity-tracker.d.ts.map +1 -0
- package/dist/velocity-tracker.js +183 -0
- package/dist/velocity-tracker.js.map +1 -0
- package/dist/x402/amount-guard.d.ts +26 -0
- package/dist/x402/amount-guard.d.ts.map +1 -0
- package/dist/x402/amount-guard.js +80 -0
- package/dist/x402/amount-guard.js.map +1 -0
- package/dist/x402/audit-trail.d.ts +26 -0
- package/dist/x402/audit-trail.d.ts.map +1 -0
- package/dist/x402/audit-trail.js +32 -0
- package/dist/x402/audit-trail.js.map +1 -0
- package/dist/x402/codec.d.ts +26 -0
- package/dist/x402/codec.d.ts.map +1 -0
- package/dist/x402/codec.js +95 -0
- package/dist/x402/codec.js.map +1 -0
- package/dist/x402/errors.d.ts +34 -0
- package/dist/x402/errors.d.ts.map +1 -0
- package/dist/x402/errors.js +53 -0
- package/dist/x402/errors.js.map +1 -0
- package/dist/x402/facilitator-verify.d.ts +24 -0
- package/dist/x402/facilitator-verify.d.ts.map +1 -0
- package/dist/x402/facilitator-verify.js +74 -0
- package/dist/x402/facilitator-verify.js.map +1 -0
- package/dist/x402/index.d.ts +14 -0
- package/dist/x402/index.d.ts.map +1 -0
- package/dist/x402/index.js +23 -0
- package/dist/x402/index.js.map +1 -0
- package/dist/x402/nonce-tracker.d.ts +65 -0
- package/dist/x402/nonce-tracker.d.ts.map +1 -0
- package/dist/x402/nonce-tracker.js +123 -0
- package/dist/x402/nonce-tracker.js.map +1 -0
- package/dist/x402/payment-selector.d.ts +20 -0
- package/dist/x402/payment-selector.d.ts.map +1 -0
- package/dist/x402/payment-selector.js +49 -0
- package/dist/x402/payment-selector.js.map +1 -0
- package/dist/x402/policy-bridge.d.ts +23 -0
- package/dist/x402/policy-bridge.d.ts.map +1 -0
- package/dist/x402/policy-bridge.js +67 -0
- package/dist/x402/policy-bridge.js.map +1 -0
- package/dist/x402/shielded-fetch.d.ts +46 -0
- package/dist/x402/shielded-fetch.d.ts.map +1 -0
- package/dist/x402/shielded-fetch.js +342 -0
- package/dist/x402/shielded-fetch.js.map +1 -0
- package/dist/x402/transfer-builder.d.ts +43 -0
- package/dist/x402/transfer-builder.d.ts.map +1 -0
- package/dist/x402/transfer-builder.js +126 -0
- package/dist/x402/transfer-builder.js.map +1 -0
- package/dist/x402/types.d.ts +109 -0
- package/dist/x402/types.d.ts.map +1 -0
- package/dist/x402/types.js +8 -0
- package/dist/x402/types.js.map +1 -0
- package/package.json +98 -0
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Reusable mock RPC factory for Kit SDK E2E tests.
|
|
3
|
+
*
|
|
4
|
+
* Provides canned responses for all RPC methods used in the execute pipeline.
|
|
5
|
+
* No real network calls — everything returns predictable data.
|
|
6
|
+
*/
|
|
7
|
+
import type { Address, Rpc, SolanaRpcApi } from "@solana/kit";
|
|
8
|
+
export declare const MOCK_VAULT: Address;
|
|
9
|
+
export declare const MOCK_AGENT: Address;
|
|
10
|
+
export declare const MOCK_OWNER: Address;
|
|
11
|
+
export declare const MOCK_POLICY: Address;
|
|
12
|
+
export declare const MOCK_SIGNATURE = "5wHu1qwD7y5B7TFDx5UKo2KRDwfJpJdHnnRr8KeUQBJGG2ZxVjktjDqfUzE6jR2Kv8Zj";
|
|
13
|
+
export declare const MOCK_BLOCKHASH: {
|
|
14
|
+
blockhash: string;
|
|
15
|
+
lastValidBlockHeight: bigint;
|
|
16
|
+
};
|
|
17
|
+
export declare const USDC_MINT = "4zMMC9srt5Ri5X14GAgXhaHii3GnPAEERYPJgZJDncDU";
|
|
18
|
+
export declare const SOL_MINT = "So11111111111111111111111111111111111111112";
|
|
19
|
+
export interface MockRpcOverrides {
|
|
20
|
+
simulateResult?: {
|
|
21
|
+
value: any;
|
|
22
|
+
};
|
|
23
|
+
sendResult?: string;
|
|
24
|
+
statusResult?: {
|
|
25
|
+
value: unknown[];
|
|
26
|
+
};
|
|
27
|
+
getAccountInfoResult?: any;
|
|
28
|
+
}
|
|
29
|
+
export declare function createMockRpc(overrides?: MockRpcOverrides): Rpc<SolanaRpcApi>;
|
|
30
|
+
export declare function createMockAgent(address?: Address): any;
|
|
31
|
+
//# sourceMappingURL=mock-rpc.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-rpc.d.ts","sourceRoot":"","sources":["../../src/testing/mock-rpc.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAK9D,eAAO,MAAM,UAAU,EAC6B,OAAO,CAAC;AAC5D,eAAO,MAAM,UAAU,EAC6B,OAAO,CAAC;AAC5D,eAAO,MAAM,UAAU,EAC6B,OAAO,CAAC;AAC5D,eAAO,MAAM,WAAW,EAC4B,OAAO,CAAC;AAC5D,eAAO,MAAM,cAAc,yEAC6C,CAAC;AAEzE,eAAO,MAAM,cAAc;;;CAG1B,CAAC;AAEF,eAAO,MAAM,SAAS,iDAAiD,CAAC;AACxE,eAAO,MAAM,QAAQ,gDAAgD,CAAC;AAItE,MAAM,WAAW,gBAAgB;IAC/B,cAAc,CAAC,EAAE;QAAE,KAAK,EAAE,GAAG,CAAA;KAAE,CAAC;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE;QAAE,KAAK,EAAE,OAAO,EAAE,CAAA;KAAE,CAAC;IACpC,oBAAoB,CAAC,EAAE,GAAG,CAAC;CAC5B;AAED,wBAAgB,aAAa,CAAC,SAAS,CAAC,EAAE,gBAAgB,GAAG,GAAG,CAAC,YAAY,CAAC,CAwB7E;AAID,wBAAgB,eAAe,CAAC,OAAO,GAAE,OAAoB,GAKtD,GAAG,CACT"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Reusable mock RPC factory for Kit SDK E2E tests.
|
|
3
|
+
*
|
|
4
|
+
* Provides canned responses for all RPC methods used in the execute pipeline.
|
|
5
|
+
* No real network calls — everything returns predictable data.
|
|
6
|
+
*/
|
|
7
|
+
// ─── Constants ──────────────────────────────────────────────────────────────
|
|
8
|
+
export const MOCK_VAULT = "Vault111111111111111111111111111111111111111";
|
|
9
|
+
export const MOCK_AGENT = "Agent111111111111111111111111111111111111111";
|
|
10
|
+
export const MOCK_OWNER = "Owner111111111111111111111111111111111111111";
|
|
11
|
+
export const MOCK_POLICY = "Policy11111111111111111111111111111111111111";
|
|
12
|
+
export const MOCK_SIGNATURE = "5wHu1qwD7y5B7TFDx5UKo2KRDwfJpJdHnnRr8KeUQBJGG2ZxVjktjDqfUzE6jR2Kv8Zj";
|
|
13
|
+
export const MOCK_BLOCKHASH = {
|
|
14
|
+
blockhash: "4NCYB3kRT8sCNodPNuCZo8VUh4xqpBQxsxed2wd9xaJ4",
|
|
15
|
+
lastValidBlockHeight: 1000n,
|
|
16
|
+
};
|
|
17
|
+
export const USDC_MINT = "4zMMC9srt5Ri5X14GAgXhaHii3GnPAEERYPJgZJDncDU";
|
|
18
|
+
export const SOL_MINT = "So11111111111111111111111111111111111111112";
|
|
19
|
+
export function createMockRpc(overrides) {
|
|
20
|
+
return {
|
|
21
|
+
getLatestBlockhash: () => ({
|
|
22
|
+
send: async () => ({ value: MOCK_BLOCKHASH }),
|
|
23
|
+
}),
|
|
24
|
+
simulateTransaction: () => ({
|
|
25
|
+
send: async () => overrides?.simulateResult ?? {
|
|
26
|
+
value: { err: null, logs: [], unitsConsumed: 400_000 },
|
|
27
|
+
},
|
|
28
|
+
}),
|
|
29
|
+
sendTransaction: () => ({
|
|
30
|
+
send: async () => overrides?.sendResult ?? MOCK_SIGNATURE,
|
|
31
|
+
}),
|
|
32
|
+
getSignatureStatuses: () => ({
|
|
33
|
+
send: async () => overrides?.statusResult ?? {
|
|
34
|
+
value: [{ confirmationStatus: "confirmed", err: null }],
|
|
35
|
+
},
|
|
36
|
+
}),
|
|
37
|
+
getAccountInfo: () => ({
|
|
38
|
+
send: async () => overrides?.getAccountInfoResult ?? { value: null },
|
|
39
|
+
}),
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
// ─── Mock Agent Signer ──────────────────────────────────────────────────────
|
|
43
|
+
export function createMockAgent(address = MOCK_AGENT) {
|
|
44
|
+
return {
|
|
45
|
+
address,
|
|
46
|
+
modifyAndSignTransactions: async (txs) => txs,
|
|
47
|
+
signTransactions: async (txs) => txs,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=mock-rpc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-rpc.js","sourceRoot":"","sources":["../../src/testing/mock-rpc.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,+EAA+E;AAE/E,MAAM,CAAC,MAAM,UAAU,GACrB,8CAAyD,CAAC;AAC5D,MAAM,CAAC,MAAM,UAAU,GACrB,8CAAyD,CAAC;AAC5D,MAAM,CAAC,MAAM,UAAU,GACrB,8CAAyD,CAAC;AAC5D,MAAM,CAAC,MAAM,WAAW,GACtB,8CAAyD,CAAC;AAC5D,MAAM,CAAC,MAAM,cAAc,GACzB,sEAAsE,CAAC;AAEzE,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,SAAS,EAAE,8CAA8C;IACzD,oBAAoB,EAAE,KAAK;CAC5B,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG,8CAA8C,CAAC;AACxE,MAAM,CAAC,MAAM,QAAQ,GAAG,6CAA6C,CAAC;AAWtE,MAAM,UAAU,aAAa,CAAC,SAA4B;IACxD,OAAO;QACL,kBAAkB,EAAE,GAAG,EAAE,CAAC,CAAC;YACzB,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC;SAC9C,CAAC;QACF,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;YAC1B,IAAI,EAAE,KAAK,IAAI,EAAE,CACf,SAAS,EAAE,cAAc,IAAI;gBAC3B,KAAK,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,aAAa,EAAE,OAAO,EAAE;aACvD;SACJ,CAAC;QACF,eAAe,EAAE,GAAG,EAAE,CAAC,CAAC;YACtB,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,SAAS,EAAE,UAAU,IAAI,cAAc;SAC1D,CAAC;QACF,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC;YAC3B,IAAI,EAAE,KAAK,IAAI,EAAE,CACf,SAAS,EAAE,YAAY,IAAI;gBACzB,KAAK,EAAE,CAAC,EAAE,kBAAkB,EAAE,WAAW,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;aACxD;SACJ,CAAC;QACF,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC;YACrB,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,SAAS,EAAE,oBAAoB,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;SACrE,CAAC;KAC6B,CAAC;AACpC,CAAC;AAED,+EAA+E;AAE/E,MAAM,UAAU,eAAe,CAAC,UAAmB,UAAU;IAC3D,OAAO;QACL,OAAO;QACP,yBAAyB,EAAE,KAAK,EAAE,GAAc,EAAE,EAAE,CAAC,GAAG;QACxD,gBAAgB,EAAE,KAAK,EAAE,GAAc,EAAE,EAAE,CAAC,GAAG;KACzC,CAAC;AACX,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared mock vault state factory for unit tests.
|
|
3
|
+
*
|
|
4
|
+
* Consolidates duplicated makeCachedState() / mockResolvedState() patterns
|
|
5
|
+
* from wrap.test.ts, shield.test.ts, velocity-tracker.test.ts, etc.
|
|
6
|
+
*/
|
|
7
|
+
import type { Address } from "@solana/kit";
|
|
8
|
+
import { VaultStatus } from "../generated/types/vaultStatus.js";
|
|
9
|
+
import type { ResolvedVaultState } from "../state-resolver.js";
|
|
10
|
+
export interface MockVaultStateOverrides {
|
|
11
|
+
vault?: Address;
|
|
12
|
+
agent?: Address;
|
|
13
|
+
owner?: Address;
|
|
14
|
+
status?: VaultStatus;
|
|
15
|
+
agentPaused?: boolean;
|
|
16
|
+
agentPermissions?: bigint;
|
|
17
|
+
noAgents?: boolean;
|
|
18
|
+
dailyCap?: bigint;
|
|
19
|
+
spent24h?: bigint;
|
|
20
|
+
protocolMode?: number;
|
|
21
|
+
protocols?: Address[];
|
|
22
|
+
developerFeeRate?: number;
|
|
23
|
+
maxConcurrentPositions?: number;
|
|
24
|
+
openPositions?: number;
|
|
25
|
+
feeDestination?: Address;
|
|
26
|
+
totalDepositedUsd?: bigint;
|
|
27
|
+
totalWithdrawnUsd?: bigint;
|
|
28
|
+
stablecoinBalances?: {
|
|
29
|
+
usdc: bigint;
|
|
30
|
+
usdt: bigint;
|
|
31
|
+
};
|
|
32
|
+
maxTransactionSizeUsd?: bigint;
|
|
33
|
+
}
|
|
34
|
+
export declare function createMockVaultState(overrides?: MockVaultStateOverrides): ResolvedVaultState;
|
|
35
|
+
//# sourceMappingURL=mock-state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-state.d.ts","sourceRoot":"","sources":["../../src/testing/mock-state.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAChE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAM/D,MAAM,WAAW,uBAAuB;IACtC,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,OAAO,EAAE,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,kBAAkB,CAAC,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IACpD,qBAAqB,CAAC,EAAE,MAAM,CAAC;CAChC;AAID,wBAAgB,oBAAoB,CAClC,SAAS,CAAC,EAAE,uBAAuB,GAClC,kBAAkB,CA4EpB"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared mock vault state factory for unit tests.
|
|
3
|
+
*
|
|
4
|
+
* Consolidates duplicated makeCachedState() / mockResolvedState() patterns
|
|
5
|
+
* from wrap.test.ts, shield.test.ts, velocity-tracker.test.ts, etc.
|
|
6
|
+
*/
|
|
7
|
+
import { VaultStatus } from "../generated/types/vaultStatus.js";
|
|
8
|
+
import { FULL_PERMISSIONS } from "../types.js";
|
|
9
|
+
import { MOCK_VAULT, MOCK_AGENT, MOCK_OWNER } from "./mock-rpc.js";
|
|
10
|
+
// ─── Factory ────────────────────────────────────────────────────────────────
|
|
11
|
+
export function createMockVaultState(overrides) {
|
|
12
|
+
const vault = overrides?.vault ?? MOCK_VAULT;
|
|
13
|
+
const agent = overrides?.agent ?? MOCK_AGENT;
|
|
14
|
+
const owner = overrides?.owner ?? MOCK_OWNER;
|
|
15
|
+
const status = overrides?.status ?? VaultStatus.Active;
|
|
16
|
+
const dailyCap = overrides?.dailyCap ?? 1000000000n;
|
|
17
|
+
const spent = overrides?.spent24h ?? 0n;
|
|
18
|
+
const maxTx = overrides?.maxTransactionSizeUsd ?? dailyCap;
|
|
19
|
+
const feeDestination = overrides?.feeDestination ??
|
|
20
|
+
"FeeDestination1111111111111111111111111111";
|
|
21
|
+
return {
|
|
22
|
+
vault: {
|
|
23
|
+
discriminator: new Uint8Array(8),
|
|
24
|
+
owner,
|
|
25
|
+
vaultId: 0n,
|
|
26
|
+
agents: overrides?.noAgents
|
|
27
|
+
? []
|
|
28
|
+
: [
|
|
29
|
+
{
|
|
30
|
+
pubkey: agent,
|
|
31
|
+
permissions: overrides?.agentPermissions ?? FULL_PERMISSIONS,
|
|
32
|
+
spendingLimitUsd: 0n,
|
|
33
|
+
paused: overrides?.agentPaused ?? false,
|
|
34
|
+
},
|
|
35
|
+
],
|
|
36
|
+
feeDestination,
|
|
37
|
+
status,
|
|
38
|
+
bump: 255,
|
|
39
|
+
createdAt: 1000n,
|
|
40
|
+
totalTransactions: 0n,
|
|
41
|
+
totalVolume: 0n,
|
|
42
|
+
openPositions: overrides?.openPositions ?? 0,
|
|
43
|
+
activeEscrowCount: 0,
|
|
44
|
+
totalFeesCollected: 0n,
|
|
45
|
+
totalDepositedUsd: overrides?.totalDepositedUsd ?? 0n,
|
|
46
|
+
totalWithdrawnUsd: overrides?.totalWithdrawnUsd ?? 0n,
|
|
47
|
+
totalFailedTransactions: 0n,
|
|
48
|
+
},
|
|
49
|
+
policy: {
|
|
50
|
+
discriminator: new Uint8Array(8),
|
|
51
|
+
vault,
|
|
52
|
+
dailySpendingCapUsd: dailyCap,
|
|
53
|
+
maxTransactionSizeUsd: maxTx,
|
|
54
|
+
protocolMode: overrides?.protocolMode ?? 0,
|
|
55
|
+
protocols: overrides?.protocols ?? [],
|
|
56
|
+
maxLeverageBps: 0,
|
|
57
|
+
canOpenPositions: true,
|
|
58
|
+
maxConcurrentPositions: overrides?.maxConcurrentPositions ?? 5,
|
|
59
|
+
developerFeeRate: overrides?.developerFeeRate ?? 0,
|
|
60
|
+
maxSlippageBps: 100,
|
|
61
|
+
timelockDuration: 0n,
|
|
62
|
+
allowedDestinations: [],
|
|
63
|
+
hasConstraints: false,
|
|
64
|
+
hasPendingPolicy: false,
|
|
65
|
+
hasProtocolCaps: false,
|
|
66
|
+
protocolCaps: [],
|
|
67
|
+
sessionExpirySlots: 0n,
|
|
68
|
+
bump: 255,
|
|
69
|
+
},
|
|
70
|
+
tracker: null,
|
|
71
|
+
overlay: null,
|
|
72
|
+
constraints: null,
|
|
73
|
+
globalBudget: {
|
|
74
|
+
spent24h: spent,
|
|
75
|
+
cap: dailyCap,
|
|
76
|
+
remaining: dailyCap > spent ? dailyCap - spent : 0n,
|
|
77
|
+
},
|
|
78
|
+
agentBudget: null,
|
|
79
|
+
allAgentBudgets: new Map(),
|
|
80
|
+
protocolBudgets: [],
|
|
81
|
+
maxTransactionUsd: maxTx,
|
|
82
|
+
stablecoinBalances: overrides?.stablecoinBalances ?? { usdc: 0n, usdt: 0n },
|
|
83
|
+
resolvedAtTimestamp: BigInt(Math.floor(Date.now() / 1000)),
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=mock-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mock-state.js","sourceRoot":"","sources":["../../src/testing/mock-state.ts"],"names":[],"mappings":"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"}
|
package/dist/tokens.d.ts
ADDED
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native token resolution + amount helpers.
|
|
3
|
+
*
|
|
4
|
+
* 5-layer resolution: hardcoded stablecoins → well-known registry →
|
|
5
|
+
* base58 parse → (caller can add Jupiter API) → error.
|
|
6
|
+
*/
|
|
7
|
+
import type { Address } from "@solana/kit";
|
|
8
|
+
import { type Network } from "./types.js";
|
|
9
|
+
export interface ResolvedToken {
|
|
10
|
+
mint: Address;
|
|
11
|
+
decimals: number;
|
|
12
|
+
symbol: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Resolve a token symbol or mint address to a ResolvedToken.
|
|
16
|
+
*
|
|
17
|
+
* Resolution order:
|
|
18
|
+
* 1. Well-known tokens (USDC, USDT, SOL, etc.) — instant, no network
|
|
19
|
+
* 2. Valid base58 address — accept as-is with default decimals
|
|
20
|
+
* 3. Returns null if unresolvable
|
|
21
|
+
*/
|
|
22
|
+
export declare function resolveToken(tokenOrMint: string, network?: Network): ResolvedToken | null;
|
|
23
|
+
/**
|
|
24
|
+
* Convert a human-readable amount to base units (bigint).
|
|
25
|
+
*
|
|
26
|
+
* Validates for NaN and negative values (H-6 fix by construction).
|
|
27
|
+
* Example: toBaseUnits(100, 6) === 100_000_000n
|
|
28
|
+
*/
|
|
29
|
+
export declare function toBaseUnits(amount: number | string, decimals: number): bigint;
|
|
30
|
+
/**
|
|
31
|
+
* Convert base units to a human-readable amount.
|
|
32
|
+
* Example: fromBaseUnits(100_000_000n, 6) === 100
|
|
33
|
+
*/
|
|
34
|
+
export declare function fromBaseUnits(amount: bigint, decimals: number): number;
|
|
35
|
+
//# sourceMappingURL=tokens.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokens.d.ts","sourceRoot":"","sources":["../src/tokens.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAKL,KAAK,OAAO,EACb,MAAM,YAAY,CAAC;AAEpB,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;CAChB;AA0GD;;;;;;;GAOG;AACH,wBAAgB,YAAY,CAC1B,WAAW,EAAE,MAAM,EACnB,OAAO,GAAE,OAAwB,GAChC,aAAa,GAAG,IAAI,CAmBtB;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAU7E;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAGtE"}
|
package/dist/tokens.js
ADDED
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native token resolution + amount helpers.
|
|
3
|
+
*
|
|
4
|
+
* 5-layer resolution: hardcoded stablecoins → well-known registry →
|
|
5
|
+
* base58 parse → (caller can add Jupiter API) → error.
|
|
6
|
+
*/
|
|
7
|
+
import { USDC_MINT_DEVNET, USDC_MINT_MAINNET, USDT_MINT_DEVNET, USDT_MINT_MAINNET, } from "./types.js";
|
|
8
|
+
/** Well-known tokens with hardcoded mints and decimals */
|
|
9
|
+
const WELL_KNOWN_TOKENS = {
|
|
10
|
+
USDC: {
|
|
11
|
+
devnet: { mint: USDC_MINT_DEVNET, decimals: 6 },
|
|
12
|
+
"mainnet-beta": { mint: USDC_MINT_MAINNET, decimals: 6 },
|
|
13
|
+
},
|
|
14
|
+
USDT: {
|
|
15
|
+
devnet: { mint: USDT_MINT_DEVNET, decimals: 6 },
|
|
16
|
+
"mainnet-beta": { mint: USDT_MINT_MAINNET, decimals: 6 },
|
|
17
|
+
},
|
|
18
|
+
SOL: {
|
|
19
|
+
devnet: {
|
|
20
|
+
mint: "So11111111111111111111111111111111111111112",
|
|
21
|
+
decimals: 9,
|
|
22
|
+
},
|
|
23
|
+
"mainnet-beta": {
|
|
24
|
+
mint: "So11111111111111111111111111111111111111112",
|
|
25
|
+
decimals: 9,
|
|
26
|
+
},
|
|
27
|
+
},
|
|
28
|
+
WSOL: {
|
|
29
|
+
devnet: {
|
|
30
|
+
mint: "So11111111111111111111111111111111111111112",
|
|
31
|
+
decimals: 9,
|
|
32
|
+
},
|
|
33
|
+
"mainnet-beta": {
|
|
34
|
+
mint: "So11111111111111111111111111111111111111112",
|
|
35
|
+
decimals: 9,
|
|
36
|
+
},
|
|
37
|
+
},
|
|
38
|
+
JUP: {
|
|
39
|
+
devnet: {
|
|
40
|
+
mint: "JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN",
|
|
41
|
+
decimals: 6,
|
|
42
|
+
},
|
|
43
|
+
"mainnet-beta": {
|
|
44
|
+
mint: "JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN",
|
|
45
|
+
decimals: 6,
|
|
46
|
+
},
|
|
47
|
+
},
|
|
48
|
+
BONK: {
|
|
49
|
+
devnet: {
|
|
50
|
+
mint: "DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263",
|
|
51
|
+
decimals: 5,
|
|
52
|
+
},
|
|
53
|
+
"mainnet-beta": {
|
|
54
|
+
mint: "DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263",
|
|
55
|
+
decimals: 5,
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
PYTH: {
|
|
59
|
+
devnet: {
|
|
60
|
+
mint: "HZ1JovNiVvGrGNiiYvEozEVgZ58xaU3RKwX8eACQBCt3",
|
|
61
|
+
decimals: 6,
|
|
62
|
+
},
|
|
63
|
+
"mainnet-beta": {
|
|
64
|
+
mint: "HZ1JovNiVvGrGNiiYvEozEVgZ58xaU3RKwX8eACQBCt3",
|
|
65
|
+
decimals: 6,
|
|
66
|
+
},
|
|
67
|
+
},
|
|
68
|
+
WIF: {
|
|
69
|
+
devnet: {
|
|
70
|
+
mint: "EKpQGSJtjMFqKZ9KQanSqYXRcF8fBopzLHYxdM65zcjm",
|
|
71
|
+
decimals: 6,
|
|
72
|
+
},
|
|
73
|
+
"mainnet-beta": {
|
|
74
|
+
mint: "EKpQGSJtjMFqKZ9KQanSqYXRcF8fBopzLHYxdM65zcjm",
|
|
75
|
+
decimals: 6,
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
JITO: {
|
|
79
|
+
devnet: {
|
|
80
|
+
mint: "J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn",
|
|
81
|
+
decimals: 9,
|
|
82
|
+
},
|
|
83
|
+
"mainnet-beta": {
|
|
84
|
+
mint: "J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn",
|
|
85
|
+
decimals: 9,
|
|
86
|
+
},
|
|
87
|
+
},
|
|
88
|
+
RAY: {
|
|
89
|
+
devnet: {
|
|
90
|
+
mint: "4k3Dyjzvzp8eMZWUXbBCjEvwSkkk59S5iCNLY3QrkX6R",
|
|
91
|
+
decimals: 6,
|
|
92
|
+
},
|
|
93
|
+
"mainnet-beta": {
|
|
94
|
+
mint: "4k3Dyjzvzp8eMZWUXbBCjEvwSkkk59S5iCNLY3QrkX6R",
|
|
95
|
+
decimals: 6,
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
};
|
|
99
|
+
/**
|
|
100
|
+
* Check if a string looks like a valid base58 public key.
|
|
101
|
+
*/
|
|
102
|
+
function isBase58Address(value) {
|
|
103
|
+
// Base58 Solana addresses are 32-44 chars, only base58 chars
|
|
104
|
+
if (value.length < 32 || value.length > 44)
|
|
105
|
+
return false;
|
|
106
|
+
return /^[1-9A-HJ-NP-Za-km-z]+$/.test(value);
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Resolve a token symbol or mint address to a ResolvedToken.
|
|
110
|
+
*
|
|
111
|
+
* Resolution order:
|
|
112
|
+
* 1. Well-known tokens (USDC, USDT, SOL, etc.) — instant, no network
|
|
113
|
+
* 2. Valid base58 address — accept as-is with default decimals
|
|
114
|
+
* 3. Returns null if unresolvable
|
|
115
|
+
*/
|
|
116
|
+
export function resolveToken(tokenOrMint, network = "mainnet-beta") {
|
|
117
|
+
// 1. Check well-known tokens (case-insensitive)
|
|
118
|
+
const upper = tokenOrMint.toUpperCase();
|
|
119
|
+
const known = WELL_KNOWN_TOKENS[upper];
|
|
120
|
+
if (known) {
|
|
121
|
+
const entry = known[network];
|
|
122
|
+
return { mint: entry.mint, decimals: entry.decimals, symbol: upper };
|
|
123
|
+
}
|
|
124
|
+
// 2. Check if it's a valid base58 address
|
|
125
|
+
if (isBase58Address(tokenOrMint)) {
|
|
126
|
+
return {
|
|
127
|
+
mint: tokenOrMint,
|
|
128
|
+
decimals: 6, // default; caller should fetch actual decimals
|
|
129
|
+
symbol: tokenOrMint.slice(0, 4) + "...",
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
return null;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Convert a human-readable amount to base units (bigint).
|
|
136
|
+
*
|
|
137
|
+
* Validates for NaN and negative values (H-6 fix by construction).
|
|
138
|
+
* Example: toBaseUnits(100, 6) === 100_000_000n
|
|
139
|
+
*/
|
|
140
|
+
export function toBaseUnits(amount, decimals) {
|
|
141
|
+
const num = typeof amount === "string" ? parseFloat(amount) : amount;
|
|
142
|
+
if (!Number.isFinite(num) || num < 0) {
|
|
143
|
+
throw new Error(`Invalid amount: ${amount}. Must be a finite non-negative number.`);
|
|
144
|
+
}
|
|
145
|
+
const multiplier = Math.pow(10, decimals);
|
|
146
|
+
const baseUnits = Math.round(num * multiplier);
|
|
147
|
+
return BigInt(baseUnits);
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Convert base units to a human-readable amount.
|
|
151
|
+
* Example: fromBaseUnits(100_000_000n, 6) === 100
|
|
152
|
+
*/
|
|
153
|
+
export function fromBaseUnits(amount, decimals) {
|
|
154
|
+
const divisor = Math.pow(10, decimals);
|
|
155
|
+
return Number(amount) / divisor;
|
|
156
|
+
}
|
|
157
|
+
//# sourceMappingURL=tokens.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokens.js","sourceRoot":"","sources":["../src/tokens.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TransactionExecutor — Kit-native transaction pipeline.
|
|
3
|
+
*
|
|
4
|
+
* Steps:
|
|
5
|
+
* 9. Compose versioned transaction (blockhash + compile)
|
|
6
|
+
* 10. Simulate (fail-closed)
|
|
7
|
+
* 11. Sign
|
|
8
|
+
* 12. Send + confirm, parse events
|
|
9
|
+
*/
|
|
10
|
+
import type { Address, Instruction, Rpc, SolanaRpcApi, TransactionSigner, AddressesByLookupTableAddress } from "@solana/kit";
|
|
11
|
+
import { composeSigilTransaction } from "./composer.js";
|
|
12
|
+
import { type SimulationResult, type RiskFlag, type DrainThresholds } from "./simulation.js";
|
|
13
|
+
import { type SigilEvent } from "./events.js";
|
|
14
|
+
import { type SendAndConfirmOptions } from "./rpc-helpers.js";
|
|
15
|
+
export interface ExecuteTransactionParams {
|
|
16
|
+
/** Fee payer address (typically the agent) */
|
|
17
|
+
feePayer: Address;
|
|
18
|
+
/** The validate_and_authorize instruction */
|
|
19
|
+
validateIx: Instruction;
|
|
20
|
+
/** DeFi protocol instruction(s) to sandwich */
|
|
21
|
+
defiInstructions: Instruction[];
|
|
22
|
+
/** The finalize_session instruction */
|
|
23
|
+
finalizeIx: Instruction;
|
|
24
|
+
/** Optional: override CU limit */
|
|
25
|
+
computeUnits?: number;
|
|
26
|
+
/** Optional: priority fee in microLamports per CU */
|
|
27
|
+
priorityFeeMicroLamports?: number;
|
|
28
|
+
/** Resolved address lookup tables for transaction compression */
|
|
29
|
+
addressLookupTables?: AddressesByLookupTableAddress;
|
|
30
|
+
/** Vault monitoring context for drain detection during simulation.
|
|
31
|
+
* Populated from SealResult.vaultContext by the caller. */
|
|
32
|
+
vaultMonitoring?: {
|
|
33
|
+
vaultAddress: string;
|
|
34
|
+
monitorAccounts: string[];
|
|
35
|
+
preBalances: Map<string, bigint>;
|
|
36
|
+
totalVaultBalance: bigint;
|
|
37
|
+
knownRecipients?: Set<string>;
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
export interface ExecuteTransactionResult {
|
|
41
|
+
/** Transaction signature (base58) */
|
|
42
|
+
signature: string;
|
|
43
|
+
/** Compute units consumed (from simulation) */
|
|
44
|
+
unitsConsumed?: number;
|
|
45
|
+
/** Transaction logs */
|
|
46
|
+
logs?: string[];
|
|
47
|
+
/** Parsed Sigil events */
|
|
48
|
+
events: SigilEvent[];
|
|
49
|
+
/** Risk flag warnings (LARGE_OUTFLOW, UNKNOWN_RECIPIENT) — non-blocking */
|
|
50
|
+
warnings?: RiskFlag[];
|
|
51
|
+
}
|
|
52
|
+
export interface TransactionExecutorOptions {
|
|
53
|
+
/** Blockhash cache TTL in milliseconds */
|
|
54
|
+
blockhashCacheTtlMs?: number;
|
|
55
|
+
/** Send+confirm options */
|
|
56
|
+
confirmOptions?: SendAndConfirmOptions;
|
|
57
|
+
/**
|
|
58
|
+
* Skip simulation (default: false — simulation is fail-closed).
|
|
59
|
+
* WARNING: This bypasses the pre-sign safety gate. Only use in test environments.
|
|
60
|
+
* Moved from per-call params to constructor-only to prevent accidental bypass.
|
|
61
|
+
*/
|
|
62
|
+
skipSimulation?: boolean;
|
|
63
|
+
/** Configurable drain detection thresholds (defaults: 50% warning, 95% block) */
|
|
64
|
+
drainThresholds?: DrainThresholds;
|
|
65
|
+
}
|
|
66
|
+
export declare class TransactionExecutor {
|
|
67
|
+
readonly rpc: Rpc<SolanaRpcApi>;
|
|
68
|
+
readonly agent: TransactionSigner;
|
|
69
|
+
private readonly blockhashCache;
|
|
70
|
+
private readonly confirmOptions;
|
|
71
|
+
private readonly _skipSimulation;
|
|
72
|
+
private readonly _drainThresholds?;
|
|
73
|
+
private altCache?;
|
|
74
|
+
constructor(rpc: Rpc<SolanaRpcApi>, agent: TransactionSigner, options?: TransactionExecutorOptions);
|
|
75
|
+
/**
|
|
76
|
+
* Resolve ALT addresses via cached RPC fetch.
|
|
77
|
+
* Returns a map of ALT address → resolved addresses.
|
|
78
|
+
*/
|
|
79
|
+
resolveAlts(rpc: Rpc<SolanaRpcApi>, altAddresses: Address[]): Promise<AddressesByLookupTableAddress>;
|
|
80
|
+
/**
|
|
81
|
+
* Step 9: Compose a versioned transaction from instructions + cached blockhash.
|
|
82
|
+
*/
|
|
83
|
+
composeTransaction(params: ExecuteTransactionParams): Promise<{
|
|
84
|
+
compiledTx: Readonly<Readonly<{
|
|
85
|
+
messageBytes: import("@solana/kit").TransactionMessageBytes;
|
|
86
|
+
signatures: import("@solana/kit").SignaturesMap;
|
|
87
|
+
}>>;
|
|
88
|
+
computeUnits: number;
|
|
89
|
+
blockhash: import("./rpc-helpers.js").Blockhash;
|
|
90
|
+
}>;
|
|
91
|
+
/**
|
|
92
|
+
* Step 10: Simulate the transaction. Fail-closed — failure blocks sending.
|
|
93
|
+
* If CU consumed differs >20% from estimate, re-composes.
|
|
94
|
+
*/
|
|
95
|
+
simulate(params: ExecuteTransactionParams, compiledTx: ReturnType<typeof composeSigilTransaction>, estimatedCU: number, blockhash: {
|
|
96
|
+
blockhash: string;
|
|
97
|
+
lastValidBlockHeight: bigint;
|
|
98
|
+
}): Promise<{
|
|
99
|
+
simulation: SimulationResult;
|
|
100
|
+
recomposedTx?: ReturnType<typeof composeSigilTransaction>;
|
|
101
|
+
finalCU: number;
|
|
102
|
+
}>;
|
|
103
|
+
/**
|
|
104
|
+
* Steps 11+12: Sign, send, and confirm the transaction.
|
|
105
|
+
*/
|
|
106
|
+
signSendConfirm(compiledTx: ReturnType<typeof composeSigilTransaction>): Promise<{
|
|
107
|
+
signature: string;
|
|
108
|
+
logs?: string[];
|
|
109
|
+
}>;
|
|
110
|
+
/**
|
|
111
|
+
* Full pipeline: compose → simulate → sign → send → parse events.
|
|
112
|
+
* Steps 9-12 in one call.
|
|
113
|
+
*/
|
|
114
|
+
executeTransaction(params: ExecuteTransactionParams): Promise<ExecuteTransactionResult>;
|
|
115
|
+
}
|
|
116
|
+
//# sourceMappingURL=transaction-executor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-executor.d.ts","sourceRoot":"","sources":["../src/transaction-executor.ts"],"names":[],"mappings":"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"}
|