@bananapus/core-v6 0.0.1
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 +21 -0
- package/README.md +112 -0
- package/SKILLS.md +151 -0
- package/docs/book.css +13 -0
- package/docs/book.toml +12 -0
- package/docs/solidity.min.js +74 -0
- package/docs/src/README.md +703 -0
- package/docs/src/SUMMARY.md +94 -0
- package/docs/src/src/JBChainlinkV3PriceFeed.sol/contract.JBChainlinkV3PriceFeed.md +83 -0
- package/docs/src/src/JBChainlinkV3SequencerPriceFeed.sol/contract.JBChainlinkV3SequencerPriceFeed.md +88 -0
- package/docs/src/src/JBController.sol/contract.JBController.md +1121 -0
- package/docs/src/src/JBDeadline.sol/contract.JBDeadline.md +84 -0
- package/docs/src/src/JBDirectory.sol/contract.JBDirectory.md +294 -0
- package/docs/src/src/JBERC20.sol/contract.JBERC20.md +190 -0
- package/docs/src/src/JBFeelessAddresses.sol/contract.JBFeelessAddresses.md +80 -0
- package/docs/src/src/JBFundAccessLimits.sol/contract.JBFundAccessLimits.md +253 -0
- package/docs/src/src/JBMultiTerminal.sol/contract.JBMultiTerminal.md +1472 -0
- package/docs/src/src/JBPermissions.sol/contract.JBPermissions.md +199 -0
- package/docs/src/src/JBPrices.sol/contract.JBPrices.md +154 -0
- package/docs/src/src/JBProjects.sol/contract.JBProjects.md +131 -0
- package/docs/src/src/JBRulesets.sol/contract.JBRulesets.md +677 -0
- package/docs/src/src/JBSplits.sol/contract.JBSplits.md +237 -0
- package/docs/src/src/JBTerminalStore.sol/contract.JBTerminalStore.md +591 -0
- package/docs/src/src/JBTokens.sol/contract.JBTokens.md +353 -0
- package/docs/src/src/README.md +25 -0
- package/docs/src/src/abstract/JBControlled.sol/abstract.JBControlled.md +64 -0
- package/docs/src/src/abstract/JBPermissioned.sol/abstract.JBPermissioned.md +84 -0
- package/docs/src/src/abstract/README.md +5 -0
- package/docs/src/src/enums/JBApprovalStatus.sol/enum.JBApprovalStatus.md +17 -0
- package/docs/src/src/enums/README.md +4 -0
- package/docs/src/src/interfaces/IJBCashOutHook.sol/interface.IJBCashOutHook.md +29 -0
- package/docs/src/src/interfaces/IJBCashOutTerminal.sol/interface.IJBCashOutTerminal.md +57 -0
- package/docs/src/src/interfaces/IJBControlled.sol/interface.IJBControlled.md +12 -0
- package/docs/src/src/interfaces/IJBController.sol/interface.IJBController.md +334 -0
- package/docs/src/src/interfaces/IJBDirectory.sol/interface.IJBDirectory.md +108 -0
- package/docs/src/src/interfaces/IJBDirectoryAccessControl.sol/interface.IJBDirectoryAccessControl.md +19 -0
- package/docs/src/src/interfaces/IJBFeeTerminal.sol/interface.IJBFeeTerminal.md +91 -0
- package/docs/src/src/interfaces/IJBFeelessAddresses.sol/interface.IJBFeelessAddresses.md +26 -0
- package/docs/src/src/interfaces/IJBFundAccessLimits.sol/interface.IJBFundAccessLimits.md +88 -0
- package/docs/src/src/interfaces/IJBMigratable.sol/interface.IJBMigratable.md +29 -0
- package/docs/src/src/interfaces/IJBMultiTerminal.sol/interface.IJBMultiTerminal.md +50 -0
- package/docs/src/src/interfaces/IJBPayHook.sol/interface.IJBPayHook.md +28 -0
- package/docs/src/src/interfaces/IJBPayoutTerminal.sol/interface.IJBPayoutTerminal.md +105 -0
- package/docs/src/src/interfaces/IJBPermissioned.sol/interface.IJBPermissioned.md +12 -0
- package/docs/src/src/interfaces/IJBPermissions.sol/interface.IJBPermissions.md +74 -0
- package/docs/src/src/interfaces/IJBPermitTerminal.sol/interface.IJBPermitTerminal.md +15 -0
- package/docs/src/src/interfaces/IJBPriceFeed.sol/interface.IJBPriceFeed.md +12 -0
- package/docs/src/src/interfaces/IJBPrices.sol/interface.IJBPrices.md +74 -0
- package/docs/src/src/interfaces/IJBProjectUriRegistry.sol/interface.IJBProjectUriRegistry.md +19 -0
- package/docs/src/src/interfaces/IJBProjects.sol/interface.IJBProjects.md +49 -0
- package/docs/src/src/interfaces/IJBRulesetApprovalHook.sol/interface.IJBRulesetApprovalHook.md +35 -0
- package/docs/src/src/interfaces/IJBRulesetDataHook.sol/interface.IJBRulesetDataHook.md +97 -0
- package/docs/src/src/interfaces/IJBRulesets.sol/interface.IJBRulesets.md +165 -0
- package/docs/src/src/interfaces/IJBSplitHook.sol/interface.IJBSplitHook.md +31 -0
- package/docs/src/src/interfaces/IJBSplits.sol/interface.IJBSplits.md +35 -0
- package/docs/src/src/interfaces/IJBTerminal.sol/interface.IJBTerminal.md +141 -0
- package/docs/src/src/interfaces/IJBTerminalStore.sol/interface.IJBTerminalStore.md +198 -0
- package/docs/src/src/interfaces/IJBToken.sol/interface.IJBToken.md +54 -0
- package/docs/src/src/interfaces/IJBTokenUriResolver.sol/interface.IJBTokenUriResolver.md +12 -0
- package/docs/src/src/interfaces/IJBTokens.sol/interface.IJBTokens.md +151 -0
- package/docs/src/src/interfaces/README.md +33 -0
- package/docs/src/src/libraries/JBCashOuts.sol/library.JBCashOuts.md +40 -0
- package/docs/src/src/libraries/JBConstants.sol/library.JBConstants.md +52 -0
- package/docs/src/src/libraries/JBCurrencyIds.sol/library.JBCurrencyIds.md +19 -0
- package/docs/src/src/libraries/JBFees.sol/library.JBFees.md +52 -0
- package/docs/src/src/libraries/JBFixedPointNumber.sol/library.JBFixedPointNumber.md +12 -0
- package/docs/src/src/libraries/JBMetadataResolver.sol/library.JBMetadataResolver.md +242 -0
- package/docs/src/src/libraries/JBRulesetMetadataResolver.sol/library.JBRulesetMetadataResolver.md +180 -0
- package/docs/src/src/libraries/JBSplitGroupIds.sol/library.JBSplitGroupIds.md +14 -0
- package/docs/src/src/libraries/JBSurplus.sol/library.JBSurplus.md +44 -0
- package/docs/src/src/libraries/README.md +12 -0
- package/docs/src/src/periphery/JBDeadline1Day.sol/contract.JBDeadline1Day.md +15 -0
- package/docs/src/src/periphery/JBDeadline3Days.sol/contract.JBDeadline3Days.md +15 -0
- package/docs/src/src/periphery/JBDeadline3Hours.sol/contract.JBDeadline3Hours.md +15 -0
- package/docs/src/src/periphery/JBDeadline7Days.sol/contract.JBDeadline7Days.md +15 -0
- package/docs/src/src/periphery/JBMatchingPriceFeed.sol/contract.JBMatchingPriceFeed.md +22 -0
- package/docs/src/src/periphery/README.md +8 -0
- package/docs/src/src/structs/JBAccountingContext.sol/struct.JBAccountingContext.md +20 -0
- package/docs/src/src/structs/JBAfterCashOutRecordedContext.sol/struct.JBAfterCashOutRecordedContext.md +43 -0
- package/docs/src/src/structs/JBAfterPayRecordedContext.sol/struct.JBAfterPayRecordedContext.md +42 -0
- package/docs/src/src/structs/JBBeforeCashOutRecordedContext.sol/struct.JBBeforeCashOutRecordedContext.md +45 -0
- package/docs/src/src/structs/JBBeforePayRecordedContext.sol/struct.JBBeforePayRecordedContext.md +41 -0
- package/docs/src/src/structs/JBCashOutHookSpecification.sol/struct.JBCashOutHookSpecification.md +22 -0
- package/docs/src/src/structs/JBCurrencyAmount.sol/struct.JBCurrencyAmount.md +17 -0
- package/docs/src/src/structs/JBFee.sol/struct.JBFee.md +20 -0
- package/docs/src/src/structs/JBFundAccessLimitGroup.sol/struct.JBFundAccessLimitGroup.md +39 -0
- package/docs/src/src/structs/JBPayHookSpecification.sol/struct.JBPayHookSpecification.md +22 -0
- package/docs/src/src/structs/JBPermissionsData.sol/struct.JBPermissionsData.md +21 -0
- package/docs/src/src/structs/JBRuleset.sol/struct.JBRuleset.md +55 -0
- package/docs/src/src/structs/JBRulesetConfig.sol/struct.JBRulesetConfig.md +51 -0
- package/docs/src/src/structs/JBRulesetMetadata.sol/struct.JBRulesetMetadata.md +79 -0
- package/docs/src/src/structs/JBRulesetWeightCache.sol/struct.JBRulesetWeightCache.md +16 -0
- package/docs/src/src/structs/JBRulesetWithMetadata.sol/struct.JBRulesetWithMetadata.md +16 -0
- package/docs/src/src/structs/JBSingleAllowance.sol/struct.JBSingleAllowance.md +26 -0
- package/docs/src/src/structs/JBSplit.sol/struct.JBSplit.md +49 -0
- package/docs/src/src/structs/JBSplitGroup.sol/struct.JBSplitGroup.md +17 -0
- package/docs/src/src/structs/JBSplitHookContext.sol/struct.JBSplitHookContext.md +29 -0
- package/docs/src/src/structs/JBTerminalConfig.sol/struct.JBTerminalConfig.md +16 -0
- package/docs/src/src/structs/JBTokenAmount.sol/struct.JBTokenAmount.md +23 -0
- package/docs/src/src/structs/README.md +25 -0
- package/foundry.lock +11 -0
- package/foundry.toml +41 -0
- package/package.json +38 -0
- package/remappings.txt +1 -0
- package/script/Deploy.s.sol +111 -0
- package/script/DeployPeriphery.s.sol +287 -0
- package/script/helpers/CoreDeploymentLib.sol +121 -0
- package/slither-ci.config.json +10 -0
- package/sphinx.lock +507 -0
- package/src/JBChainlinkV3PriceFeed.sol +77 -0
- package/src/JBChainlinkV3SequencerPriceFeed.sol +75 -0
- package/src/JBController.sol +1186 -0
- package/src/JBDeadline.sol +73 -0
- package/src/JBDirectory.sol +343 -0
- package/src/JBERC20.sol +131 -0
- package/src/JBFeelessAddresses.sol +54 -0
- package/src/JBFundAccessLimits.sol +308 -0
- package/src/JBMultiTerminal.sol +2024 -0
- package/src/JBPermissions.sol +252 -0
- package/src/JBPrices.sol +227 -0
- package/src/JBProjects.sol +126 -0
- package/src/JBRulesets.sol +1093 -0
- package/src/JBSplits.sol +324 -0
- package/src/JBTerminalStore.sol +908 -0
- package/src/JBTokens.sol +376 -0
- package/src/abstract/JBControlled.sol +48 -0
- package/src/abstract/JBPermissioned.sol +77 -0
- package/src/enums/JBApprovalStatus.sol +12 -0
- package/src/interfaces/IJBCashOutHook.sol +15 -0
- package/src/interfaces/IJBCashOutTerminal.sol +51 -0
- package/src/interfaces/IJBControlled.sol +10 -0
- package/src/interfaces/IJBController.sol +280 -0
- package/src/interfaces/IJBDirectory.sol +69 -0
- package/src/interfaces/IJBDirectoryAccessControl.sol +15 -0
- package/src/interfaces/IJBFeeTerminal.sol +61 -0
- package/src/interfaces/IJBFeelessAddresses.sol +17 -0
- package/src/interfaces/IJBFundAccessLimits.sol +94 -0
- package/src/interfaces/IJBMigratable.sol +24 -0
- package/src/interfaces/IJBMultiTerminal.sol +36 -0
- package/src/interfaces/IJBPayHook.sol +14 -0
- package/src/interfaces/IJBPayoutTerminal.sol +92 -0
- package/src/interfaces/IJBPermissioned.sol +10 -0
- package/src/interfaces/IJBPermissions.sol +71 -0
- package/src/interfaces/IJBPermitTerminal.sol +14 -0
- package/src/interfaces/IJBPriceFeed.sol +10 -0
- package/src/interfaces/IJBPrices.sol +65 -0
- package/src/interfaces/IJBProjectUriRegistry.sol +15 -0
- package/src/interfaces/IJBProjects.sol +27 -0
- package/src/interfaces/IJBRulesetApprovalHook.sol +21 -0
- package/src/interfaces/IJBRulesetDataHook.sol +56 -0
- package/src/interfaces/IJBRulesets.sol +151 -0
- package/src/interfaces/IJBSplitHook.sol +16 -0
- package/src/interfaces/IJBSplits.sol +28 -0
- package/src/interfaces/IJBTerminal.sol +120 -0
- package/src/interfaces/IJBTerminalStore.sol +225 -0
- package/src/interfaces/IJBToken.sol +39 -0
- package/src/interfaces/IJBTokenUriResolver.sol +10 -0
- package/src/interfaces/IJBTokens.sol +113 -0
- package/src/libraries/JBCashOuts.sol +120 -0
- package/src/libraries/JBConstants.sol +14 -0
- package/src/libraries/JBCurrencyIds.sol +7 -0
- package/src/libraries/JBFees.sol +28 -0
- package/src/libraries/JBFixedPointNumber.sol +12 -0
- package/src/libraries/JBMetadataResolver.sol +306 -0
- package/src/libraries/JBRulesetMetadataResolver.sol +160 -0
- package/src/libraries/JBSplitGroupIds.sol +7 -0
- package/src/libraries/JBSurplus.sol +40 -0
- package/src/periphery/JBDeadline1Day.sol +8 -0
- package/src/periphery/JBDeadline3Days.sol +8 -0
- package/src/periphery/JBDeadline3Hours.sol +8 -0
- package/src/periphery/JBDeadline7Days.sol +8 -0
- package/src/periphery/JBMatchingPriceFeed.sol +13 -0
- package/src/structs/JBAccountingContext.sol +12 -0
- package/src/structs/JBAfterCashOutRecordedContext.sol +30 -0
- package/src/structs/JBAfterPayRecordedContext.sol +29 -0
- package/src/structs/JBBeforeCashOutRecordedContext.sol +31 -0
- package/src/structs/JBBeforePayRecordedContext.sol +28 -0
- package/src/structs/JBCashOutHookSpecification.sol +15 -0
- package/src/structs/JBCurrencyAmount.sol +10 -0
- package/src/structs/JBFee.sol +12 -0
- package/src/structs/JBFundAccessLimitGroup.sol +28 -0
- package/src/structs/JBPayHookSpecification.sol +15 -0
- package/src/structs/JBPermissionsData.sol +13 -0
- package/src/structs/JBRuleset.sol +42 -0
- package/src/structs/JBRulesetConfig.sol +43 -0
- package/src/structs/JBRulesetMetadata.sol +56 -0
- package/src/structs/JBRulesetWeightCache.sol +9 -0
- package/src/structs/JBRulesetWithMetadata.sol +12 -0
- package/src/structs/JBSingleAllowance.sol +16 -0
- package/src/structs/JBSplit.sol +37 -0
- package/src/structs/JBSplitGroup.sol +12 -0
- package/src/structs/JBSplitHookContext.sol +20 -0
- package/src/structs/JBTerminalConfig.sol +12 -0
- package/src/structs/JBTokenAmount.sol +14 -0
- package/test/AuditExploits.t.sol +2710 -0
- package/test/ComprehensiveInvariant.t.sol +298 -0
- package/test/EconomicSimulation.t.sol +340 -0
- package/test/EntryPointPermutations.t.sol +671 -0
- package/test/FlashLoanAttacks.t.sol +792 -0
- package/test/PermissionEscalation.t.sol +679 -0
- package/test/RulesetTransitions.t.sol +699 -0
- package/test/SplitLoopTests.t.sol +731 -0
- package/test/TestAccessToFunds.sol +2644 -0
- package/test/TestCashOut.sol +185 -0
- package/test/TestCashOutCountFor.sol +272 -0
- package/test/TestCashOutHooks.sol +317 -0
- package/test/TestCashOutTimingEdge.sol +229 -0
- package/test/TestDurationUnderflow.sol +220 -0
- package/test/TestFeeProcessingFailure.sol +208 -0
- package/test/TestFees.sol +604 -0
- package/test/TestInterfaceSupport.sol +62 -0
- package/test/TestJBERC20Inheritance.sol +91 -0
- package/test/TestLaunchProject.sol +176 -0
- package/test/TestMetaTx.sol +203 -0
- package/test/TestMetadataParserLib.sol +438 -0
- package/test/TestMigrationHeldFees.sol +249 -0
- package/test/TestMintTokensOf.sol +172 -0
- package/test/TestMultiTokenSurplus.sol +206 -0
- package/test/TestMultipleAccessLimits.sol +642 -0
- package/test/TestPayBurnRedeemFlow.sol +180 -0
- package/test/TestPayHooks.sol +190 -0
- package/test/TestPermissions.sol +305 -0
- package/test/TestPermissionsEdge.sol +286 -0
- package/test/TestPermit2Terminal.sol +339 -0
- package/test/TestRulesetQueueing.sol +1001 -0
- package/test/TestRulesetQueuingStress.sol +778 -0
- package/test/TestRulesetWeightCaching.sol +177 -0
- package/test/TestSplits.sol +369 -0
- package/test/TestTerminalMigration.sol +167 -0
- package/test/TestTokenFlow.sol +174 -0
- package/test/WeirdTokenTests.t.sol +764 -0
- package/test/formal/BondingCurveProperties.t.sol +411 -0
- package/test/formal/FeeProperties.t.sol +246 -0
- package/test/helpers/JBTest.sol +129 -0
- package/test/helpers/MetadataResolverHelper.sol +116 -0
- package/test/helpers/TestBaseWorkflow.sol +317 -0
- package/test/invariants/Phase3DeepInvariant.t.sol +404 -0
- package/test/invariants/RulesetsInvariant.t.sol +115 -0
- package/test/invariants/TerminalStoreInvariant.t.sol +220 -0
- package/test/invariants/TokensInvariant.t.sol +184 -0
- package/test/invariants/handlers/ComprehensiveHandler.sol +285 -0
- package/test/invariants/handlers/EconomicHandler.sol +347 -0
- package/test/invariants/handlers/Phase3Handler.sol +414 -0
- package/test/invariants/handlers/RulesetsHandler.sol +111 -0
- package/test/invariants/handlers/TerminalStoreHandler.sol +146 -0
- package/test/invariants/handlers/TokensHandler.sol +127 -0
- package/test/mock/ERC2771ForwarderMock.sol +37 -0
- package/test/mock/MockERC20.sol +18 -0
- package/test/mock/MockMaliciousBeneficiary.sol +67 -0
- package/test/mock/MockMaliciousSplitHook.sol +42 -0
- package/test/mock/MockPriceFeed.sol +20 -0
- package/test/trees/JBController/burnTokensOf.tree +9 -0
- package/test/trees/JBController/claimTokensFor.tree +5 -0
- package/test/trees/JBController/deployERC20For.tree +5 -0
- package/test/trees/JBController/getRulesetOf.tree +5 -0
- package/test/trees/JBController/launchProjectFor.tree +12 -0
- package/test/trees/JBController/launchRulesetsFor.tree +8 -0
- package/test/trees/JBController/migrateController.tree +12 -0
- package/test/trees/JBController/mintTokensOf.tree +12 -0
- package/test/trees/JBController/payReservedTokenToTerminal.tree +8 -0
- package/test/trees/JBController/receiveMigrationFrom.tree +4 -0
- package/test/trees/JBController/sendReservedTokensToSplitsOf.tree +12 -0
- package/test/trees/JBController/setMetadataOf.tree +5 -0
- package/test/trees/JBController/setSplitGroupsOf.tree +5 -0
- package/test/trees/JBController/setTokenFor.tree +5 -0
- package/test/trees/JBController/transferCreditsFrom.tree +8 -0
- package/test/trees/JBDirectory/primaryTerminalOf.tree +8 -0
- package/test/trees/JBDirectory/setControllerOf.tree +11 -0
- package/test/trees/JBDirectory/setPrimaryTerminalOf.tree +15 -0
- package/test/trees/JBDirectory/setTerminalsOf.tree +11 -0
- package/test/trees/JBERC20/initialize.tree +7 -0
- package/test/trees/JBERC20/name.tree +5 -0
- package/test/trees/JBERC20/nonces.tree +5 -0
- package/test/trees/JBERC20/symbol.tree +5 -0
- package/test/trees/JBFeelessAddresses/setFeelessAddress.tree +5 -0
- package/test/trees/JBFeelessAddresses/supportsInterface.tree +5 -0
- package/test/trees/JBFundAccessLimits/payoutLimitOf.tree +5 -0
- package/test/trees/JBFundAccessLimits/payoutLimitsOf.tree +8 -0
- package/test/trees/JBFundAccessLimits/setFundAccessLimitsFor.tree +18 -0
- package/test/trees/JBFundAccessLimits/surplusAllowanceOf.tree +5 -0
- package/test/trees/JBFundAccessLimits/surplusAllowancesOf.tree +8 -0
- package/test/trees/JBMetadataResolver/getDataFor.tree +8 -0
- package/test/trees/JBMultiTerminal/accountingContextsOf.tree +5 -0
- package/test/trees/JBMultiTerminal/addAccountingContextsFor.tree +10 -0
- package/test/trees/JBMultiTerminal/addToBalanceOf.tree +23 -0
- package/test/trees/JBMultiTerminal/cashOutTokensOf.tree +23 -0
- package/test/trees/JBMultiTerminal/executePayout.tree +32 -0
- package/test/trees/JBMultiTerminal/executeProcessFee.tree +14 -0
- package/test/trees/JBMultiTerminal/migrateBalanceOf.tree +12 -0
- package/test/trees/JBMultiTerminal/pay.tree +23 -0
- package/test/trees/JBMultiTerminal/processHeldFeesOf.tree +8 -0
- package/test/trees/JBMultiTerminal/sendPayoutsOf.tree +34 -0
- package/test/trees/JBMultiTerminal/useAllowanceOf.tree +16 -0
- package/test/trees/JBPermissions/hasPermission.tree +8 -0
- package/test/trees/JBPermissions/hasPermissions.tree +8 -0
- package/test/trees/JBPermissions/setPermissionsFor.tree +5 -0
- package/test/trees/JBPrices/addPriceFeedFor.tree +14 -0
- package/test/trees/JBPrices/pricePerUnitOf.tree +11 -0
- package/test/trees/JBProjects/createFor.tree +11 -0
- package/test/trees/JBProjects/setTokenUriResolver.tree +5 -0
- package/test/trees/JBProjects/supportsInterface.tree +9 -0
- package/test/trees/JBProjects/tokenURI.tree +5 -0
- package/test/trees/JBRulesets/currentApprovalStatusForLatestRulesetOf.tree +8 -0
- package/test/trees/JBRulesets/currentOf.tree +12 -0
- package/test/trees/JBRulesets/getRulesetOf.tree +5 -0
- package/test/trees/JBRulesets/latestQueuedRulesetOf.tree +10 -0
- package/test/trees/JBRulesets/rulesetsOf.tree +11 -0
- package/test/trees/JBRulesets/upcomingRulesetOf.tree +20 -0
- package/test/trees/JBRulesets/updateRulesetWeightCache.tree +5 -0
- package/test/trees/JBSplits/setSplitGroupsOf.tree +17 -0
- package/test/trees/JBSplits/splitsOf.tree +5 -0
- package/test/trees/JBTerminalStore/currentReclaimableSurplusOf.tree +16 -0
- package/test/trees/JBTerminalStore/currentSurplusOf.tree +25 -0
- package/test/trees/JBTerminalStore/currentTotalSurplusOf.tree +5 -0
- package/test/trees/JBTerminalStore/recordCashOutsFor.tree +16 -0
- package/test/trees/JBTerminalStore/recordPaymentFrom.tree +14 -0
- package/test/trees/JBTerminalStore/recordPayoutFor.tree +10 -0
- package/test/trees/JBTerminalStore/recordTerminalMigration.tree +5 -0
- package/test/trees/JBTerminalStore/recordUsedAllowanceOf.tree +10 -0
- package/test/trees/JBTokens/burnFrom.tree +10 -0
- package/test/trees/JBTokens/claimTokensFor.tree +10 -0
- package/test/trees/JBTokens/deployERC20For.tree +12 -0
- package/test/trees/JBTokens/mintFor.tree +10 -0
- package/test/trees/JBTokens/setTokenFor.tree +11 -0
- package/test/trees/JBTokens/totalBalanceOf.tree +5 -0
- package/test/trees/JBTokens/totalSupplyOf.tree +5 -0
- package/test/trees/JBTokens/transferCreditsFrom.tree +8 -0
- package/test/trees/mintTokensOf.tree +12 -0
- package/test/units/static/JBChainlinkV3PriceFeed/TestPriceFeed.sol +220 -0
- package/test/units/static/JBController/JBControllerSetup.sol +40 -0
- package/test/units/static/JBController/TestBurnTokensOf.sol +107 -0
- package/test/units/static/JBController/TestClaimTokensFor.sol +60 -0
- package/test/units/static/JBController/TestDeployErc20For.sol +80 -0
- package/test/units/static/JBController/TestLaunchProjectFor.sol +282 -0
- package/test/units/static/JBController/TestLaunchRulesetsFor.sol +322 -0
- package/test/units/static/JBController/TestMigrateController.sol +148 -0
- package/test/units/static/JBController/TestMintTokensOfUnits.sol +102 -0
- package/test/units/static/JBController/TestPayReservedTokenToTerminal.sol +71 -0
- package/test/units/static/JBController/TestReceiveMigrationFrom.sol +95 -0
- package/test/units/static/JBController/TestRulesetViews.sol +219 -0
- package/test/units/static/JBController/TestSendReservedTokensToSplitsOf.sol +595 -0
- package/test/units/static/JBController/TestSetSplitGroupsOf.sol +63 -0
- package/test/units/static/JBController/TestSetTokenFor.sol +227 -0
- package/test/units/static/JBController/TestSetUriOf.sol +53 -0
- package/test/units/static/JBController/TestTransferCreditsFrom.sol +159 -0
- package/test/units/static/JBDeadline/TestDeadlineFuzz.sol +194 -0
- package/test/units/static/JBDirectory/JBDirectorySetup.sol +22 -0
- package/test/units/static/JBDirectory/TestPrimaryTerminalOf.sol +122 -0
- package/test/units/static/JBDirectory/TestSetControllerOf.sol +173 -0
- package/test/units/static/JBDirectory/TestSetControllerOfMigrationOrder.sol +98 -0
- package/test/units/static/JBDirectory/TestSetPrimaryTerminalOf.sol +169 -0
- package/test/units/static/JBDirectory/TestSetTerminalsOf.sol +128 -0
- package/test/units/static/JBERC20/JBERC20Setup.sol +20 -0
- package/test/units/static/JBERC20/SigUtils.sol +34 -0
- package/test/units/static/JBERC20/TestInitialize.sol +54 -0
- package/test/units/static/JBERC20/TestName.sol +30 -0
- package/test/units/static/JBERC20/TestNonces.sol +59 -0
- package/test/units/static/JBERC20/TestSymbol.sol +31 -0
- package/test/units/static/JBFeelessAdresses/JBFeelessSetup.sol +20 -0
- package/test/units/static/JBFeelessAdresses/TestInterfaces.sol +29 -0
- package/test/units/static/JBFeelessAdresses/TestSetFeelessAddress.sol +35 -0
- package/test/units/static/JBFees/TestFeesFuzz.sol +78 -0
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimals.sol +16 -0
- package/test/units/static/JBFixedPointNumber/TestAdjustDecimalsFuzz.sol +71 -0
- package/test/units/static/JBFundAccessLimits/JBFundAccessSetup.sol +21 -0
- package/test/units/static/JBFundAccessLimits/TestFundAccessLimitsEdge.sol +159 -0
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitOf.sol +56 -0
- package/test/units/static/JBFundAccessLimits/TestPayoutLimitsOf.sol +94 -0
- package/test/units/static/JBFundAccessLimits/TestSetFundAccessLimitsFor.sol +182 -0
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowanceOf.sol +61 -0
- package/test/units/static/JBFundAccessLimits/TestSurplusAllowancesOf.sol +96 -0
- package/test/units/static/JBMetadataResolver/TestGetDataFor.sol +89 -0
- package/test/units/static/JBMetadataResolver/TestMetadataResolverFuzz.sol +227 -0
- package/test/units/static/JBMetadataResolver/TestMetadataResolverM20M21.sol +245 -0
- package/test/units/static/JBMultiTerminal/JBMultiTerminalSetup.sol +39 -0
- package/test/units/static/JBMultiTerminal/TestAccountingContextsOf.sol +65 -0
- package/test/units/static/JBMultiTerminal/TestAddAccountingContextsFor.sol +313 -0
- package/test/units/static/JBMultiTerminal/TestAddToBalanceOf.sol +432 -0
- package/test/units/static/JBMultiTerminal/TestCashOutTokensOf.sol +478 -0
- package/test/units/static/JBMultiTerminal/TestExecutePayout.sol +577 -0
- package/test/units/static/JBMultiTerminal/TestExecuteProcessFee.sol +176 -0
- package/test/units/static/JBMultiTerminal/TestMigrateBalanceOf.sol +190 -0
- package/test/units/static/JBMultiTerminal/TestPay.sol +514 -0
- package/test/units/static/JBMultiTerminal/TestProcessHeldFeesOf.sol +29 -0
- package/test/units/static/JBMultiTerminal/TestSendPayoutsOf.sol +243 -0
- package/test/units/static/JBMultiTerminal/TestUseAllowanceOf.sol +310 -0
- package/test/units/static/JBPermissions/JBPermissionsSetup.sol +18 -0
- package/test/units/static/JBPermissions/TestHasPermission.sol +50 -0
- package/test/units/static/JBPermissions/TestHasPermissions.sol +93 -0
- package/test/units/static/JBPermissions/TestSetPermissionsFor.sol +62 -0
- package/test/units/static/JBPrices/JBPricesSetup.sol +26 -0
- package/test/units/static/JBPrices/TestAddPriceFeedFor.sol +102 -0
- package/test/units/static/JBPrices/TestPricePerUnitOf.sol +129 -0
- package/test/units/static/JBPrices/TestPrices.sol +262 -0
- package/test/units/static/JBProjects/JBProjectsSetup.sol +20 -0
- package/test/units/static/JBProjects/TestCreateFor.sol +69 -0
- package/test/units/static/JBProjects/TestInitialProject.sol +19 -0
- package/test/units/static/JBProjects/TestInterfaces.sol +27 -0
- package/test/units/static/JBProjects/TestSetResolver.sol +36 -0
- package/test/units/static/JBProjects/TestTokenUri.sol +38 -0
- package/test/units/static/JBRulesetMetadataResolver/TestSetCashOutTaxRateTo.sol +99 -0
- package/test/units/static/JBRulesets/JBRulesetsSetup.sol +21 -0
- package/test/units/static/JBRulesets/TestCurrentApprovalStatusForLatestRulesetOf.sol +257 -0
- package/test/units/static/JBRulesets/TestCurrentOf.sol +231 -0
- package/test/units/static/JBRulesets/TestGetRulesetOf.sol +94 -0
- package/test/units/static/JBRulesets/TestLatestQueuedRulesetOf.sol +252 -0
- package/test/units/static/JBRulesets/TestRulesets.sol +617 -0
- package/test/units/static/JBRulesets/TestRulesetsOf.sol +37 -0
- package/test/units/static/JBRulesets/TestUpcomingRulesetOf.sol +526 -0
- package/test/units/static/JBRulesets/TestUpdateRulesetWeightCache.sol +91 -0
- package/test/units/static/JBSplits/JBSplitsSetup.sol +23 -0
- package/test/units/static/JBSplits/TestSelfManagedSplitGroups.sol +502 -0
- package/test/units/static/JBSplits/TestSetSplitGroupsOf.sol +370 -0
- package/test/units/static/JBSplits/TestSplitsLockedEdge.sol +262 -0
- package/test/units/static/JBSplits/TestSplitsOf.sol +24 -0
- package/test/units/static/JBSplits/TestSplitsPacking.sol +33 -0
- package/test/units/static/JBSurplus/TestSurplusFuzz.sol +125 -0
- package/test/units/static/JBTerminalStore/JBTerminalStoreSetup.sol +23 -0
- package/test/units/static/JBTerminalStore/TestCurrentReclaimableSurplusOf.sol +434 -0
- package/test/units/static/JBTerminalStore/TestCurrentSurplusOf.sol +428 -0
- package/test/units/static/JBTerminalStore/TestCurrentTotalSurplusOf.sol +65 -0
- package/test/units/static/JBTerminalStore/TestRecordCashOutsFor.sol +479 -0
- package/test/units/static/JBTerminalStore/TestRecordPaymentFrom.sol +508 -0
- package/test/units/static/JBTerminalStore/TestRecordPayoutFor.sol +257 -0
- package/test/units/static/JBTerminalStore/TestRecordTerminalMigration.sol +131 -0
- package/test/units/static/JBTerminalStore/TestRecordUsedAllowanceOf.sol +390 -0
- package/test/units/static/JBTerminalStore/TestUint224Overflow.sol +187 -0
- package/test/units/static/JBTokens/JBTokensSetup.sol +23 -0
- package/test/units/static/JBTokens/TestBurnFrom.sol +104 -0
- package/test/units/static/JBTokens/TestClaimTokensFor.sol +107 -0
- package/test/units/static/JBTokens/TestDeployERC20ForUnits.sol +89 -0
- package/test/units/static/JBTokens/TestMintFor.sol +97 -0
- package/test/units/static/JBTokens/TestSetTokenFor.sol +95 -0
- package/test/units/static/JBTokens/TestTotalBalanceOf.sol +65 -0
- package/test/units/static/JBTokens/TestTotalSupplyOf.sol +56 -0
- package/test/units/static/JBTokens/TestTransferCreditsFrom.sol +54 -0
|
@@ -0,0 +1,432 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT
|
|
2
|
+
pragma solidity 0.8.23;
|
|
3
|
+
|
|
4
|
+
import /* {*} from */ "../../../helpers/TestBaseWorkflow.sol";
|
|
5
|
+
import {JBMultiTerminalSetup} from "./JBMultiTerminalSetup.sol";
|
|
6
|
+
|
|
7
|
+
contract TestAddToBalanceOf_Local is JBMultiTerminalSetup {
|
|
8
|
+
// Permit2
|
|
9
|
+
IPermit2 private _permit2;
|
|
10
|
+
|
|
11
|
+
// global constants
|
|
12
|
+
uint256 _projectId = 1;
|
|
13
|
+
address _native = JBConstants.NATIVE_TOKEN;
|
|
14
|
+
uint256 _nativeCurrency = uint32(uint160(_native));
|
|
15
|
+
address _usdc = makeAddr("USDC");
|
|
16
|
+
uint256 _usdcCurrency = uint32(uint160(_usdc));
|
|
17
|
+
uint256 _terminalUSDCBalance = 1e18;
|
|
18
|
+
|
|
19
|
+
// set by modifiers
|
|
20
|
+
uint256 payAmount;
|
|
21
|
+
uint256 feeAmount;
|
|
22
|
+
uint256 feeAmountFrom;
|
|
23
|
+
uint256 amountFromFee;
|
|
24
|
+
uint256 leftOverAmount;
|
|
25
|
+
bool _shouldReturnHeldFees;
|
|
26
|
+
|
|
27
|
+
// Permit2 params.
|
|
28
|
+
bytes32 DOMAIN_SEPARATOR;
|
|
29
|
+
address from;
|
|
30
|
+
uint256 fromPrivateKey = 0x12341234;
|
|
31
|
+
|
|
32
|
+
function setUp() public {
|
|
33
|
+
super.multiTerminalSetup();
|
|
34
|
+
|
|
35
|
+
from = vm.addr(fromPrivateKey);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
modifier whenNativeTokenIsAccepted() {
|
|
39
|
+
// Accounting Context to set
|
|
40
|
+
JBAccountingContext memory _context =
|
|
41
|
+
JBAccountingContext({token: _native, decimals: 18, currency: uint32(_nativeCurrency)});
|
|
42
|
+
|
|
43
|
+
// Find the storage slot
|
|
44
|
+
bytes32 contextSlot = keccak256(abi.encode(_projectId, uint256(0)));
|
|
45
|
+
bytes32 slot = keccak256(abi.encode(_native, contextSlot));
|
|
46
|
+
|
|
47
|
+
// Set storage
|
|
48
|
+
vm.store(address(_terminal), slot, bytes32(abi.encode(_context)));
|
|
49
|
+
|
|
50
|
+
JBAccountingContext memory _storedContext = _terminal.accountingContextForTokenOf(_projectId, _native);
|
|
51
|
+
assertEq(_storedContext.token, _native);
|
|
52
|
+
|
|
53
|
+
_;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
modifier whenShouldReturnHeldFeesEqTrue() {
|
|
57
|
+
// Accounting Context to set
|
|
58
|
+
JBAccountingContext memory _context =
|
|
59
|
+
JBAccountingContext({token: _native, decimals: 18, currency: uint32(_nativeCurrency)});
|
|
60
|
+
|
|
61
|
+
// Find the storage slot
|
|
62
|
+
bytes32 contextSlot = keccak256(abi.encode(_projectId, uint256(0)));
|
|
63
|
+
bytes32 slot = keccak256(abi.encode(_native, contextSlot));
|
|
64
|
+
|
|
65
|
+
// Set storage
|
|
66
|
+
vm.store(address(_terminal), slot, bytes32(abi.encode(_context)));
|
|
67
|
+
|
|
68
|
+
JBAccountingContext memory _storedContext = _terminal.accountingContextForTokenOf(_projectId, _native);
|
|
69
|
+
assertEq(_storedContext.token, _native);
|
|
70
|
+
|
|
71
|
+
// Find the storage slot for fees array
|
|
72
|
+
bytes32 feeSlot = keccak256(abi.encode(_projectId, uint256(2)));
|
|
73
|
+
bytes32 slotForArrayLength = keccak256(abi.encode(_native, feeSlot));
|
|
74
|
+
|
|
75
|
+
// Set the length of the fees array in the storage slot
|
|
76
|
+
vm.store(address(_terminal), slotForArrayLength, bytes32(uint256(1)));
|
|
77
|
+
|
|
78
|
+
// First item should be stored at the next slot
|
|
79
|
+
bytes32 firstItemSlot = keccak256(abi.encodePacked(slotForArrayLength));
|
|
80
|
+
|
|
81
|
+
feeAmount = 1e9;
|
|
82
|
+
|
|
83
|
+
vm.store(address(_terminal), firstItemSlot, bytes32(feeAmount));
|
|
84
|
+
|
|
85
|
+
JBFee[] memory setFees = _terminal.heldFeesOf(_projectId, _native, 100);
|
|
86
|
+
assertEq(setFees[0].amount, feeAmount);
|
|
87
|
+
|
|
88
|
+
payAmount = 2e18;
|
|
89
|
+
feeAmountFrom = JBFees.feeAmountFrom(feeAmount, 25);
|
|
90
|
+
|
|
91
|
+
amountFromFee = feeAmount - feeAmountFrom;
|
|
92
|
+
leftOverAmount = payAmount - amountFromFee;
|
|
93
|
+
|
|
94
|
+
_shouldReturnHeldFees = true;
|
|
95
|
+
|
|
96
|
+
_;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
function test_GivenReturnAmountIsZero() external whenShouldReturnHeldFeesEqTrue {
|
|
100
|
+
// it will set heldFeesOf project to the previously set heldFee
|
|
101
|
+
|
|
102
|
+
// mock call to store recordAddedBalanceFor
|
|
103
|
+
mockExpect(address(store), abi.encodeCall(IJBTerminalStore.recordAddedBalanceFor, (_projectId, _native, 0)), "");
|
|
104
|
+
|
|
105
|
+
_terminal.addToBalanceOf({
|
|
106
|
+
projectId: _projectId,
|
|
107
|
+
token: _native,
|
|
108
|
+
amount: 0,
|
|
109
|
+
shouldReturnHeldFees: _shouldReturnHeldFees,
|
|
110
|
+
memo: "",
|
|
111
|
+
metadata: ""
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
// Heldfee should remain
|
|
115
|
+
JBFee[] memory feesAfter = _terminal.heldFeesOf(_projectId, _native, 100);
|
|
116
|
+
assertEq(feesAfter[0].amount, feeAmount);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
function test_GivenReturnAmountIsNon_zeroAndLeftoverAmountGTEQAmountFromFee()
|
|
120
|
+
external
|
|
121
|
+
whenShouldReturnHeldFeesEqTrue
|
|
122
|
+
{
|
|
123
|
+
// it will return leftoverAmount - amountFromFee and return the held fee to beneficiary
|
|
124
|
+
|
|
125
|
+
// mock call to store recordAddedBalanceFor
|
|
126
|
+
mockExpect(
|
|
127
|
+
address(store),
|
|
128
|
+
abi.encodeCall(IJBTerminalStore.recordAddedBalanceFor, (_projectId, _native, payAmount + feeAmountFrom)),
|
|
129
|
+
""
|
|
130
|
+
);
|
|
131
|
+
|
|
132
|
+
vm.expectEmit();
|
|
133
|
+
emit IJBFeeTerminal.ReturnHeldFees(_projectId, _native, payAmount, feeAmountFrom, leftOverAmount, address(this));
|
|
134
|
+
|
|
135
|
+
_terminal.addToBalanceOf{value: payAmount}({
|
|
136
|
+
projectId: _projectId,
|
|
137
|
+
token: _native,
|
|
138
|
+
amount: payAmount,
|
|
139
|
+
shouldReturnHeldFees: _shouldReturnHeldFees,
|
|
140
|
+
memo: "",
|
|
141
|
+
metadata: ""
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
// Heldfee should be erased
|
|
145
|
+
JBFee[] memory feesAfter = _terminal.heldFeesOf(_projectId, _native, 100);
|
|
146
|
+
assertEq(feesAfter.length, 0);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
function test_GivenReturnAmountIsNon_zeroAndLeftoverAmountLTAmountFromFee()
|
|
150
|
+
external
|
|
151
|
+
whenShouldReturnHeldFeesEqTrue
|
|
152
|
+
{
|
|
153
|
+
// it will set heldFeesOf return feeAmountFrom and set leftoverAmount to zero
|
|
154
|
+
uint256 lowerPayAmount = 1e8;
|
|
155
|
+
uint256 returnedFee = JBFees.feeAmountResultingIn(lowerPayAmount, 25);
|
|
156
|
+
|
|
157
|
+
// mock call to store recordAddedBalanceFor
|
|
158
|
+
mockExpect(
|
|
159
|
+
address(store),
|
|
160
|
+
abi.encodeCall(IJBTerminalStore.recordAddedBalanceFor, (_projectId, _native, lowerPayAmount + returnedFee)),
|
|
161
|
+
""
|
|
162
|
+
);
|
|
163
|
+
|
|
164
|
+
vm.expectEmit();
|
|
165
|
+
emit IJBFeeTerminal.ReturnHeldFees(_projectId, _native, lowerPayAmount, returnedFee, 0, address(this));
|
|
166
|
+
|
|
167
|
+
_terminal.addToBalanceOf{value: lowerPayAmount}({
|
|
168
|
+
projectId: _projectId,
|
|
169
|
+
token: _native,
|
|
170
|
+
amount: lowerPayAmount,
|
|
171
|
+
shouldReturnHeldFees: _shouldReturnHeldFees,
|
|
172
|
+
memo: "",
|
|
173
|
+
metadata: ""
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
uint256 newFeeAmount = feeAmount - (lowerPayAmount + returnedFee);
|
|
177
|
+
|
|
178
|
+
// Heldfee should be a new amount
|
|
179
|
+
JBFee[] memory feesAfter = _terminal.heldFeesOf(_projectId, _native, 100);
|
|
180
|
+
assertEq(feesAfter[0].amount, newFeeAmount);
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
function test_WhenShouldReturnHeldFeesEqFalse() external whenNativeTokenIsAccepted {
|
|
184
|
+
// it will call terminalstore recordAddedBalanceFor and emit AddToBalance
|
|
185
|
+
|
|
186
|
+
// mock call to store recordAddedBalanceFor
|
|
187
|
+
mockExpect(
|
|
188
|
+
address(store),
|
|
189
|
+
abi.encodeCall(IJBTerminalStore.recordAddedBalanceFor, (_projectId, _native, payAmount + feeAmountFrom)),
|
|
190
|
+
""
|
|
191
|
+
);
|
|
192
|
+
|
|
193
|
+
vm.expectEmit();
|
|
194
|
+
emit IJBTerminal.AddToBalance(_projectId, payAmount, 0, "", "", address(this));
|
|
195
|
+
|
|
196
|
+
_terminal.addToBalanceOf{value: payAmount}({
|
|
197
|
+
projectId: _projectId,
|
|
198
|
+
token: _native,
|
|
199
|
+
amount: payAmount,
|
|
200
|
+
shouldReturnHeldFees: _shouldReturnHeldFees,
|
|
201
|
+
memo: "",
|
|
202
|
+
metadata: ""
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
function test_WhenTheProjectDNHAccountingContextForTheToken() external {
|
|
207
|
+
// it will revert TOKEN_NOT_ACCEPTED
|
|
208
|
+
|
|
209
|
+
vm.expectRevert(abi.encodeWithSelector(JBMultiTerminal.JBMultiTerminal_TokenNotAccepted.selector, _native));
|
|
210
|
+
|
|
211
|
+
_terminal.addToBalanceOf{value: payAmount}({
|
|
212
|
+
projectId: _projectId,
|
|
213
|
+
token: _native,
|
|
214
|
+
amount: payAmount,
|
|
215
|
+
shouldReturnHeldFees: _shouldReturnHeldFees,
|
|
216
|
+
memo: "",
|
|
217
|
+
metadata: ""
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
function test_WhenTheSpecifiedTokenDNEQNativeTokenAndMsgvalueEqZero() external {
|
|
222
|
+
// it will revert NO_MSG_VALUE_ALLOWED
|
|
223
|
+
|
|
224
|
+
// Accounting Context to set
|
|
225
|
+
JBAccountingContext memory _context =
|
|
226
|
+
JBAccountingContext({token: _usdc, decimals: 18, currency: uint32(_usdcCurrency)});
|
|
227
|
+
|
|
228
|
+
// Find the storage slot
|
|
229
|
+
bytes32 contextSlot = keccak256(abi.encode(_projectId, uint256(0)));
|
|
230
|
+
bytes32 slot = keccak256(abi.encode(_usdc, contextSlot));
|
|
231
|
+
|
|
232
|
+
// Set storage
|
|
233
|
+
vm.store(address(_terminal), slot, bytes32(abi.encode(_context)));
|
|
234
|
+
|
|
235
|
+
JBAccountingContext memory _storedContext = _terminal.accountingContextForTokenOf(_projectId, _usdc);
|
|
236
|
+
assertEq(_storedContext.token, _usdc);
|
|
237
|
+
|
|
238
|
+
vm.expectRevert(abi.encodeWithSelector(JBMultiTerminal.JBMultiTerminal_NoMsgValueAllowed.selector, 1));
|
|
239
|
+
|
|
240
|
+
_terminal.addToBalanceOf{value: 1}({
|
|
241
|
+
projectId: _projectId,
|
|
242
|
+
token: _usdc,
|
|
243
|
+
amount: payAmount,
|
|
244
|
+
shouldReturnHeldFees: _shouldReturnHeldFees,
|
|
245
|
+
memo: "",
|
|
246
|
+
metadata: ""
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
modifier whenPayMetadataContainsPermitData() {
|
|
251
|
+
// Accounting Context to set
|
|
252
|
+
JBAccountingContext memory _context =
|
|
253
|
+
JBAccountingContext({token: _usdc, decimals: 18, currency: uint32(_usdcCurrency)});
|
|
254
|
+
|
|
255
|
+
// Find the storage slot
|
|
256
|
+
bytes32 contextSlot = keccak256(abi.encode(_projectId, uint256(0)));
|
|
257
|
+
bytes32 slot = keccak256(abi.encode(_usdc, contextSlot));
|
|
258
|
+
|
|
259
|
+
// Set storage
|
|
260
|
+
vm.store(address(_terminal), slot, bytes32(abi.encode(_context)));
|
|
261
|
+
|
|
262
|
+
JBAccountingContext memory _storedContext = _terminal.accountingContextForTokenOf(_projectId, _usdc);
|
|
263
|
+
assertEq(_storedContext.token, _usdc);
|
|
264
|
+
|
|
265
|
+
_;
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
/// Permit2 signature helpers.
|
|
269
|
+
/// (required because `permit2/test/utils/PermitSignature.sol` imports `draft-EIP712.sol` which is no longer a
|
|
270
|
+
/// draft.)
|
|
271
|
+
|
|
272
|
+
bytes32 public constant _PERMIT_DETAILS_TYPEHASH =
|
|
273
|
+
keccak256("PermitDetails(address token,uint160 amount,uint48 expiration,uint48 nonce)");
|
|
274
|
+
|
|
275
|
+
bytes32 public constant _PERMIT_SINGLE_TYPEHASH = keccak256(
|
|
276
|
+
"PermitSingle(PermitDetails details,address spender,uint256 sigDeadline)PermitDetails(address token,uint160 amount,uint48 expiration,uint48 nonce)"
|
|
277
|
+
);
|
|
278
|
+
|
|
279
|
+
bytes32 public constant _PERMIT_BATCH_TYPEHASH = keccak256(
|
|
280
|
+
"PermitBatch(PermitDetails[] details,address spender,uint256 sigDeadline)PermitDetails(address token,uint160 amount,uint48 expiration,uint48 nonce)"
|
|
281
|
+
);
|
|
282
|
+
|
|
283
|
+
bytes32 public constant _TOKEN_PERMISSIONS_TYPEHASH = keccak256("TokenPermissions(address token,uint256 amount)");
|
|
284
|
+
|
|
285
|
+
bytes32 public constant _PERMIT_TRANSFER_FROM_TYPEHASH = keccak256(
|
|
286
|
+
"PermitTransferFrom(TokenPermissions permitted,address spender,uint256 nonce,uint256 deadline)TokenPermissions(address token,uint256 amount)"
|
|
287
|
+
);
|
|
288
|
+
|
|
289
|
+
bytes32 public constant _PERMIT_BATCH_TRANSFER_FROM_TYPEHASH = keccak256(
|
|
290
|
+
"PermitBatchTransferFrom(TokenPermissions[] permitted,address spender,uint256 nonce,uint256 deadline)TokenPermissions(address token,uint256 amount)"
|
|
291
|
+
);
|
|
292
|
+
|
|
293
|
+
function getPermitSignatureRaw(
|
|
294
|
+
IAllowanceTransfer.PermitSingle memory permit,
|
|
295
|
+
uint256 privateKey,
|
|
296
|
+
bytes32 domainSeparator
|
|
297
|
+
)
|
|
298
|
+
internal
|
|
299
|
+
pure
|
|
300
|
+
returns (uint8 v, bytes32 r, bytes32 s)
|
|
301
|
+
{
|
|
302
|
+
bytes32 permitHash = keccak256(abi.encode(_PERMIT_DETAILS_TYPEHASH, permit.details));
|
|
303
|
+
|
|
304
|
+
bytes32 msgHash = keccak256(
|
|
305
|
+
abi.encodePacked(
|
|
306
|
+
"\x19\x01",
|
|
307
|
+
domainSeparator,
|
|
308
|
+
keccak256(abi.encode(_PERMIT_SINGLE_TYPEHASH, permitHash, permit.spender, permit.sigDeadline))
|
|
309
|
+
)
|
|
310
|
+
);
|
|
311
|
+
|
|
312
|
+
(v, r, s) = vm.sign(privateKey, msgHash);
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
function getPermitSignature(
|
|
316
|
+
IAllowanceTransfer.PermitSingle memory permit,
|
|
317
|
+
uint256 privateKey,
|
|
318
|
+
bytes32 domainSeparator
|
|
319
|
+
)
|
|
320
|
+
internal
|
|
321
|
+
pure
|
|
322
|
+
returns (bytes memory sig)
|
|
323
|
+
{
|
|
324
|
+
(uint8 v, bytes32 r, bytes32 s) = getPermitSignatureRaw(permit, privateKey, domainSeparator);
|
|
325
|
+
return bytes.concat(r, s, bytes1(v));
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
function test_GivenThePermitAllowanceLtAmount() external whenPayMetadataContainsPermitData {
|
|
329
|
+
// it will revert PERMIT_ALLOWANCE_NOT_ENOUGH
|
|
330
|
+
|
|
331
|
+
uint256 expiration = block.timestamp + 10;
|
|
332
|
+
uint256 deadline = block.timestamp + 10;
|
|
333
|
+
payAmount = 1e18;
|
|
334
|
+
|
|
335
|
+
// Setup: prepare permit details for signing.
|
|
336
|
+
IAllowanceTransfer.PermitDetails memory details = IAllowanceTransfer.PermitDetails({
|
|
337
|
+
token: address(_usdc), amount: uint160(payAmount), expiration: uint48(expiration), nonce: 0
|
|
338
|
+
});
|
|
339
|
+
|
|
340
|
+
IAllowanceTransfer.PermitSingle memory permit =
|
|
341
|
+
IAllowanceTransfer.PermitSingle({details: details, spender: address(_terminal), sigDeadline: deadline});
|
|
342
|
+
|
|
343
|
+
// Setup: sign permit details.
|
|
344
|
+
bytes memory sig = getPermitSignature(permit, fromPrivateKey, DOMAIN_SEPARATOR);
|
|
345
|
+
|
|
346
|
+
JBSingleAllowance memory permitData = JBSingleAllowance({
|
|
347
|
+
sigDeadline: deadline, amount: uint160(1), expiration: uint48(expiration), nonce: uint48(0), signature: sig
|
|
348
|
+
});
|
|
349
|
+
|
|
350
|
+
// Setup: prepare data for metadata helper.
|
|
351
|
+
bytes4[] memory _ids = new bytes4[](1);
|
|
352
|
+
bytes[] memory _datas = new bytes[](1);
|
|
353
|
+
_datas[0] = abi.encode(permitData);
|
|
354
|
+
_ids[0] = _metadataHelper.getId("permit2", address(_terminal));
|
|
355
|
+
|
|
356
|
+
// Setup: use the metadata library to encode.
|
|
357
|
+
bytes memory _packedData = _metadataHelper.createMetadata(_ids, _datas);
|
|
358
|
+
|
|
359
|
+
vm.expectRevert(
|
|
360
|
+
abi.encodeWithSelector(JBMultiTerminal.JBMultiTerminal_PermitAllowanceNotEnough.selector, payAmount, 1)
|
|
361
|
+
);
|
|
362
|
+
|
|
363
|
+
vm.startPrank(from);
|
|
364
|
+
|
|
365
|
+
_terminal.addToBalanceOf({
|
|
366
|
+
projectId: _projectId,
|
|
367
|
+
token: _usdc,
|
|
368
|
+
amount: payAmount,
|
|
369
|
+
shouldReturnHeldFees: false,
|
|
370
|
+
memo: "",
|
|
371
|
+
metadata: _packedData
|
|
372
|
+
});
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
// unfortunately the interface is bugged for the encodeCall here, skipping for now to revisit.
|
|
376
|
+
/* function test_GivenPermitAllowanceIsGood() external whenPayMetadataContainsPermitData {
|
|
377
|
+
// it will set permit allowance to spend tokens for user via permit2
|
|
378
|
+
|
|
379
|
+
uint256 expiration = block.timestamp + 10;
|
|
380
|
+
uint256 deadline = block.timestamp + 10;
|
|
381
|
+
payAmount = 1e18;
|
|
382
|
+
|
|
383
|
+
// Setup: prepare permit details for signing.
|
|
384
|
+
IAllowanceTransfer.PermitDetails memory details = IAllowanceTransfer.PermitDetails({
|
|
385
|
+
token: address(_usdc),
|
|
386
|
+
amount: uint160(payAmount),
|
|
387
|
+
expiration: uint48(expiration),
|
|
388
|
+
nonce: 0
|
|
389
|
+
});
|
|
390
|
+
|
|
391
|
+
IAllowanceTransfer.PermitSingle memory permit =
|
|
392
|
+
IAllowanceTransfer.PermitSingle({details: details, spender: address(_terminal), sigDeadline: deadline});
|
|
393
|
+
|
|
394
|
+
// Setup: sign permit details.
|
|
395
|
+
bytes memory sig = getPermitSignature(permit, fromPrivateKey, DOMAIN_SEPARATOR);
|
|
396
|
+
|
|
397
|
+
JBSingleAllowance memory permitData = JBSingleAllowance({
|
|
398
|
+
sigDeadline: deadline,
|
|
399
|
+
amount: uint160(payAmount),
|
|
400
|
+
expiration: uint48(expiration),
|
|
401
|
+
nonce: uint48(0),
|
|
402
|
+
signature: sig
|
|
403
|
+
});
|
|
404
|
+
|
|
405
|
+
// Setup: prepare data for metadata helper.
|
|
406
|
+
bytes4[] memory _ids = new bytes4[](1);
|
|
407
|
+
bytes[] memory _datas = new bytes[](1);
|
|
408
|
+
_datas[0] = abi.encode(permitData);
|
|
409
|
+
_ids[0] = _metadataHelper.getId("permit2", _terminal)
|
|
410
|
+
|
|
411
|
+
// Setup: use the metadata library to encode.
|
|
412
|
+
bytes memory _packedData = _metadataHelper.createMetadata(_ids, _datas);
|
|
413
|
+
|
|
414
|
+
mockExpect(
|
|
415
|
+
address(permit2),
|
|
416
|
+
abi.encodeCall(IAllowanceTransfer.permit(address, PermitSingle, bytes), (address(from), permit, sig)),
|
|
417
|
+
""
|
|
418
|
+
);
|
|
419
|
+
|
|
420
|
+
vm.startPrank(from);
|
|
421
|
+
|
|
422
|
+
_terminal.addToBalanceOf({
|
|
423
|
+
projectId: _projectId,
|
|
424
|
+
token: _usdc,
|
|
425
|
+
amount: payAmount,
|
|
426
|
+
shouldReturnHeldFees: false,
|
|
427
|
+
memo: "",
|
|
428
|
+
metadata: _packedData
|
|
429
|
+
});
|
|
430
|
+
|
|
431
|
+
} */
|
|
432
|
+
}
|