@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,181 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Balance tracking and P&L computation for Sigil vaults.
|
|
3
|
+
*
|
|
4
|
+
* Two complementary approaches:
|
|
5
|
+
* - `getVaultPnL()`: Lifetime P&L from on-chain cumulative counters (single RPC call)
|
|
6
|
+
* - `BalanceSnapshotStore` + `getBalancePnL()`: Session-scoped P&L from balance snapshots (for charts)
|
|
7
|
+
*/
|
|
8
|
+
import { isStablecoinMint } from "./types.js";
|
|
9
|
+
import { resolveVaultStateForOwner } from "./state-resolver.js";
|
|
10
|
+
import { resolveToken } from "./tokens.js";
|
|
11
|
+
// ─── On-chain P&L (lifetime) ────────────────────────────────────────────────
|
|
12
|
+
/**
|
|
13
|
+
* Compute lifetime P&L for a vault from on-chain cumulative counters.
|
|
14
|
+
* Single RPC call via resolveVaultStateForOwner. O(1) — no event parsing needed.
|
|
15
|
+
*
|
|
16
|
+
* P&L = current_stablecoin_balance - (total_deposited_usd - total_withdrawn_usd)
|
|
17
|
+
*/
|
|
18
|
+
export async function getVaultPnL(rpc, vault, network = "mainnet-beta") {
|
|
19
|
+
const state = await resolveVaultStateForOwner(rpc, vault, undefined, network);
|
|
20
|
+
const totalDeposited = state.vault.totalDepositedUsd;
|
|
21
|
+
const totalWithdrawn = state.vault.totalWithdrawnUsd;
|
|
22
|
+
const currentBalance = state.stablecoinBalances.usdc + state.stablecoinBalances.usdt;
|
|
23
|
+
const netInvestment = totalDeposited - totalWithdrawn;
|
|
24
|
+
const pnl = currentBalance - netInvestment;
|
|
25
|
+
const pnlPercent = netInvestment > 0n
|
|
26
|
+
? Number((pnl * 10000n) / netInvestment) / 100
|
|
27
|
+
: 0;
|
|
28
|
+
return {
|
|
29
|
+
totalDeposited,
|
|
30
|
+
totalWithdrawn,
|
|
31
|
+
currentBalance,
|
|
32
|
+
netInvestment,
|
|
33
|
+
pnl,
|
|
34
|
+
pnlPercent,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
// ─── Token balance query ────────────────────────────────────────────────────
|
|
38
|
+
const TOKEN_PROGRAM_ADDRESS = "TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA";
|
|
39
|
+
/**
|
|
40
|
+
* Fetch all SPL token balances for a vault PDA.
|
|
41
|
+
* Uses getTokenAccountsByOwner with jsonParsed encoding.
|
|
42
|
+
* Excludes zero-balance accounts. Resolves well-known symbols.
|
|
43
|
+
*/
|
|
44
|
+
export async function getVaultTokenBalances(rpc, vault, network = "mainnet-beta") {
|
|
45
|
+
const response = await rpc
|
|
46
|
+
.getTokenAccountsByOwner(vault, { programId: TOKEN_PROGRAM_ADDRESS }, { encoding: "jsonParsed" })
|
|
47
|
+
.send();
|
|
48
|
+
const balances = [];
|
|
49
|
+
for (const item of response.value) {
|
|
50
|
+
const data = item.account.data;
|
|
51
|
+
if (!data?.parsed?.info?.tokenAmount)
|
|
52
|
+
continue;
|
|
53
|
+
const info = data.parsed.info;
|
|
54
|
+
const mint = info.mint;
|
|
55
|
+
const amount = BigInt(info.tokenAmount.amount);
|
|
56
|
+
if (amount === 0n)
|
|
57
|
+
continue;
|
|
58
|
+
const resolved = resolveToken(mint, network);
|
|
59
|
+
const symbol = resolved ? resolved.symbol : mint.slice(0, 4) + "...";
|
|
60
|
+
const decimals = resolved ? resolved.decimals : info.tokenAmount.decimals;
|
|
61
|
+
balances.push({ mint, balance: amount, symbol, decimals });
|
|
62
|
+
}
|
|
63
|
+
return balances;
|
|
64
|
+
}
|
|
65
|
+
// ─── Balance Snapshot Store (client-side, session-scoped) ───────────────────
|
|
66
|
+
/**
|
|
67
|
+
* Client-side balance snapshot store for P&L charts.
|
|
68
|
+
* Preserves baseline (first-ever snapshot, never evicted) for session-lifetime P&L.
|
|
69
|
+
* Supports JSON serialization for cross-session persistence (localStorage/IndexedDB).
|
|
70
|
+
*/
|
|
71
|
+
export class BalanceSnapshotStore {
|
|
72
|
+
baseline = null;
|
|
73
|
+
maxEntries;
|
|
74
|
+
snapshots = new Map();
|
|
75
|
+
orderedTimestamps = [];
|
|
76
|
+
constructor(maxEntries = 144) {
|
|
77
|
+
this.maxEntries = maxEntries;
|
|
78
|
+
}
|
|
79
|
+
snapshot(timestamp, balances) {
|
|
80
|
+
if (!this.baseline)
|
|
81
|
+
this.baseline = { timestamp, balances };
|
|
82
|
+
// Guard against duplicate timestamps — update existing, don't push duplicate
|
|
83
|
+
if (this.snapshots.has(timestamp)) {
|
|
84
|
+
this.snapshots.set(timestamp, balances);
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
this.snapshots.set(timestamp, balances);
|
|
88
|
+
this.orderedTimestamps.push(timestamp);
|
|
89
|
+
while (this.orderedTimestamps.length > this.maxEntries) {
|
|
90
|
+
const oldest = this.orderedTimestamps.shift();
|
|
91
|
+
this.snapshots.delete(oldest);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
getBaseline() {
|
|
95
|
+
return this.baseline;
|
|
96
|
+
}
|
|
97
|
+
getFirst() {
|
|
98
|
+
if (this.orderedTimestamps.length === 0)
|
|
99
|
+
return null;
|
|
100
|
+
const ts = this.orderedTimestamps[0];
|
|
101
|
+
return { timestamp: ts, balances: this.snapshots.get(ts) };
|
|
102
|
+
}
|
|
103
|
+
getLatest() {
|
|
104
|
+
if (this.orderedTimestamps.length === 0)
|
|
105
|
+
return null;
|
|
106
|
+
const ts = this.orderedTimestamps[this.orderedTimestamps.length - 1];
|
|
107
|
+
return { timestamp: ts, balances: this.snapshots.get(ts) };
|
|
108
|
+
}
|
|
109
|
+
get size() {
|
|
110
|
+
return this.orderedTimestamps.length;
|
|
111
|
+
}
|
|
112
|
+
clear() {
|
|
113
|
+
this.baseline = null;
|
|
114
|
+
this.snapshots.clear();
|
|
115
|
+
this.orderedTimestamps = [];
|
|
116
|
+
}
|
|
117
|
+
toJSON() {
|
|
118
|
+
return JSON.stringify({
|
|
119
|
+
baseline: this.baseline
|
|
120
|
+
? {
|
|
121
|
+
timestamp: this.baseline.timestamp.toString(),
|
|
122
|
+
balances: this.baseline.balances.map((b) => ({
|
|
123
|
+
...b,
|
|
124
|
+
balance: b.balance.toString(),
|
|
125
|
+
})),
|
|
126
|
+
}
|
|
127
|
+
: null,
|
|
128
|
+
snapshots: Array.from(this.snapshots.entries()).map(([ts, bals]) => ({
|
|
129
|
+
timestamp: ts.toString(),
|
|
130
|
+
balances: bals.map((b) => ({ ...b, balance: b.balance.toString() })),
|
|
131
|
+
})),
|
|
132
|
+
maxEntries: this.maxEntries,
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
static fromJSON(json) {
|
|
136
|
+
const data = JSON.parse(json);
|
|
137
|
+
const maxEntries = Number.isInteger(data.maxEntries) ? data.maxEntries : 144;
|
|
138
|
+
const store = new BalanceSnapshotStore(maxEntries);
|
|
139
|
+
if (data.baseline) {
|
|
140
|
+
store.baseline = {
|
|
141
|
+
timestamp: BigInt(data.baseline.timestamp),
|
|
142
|
+
balances: data.baseline.balances.map((b) => ({
|
|
143
|
+
...b,
|
|
144
|
+
balance: BigInt(b.balance),
|
|
145
|
+
})),
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
for (const snap of data.snapshots) {
|
|
149
|
+
const ts = BigInt(snap.timestamp);
|
|
150
|
+
const bals = snap.balances.map((b) => ({
|
|
151
|
+
...b,
|
|
152
|
+
balance: BigInt(b.balance),
|
|
153
|
+
}));
|
|
154
|
+
store.snapshots.set(ts, bals);
|
|
155
|
+
store.orderedTimestamps.push(ts);
|
|
156
|
+
}
|
|
157
|
+
return store;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
// ─── Session-scoped P&L (from snapshots) ────────────────────────────────────
|
|
161
|
+
/**
|
|
162
|
+
* Session-scoped P&L from balance snapshots (for charts).
|
|
163
|
+
* Uses baseline → latest for session lifetime P&L.
|
|
164
|
+
* Aggregates stablecoin balances only (USDC + USDT).
|
|
165
|
+
*/
|
|
166
|
+
export function getBalancePnL(store, network = "mainnet-beta") {
|
|
167
|
+
const baseline = store.getBaseline();
|
|
168
|
+
const latest = store.getLatest();
|
|
169
|
+
if (!baseline || !latest || baseline.timestamp === latest.timestamp) {
|
|
170
|
+
return { startBalance: 0n, currentBalance: 0n, delta: 0n, percentChange: 0 };
|
|
171
|
+
}
|
|
172
|
+
const sumStablecoins = (balances) => balances.reduce((sum, b) => (isStablecoinMint(b.mint, network) ? sum + b.balance : sum), 0n);
|
|
173
|
+
const startBalance = sumStablecoins(baseline.balances);
|
|
174
|
+
const currentBalance = sumStablecoins(latest.balances);
|
|
175
|
+
const delta = currentBalance - startBalance;
|
|
176
|
+
const percentChange = startBalance > 0n
|
|
177
|
+
? Number((delta * 10000n) / startBalance) / 100
|
|
178
|
+
: 0;
|
|
179
|
+
return { startBalance, currentBalance, delta, percentChange };
|
|
180
|
+
}
|
|
181
|
+
//# sourceMappingURL=balance-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"balance-tracker.js","sourceRoot":"","sources":["../src/balance-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native pipe() transaction composer for Sigil.
|
|
3
|
+
*
|
|
4
|
+
* Builds atomic composed transactions:
|
|
5
|
+
* [ComputeBudget, PriorityFee?, ValidateAndAuthorize, ...defiIxs, FinalizeSession]
|
|
6
|
+
*/
|
|
7
|
+
import type { Address, Instruction } from "@solana/kit";
|
|
8
|
+
import type { AddressesByLookupTableAddress } from "@solana/kit";
|
|
9
|
+
import { compileTransaction } from "@solana/kit";
|
|
10
|
+
/** Maximum Solana transaction size in bytes */
|
|
11
|
+
declare const MAX_TX_SIZE = 1232;
|
|
12
|
+
export interface ComposeTransactionParams {
|
|
13
|
+
/** Fee payer (typically the agent) */
|
|
14
|
+
feePayer: Address;
|
|
15
|
+
/** The validate_and_authorize instruction */
|
|
16
|
+
validateIx: Instruction;
|
|
17
|
+
/** DeFi protocol instruction(s) to sandwich */
|
|
18
|
+
defiInstructions: Instruction[];
|
|
19
|
+
/** The finalize_session instruction */
|
|
20
|
+
finalizeIx: Instruction;
|
|
21
|
+
/** Recent blockhash for lifetime */
|
|
22
|
+
blockhash: {
|
|
23
|
+
blockhash: string;
|
|
24
|
+
lastValidBlockHeight: bigint;
|
|
25
|
+
};
|
|
26
|
+
/** Optional: override CU limit */
|
|
27
|
+
computeUnits?: number;
|
|
28
|
+
/** Optional: priority fee in microLamports per CU */
|
|
29
|
+
priorityFeeMicroLamports?: number;
|
|
30
|
+
/** Resolved address lookup tables for transaction compression */
|
|
31
|
+
addressLookupTables?: AddressesByLookupTableAddress;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Build an atomic composed transaction using Kit's pipe().
|
|
35
|
+
*
|
|
36
|
+
* Transaction order: [ComputeBudget, PriorityFee?, Validate, ...DeFi, Finalize]
|
|
37
|
+
* All instructions succeed or all revert atomically.
|
|
38
|
+
*/
|
|
39
|
+
export declare function composeSigilTransaction(params: ComposeTransactionParams): ReturnType<typeof compileTransaction>;
|
|
40
|
+
/**
|
|
41
|
+
* Validate that a compiled transaction doesn't exceed the Solana size limit.
|
|
42
|
+
* Returns the base64-encoded wire transaction if valid, throws if too large.
|
|
43
|
+
*/
|
|
44
|
+
export declare function validateTransactionSize(compiledTx: ReturnType<typeof compileTransaction>): string;
|
|
45
|
+
/**
|
|
46
|
+
* Measure transaction wire size without throwing.
|
|
47
|
+
* Non-throwing alternative to validateTransactionSize for pre-send checks.
|
|
48
|
+
*/
|
|
49
|
+
export declare function measureTransactionSize(compiledTx: ReturnType<typeof compileTransaction>): {
|
|
50
|
+
wireBase64: string;
|
|
51
|
+
byteLength: number;
|
|
52
|
+
withinLimit: boolean;
|
|
53
|
+
};
|
|
54
|
+
/** Exported for use in fallback checks */
|
|
55
|
+
export { MAX_TX_SIZE };
|
|
56
|
+
//# sourceMappingURL=composer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"composer.d.ts","sourceRoot":"","sources":["../src/composer.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,aAAa,CAAC;AACjE,OAAO,EAOL,kBAAkB,EAEnB,MAAM,aAAa,CAAC;AAOrB,+CAA+C;AAC/C,QAAA,MAAM,WAAW,OAAQ,CAAC;AAE1B,MAAM,WAAW,wBAAwB;IACvC,sCAAsC;IACtC,QAAQ,EAAE,OAAO,CAAC;IAClB,6CAA6C;IAC7C,UAAU,EAAE,WAAW,CAAC;IACxB,+CAA+C;IAC/C,gBAAgB,EAAE,WAAW,EAAE,CAAC;IAChC,uCAAuC;IACvC,UAAU,EAAE,WAAW,CAAC;IACxB,oCAAoC;IACpC,SAAS,EAAE;QACT,SAAS,EAAE,MAAM,CAAC;QAClB,oBAAoB,EAAE,MAAM,CAAC;KAC9B,CAAC;IACF,kCAAkC;IAClC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,qDAAqD;IACrD,wBAAwB,CAAC,EAAE,MAAM,CAAC;IAClC,iEAAiE;IACjE,mBAAmB,CAAC,EAAE,6BAA6B,CAAC;CACrD;AAED;;;;;GAKG;AACH,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,wBAAwB,GAC/B,UAAU,CAAC,OAAO,kBAAkB,CAAC,CAiDvC;AAgBD;;;GAGG;AACH,wBAAgB,uBAAuB,CACrC,UAAU,EAAE,UAAU,CAAC,OAAO,kBAAkB,CAAC,GAChD,MAAM,CAUR;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CACpC,UAAU,EAAE,UAAU,CAAC,OAAO,kBAAkB,CAAC,GAChD;IACD,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,OAAO,CAAC;CACtB,CAIA;AAED,0CAA0C;AAC1C,OAAO,EAAE,WAAW,EAAE,CAAC"}
|
package/dist/composer.js
ADDED
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kit-native pipe() transaction composer for Sigil.
|
|
3
|
+
*
|
|
4
|
+
* Builds atomic composed transactions:
|
|
5
|
+
* [ComputeBudget, PriorityFee?, ValidateAndAuthorize, ...defiIxs, FinalizeSession]
|
|
6
|
+
*/
|
|
7
|
+
import { pipe, createTransactionMessage, setTransactionMessageFeePayer, appendTransactionMessageInstructions, setTransactionMessageLifetimeUsingBlockhash, compressTransactionMessageUsingAddressLookupTables, compileTransaction, getBase64EncodedWireTransaction, } from "@solana/kit";
|
|
8
|
+
import { getSetComputeUnitLimitInstruction, getSetComputeUnitPriceInstruction, } from "@solana-program/compute-budget";
|
|
9
|
+
import { estimateComposedCU } from "./priority-fees.js";
|
|
10
|
+
/** Maximum Solana transaction size in bytes */
|
|
11
|
+
const MAX_TX_SIZE = 1_232;
|
|
12
|
+
/**
|
|
13
|
+
* Build an atomic composed transaction using Kit's pipe().
|
|
14
|
+
*
|
|
15
|
+
* Transaction order: [ComputeBudget, PriorityFee?, Validate, ...DeFi, Finalize]
|
|
16
|
+
* All instructions succeed or all revert atomically.
|
|
17
|
+
*/
|
|
18
|
+
export function composeSigilTransaction(params) {
|
|
19
|
+
const units = params.computeUnits ?? estimateComposedCU(params.defiInstructions);
|
|
20
|
+
const computeBudgetIx = getSetComputeUnitLimitInstruction({ units });
|
|
21
|
+
const allInstructions = [computeBudgetIx];
|
|
22
|
+
if (params.priorityFeeMicroLamports !== undefined &&
|
|
23
|
+
params.priorityFeeMicroLamports > 0) {
|
|
24
|
+
const priorityFeeIx = getSetComputeUnitPriceInstruction({
|
|
25
|
+
microLamports: params.priorityFeeMicroLamports,
|
|
26
|
+
});
|
|
27
|
+
allInstructions.push(priorityFeeIx);
|
|
28
|
+
}
|
|
29
|
+
allInstructions.push(params.validateIx, ...params.defiInstructions, params.finalizeIx);
|
|
30
|
+
let txMessage = pipe(createTransactionMessage({ version: 0 }), (tx) => setTransactionMessageFeePayer(params.feePayer, tx), (tx) => setTransactionMessageLifetimeUsingBlockhash(params.blockhash, tx), (tx) => appendTransactionMessageInstructions(allInstructions, tx));
|
|
31
|
+
// Apply ALT compression if lookup tables provided
|
|
32
|
+
if (params.addressLookupTables &&
|
|
33
|
+
Object.keys(params.addressLookupTables).length > 0) {
|
|
34
|
+
txMessage = compressTransactionMessageUsingAddressLookupTables(txMessage, params.addressLookupTables);
|
|
35
|
+
}
|
|
36
|
+
return compileTransaction(txMessage);
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Compute actual byte length from a padded base64 string.
|
|
40
|
+
* The naive `Math.ceil(len * 3 / 4)` overestimates by 1-2 bytes
|
|
41
|
+
* when padding is present (RFC 4648). At the 1232-byte TX limit,
|
|
42
|
+
* this causes false rejections of valid transactions.
|
|
43
|
+
*/
|
|
44
|
+
function base64ByteLength(b64) {
|
|
45
|
+
const len = b64.length;
|
|
46
|
+
let padding = 0;
|
|
47
|
+
if (len > 0 && b64[len - 1] === "=")
|
|
48
|
+
padding++;
|
|
49
|
+
if (len > 1 && b64[len - 2] === "=")
|
|
50
|
+
padding++;
|
|
51
|
+
return (len / 4) * 3 - padding;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Validate that a compiled transaction doesn't exceed the Solana size limit.
|
|
55
|
+
* Returns the base64-encoded wire transaction if valid, throws if too large.
|
|
56
|
+
*/
|
|
57
|
+
export function validateTransactionSize(compiledTx) {
|
|
58
|
+
const wireBytes = getBase64EncodedWireTransaction(compiledTx);
|
|
59
|
+
const byteLength = base64ByteLength(wireBytes);
|
|
60
|
+
if (byteLength > MAX_TX_SIZE) {
|
|
61
|
+
throw new Error(`Transaction size ${byteLength} bytes exceeds limit of ${MAX_TX_SIZE} bytes. ` +
|
|
62
|
+
`Use address lookup tables or reduce instruction count.`);
|
|
63
|
+
}
|
|
64
|
+
return wireBytes;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Measure transaction wire size without throwing.
|
|
68
|
+
* Non-throwing alternative to validateTransactionSize for pre-send checks.
|
|
69
|
+
*/
|
|
70
|
+
export function measureTransactionSize(compiledTx) {
|
|
71
|
+
const wireBase64 = getBase64EncodedWireTransaction(compiledTx);
|
|
72
|
+
const byteLength = base64ByteLength(wireBase64);
|
|
73
|
+
return { wireBase64, byteLength, withinLimit: byteLength <= MAX_TX_SIZE };
|
|
74
|
+
}
|
|
75
|
+
/** Exported for use in fallback checks */
|
|
76
|
+
export { MAX_TX_SIZE };
|
|
77
|
+
//# sourceMappingURL=composer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"composer.js","sourceRoot":"","sources":["../src/composer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { PolicyViolation } from "./errors.js";
|
|
2
|
+
import { ResolvedPolicies, TransactionAnalysis } from "./policies.js";
|
|
3
|
+
import { ShieldState } from "./state.js";
|
|
4
|
+
/**
|
|
5
|
+
* Evaluate a transaction against resolved policies and current state.
|
|
6
|
+
* Returns an array of violations (empty = transaction allowed).
|
|
7
|
+
*/
|
|
8
|
+
export declare function evaluatePolicy(analysis: TransactionAnalysis, policies: ResolvedPolicies, state: ShieldState): PolicyViolation[];
|
|
9
|
+
/**
|
|
10
|
+
* Evaluate policies and throw ShieldDeniedError if any violations found.
|
|
11
|
+
*/
|
|
12
|
+
export declare function enforcePolicy(analysis: TransactionAnalysis, policies: ResolvedPolicies, state: ShieldState): void;
|
|
13
|
+
/**
|
|
14
|
+
* After a transaction is signed, record the spend and transaction in state.
|
|
15
|
+
*/
|
|
16
|
+
export declare function recordTransaction(analysis: TransactionAnalysis, state: ShieldState): void;
|
|
17
|
+
//# sourceMappingURL=engine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../src/core/engine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAqB,MAAM,aAAa,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAEtE,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAKzC;;;GAGG;AACH,wBAAgB,cAAc,CAC5B,QAAQ,EAAE,mBAAmB,EAC7B,QAAQ,EAAE,gBAAgB,EAC1B,KAAK,EAAE,WAAW,GACjB,eAAe,EAAE,CAmBnB;AAED;;GAEG;AACH,wBAAgB,aAAa,CAC3B,QAAQ,EAAE,mBAAmB,EAC7B,QAAQ,EAAE,gBAAgB,EAC1B,KAAK,EAAE,WAAW,GACjB,IAAI,CAKN;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,mBAAmB,EAC7B,KAAK,EAAE,WAAW,GACjB,IAAI,CAcN"}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import { ShieldDeniedError } from "./errors.js";
|
|
2
|
+
import { isSystemProgram, isKnownProtocol, getTokenInfo } from "./registry.js";
|
|
3
|
+
/** Base58 encoding of a 32-byte zero key (PublicKey.default) */
|
|
4
|
+
const DEFAULT_ADDRESS = "11111111111111111111111111111111";
|
|
5
|
+
/**
|
|
6
|
+
* Evaluate a transaction against resolved policies and current state.
|
|
7
|
+
* Returns an array of violations (empty = transaction allowed).
|
|
8
|
+
*/
|
|
9
|
+
export function evaluatePolicy(analysis, policies, state) {
|
|
10
|
+
const violations = [];
|
|
11
|
+
// 1. Check protocol allowlist / unknown program blocking
|
|
12
|
+
checkPrograms(analysis, policies, violations);
|
|
13
|
+
// 2. Check token allowlist
|
|
14
|
+
checkTokens(analysis, policies, violations);
|
|
15
|
+
// 3. Check spending caps
|
|
16
|
+
checkSpendingCaps(analysis, policies, state, violations);
|
|
17
|
+
// 4. Check per-transaction size limit
|
|
18
|
+
checkTransactionSize(analysis, policies, violations);
|
|
19
|
+
// 5. Check rate limit
|
|
20
|
+
checkRateLimit(policies, state, violations);
|
|
21
|
+
return violations;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Evaluate policies and throw ShieldDeniedError if any violations found.
|
|
25
|
+
*/
|
|
26
|
+
export function enforcePolicy(analysis, policies, state) {
|
|
27
|
+
const violations = evaluatePolicy(analysis, policies, state);
|
|
28
|
+
if (violations.length > 0) {
|
|
29
|
+
throw new ShieldDeniedError(violations);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* After a transaction is signed, record the spend and transaction in state.
|
|
34
|
+
*/
|
|
35
|
+
export function recordTransaction(analysis, state) {
|
|
36
|
+
// Record each outgoing transfer
|
|
37
|
+
for (const transfer of analysis.transfers) {
|
|
38
|
+
if (transfer.direction === "outgoing") {
|
|
39
|
+
const mintKey = transfer.mint === DEFAULT_ADDRESS || transfer.mint === ""
|
|
40
|
+
? "unknown"
|
|
41
|
+
: transfer.mint;
|
|
42
|
+
state.recordSpend(mintKey, transfer.amount);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
// Record the transaction for rate limiting
|
|
46
|
+
state.recordTransaction();
|
|
47
|
+
}
|
|
48
|
+
// --- Internal check functions ---
|
|
49
|
+
function checkPrograms(analysis, policies, violations) {
|
|
50
|
+
for (const programId of analysis.programIds) {
|
|
51
|
+
// System programs are always allowed
|
|
52
|
+
if (isSystemProgram(programId))
|
|
53
|
+
continue;
|
|
54
|
+
// If explicit allowlist is set, only those protocols are allowed
|
|
55
|
+
if (policies.allowedProtocols) {
|
|
56
|
+
if (!policies.allowedProtocols.has(programId)) {
|
|
57
|
+
violations.push({
|
|
58
|
+
rule: "protocol_not_allowed",
|
|
59
|
+
message: `Protocol ${programId} is not in the allowlist`,
|
|
60
|
+
suggestion: "Add this protocol to allowedProtocols in your shield config.",
|
|
61
|
+
details: { programId },
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
continue;
|
|
65
|
+
}
|
|
66
|
+
// If blockUnknownPrograms is set, block unregistered protocols
|
|
67
|
+
if (policies.blockUnknownPrograms && !isKnownProtocol(programId)) {
|
|
68
|
+
violations.push({
|
|
69
|
+
rule: "unknown_program",
|
|
70
|
+
message: `Unknown program ${programId} — not in the known protocol registry`,
|
|
71
|
+
suggestion: "Add this program ID to allowedProtocols or set blockUnknownPrograms: false.",
|
|
72
|
+
details: { programId },
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
function checkTokens(analysis, policies, violations) {
|
|
78
|
+
if (!policies.allowedTokens)
|
|
79
|
+
return;
|
|
80
|
+
for (const transfer of analysis.transfers) {
|
|
81
|
+
if (transfer.direction !== "outgoing")
|
|
82
|
+
continue;
|
|
83
|
+
if (transfer.mint === DEFAULT_ADDRESS || transfer.mint === "")
|
|
84
|
+
continue;
|
|
85
|
+
if (!policies.allowedTokens.has(transfer.mint)) {
|
|
86
|
+
const tokenInfo = getTokenInfo(transfer.mint);
|
|
87
|
+
violations.push({
|
|
88
|
+
rule: "token_not_allowed",
|
|
89
|
+
message: `Token ${tokenInfo?.symbol ?? transfer.mint} is not in the allowed token list`,
|
|
90
|
+
suggestion: "Add this token mint to allowedTokens in your shield config.",
|
|
91
|
+
details: { tokenMint: transfer.mint },
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
function checkSpendingCaps(analysis, policies, state, violations) {
|
|
97
|
+
for (const limit of policies.spendLimits) {
|
|
98
|
+
const mintKey = limit.mint;
|
|
99
|
+
const windowMs = limit.windowMs ?? 86_400_000;
|
|
100
|
+
// Sum outgoing transfers for this token in this transaction
|
|
101
|
+
let txSpend = BigInt(0);
|
|
102
|
+
for (const transfer of analysis.transfers) {
|
|
103
|
+
if (transfer.direction !== "outgoing")
|
|
104
|
+
continue;
|
|
105
|
+
const transferMint = transfer.mint === DEFAULT_ADDRESS || transfer.mint === ""
|
|
106
|
+
? "unknown"
|
|
107
|
+
: transfer.mint;
|
|
108
|
+
if (transferMint === mintKey) {
|
|
109
|
+
txSpend += transfer.amount;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
if (txSpend === BigInt(0))
|
|
113
|
+
continue;
|
|
114
|
+
// Check against rolling window
|
|
115
|
+
const currentSpend = state.getSpendInWindow(mintKey, windowMs);
|
|
116
|
+
const totalAfterTx = currentSpend + txSpend;
|
|
117
|
+
if (totalAfterTx > limit.amount) {
|
|
118
|
+
const tokenInfo = getTokenInfo(mintKey);
|
|
119
|
+
const symbol = tokenInfo?.symbol ?? "tokens";
|
|
120
|
+
const decimals = tokenInfo?.decimals ?? 0;
|
|
121
|
+
const remaining = limit.amount > currentSpend ? limit.amount - currentSpend : BigInt(0);
|
|
122
|
+
violations.push({
|
|
123
|
+
rule: "spending_cap",
|
|
124
|
+
message: `Spending cap exceeded for ${symbol}: attempting ${formatAmount(txSpend, decimals)}, limit ${formatAmount(limit.amount, decimals)}, already spent ${formatAmount(currentSpend, decimals)}`,
|
|
125
|
+
suggestion: `Reduce the transaction amount to ${formatAmount(remaining, decimals)} ${symbol} or wait for the spending window to roll over.`,
|
|
126
|
+
details: {
|
|
127
|
+
limit: limit.amount,
|
|
128
|
+
attempted: txSpend,
|
|
129
|
+
remaining,
|
|
130
|
+
tokenMint: mintKey,
|
|
131
|
+
},
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
function checkTransactionSize(analysis, policies, violations) {
|
|
137
|
+
if (!policies.maxTransactionSize)
|
|
138
|
+
return;
|
|
139
|
+
if (analysis.estimatedValueLamports > policies.maxTransactionSize) {
|
|
140
|
+
violations.push({
|
|
141
|
+
rule: "transaction_size",
|
|
142
|
+
message: `Transaction value ${analysis.estimatedValueLamports} exceeds max transaction size ${policies.maxTransactionSize}`,
|
|
143
|
+
suggestion: "Split this into smaller transactions or increase maxTransactionSize.",
|
|
144
|
+
details: {
|
|
145
|
+
limit: policies.maxTransactionSize,
|
|
146
|
+
attempted: analysis.estimatedValueLamports,
|
|
147
|
+
},
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
function checkRateLimit(policies, state, violations) {
|
|
152
|
+
const { maxTransactions, windowMs } = policies.rateLimit;
|
|
153
|
+
const count = state.getTransactionCountInWindow(windowMs);
|
|
154
|
+
if (count >= maxTransactions) {
|
|
155
|
+
const windowDesc = windowMs >= 3_600_000
|
|
156
|
+
? `${windowMs / 3_600_000}h`
|
|
157
|
+
: `${windowMs / 60_000}min`;
|
|
158
|
+
violations.push({
|
|
159
|
+
rule: "rate_limit",
|
|
160
|
+
message: `Rate limit exceeded: ${count}/${maxTransactions} transactions in the last ${windowDesc}`,
|
|
161
|
+
suggestion: `Wait for the rate limit window to reset or increase rateLimit.maxTransactions.`,
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
/** Format a token amount with decimals for display */
|
|
166
|
+
function formatAmount(amount, decimals) {
|
|
167
|
+
if (decimals === 0)
|
|
168
|
+
return amount.toString();
|
|
169
|
+
const divisor = BigInt(10 ** decimals);
|
|
170
|
+
const whole = amount / divisor;
|
|
171
|
+
const frac = amount % divisor;
|
|
172
|
+
if (frac === BigInt(0))
|
|
173
|
+
return whole.toString();
|
|
174
|
+
const fracStr = frac.toString().padStart(decimals, "0").replace(/0+$/, "");
|
|
175
|
+
return `${whole}.${fracStr}`;
|
|
176
|
+
}
|
|
177
|
+
//# sourceMappingURL=engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../../src/core/engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export interface PolicyViolation {
|
|
2
|
+
/** Which policy rule was violated */
|
|
3
|
+
rule: "spending_cap" | "transaction_size" | "protocol_not_allowed" | "token_not_allowed" | "rate_limit" | "unknown_program";
|
|
4
|
+
/** Human-readable description of the violation */
|
|
5
|
+
message: string;
|
|
6
|
+
/** Actionable suggestion for the developer */
|
|
7
|
+
suggestion: string;
|
|
8
|
+
/** Additional context */
|
|
9
|
+
details?: {
|
|
10
|
+
limit?: bigint;
|
|
11
|
+
attempted?: bigint;
|
|
12
|
+
remaining?: bigint;
|
|
13
|
+
programId?: string;
|
|
14
|
+
tokenMint?: string;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export declare class ShieldDeniedError extends Error {
|
|
18
|
+
readonly violations: PolicyViolation[];
|
|
19
|
+
constructor(violations: PolicyViolation[]);
|
|
20
|
+
}
|
|
21
|
+
export declare class ShieldConfigError extends Error {
|
|
22
|
+
constructor(message: string);
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/core/errors.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,eAAe;IAC9B,qCAAqC;IACrC,IAAI,EACA,cAAc,GACd,kBAAkB,GAClB,sBAAsB,GACtB,mBAAmB,GACnB,YAAY,GACZ,iBAAiB,CAAC;IACtB,kDAAkD;IAClD,OAAO,EAAE,MAAM,CAAC;IAChB,8CAA8C;IAC9C,UAAU,EAAE,MAAM,CAAC;IACnB,yBAAyB;IACzB,OAAO,CAAC,EAAE;QACR,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,CAAC;CACH;AAED,qBAAa,iBAAkB,SAAQ,KAAK;IAC1C,QAAQ,CAAC,UAAU,EAAE,eAAe,EAAE,CAAC;gBAE3B,UAAU,EAAE,eAAe,EAAE;CAM1C;AAED,qBAAa,iBAAkB,SAAQ,KAAK;gBAC9B,OAAO,EAAE,MAAM;CAI5B"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export class ShieldDeniedError extends Error {
|
|
2
|
+
violations;
|
|
3
|
+
constructor(violations) {
|
|
4
|
+
const summary = violations.map((v) => v.message).join("; ");
|
|
5
|
+
super(`Transaction denied by Sigil: ${summary}`);
|
|
6
|
+
this.name = "ShieldDeniedError";
|
|
7
|
+
this.violations = violations;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export class ShieldConfigError extends Error {
|
|
11
|
+
constructor(message) {
|
|
12
|
+
super(message);
|
|
13
|
+
this.name = "ShieldConfigError";
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/core/errors.ts"],"names":[],"mappings":"AAuBA,MAAM,OAAO,iBAAkB,SAAQ,KAAK;IACjC,UAAU,CAAoB;IAEvC,YAAY,UAA6B;QACvC,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5D,KAAK,CAAC,gCAAgC,OAAO,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC;QAChC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;CACF;AAED,MAAM,OAAO,iBAAkB,SAAQ,KAAK;IAC1C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC;IAClC,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { ShieldDeniedError, ShieldConfigError } from "./errors.js";
|
|
2
|
+
export type { PolicyViolation } from "./errors.js";
|
|
3
|
+
export type { ShieldPolicies, SpendLimit, RateLimitConfig, PolicyCheckResult, TransactionAnalysis, TokenTransfer, ResolvedPolicies, } from "./policies.js";
|
|
4
|
+
export { parseSpendLimit, resolvePolicies, DEFAULT_POLICIES } from "./policies.js";
|
|
5
|
+
export { KNOWN_PROTOCOLS, KNOWN_TOKENS, SYSTEM_PROGRAMS, getTokenInfo, getProtocolName, isSystemProgram, isKnownProtocol, } from "./registry.js";
|
|
6
|
+
export { ShieldState } from "./state.js";
|
|
7
|
+
export type { ShieldStorage, SpendEntry, TxEntry } from "./state.js";
|
|
8
|
+
export { evaluatePolicy, enforcePolicy, recordTransaction } from "./engine.js";
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AACnE,YAAY,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAGnD,YAAY,EACV,cAAc,EACd,UAAU,EACV,eAAe,EACf,iBAAiB,EACjB,mBAAmB,EACnB,aAAa,EACb,gBAAgB,GACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAGnF,OAAO,EACL,eAAe,EACf,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,eAAe,EACf,eAAe,EACf,eAAe,GAChB,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAGrE,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// Errors
|
|
2
|
+
export { ShieldDeniedError, ShieldConfigError } from "./errors.js";
|
|
3
|
+
export { parseSpendLimit, resolvePolicies, DEFAULT_POLICIES } from "./policies.js";
|
|
4
|
+
// Protocol & token registry
|
|
5
|
+
export { KNOWN_PROTOCOLS, KNOWN_TOKENS, SYSTEM_PROGRAMS, getTokenInfo, getProtocolName, isSystemProgram, isKnownProtocol, } from "./registry.js";
|
|
6
|
+
// Client-side state
|
|
7
|
+
export { ShieldState } from "./state.js";
|
|
8
|
+
// Policy engine
|
|
9
|
+
export { evaluatePolicy, enforcePolicy, recordTransaction } from "./engine.js";
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,SAAS;AACT,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAanE,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAEnF,4BAA4B;AAC5B,OAAO,EACL,eAAe,EACf,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,eAAe,EACf,eAAe,EACf,eAAe,GAChB,MAAM,eAAe,CAAC;AAEvB,oBAAoB;AACpB,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAGzC,gBAAgB;AAChB,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC"}
|