@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
package/dist/presets.js
ADDED
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Vault creation presets — safe defaults for common use cases.
|
|
3
|
+
*
|
|
4
|
+
* Presets provide the policy/permission fields for CreateVaultOptions.
|
|
5
|
+
* Runtime fields (rpc, network, owner, agent, feeDestination, vaultId)
|
|
6
|
+
* are NOT included — the caller supplies those.
|
|
7
|
+
*
|
|
8
|
+
* Dashboard "Create Vault" wizard uses these as "Quick Setup" cards
|
|
9
|
+
* before the custom configuration step.
|
|
10
|
+
*/
|
|
11
|
+
import { FULL_PERMISSIONS, SWAP_ONLY, PERPS_FULL, PROTOCOL_MODE_ALL, PROTOCOL_MODE_ALLOWLIST, JUPITER_PROGRAM_ADDRESS, } from "./types.js";
|
|
12
|
+
// ─── Protocol Addresses ──────────────────────────────────────────────────────
|
|
13
|
+
const FLASH_TRADE_PROGRAM = "FLASH6Lo6h3iasJKWDs2F8TkW2UKf3s15C8PMGuVfgBn";
|
|
14
|
+
const JUPITER_LEND_PROGRAM = "JLend2fEim9xUFcaHsyGePEoBzFLvkjMi3MnPcSuCdu";
|
|
15
|
+
const KAMINO_LEND_PROGRAM = "KLend2g3cP87ber8CzRaqeECGwNvLFM9acPVcRkRHvM";
|
|
16
|
+
// ─── Permission Helpers ──────────────────────────────────────────────────────
|
|
17
|
+
/** Swap (0) + Deposit (5) + Withdraw (6) — lending use case */
|
|
18
|
+
const LENDING_PERMISSIONS = SWAP_ONLY | (1n << 5n) | (1n << 6n);
|
|
19
|
+
// ─── Presets ────────────────────────────────────────────────────────────────
|
|
20
|
+
export const VAULT_PRESETS = {
|
|
21
|
+
"jupiter-swap-bot": {
|
|
22
|
+
label: "Jupiter Swap Bot",
|
|
23
|
+
description: "Simple swap bot using Jupiter. Swap permission only, conservative caps.",
|
|
24
|
+
permissions: SWAP_ONLY,
|
|
25
|
+
dailySpendingCapUsd: 500000000n, // $500
|
|
26
|
+
maxTransactionSizeUsd: 100000000n, // $100
|
|
27
|
+
maxSlippageBps: 200, // 2%
|
|
28
|
+
protocolMode: PROTOCOL_MODE_ALLOWLIST,
|
|
29
|
+
protocols: [JUPITER_PROGRAM_ADDRESS],
|
|
30
|
+
maxLeverageBps: 0,
|
|
31
|
+
maxConcurrentPositions: 0,
|
|
32
|
+
},
|
|
33
|
+
"perps-trader": {
|
|
34
|
+
label: "Perps Trader",
|
|
35
|
+
description: "Leveraged trading on Flash Trade and Jupiter. Full order management with position limits.",
|
|
36
|
+
permissions: PERPS_FULL | SWAP_ONLY,
|
|
37
|
+
dailySpendingCapUsd: 5000000000n, // $5,000
|
|
38
|
+
maxTransactionSizeUsd: 1000000000n, // $1,000
|
|
39
|
+
maxSlippageBps: 500, // 5%
|
|
40
|
+
protocolMode: PROTOCOL_MODE_ALLOWLIST,
|
|
41
|
+
protocols: [JUPITER_PROGRAM_ADDRESS, FLASH_TRADE_PROGRAM],
|
|
42
|
+
maxLeverageBps: 10_000, // 10x
|
|
43
|
+
maxConcurrentPositions: 5,
|
|
44
|
+
},
|
|
45
|
+
"lending-optimizer": {
|
|
46
|
+
label: "Lending Optimizer",
|
|
47
|
+
description: "Deposit and withdraw across lending protocols. Low slippage, moderate caps.",
|
|
48
|
+
permissions: LENDING_PERMISSIONS,
|
|
49
|
+
dailySpendingCapUsd: 2000000000n, // $2,000
|
|
50
|
+
maxTransactionSizeUsd: 500000000n, // $500
|
|
51
|
+
maxSlippageBps: 100, // 1%
|
|
52
|
+
protocolMode: PROTOCOL_MODE_ALLOWLIST,
|
|
53
|
+
protocols: [JUPITER_PROGRAM_ADDRESS, JUPITER_LEND_PROGRAM, KAMINO_LEND_PROGRAM],
|
|
54
|
+
maxLeverageBps: 0,
|
|
55
|
+
maxConcurrentPositions: 0,
|
|
56
|
+
},
|
|
57
|
+
"full-access": {
|
|
58
|
+
label: "Full Access",
|
|
59
|
+
description: "All permissions enabled, all protocols allowed. For experienced users who need maximum flexibility.",
|
|
60
|
+
permissions: FULL_PERMISSIONS,
|
|
61
|
+
dailySpendingCapUsd: 10000000000n, // $10,000
|
|
62
|
+
maxTransactionSizeUsd: 5000000000n, // $5,000
|
|
63
|
+
maxSlippageBps: 500, // 5%
|
|
64
|
+
protocolMode: PROTOCOL_MODE_ALL,
|
|
65
|
+
protocols: [],
|
|
66
|
+
maxLeverageBps: 20_000, // 20x
|
|
67
|
+
maxConcurrentPositions: 10,
|
|
68
|
+
},
|
|
69
|
+
};
|
|
70
|
+
// ─── Functions ──────────────────────────────────────────────────────────────
|
|
71
|
+
/**
|
|
72
|
+
* Get a vault preset by name.
|
|
73
|
+
* @returns The preset, or undefined if name is not recognized.
|
|
74
|
+
*/
|
|
75
|
+
export function getPreset(name) {
|
|
76
|
+
if (!Object.prototype.hasOwnProperty.call(VAULT_PRESETS, name))
|
|
77
|
+
return undefined;
|
|
78
|
+
return VAULT_PRESETS[name];
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* List all available preset names.
|
|
82
|
+
*/
|
|
83
|
+
export function listPresets() {
|
|
84
|
+
return Object.keys(VAULT_PRESETS);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Convert a preset into CreateVaultOptions fields (without runtime fields).
|
|
88
|
+
* Merge with your own rpc, network, owner, agent to get a complete CreateVaultOptions.
|
|
89
|
+
*
|
|
90
|
+
* @example
|
|
91
|
+
* ```typescript
|
|
92
|
+
* const preset = presetToCreateVaultFields("jupiter-swap-bot");
|
|
93
|
+
* const opts: CreateVaultOptions = { rpc, network: "devnet", owner, agent, ...preset };
|
|
94
|
+
* const result = await createVault(opts);
|
|
95
|
+
* ```
|
|
96
|
+
*/
|
|
97
|
+
export function presetToCreateVaultFields(name) {
|
|
98
|
+
const preset = VAULT_PRESETS[name];
|
|
99
|
+
return {
|
|
100
|
+
permissions: preset.permissions,
|
|
101
|
+
dailySpendingCapUsd: preset.dailySpendingCapUsd,
|
|
102
|
+
maxTransactionSizeUsd: preset.maxTransactionSizeUsd,
|
|
103
|
+
maxSlippageBps: preset.maxSlippageBps,
|
|
104
|
+
protocolMode: preset.protocolMode,
|
|
105
|
+
protocols: [...preset.protocols],
|
|
106
|
+
maxLeverageBps: preset.maxLeverageBps,
|
|
107
|
+
maxConcurrentPositions: preset.maxConcurrentPositions,
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=presets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presets.js","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native CU estimation + priority fee estimation.
|
|
3
|
+
*
|
|
4
|
+
* CU constants match the existing SDK values (measured via LiteSVM).
|
|
5
|
+
* 3-layer fallback: Helius → Kit RPC → static.
|
|
6
|
+
*/
|
|
7
|
+
import type { Instruction, Rpc, SolanaRpcApi } from "@solana/kit";
|
|
8
|
+
export declare const CU_AGENT_TRANSFER = 200000;
|
|
9
|
+
export declare const CU_JUPITER_SWAP = 600000;
|
|
10
|
+
export declare const CU_JUPITER_MULTI_HOP = 900000;
|
|
11
|
+
export declare const CU_FLASH_TRADE = 800000;
|
|
12
|
+
export declare const CU_JUPITER_LEND = 400000;
|
|
13
|
+
export declare const CU_DRIFT = 800000;
|
|
14
|
+
export declare const CU_KAMINO_LEND = 400000;
|
|
15
|
+
export declare const CU_DEFAULT_COMPOSED = 800000;
|
|
16
|
+
export declare const CU_VAULT_CREATION = 400000;
|
|
17
|
+
export declare const CU_OWNER_ACTION = 200000;
|
|
18
|
+
/**
|
|
19
|
+
* Detect CU budget based on the DeFi instructions in a composed transaction.
|
|
20
|
+
* Uses `programAddress` (Kit convention, not `programId`).
|
|
21
|
+
*/
|
|
22
|
+
export declare function estimateComposedCU(defiInstructions: Instruction[]): number;
|
|
23
|
+
export type PriorityLevel = "low" | "medium" | "high" | "very_high";
|
|
24
|
+
export interface PriorityFeeConfig {
|
|
25
|
+
strategy?: "auto" | "helius" | "rpc" | "static";
|
|
26
|
+
cacheTtlMs?: number;
|
|
27
|
+
fallbackMicroLamports?: number;
|
|
28
|
+
defaultLevel?: PriorityLevel;
|
|
29
|
+
maxMicroLamports?: number;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Priority fee estimator with 3-layer fallback and caching.
|
|
33
|
+
*
|
|
34
|
+
* Layer 1: Helius getPriorityFeeEstimate (auto-detected from URL)
|
|
35
|
+
* Layer 2: Kit RPC getRecentPrioritizationFees + percentile
|
|
36
|
+
* Layer 3: Static fallback
|
|
37
|
+
*/
|
|
38
|
+
export declare class PriorityFeeEstimator {
|
|
39
|
+
private readonly rpcEndpoint;
|
|
40
|
+
private readonly rpc;
|
|
41
|
+
private readonly config;
|
|
42
|
+
private readonly cache;
|
|
43
|
+
private readonly isHelius;
|
|
44
|
+
constructor(rpcEndpoint: string, rpc: Rpc<SolanaRpcApi> | null, config?: PriorityFeeConfig);
|
|
45
|
+
estimate(level?: PriorityLevel): Promise<number>;
|
|
46
|
+
private estimateHelius;
|
|
47
|
+
private estimateRpc;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=priority-fees.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"priority-fees.d.ts","sourceRoot":"","sources":["../src/priority-fees.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,GAAG,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAYlE,eAAO,MAAM,iBAAiB,SAAU,CAAC;AACzC,eAAO,MAAM,eAAe,SAAU,CAAC;AACvC,eAAO,MAAM,oBAAoB,SAAU,CAAC;AAC5C,eAAO,MAAM,cAAc,SAAU,CAAC;AACtC,eAAO,MAAM,eAAe,SAAU,CAAC;AACvC,eAAO,MAAM,QAAQ,SAAU,CAAC;AAChC,eAAO,MAAM,cAAc,SAAU,CAAC;AACtC,eAAO,MAAM,mBAAmB,SAAU,CAAC;AAC3C,eAAO,MAAM,iBAAiB,SAAU,CAAC;AACzC,eAAO,MAAM,eAAe,SAAU,CAAC;AAEvC;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,gBAAgB,EAAE,WAAW,EAAE,GAAG,MAAM,CA2B1E;AAID,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,WAAW,CAAC;AAEpE,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,KAAK,GAAG,QAAQ,CAAC;IAChD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,YAAY,CAAC,EAAE,aAAa,CAAC;IAC7B,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAqBD;;;;;;GAMG;AACH,qBAAa,oBAAoB;IAM7B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,GAAG;IANtB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA8B;IACrD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAwC;IAC9D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAU;gBAGhB,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,GAAG,CAAC,YAAY,CAAC,GAAG,IAAI,EAC9C,MAAM,CAAC,EAAE,iBAAiB;IAiBtB,QAAQ,CAAC,KAAK,CAAC,EAAE,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC;YAmCxC,cAAc;YAqCd,WAAW;CAyB1B"}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native CU estimation + priority fee estimation.
|
|
3
|
+
*
|
|
4
|
+
* CU constants match the existing SDK values (measured via LiteSVM).
|
|
5
|
+
* 3-layer fallback: Helius → Kit RPC → static.
|
|
6
|
+
*/
|
|
7
|
+
// ─── Known Protocol Program Addresses ────────────────────────────────────────
|
|
8
|
+
const JUPITER_PROGRAM = "JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4";
|
|
9
|
+
const JUPITER_LEND_PROGRAM = "JLend2fEim9xUFcaHsyGePEoBzFLvkjMi3MnPcSuCdu";
|
|
10
|
+
const FLASH_TRADE_PROGRAM = "FLASH6Lo6h3iasJKWDs2F8TkW2UKf3s15C8PMGuVfgBn";
|
|
11
|
+
const DRIFT_PROGRAM = "dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH";
|
|
12
|
+
const KAMINO_LEND_PROGRAM = "KLend2g3cP87ber8CzRaqeECGwNvLFM9acPVcRkRHvM";
|
|
13
|
+
// ─── CU Budget Defaults ─────────────────────────────────────────────────────
|
|
14
|
+
export const CU_AGENT_TRANSFER = 200_000;
|
|
15
|
+
export const CU_JUPITER_SWAP = 600_000;
|
|
16
|
+
export const CU_JUPITER_MULTI_HOP = 900_000;
|
|
17
|
+
export const CU_FLASH_TRADE = 800_000;
|
|
18
|
+
export const CU_JUPITER_LEND = 400_000;
|
|
19
|
+
export const CU_DRIFT = 800_000;
|
|
20
|
+
export const CU_KAMINO_LEND = 400_000;
|
|
21
|
+
export const CU_DEFAULT_COMPOSED = 800_000;
|
|
22
|
+
export const CU_VAULT_CREATION = 400_000;
|
|
23
|
+
export const CU_OWNER_ACTION = 200_000;
|
|
24
|
+
/**
|
|
25
|
+
* Detect CU budget based on the DeFi instructions in a composed transaction.
|
|
26
|
+
* Uses `programAddress` (Kit convention, not `programId`).
|
|
27
|
+
*/
|
|
28
|
+
export function estimateComposedCU(defiInstructions) {
|
|
29
|
+
if (defiInstructions.length === 0)
|
|
30
|
+
return CU_AGENT_TRANSFER;
|
|
31
|
+
const programAddresses = defiInstructions.map((ix) => ix.programAddress);
|
|
32
|
+
const hasJupiter = programAddresses.some((id) => id === JUPITER_PROGRAM);
|
|
33
|
+
const hasJupiterLend = programAddresses.some((id) => id === JUPITER_LEND_PROGRAM);
|
|
34
|
+
const hasFlashTrade = programAddresses.some((id) => id === FLASH_TRADE_PROGRAM);
|
|
35
|
+
const hasDrift = programAddresses.some((id) => id === DRIFT_PROGRAM);
|
|
36
|
+
const hasKaminoLend = programAddresses.some((id) => id === KAMINO_LEND_PROGRAM);
|
|
37
|
+
if (hasJupiter && defiInstructions.length > 2)
|
|
38
|
+
return CU_JUPITER_MULTI_HOP;
|
|
39
|
+
if (hasJupiter)
|
|
40
|
+
return CU_JUPITER_SWAP;
|
|
41
|
+
if (hasJupiterLend)
|
|
42
|
+
return CU_JUPITER_LEND;
|
|
43
|
+
if (hasFlashTrade)
|
|
44
|
+
return CU_FLASH_TRADE;
|
|
45
|
+
if (hasDrift)
|
|
46
|
+
return CU_DRIFT;
|
|
47
|
+
if (hasKaminoLend)
|
|
48
|
+
return CU_KAMINO_LEND;
|
|
49
|
+
return CU_DEFAULT_COMPOSED;
|
|
50
|
+
}
|
|
51
|
+
const LEVEL_PERCENTILES = {
|
|
52
|
+
low: 25,
|
|
53
|
+
medium: 50,
|
|
54
|
+
high: 75,
|
|
55
|
+
very_high: 95,
|
|
56
|
+
};
|
|
57
|
+
const HELIUS_LEVELS = {
|
|
58
|
+
low: "Low",
|
|
59
|
+
medium: "Medium",
|
|
60
|
+
high: "High",
|
|
61
|
+
very_high: "VeryHigh",
|
|
62
|
+
};
|
|
63
|
+
/**
|
|
64
|
+
* Priority fee estimator with 3-layer fallback and caching.
|
|
65
|
+
*
|
|
66
|
+
* Layer 1: Helius getPriorityFeeEstimate (auto-detected from URL)
|
|
67
|
+
* Layer 2: Kit RPC getRecentPrioritizationFees + percentile
|
|
68
|
+
* Layer 3: Static fallback
|
|
69
|
+
*/
|
|
70
|
+
export class PriorityFeeEstimator {
|
|
71
|
+
rpcEndpoint;
|
|
72
|
+
rpc;
|
|
73
|
+
config;
|
|
74
|
+
cache = new Map();
|
|
75
|
+
isHelius;
|
|
76
|
+
constructor(rpcEndpoint, rpc, config) {
|
|
77
|
+
this.rpcEndpoint = rpcEndpoint;
|
|
78
|
+
this.rpc = rpc;
|
|
79
|
+
this.config = {
|
|
80
|
+
strategy: config?.strategy ?? "auto",
|
|
81
|
+
cacheTtlMs: config?.cacheTtlMs ?? 10_000,
|
|
82
|
+
fallbackMicroLamports: config?.fallbackMicroLamports ?? 10_000,
|
|
83
|
+
defaultLevel: config?.defaultLevel ?? "high",
|
|
84
|
+
maxMicroLamports: config?.maxMicroLamports ?? 1_000_000,
|
|
85
|
+
};
|
|
86
|
+
if (this.config.strategy === "auto") {
|
|
87
|
+
this.isHelius = /helius/i.test(this.rpcEndpoint);
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
this.isHelius = this.config.strategy === "helius";
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
async estimate(level) {
|
|
94
|
+
const targetLevel = level ?? this.config.defaultLevel;
|
|
95
|
+
const cached = this.cache.get(targetLevel);
|
|
96
|
+
if (cached && cached.expiresAt > Date.now()) {
|
|
97
|
+
return cached.microLamports;
|
|
98
|
+
}
|
|
99
|
+
let fee = null;
|
|
100
|
+
// Layer 1: Helius
|
|
101
|
+
if (this.isHelius) {
|
|
102
|
+
fee = await this.estimateHelius(targetLevel);
|
|
103
|
+
}
|
|
104
|
+
// Layer 2: Standard RPC
|
|
105
|
+
if (fee === null && this.rpc) {
|
|
106
|
+
fee = await this.estimateRpc(targetLevel);
|
|
107
|
+
}
|
|
108
|
+
// Layer 3: Static
|
|
109
|
+
if (fee === null) {
|
|
110
|
+
fee = this.config.fallbackMicroLamports;
|
|
111
|
+
}
|
|
112
|
+
fee = Math.min(fee, this.config.maxMicroLamports);
|
|
113
|
+
this.cache.set(targetLevel, {
|
|
114
|
+
microLamports: fee,
|
|
115
|
+
expiresAt: Date.now() + this.config.cacheTtlMs,
|
|
116
|
+
});
|
|
117
|
+
return fee;
|
|
118
|
+
}
|
|
119
|
+
async estimateHelius(level) {
|
|
120
|
+
try {
|
|
121
|
+
const body = {
|
|
122
|
+
jsonrpc: "2.0",
|
|
123
|
+
id: "sigil-fee-estimate",
|
|
124
|
+
method: "getPriorityFeeEstimate",
|
|
125
|
+
params: [
|
|
126
|
+
{
|
|
127
|
+
options: {
|
|
128
|
+
recommended: true,
|
|
129
|
+
priorityLevel: HELIUS_LEVELS[level],
|
|
130
|
+
},
|
|
131
|
+
},
|
|
132
|
+
],
|
|
133
|
+
};
|
|
134
|
+
const response = await fetch(this.rpcEndpoint, {
|
|
135
|
+
method: "POST",
|
|
136
|
+
headers: { "Content-Type": "application/json" },
|
|
137
|
+
body: JSON.stringify(body),
|
|
138
|
+
signal: AbortSignal.timeout(5_000),
|
|
139
|
+
});
|
|
140
|
+
if (!response.ok)
|
|
141
|
+
return null;
|
|
142
|
+
const json = (await response.json());
|
|
143
|
+
const estimate = json?.result?.priorityFeeEstimate;
|
|
144
|
+
if (typeof estimate === "number" && estimate >= 0) {
|
|
145
|
+
return Math.ceil(estimate);
|
|
146
|
+
}
|
|
147
|
+
return null;
|
|
148
|
+
}
|
|
149
|
+
catch {
|
|
150
|
+
return null;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
async estimateRpc(level) {
|
|
154
|
+
try {
|
|
155
|
+
if (!this.rpc)
|
|
156
|
+
return null;
|
|
157
|
+
const fees = await this.rpc.getRecentPrioritizationFees().send();
|
|
158
|
+
if (!fees || fees.length === 0)
|
|
159
|
+
return null;
|
|
160
|
+
const sorted = fees
|
|
161
|
+
.map((f) => Number(f.prioritizationFee))
|
|
162
|
+
.filter((f) => f > 0)
|
|
163
|
+
.sort((a, b) => a - b);
|
|
164
|
+
if (sorted.length === 0)
|
|
165
|
+
return this.config.fallbackMicroLamports;
|
|
166
|
+
const percentile = LEVEL_PERCENTILES[level];
|
|
167
|
+
const index = Math.min(Math.ceil((percentile / 100) * sorted.length) - 1, sorted.length - 1);
|
|
168
|
+
return sorted[index];
|
|
169
|
+
}
|
|
170
|
+
catch {
|
|
171
|
+
return null;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
//# sourceMappingURL=priority-fees.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"priority-fees.js","sourceRoot":"","sources":["../src/priority-fees.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Protocol analytics — per-protocol spending breakdown and cross-vault usage.
|
|
3
|
+
*
|
|
4
|
+
* getProtocolBreakdown(): Pure function — donut chart data for spending by protocol.
|
|
5
|
+
* getProtocolUsageAcrossVaults(): Async — aggregated protocol usage across all vaults.
|
|
6
|
+
*/
|
|
7
|
+
import type { Address, Rpc, SolanaRpcApi } from "@solana/kit";
|
|
8
|
+
import type { ResolvedVaultState } from "./state-resolver.js";
|
|
9
|
+
import type { Network } from "./types.js";
|
|
10
|
+
export interface ProtocolBreakdownItem {
|
|
11
|
+
protocol: Address;
|
|
12
|
+
protocolName: string;
|
|
13
|
+
spent24h: bigint;
|
|
14
|
+
cap: bigint | null;
|
|
15
|
+
utilization: number;
|
|
16
|
+
/** This protocol's share of total vault spending (0-100%) */
|
|
17
|
+
percentOfTotalSpend: number;
|
|
18
|
+
}
|
|
19
|
+
export interface PlatformProtocolUsage {
|
|
20
|
+
protocol: Address;
|
|
21
|
+
protocolName: string;
|
|
22
|
+
vaultCount: number;
|
|
23
|
+
totalSpend24h: bigint;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Per-protocol spending breakdown for a single vault.
|
|
27
|
+
* Used for the Spending tab donut chart.
|
|
28
|
+
*/
|
|
29
|
+
export declare function getProtocolBreakdown(state: ResolvedVaultState): ProtocolBreakdownItem[];
|
|
30
|
+
/**
|
|
31
|
+
* Protocol usage across all of an owner's vaults.
|
|
32
|
+
* Parallel RPC — N vaults resolved concurrently.
|
|
33
|
+
*/
|
|
34
|
+
export declare function getProtocolUsageAcrossVaults(rpc: Rpc<SolanaRpcApi>, owner: Address, network?: Network): Promise<PlatformProtocolUsage[]>;
|
|
35
|
+
//# sourceMappingURL=protocol-analytics.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol-analytics.d.ts","sourceRoot":"","sources":["../src/protocol-analytics.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAG9D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAI1C,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,OAAO,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;IACjB,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,6DAA6D;IAC7D,mBAAmB,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,OAAO,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;CACvB;AAID;;;GAGG;AACH,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,kBAAkB,GACxB,qBAAqB,EAAE,CAgBzB;AAID;;;GAGG;AACH,wBAAsB,4BAA4B,CAChD,GAAG,EAAE,GAAG,CAAC,YAAY,CAAC,EACtB,KAAK,EAAE,OAAO,EACd,OAAO,GAAE,OAAwB,GAChC,OAAO,CAAC,qBAAqB,EAAE,CAAC,CA6ClC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Protocol analytics — per-protocol spending breakdown and cross-vault usage.
|
|
3
|
+
*
|
|
4
|
+
* getProtocolBreakdown(): Pure function — donut chart data for spending by protocol.
|
|
5
|
+
* getProtocolUsageAcrossVaults(): Async — aggregated protocol usage across all vaults.
|
|
6
|
+
*/
|
|
7
|
+
import { findVaultsByOwner, resolveVaultStateForOwner } from "./state-resolver.js";
|
|
8
|
+
import { resolveProtocolName } from "./protocol-names.js";
|
|
9
|
+
// ─── getProtocolBreakdown ────────────────────────────────────────────────────
|
|
10
|
+
/**
|
|
11
|
+
* Per-protocol spending breakdown for a single vault.
|
|
12
|
+
* Used for the Spending tab donut chart.
|
|
13
|
+
*/
|
|
14
|
+
export function getProtocolBreakdown(state) {
|
|
15
|
+
const { protocolBudgets, globalBudget } = state;
|
|
16
|
+
const totalSpend = globalBudget.spent24h;
|
|
17
|
+
return protocolBudgets.map((pb) => ({
|
|
18
|
+
protocol: pb.protocol,
|
|
19
|
+
protocolName: resolveProtocolName(pb.protocol),
|
|
20
|
+
spent24h: pb.spent24h,
|
|
21
|
+
cap: pb.cap > 0n ? pb.cap : null,
|
|
22
|
+
utilization: pb.cap > 0n ? Number((pb.spent24h * 10000n) / pb.cap) / 100 : 0,
|
|
23
|
+
percentOfTotalSpend: totalSpend > 0n
|
|
24
|
+
? Number((pb.spent24h * 10000n) / totalSpend) / 100
|
|
25
|
+
: 0,
|
|
26
|
+
}));
|
|
27
|
+
}
|
|
28
|
+
// ─── getProtocolUsageAcrossVaults ────────────────────────────────────────────
|
|
29
|
+
/**
|
|
30
|
+
* Protocol usage across all of an owner's vaults.
|
|
31
|
+
* Parallel RPC — N vaults resolved concurrently.
|
|
32
|
+
*/
|
|
33
|
+
export async function getProtocolUsageAcrossVaults(rpc, owner, network = "mainnet-beta") {
|
|
34
|
+
const discovered = await findVaultsByOwner(rpc, owner);
|
|
35
|
+
// Use allSettled so one failed vault doesn't kill the entire query
|
|
36
|
+
const results = await Promise.allSettled(discovered.map((v) => resolveVaultStateForOwner(rpc, v.vaultAddress, undefined, network)));
|
|
37
|
+
const states = results
|
|
38
|
+
.filter((r) => r.status === "fulfilled")
|
|
39
|
+
.map((r) => r.value);
|
|
40
|
+
const protocolMap = new Map();
|
|
41
|
+
for (const state of states) {
|
|
42
|
+
for (const pb of state.protocolBudgets) {
|
|
43
|
+
const existing = protocolMap.get(pb.protocol) ?? {
|
|
44
|
+
vaultCount: 0,
|
|
45
|
+
totalSpend: 0n,
|
|
46
|
+
};
|
|
47
|
+
existing.vaultCount++;
|
|
48
|
+
existing.totalSpend += pb.spent24h;
|
|
49
|
+
protocolMap.set(pb.protocol, existing);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
const usage = [];
|
|
53
|
+
for (const [protocol, data] of protocolMap) {
|
|
54
|
+
usage.push({
|
|
55
|
+
protocol: protocol,
|
|
56
|
+
protocolName: resolveProtocolName(protocol),
|
|
57
|
+
vaultCount: data.vaultCount,
|
|
58
|
+
totalSpend24h: data.totalSpend,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
usage.sort((a, b) => b.totalSpend24h > a.totalSpend24h ? 1 : b.totalSpend24h < a.totalSpend24h ? -1 : 0);
|
|
62
|
+
return usage;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=protocol-analytics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol-analytics.js","sourceRoot":"","sources":["../src/protocol-analytics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared protocol name resolution — used by event-analytics and spending-analytics.
|
|
3
|
+
*
|
|
4
|
+
* Extracted per ANALYTICS-IMPLEMENTATION-GUIDE-PT2 Bug #6 recommendation
|
|
5
|
+
* to avoid duplicate maps that drift independently.
|
|
6
|
+
*/
|
|
7
|
+
export declare const PROTOCOL_NAMES: Record<string, string>;
|
|
8
|
+
export declare function resolveProtocolName(protocol: string): string;
|
|
9
|
+
//# sourceMappingURL=protocol-names.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol-names.d.ts","sourceRoot":"","sources":["../src/protocol-names.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,eAAO,MAAM,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAMjD,CAAC;AAEF,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAE5D"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared protocol name resolution — used by event-analytics and spending-analytics.
|
|
3
|
+
*
|
|
4
|
+
* Extracted per ANALYTICS-IMPLEMENTATION-GUIDE-PT2 Bug #6 recommendation
|
|
5
|
+
* to avoid duplicate maps that drift independently.
|
|
6
|
+
*/
|
|
7
|
+
import { formatAddress } from "./formatting.js";
|
|
8
|
+
export const PROTOCOL_NAMES = {
|
|
9
|
+
JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4: "Jupiter",
|
|
10
|
+
FLASH6Lo6h3iasJKWDs2F8TkW2UKf3s15C8PMGuVfgBn: "Flash Trade",
|
|
11
|
+
dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH: "Drift",
|
|
12
|
+
KLend2g3cP87ber8CzRaqeECGwNvLFM9acPVcRkRHvM: "Kamino",
|
|
13
|
+
JLend2fEim9xUFcaHsyGePEoBzFLvkjMi3MnPcSuCdu: "Jupiter Lend",
|
|
14
|
+
};
|
|
15
|
+
export function resolveProtocolName(protocol) {
|
|
16
|
+
return PROTOCOL_NAMES[protocol] ?? formatAddress(protocol);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=protocol-names.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol-names.js","sourceRoot":"","sources":["../src/protocol-names.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD,MAAM,CAAC,MAAM,cAAc,GAA2B;IACpD,2CAA2C,EAAE,SAAS;IACtD,4CAA4C,EAAE,aAAa;IAC3D,2CAA2C,EAAE,OAAO;IACpD,2CAA2C,EAAE,QAAQ;IACrD,2CAA2C,EAAE,cAAc;CAC5D,CAAC;AAEF,MAAM,UAAU,mBAAmB,CAAC,QAAgB;IAClD,OAAO,cAAc,CAAC,QAAQ,CAAC,IAAI,aAAa,CAAC,QAAQ,CAAC,CAAC;AAC7D,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
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 type { Address } from "@solana/kit";
|
|
10
|
+
export declare enum ProtocolTier {
|
|
11
|
+
KNOWN = 1,
|
|
12
|
+
DEFAULT = 2,
|
|
13
|
+
NOT_ALLOWED = 3
|
|
14
|
+
}
|
|
15
|
+
export interface ProtocolResolution {
|
|
16
|
+
tier: ProtocolTier;
|
|
17
|
+
protocolId: string;
|
|
18
|
+
programId: Address;
|
|
19
|
+
displayName: string;
|
|
20
|
+
reason: string;
|
|
21
|
+
constraintsConfigured?: boolean;
|
|
22
|
+
escalation?: EscalationInfo;
|
|
23
|
+
}
|
|
24
|
+
export interface EscalationInfo {
|
|
25
|
+
type: "not_in_allowlist" | "no_handler_no_constraints" | "no_handler_has_constraints" | "not_in_allowlist_and_no_handler";
|
|
26
|
+
message: string;
|
|
27
|
+
requiredActions: string[];
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Check if a program is in the vault's protocol allowlist/denylist.
|
|
31
|
+
*
|
|
32
|
+
* @param programId - Program address to check
|
|
33
|
+
* @param policy - Vault policy with protocolMode and protocols list
|
|
34
|
+
* @returns true if the program is allowed by the policy
|
|
35
|
+
*/
|
|
36
|
+
export declare function isProtocolAllowed(programId: Address, policy: {
|
|
37
|
+
protocolMode: number;
|
|
38
|
+
protocols: Address[];
|
|
39
|
+
}): boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Resolve the tier and escalation info for a given protocol.
|
|
42
|
+
*
|
|
43
|
+
* Resolution logic:
|
|
44
|
+
* 1. Known program + in allowlist -> KNOWN
|
|
45
|
+
* 2. Known program + NOT in allowlist -> NOT_ALLOWED
|
|
46
|
+
* 3. Unknown program + in allowlist + constraints -> DEFAULT (passthrough)
|
|
47
|
+
* 4. Unknown program + in allowlist + NO constraints -> NOT_ALLOWED (escalation)
|
|
48
|
+
* 5. Unknown program + NOT in allowlist -> NOT_ALLOWED (escalation)
|
|
49
|
+
*/
|
|
50
|
+
export declare function resolveProtocol(programId: Address, policy: {
|
|
51
|
+
protocolMode: number;
|
|
52
|
+
protocols: Address[];
|
|
53
|
+
}, constraintsConfigured: boolean): ProtocolResolution;
|
|
54
|
+
//# sourceMappingURL=protocol-resolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol-resolver.d.ts","sourceRoot":"","sources":["../src/protocol-resolver.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAO3C,oBAAY,YAAY;IACtB,KAAK,IAAI;IACT,OAAO,IAAI;IACX,WAAW,IAAI;CAChB;AAED,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,YAAY,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,UAAU,CAAC,EAAE,cAAc,CAAC;CAC7B;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EACA,kBAAkB,GAClB,2BAA2B,GAC3B,4BAA4B,GAC5B,iCAAiC,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,MAAM,EAAE,CAAC;CAC3B;AAMD;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAC/B,SAAS,EAAE,OAAO,EAClB,MAAM,EAAE;IAAE,YAAY,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,OAAO,EAAE,CAAA;CAAE,GACrD,OAAO,CAKT;AAED;;;;;;;;;GASG;AACH,wBAAgB,eAAe,CAC7B,SAAS,EAAE,OAAO,EAClB,MAAM,EAAE;IAAE,YAAY,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,OAAO,EAAE,CAAA;CAAE,EACtD,qBAAqB,EAAE,OAAO,GAC7B,kBAAkB,CAkFpB"}
|