@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,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Protocol Resolver — Kit-native
|
|
3
|
+
*
|
|
4
|
+
* Determines protocol tier for allowlist/constraint enforcement:
|
|
5
|
+
* KNOWN: Program is in the known protocols registry
|
|
6
|
+
* DEFAULT: Passthrough with on-chain constraints
|
|
7
|
+
* NOT_ALLOWED: Blocked by policy
|
|
8
|
+
*/
|
|
9
|
+
import * as Core from "./core/index.js";
|
|
10
|
+
// ---------------------------------------------------------------------------
|
|
11
|
+
// Types
|
|
12
|
+
// ---------------------------------------------------------------------------
|
|
13
|
+
export var ProtocolTier;
|
|
14
|
+
(function (ProtocolTier) {
|
|
15
|
+
ProtocolTier[ProtocolTier["KNOWN"] = 1] = "KNOWN";
|
|
16
|
+
ProtocolTier[ProtocolTier["DEFAULT"] = 2] = "DEFAULT";
|
|
17
|
+
ProtocolTier[ProtocolTier["NOT_ALLOWED"] = 3] = "NOT_ALLOWED";
|
|
18
|
+
})(ProtocolTier || (ProtocolTier = {}));
|
|
19
|
+
// ---------------------------------------------------------------------------
|
|
20
|
+
// Core Logic
|
|
21
|
+
// ---------------------------------------------------------------------------
|
|
22
|
+
/**
|
|
23
|
+
* Check if a program is in the vault's protocol allowlist/denylist.
|
|
24
|
+
*
|
|
25
|
+
* @param programId - Program address to check
|
|
26
|
+
* @param policy - Vault policy with protocolMode and protocols list
|
|
27
|
+
* @returns true if the program is allowed by the policy
|
|
28
|
+
*/
|
|
29
|
+
export function isProtocolAllowed(programId, policy) {
|
|
30
|
+
if (policy.protocolMode === 0)
|
|
31
|
+
return true; // mode 0: all allowed
|
|
32
|
+
const isInList = policy.protocols.some((p) => p === programId);
|
|
33
|
+
if (policy.protocolMode === 1)
|
|
34
|
+
return isInList; // allowlist
|
|
35
|
+
return !isInList; // denylist
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Resolve the tier and escalation info for a given protocol.
|
|
39
|
+
*
|
|
40
|
+
* Resolution logic:
|
|
41
|
+
* 1. Known program + in allowlist -> KNOWN
|
|
42
|
+
* 2. Known program + NOT in allowlist -> NOT_ALLOWED
|
|
43
|
+
* 3. Unknown program + in allowlist + constraints -> DEFAULT (passthrough)
|
|
44
|
+
* 4. Unknown program + in allowlist + NO constraints -> NOT_ALLOWED (escalation)
|
|
45
|
+
* 5. Unknown program + NOT in allowlist -> NOT_ALLOWED (escalation)
|
|
46
|
+
*/
|
|
47
|
+
export function resolveProtocol(programId, policy, constraintsConfigured) {
|
|
48
|
+
const allowed = isProtocolAllowed(programId, policy);
|
|
49
|
+
const knownName = Core.KNOWN_PROTOCOLS.get(programId);
|
|
50
|
+
if (knownName) {
|
|
51
|
+
if (!allowed) {
|
|
52
|
+
// Path 2: Known but not in allowlist
|
|
53
|
+
return {
|
|
54
|
+
tier: ProtocolTier.NOT_ALLOWED,
|
|
55
|
+
protocolId: programId,
|
|
56
|
+
programId,
|
|
57
|
+
displayName: knownName,
|
|
58
|
+
reason: `${knownName} is not in the vault's protocol allowlist`,
|
|
59
|
+
escalation: {
|
|
60
|
+
type: "not_in_allowlist",
|
|
61
|
+
message: `${knownName} (${programId}) is not in your vault's protocol allowlist.`,
|
|
62
|
+
requiredActions: [
|
|
63
|
+
`Add program ${programId} to the vault's protocol allowlist`,
|
|
64
|
+
],
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
// Path 1: Known + allowed
|
|
69
|
+
return {
|
|
70
|
+
tier: ProtocolTier.KNOWN,
|
|
71
|
+
protocolId: programId,
|
|
72
|
+
programId,
|
|
73
|
+
displayName: knownName,
|
|
74
|
+
reason: `${knownName} is a known protocol`,
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
// Unknown protocol
|
|
78
|
+
if (allowed && constraintsConfigured) {
|
|
79
|
+
// Path 3: Unknown + allowed + constraints -> passthrough
|
|
80
|
+
return {
|
|
81
|
+
tier: ProtocolTier.DEFAULT,
|
|
82
|
+
protocolId: programId,
|
|
83
|
+
programId,
|
|
84
|
+
displayName: programId,
|
|
85
|
+
reason: "Unknown protocol — using on-chain constraint validation (passthrough)",
|
|
86
|
+
constraintsConfigured: true,
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
if (allowed && !constraintsConfigured) {
|
|
90
|
+
// Path 4: Unknown + allowed + no constraints
|
|
91
|
+
return {
|
|
92
|
+
tier: ProtocolTier.NOT_ALLOWED,
|
|
93
|
+
protocolId: programId,
|
|
94
|
+
programId,
|
|
95
|
+
displayName: programId,
|
|
96
|
+
reason: "Protocol is allowed but no constraints are configured for validation",
|
|
97
|
+
escalation: {
|
|
98
|
+
type: "no_handler_no_constraints",
|
|
99
|
+
message: `Program ${programId} is in the allowlist but has no on-chain instruction constraints configured.`,
|
|
100
|
+
requiredActions: [
|
|
101
|
+
`Configure instruction constraints for program ${programId} using createConstraints`,
|
|
102
|
+
],
|
|
103
|
+
},
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
// Path 5: Unknown + not in allowlist
|
|
107
|
+
return {
|
|
108
|
+
tier: ProtocolTier.NOT_ALLOWED,
|
|
109
|
+
protocolId: programId,
|
|
110
|
+
programId,
|
|
111
|
+
displayName: programId,
|
|
112
|
+
reason: "Protocol is not in the vault's allowlist",
|
|
113
|
+
escalation: {
|
|
114
|
+
type: "not_in_allowlist_and_no_handler",
|
|
115
|
+
message: `Program ${programId} is not in the vault's protocol allowlist.`,
|
|
116
|
+
requiredActions: [
|
|
117
|
+
`Add program ${programId} to the vault's protocol allowlist`,
|
|
118
|
+
`Configure instruction constraints for program ${programId}`,
|
|
119
|
+
],
|
|
120
|
+
},
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=protocol-resolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol-resolver.js","sourceRoot":"","sources":["../src/protocol-resolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native PDA resolution for Sigil accounts.
|
|
3
|
+
*
|
|
4
|
+
* Uses Kit's `getProgramDerivedAddress()` and `getAddressEncoder()` for
|
|
5
|
+
* seed encoding. All 9 PDA types are derivable.
|
|
6
|
+
*/
|
|
7
|
+
import type { Address } from "@solana/kit";
|
|
8
|
+
export declare function getVaultPDA(owner: Address, vaultId: bigint, programAddress?: Address): Promise<[Address, number]>;
|
|
9
|
+
export declare function getPolicyPDA(vault: Address, programAddress?: Address): Promise<[Address, number]>;
|
|
10
|
+
export declare function getTrackerPDA(vault: Address, programAddress?: Address): Promise<[Address, number]>;
|
|
11
|
+
export declare function getSessionPDA(vault: Address, agent: Address, tokenMint: Address, programAddress?: Address): Promise<[Address, number]>;
|
|
12
|
+
export declare function getPendingPolicyPDA(vault: Address, programAddress?: Address): Promise<[Address, number]>;
|
|
13
|
+
export declare function getEscrowPDA(sourceVault: Address, destinationVault: Address, escrowId: bigint, programAddress?: Address): Promise<[Address, number]>;
|
|
14
|
+
export declare function getAgentOverlayPDA(vault: Address, shardIndex?: number, programAddress?: Address): Promise<[Address, number]>;
|
|
15
|
+
export declare function getConstraintsPDA(vault: Address, programAddress?: Address): Promise<[Address, number]>;
|
|
16
|
+
export declare function getPendingConstraintsPDA(vault: Address, programAddress?: Address): Promise<[Address, number]>;
|
|
17
|
+
export interface ResolveAccountsInput {
|
|
18
|
+
vault: Address;
|
|
19
|
+
agent: Address;
|
|
20
|
+
tokenMint: Address;
|
|
21
|
+
outputMint?: Address;
|
|
22
|
+
feeDestination?: Address;
|
|
23
|
+
hasConstraints?: boolean;
|
|
24
|
+
}
|
|
25
|
+
export interface ResolvedAccounts {
|
|
26
|
+
vault: Address;
|
|
27
|
+
policyPda: Address;
|
|
28
|
+
trackerPda: Address;
|
|
29
|
+
sessionPda: Address;
|
|
30
|
+
constraintsPda?: Address;
|
|
31
|
+
agentOverlayPda?: Address;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Auto-derive all PDA accounts needed for a composed Sigil transaction.
|
|
35
|
+
* Token ATAs must be derived separately using `@solana-program/token`.
|
|
36
|
+
*/
|
|
37
|
+
export declare function resolveAccounts(input: ResolveAccountsInput, programAddress?: Address): Promise<ResolvedAccounts>;
|
|
38
|
+
//# sourceMappingURL=resolve-accounts.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-accounts.d.ts","sourceRoot":"","sources":["../src/resolve-accounts.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAsB,MAAM,aAAa,CAAC;AA8B/D,wBAAsB,WAAW,CAC/B,KAAK,EAAE,OAAO,EACd,OAAO,EAAE,MAAM,EACf,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAM5B;AAED,wBAAsB,YAAY,CAChC,KAAK,EAAE,OAAO,EACd,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAM5B;AAED,wBAAsB,aAAa,CACjC,KAAK,EAAE,OAAO,EACd,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAM5B;AAED,wBAAsB,aAAa,CACjC,KAAK,EAAE,OAAO,EACd,KAAK,EAAE,OAAO,EACd,SAAS,EAAE,OAAO,EAClB,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAW5B;AAED,wBAAsB,mBAAmB,CACvC,KAAK,EAAE,OAAO,EACd,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAM5B;AAED,wBAAsB,YAAY,CAChC,WAAW,EAAE,OAAO,EACpB,gBAAgB,EAAE,OAAO,EACzB,QAAQ,EAAE,MAAM,EAChB,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAW5B;AAED,wBAAsB,kBAAkB,CACtC,KAAK,EAAE,OAAO,EACd,UAAU,GAAE,MAAU,EACtB,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAM5B;AAED,wBAAsB,iBAAiB,CACrC,KAAK,EAAE,OAAO,EACd,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAM5B;AAED,wBAAsB,wBAAwB,CAC5C,KAAK,EAAE,OAAO,EACd,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAM5B;AAID,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,OAAO,CAAC;IACf,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED;;;GAGG;AACH,wBAAsB,eAAe,CACnC,KAAK,EAAE,oBAAoB,EAC3B,cAAc,GAAE,OAA+B,GAC9C,OAAO,CAAC,gBAAgB,CAAC,CA0B3B"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native PDA resolution for Sigil accounts.
|
|
3
|
+
*
|
|
4
|
+
* Uses Kit's `getProgramDerivedAddress()` and `getAddressEncoder()` for
|
|
5
|
+
* seed encoding. All 9 PDA types are derivable.
|
|
6
|
+
*/
|
|
7
|
+
import { getAddressEncoder, getProgramDerivedAddress } from "@solana/kit";
|
|
8
|
+
import { SIGIL_PROGRAM_ADDRESS } from "./generated/programs/sigil.js";
|
|
9
|
+
// ─── PDA Derivation ──────────────────────────────────────────────────────────
|
|
10
|
+
const encoder = getAddressEncoder();
|
|
11
|
+
const textEncoder = new TextEncoder();
|
|
12
|
+
function seedString(s) {
|
|
13
|
+
return textEncoder.encode(s);
|
|
14
|
+
}
|
|
15
|
+
function seedAddress(addr) {
|
|
16
|
+
return encoder.encode(addr);
|
|
17
|
+
}
|
|
18
|
+
function seedU64Le(value) {
|
|
19
|
+
const buf = new Uint8Array(8);
|
|
20
|
+
const view = new DataView(buf.buffer);
|
|
21
|
+
view.setBigUint64(0, value, true); // little-endian
|
|
22
|
+
return buf;
|
|
23
|
+
}
|
|
24
|
+
function seedU8(value) {
|
|
25
|
+
return new Uint8Array([value]);
|
|
26
|
+
}
|
|
27
|
+
export async function getVaultPDA(owner, vaultId, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
28
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
29
|
+
programAddress,
|
|
30
|
+
seeds: [seedString("vault"), seedAddress(owner), seedU64Le(vaultId)],
|
|
31
|
+
});
|
|
32
|
+
return [pda, bump];
|
|
33
|
+
}
|
|
34
|
+
export async function getPolicyPDA(vault, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
35
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
36
|
+
programAddress,
|
|
37
|
+
seeds: [seedString("policy"), seedAddress(vault)],
|
|
38
|
+
});
|
|
39
|
+
return [pda, bump];
|
|
40
|
+
}
|
|
41
|
+
export async function getTrackerPDA(vault, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
42
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
43
|
+
programAddress,
|
|
44
|
+
seeds: [seedString("tracker"), seedAddress(vault)],
|
|
45
|
+
});
|
|
46
|
+
return [pda, bump];
|
|
47
|
+
}
|
|
48
|
+
export async function getSessionPDA(vault, agent, tokenMint, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
49
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
50
|
+
programAddress,
|
|
51
|
+
seeds: [
|
|
52
|
+
seedString("session"),
|
|
53
|
+
seedAddress(vault),
|
|
54
|
+
seedAddress(agent),
|
|
55
|
+
seedAddress(tokenMint),
|
|
56
|
+
],
|
|
57
|
+
});
|
|
58
|
+
return [pda, bump];
|
|
59
|
+
}
|
|
60
|
+
export async function getPendingPolicyPDA(vault, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
61
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
62
|
+
programAddress,
|
|
63
|
+
seeds: [seedString("pending_policy"), seedAddress(vault)],
|
|
64
|
+
});
|
|
65
|
+
return [pda, bump];
|
|
66
|
+
}
|
|
67
|
+
export async function getEscrowPDA(sourceVault, destinationVault, escrowId, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
68
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
69
|
+
programAddress,
|
|
70
|
+
seeds: [
|
|
71
|
+
seedString("escrow"),
|
|
72
|
+
seedAddress(sourceVault),
|
|
73
|
+
seedAddress(destinationVault),
|
|
74
|
+
seedU64Le(escrowId),
|
|
75
|
+
],
|
|
76
|
+
});
|
|
77
|
+
return [pda, bump];
|
|
78
|
+
}
|
|
79
|
+
export async function getAgentOverlayPDA(vault, shardIndex = 0, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
80
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
81
|
+
programAddress,
|
|
82
|
+
seeds: [seedString("agent_spend"), seedAddress(vault), seedU8(shardIndex)],
|
|
83
|
+
});
|
|
84
|
+
return [pda, bump];
|
|
85
|
+
}
|
|
86
|
+
export async function getConstraintsPDA(vault, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
87
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
88
|
+
programAddress,
|
|
89
|
+
seeds: [seedString("constraints"), seedAddress(vault)],
|
|
90
|
+
});
|
|
91
|
+
return [pda, bump];
|
|
92
|
+
}
|
|
93
|
+
export async function getPendingConstraintsPDA(vault, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
94
|
+
const [pda, bump] = await getProgramDerivedAddress({
|
|
95
|
+
programAddress,
|
|
96
|
+
seeds: [seedString("pending_constraints"), seedAddress(vault)],
|
|
97
|
+
});
|
|
98
|
+
return [pda, bump];
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Auto-derive all PDA accounts needed for a composed Sigil transaction.
|
|
102
|
+
* Token ATAs must be derived separately using `@solana-program/token`.
|
|
103
|
+
*/
|
|
104
|
+
export async function resolveAccounts(input, programAddress = SIGIL_PROGRAM_ADDRESS) {
|
|
105
|
+
const [policyPda] = await getPolicyPDA(input.vault, programAddress);
|
|
106
|
+
const [trackerPda] = await getTrackerPDA(input.vault, programAddress);
|
|
107
|
+
const [sessionPda] = await getSessionPDA(input.vault, input.agent, input.tokenMint, programAddress);
|
|
108
|
+
const result = {
|
|
109
|
+
vault: input.vault,
|
|
110
|
+
policyPda,
|
|
111
|
+
trackerPda,
|
|
112
|
+
sessionPda,
|
|
113
|
+
};
|
|
114
|
+
if (input.hasConstraints) {
|
|
115
|
+
const [constraintsPda] = await getConstraintsPDA(input.vault, programAddress);
|
|
116
|
+
result.constraintsPda = constraintsPda;
|
|
117
|
+
}
|
|
118
|
+
return result;
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=resolve-accounts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-accounts.js","sourceRoot":"","sources":["../src/resolve-accounts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native RPC helpers for Sigil SDK.
|
|
3
|
+
*
|
|
4
|
+
* - BlockhashCache: Caches getLatestBlockhash with configurable TTL
|
|
5
|
+
* - signAndEncode: Sign a compiled TX + encode to base64 wire format
|
|
6
|
+
* - sendAndConfirmTransaction: Send + poll getSignatureStatuses
|
|
7
|
+
*/
|
|
8
|
+
import type { Rpc, SolanaRpcApi, Commitment, Base64EncodedWireTransaction, TransactionSigner } from "@solana/kit";
|
|
9
|
+
export interface Blockhash {
|
|
10
|
+
blockhash: string;
|
|
11
|
+
lastValidBlockHeight: bigint;
|
|
12
|
+
}
|
|
13
|
+
export interface SendAndConfirmOptions {
|
|
14
|
+
/** Max time to wait for confirmation (ms). Default: 30_000 */
|
|
15
|
+
timeoutMs?: number;
|
|
16
|
+
/** Poll interval (ms). Default: 1_000 */
|
|
17
|
+
pollIntervalMs?: number;
|
|
18
|
+
/** Confirmation commitment. Default: "confirmed" */
|
|
19
|
+
commitment?: Commitment;
|
|
20
|
+
}
|
|
21
|
+
export declare class BlockhashCache {
|
|
22
|
+
private cached;
|
|
23
|
+
private fetchedAt;
|
|
24
|
+
private readonly ttlMs;
|
|
25
|
+
constructor(ttlMs?: number);
|
|
26
|
+
/**
|
|
27
|
+
* Get a blockhash, returning cached value if still within TTL.
|
|
28
|
+
*/
|
|
29
|
+
get(rpc: Rpc<SolanaRpcApi>): Promise<Blockhash>;
|
|
30
|
+
/**
|
|
31
|
+
* Force a fresh blockhash fetch regardless of TTL.
|
|
32
|
+
*/
|
|
33
|
+
invalidate(): void;
|
|
34
|
+
private refresh;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Sign a compiled transaction and encode to base64 wire format.
|
|
38
|
+
*
|
|
39
|
+
* Handles Kit's TransactionSigner interface which may expose
|
|
40
|
+
* `modifyAndSignTransactions` or `signTransactions` (both accept/return arrays).
|
|
41
|
+
*
|
|
42
|
+
* @returns Base64-encoded wire transaction ready for sendTransaction RPC.
|
|
43
|
+
*/
|
|
44
|
+
export declare function signAndEncode(signer: TransactionSigner, compiledTx: unknown): Promise<Base64EncodedWireTransaction>;
|
|
45
|
+
/**
|
|
46
|
+
* Send a base64-encoded transaction and poll for confirmation.
|
|
47
|
+
* Throws on timeout or confirmed failure.
|
|
48
|
+
*/
|
|
49
|
+
export declare function sendAndConfirmTransaction(rpc: Rpc<SolanaRpcApi>, encodedTransaction: Base64EncodedWireTransaction, options?: SendAndConfirmOptions): Promise<string>;
|
|
50
|
+
//# sourceMappingURL=rpc-helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc-helpers.d.ts","sourceRoot":"","sources":["../src/rpc-helpers.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,GAAG,EAAE,YAAY,EAAE,UAAU,EAAE,4BAA4B,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAWlH,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,oBAAoB,EAAE,MAAM,CAAC;CAC9B;AAED,MAAM,WAAW,qBAAqB;IACpC,8DAA8D;IAC9D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,yCAAyC;IACzC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,oDAAoD;IACpD,UAAU,CAAC,EAAE,UAAU,CAAC;CACzB;AAMD,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAA0B;IACxC,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAS;gBAEnB,KAAK,CAAC,EAAE,MAAM;IAI1B;;OAEG;IACG,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC;IAQrD;;OAEG;IACH,UAAU,IAAI,IAAI;YAKJ,OAAO;CAgBtB;AAID;;;;;;;GAOG;AACH,wBAAsB,aAAa,CACjC,MAAM,EAAE,iBAAiB,EACzB,UAAU,EAAE,OAAO,GAClB,OAAO,CAAC,4BAA4B,CAAC,CAmBvC;AAID;;;GAGG;AACH,wBAAsB,yBAAyB,CAC7C,GAAG,EAAE,GAAG,CAAC,YAAY,CAAC,EACtB,kBAAkB,EAAE,4BAA4B,EAChD,OAAO,CAAC,EAAE,qBAAqB,GAC9B,OAAO,CAAC,MAAM,CAAC,CAwDjB"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native RPC helpers for Sigil SDK.
|
|
3
|
+
*
|
|
4
|
+
* - BlockhashCache: Caches getLatestBlockhash with configurable TTL
|
|
5
|
+
* - signAndEncode: Sign a compiled TX + encode to base64 wire format
|
|
6
|
+
* - sendAndConfirmTransaction: Send + poll getSignatureStatuses
|
|
7
|
+
*/
|
|
8
|
+
import { getBase64EncodedWireTransaction } from "@solana/kit";
|
|
9
|
+
// ─── BlockhashCache ─────────────────────────────────────────────────────────
|
|
10
|
+
const DEFAULT_BLOCKHASH_TTL_MS = 30_000;
|
|
11
|
+
export class BlockhashCache {
|
|
12
|
+
cached = null;
|
|
13
|
+
fetchedAt = 0;
|
|
14
|
+
ttlMs;
|
|
15
|
+
constructor(ttlMs) {
|
|
16
|
+
this.ttlMs = ttlMs ?? DEFAULT_BLOCKHASH_TTL_MS;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Get a blockhash, returning cached value if still within TTL.
|
|
20
|
+
*/
|
|
21
|
+
async get(rpc) {
|
|
22
|
+
const now = Date.now();
|
|
23
|
+
if (this.cached && now - this.fetchedAt < this.ttlMs) {
|
|
24
|
+
return this.cached;
|
|
25
|
+
}
|
|
26
|
+
return this.refresh(rpc);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Force a fresh blockhash fetch regardless of TTL.
|
|
30
|
+
*/
|
|
31
|
+
invalidate() {
|
|
32
|
+
this.cached = null;
|
|
33
|
+
this.fetchedAt = 0;
|
|
34
|
+
}
|
|
35
|
+
async refresh(rpc) {
|
|
36
|
+
const result = await rpc
|
|
37
|
+
.getLatestBlockhash({ commitment: "confirmed" })
|
|
38
|
+
.send();
|
|
39
|
+
const value = result.value;
|
|
40
|
+
this.cached = {
|
|
41
|
+
blockhash: value.blockhash,
|
|
42
|
+
lastValidBlockHeight: value.lastValidBlockHeight,
|
|
43
|
+
};
|
|
44
|
+
this.fetchedAt = Date.now();
|
|
45
|
+
return this.cached;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
// ─── signAndEncode ───────────────────────────────────────────────────────────
|
|
49
|
+
/**
|
|
50
|
+
* Sign a compiled transaction and encode to base64 wire format.
|
|
51
|
+
*
|
|
52
|
+
* Handles Kit's TransactionSigner interface which may expose
|
|
53
|
+
* `modifyAndSignTransactions` or `signTransactions` (both accept/return arrays).
|
|
54
|
+
*
|
|
55
|
+
* @returns Base64-encoded wire transaction ready for sendTransaction RPC.
|
|
56
|
+
*/
|
|
57
|
+
export async function signAndEncode(signer, compiledTx) {
|
|
58
|
+
const signerTyped = signer;
|
|
59
|
+
const signFn = signerTyped.modifyAndSignTransactions ?? signerTyped.signTransactions;
|
|
60
|
+
if (typeof signFn !== "function") {
|
|
61
|
+
throw new Error("Signer must implement signTransactions() or modifyAndSignTransactions()");
|
|
62
|
+
}
|
|
63
|
+
const results = await signFn.call(signerTyped, [compiledTx]);
|
|
64
|
+
if (!Array.isArray(results) || results.length === 0) {
|
|
65
|
+
throw new Error("signTransactions returned invalid result: expected non-empty array");
|
|
66
|
+
}
|
|
67
|
+
const [signedTx] = results;
|
|
68
|
+
return getBase64EncodedWireTransaction(signedTx);
|
|
69
|
+
}
|
|
70
|
+
// ─── sendAndConfirmTransaction ──────────────────────────────────────────────
|
|
71
|
+
/**
|
|
72
|
+
* Send a base64-encoded transaction and poll for confirmation.
|
|
73
|
+
* Throws on timeout or confirmed failure.
|
|
74
|
+
*/
|
|
75
|
+
export async function sendAndConfirmTransaction(rpc, encodedTransaction, options) {
|
|
76
|
+
const timeoutMs = options?.timeoutMs ?? 30_000;
|
|
77
|
+
const pollIntervalMs = options?.pollIntervalMs ?? 1_000;
|
|
78
|
+
const commitment = options?.commitment ?? "confirmed";
|
|
79
|
+
// Send the transaction
|
|
80
|
+
const signature = await rpc
|
|
81
|
+
.sendTransaction(encodedTransaction, {
|
|
82
|
+
encoding: "base64",
|
|
83
|
+
skipPreflight: false,
|
|
84
|
+
preflightCommitment: commitment,
|
|
85
|
+
})
|
|
86
|
+
.send();
|
|
87
|
+
// Poll for confirmation
|
|
88
|
+
const deadline = Date.now() + timeoutMs;
|
|
89
|
+
let delay = pollIntervalMs;
|
|
90
|
+
while (Date.now() < deadline) {
|
|
91
|
+
const statusResult = await rpc
|
|
92
|
+
.getSignatureStatuses([signature])
|
|
93
|
+
.send();
|
|
94
|
+
const statuses = statusResult.value;
|
|
95
|
+
if (statuses && statuses[0]) {
|
|
96
|
+
const status = statuses[0];
|
|
97
|
+
// Check for error
|
|
98
|
+
if (status.err) {
|
|
99
|
+
throw new Error(`Transaction ${signature} failed: ${JSON.stringify(status.err)}`);
|
|
100
|
+
}
|
|
101
|
+
// Check for sufficient confirmation
|
|
102
|
+
const level = status.confirmationStatus;
|
|
103
|
+
if (level === "confirmed" ||
|
|
104
|
+
level === "finalized" ||
|
|
105
|
+
(commitment === "processed" && level === "processed")) {
|
|
106
|
+
return signature;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
// Exponential backoff: 1s → 1.5s → 2.25s → ...
|
|
110
|
+
await sleep(delay);
|
|
111
|
+
delay = Math.min(delay * (1.3 + Math.random() * 0.4), 5_000);
|
|
112
|
+
}
|
|
113
|
+
throw new Error(`Transaction ${signature} confirmation timed out after ${timeoutMs}ms`);
|
|
114
|
+
}
|
|
115
|
+
// ─── Helpers ────────────────────────────────────────────────────────────────
|
|
116
|
+
function sleep(ms) {
|
|
117
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=rpc-helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc-helpers.js","sourceRoot":"","sources":["../src/rpc-helpers.ts"],"names":[],"mappings":"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"}
|