@zoralabs/coins 0.7.1 → 1.0.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.
Files changed (167) hide show
  1. package/.turbo/turbo-build.log +106 -84
  2. package/CHANGELOG.md +68 -0
  3. package/abis/BadImpl.json +15 -0
  4. package/abis/BalanceDeltaLibrary.json +15 -0
  5. package/abis/BaseCoin.json +1350 -0
  6. package/abis/BaseCoinDeployHook.json +78 -0
  7. package/abis/BaseHook.json +897 -0
  8. package/abis/BaseTest.json +60 -91
  9. package/abis/BeforeSwapDeltaLibrary.json +15 -0
  10. package/abis/BuySupplyWithSwapRouterHook.json +126 -0
  11. package/abis/Coin.json +214 -150
  12. package/abis/CoinConstants.json +65 -0
  13. package/abis/CoinDopplerMultiCurve.json +38 -0
  14. package/abis/CoinRewardsV4.json +54 -0
  15. package/abis/CoinTest.json +66 -111
  16. package/abis/CoinUniV4Test.json +1053 -0
  17. package/abis/CoinV4.json +1687 -0
  18. package/abis/CurrencyLibrary.json +25 -0
  19. package/abis/DeployHooks.json +9 -0
  20. package/abis/DeployScript.json +47 -0
  21. package/abis/DeployedCoinVersionLookup.json +21 -0
  22. package/abis/DeployedCoinVersionLookupTest.json +716 -0
  23. package/abis/DifferentNamespaceVersionLookup.json +39 -0
  24. package/abis/DopplerUniswapV3Test.json +62 -184
  25. package/abis/ERC20.json +310 -0
  26. package/abis/FactoryTest.json +98 -98
  27. package/abis/FakeHookNoInterface.json +21 -0
  28. package/abis/FeeEstimatorHook.json +1528 -0
  29. package/abis/Hooks.json +28 -0
  30. package/abis/HooksDeployment.json +23 -0
  31. package/abis/HooksTest.json +698 -0
  32. package/abis/IAllowanceTransfer.json +486 -0
  33. package/abis/ICoin.json +62 -69
  34. package/abis/ICoinDeployHook.json +31 -0
  35. package/abis/ICoinV3.json +879 -0
  36. package/abis/ICoinV4.json +915 -0
  37. package/abis/IContractMetadata.json +28 -0
  38. package/abis/IDeployedCoinVersionLookup.json +21 -0
  39. package/abis/IEIP712.json +15 -0
  40. package/abis/IEIP712_v4.json +15 -0
  41. package/abis/IERC20Minimal.json +172 -0
  42. package/abis/IERC6909Claims.json +288 -0
  43. package/abis/IERC721.json +36 -36
  44. package/abis/IERC721Permit_v4.json +88 -0
  45. package/abis/IExtsload.json +64 -0
  46. package/abis/IExttload.json +40 -0
  47. package/abis/IHasAfterCoinDeploy.json +31 -0
  48. package/abis/IHasContractName.json +15 -0
  49. package/abis/IHasPoolKey.json +42 -0
  50. package/abis/IHasRewardsRecipients.json +54 -0
  51. package/abis/IHasSwapPath.json +60 -0
  52. package/abis/IHooks.json +789 -0
  53. package/abis/IImmutableState.json +15 -0
  54. package/abis/IMsgSender.json +15 -0
  55. package/abis/IMulticall_v4.json +21 -0
  56. package/abis/INotifier.json +187 -0
  57. package/abis/IPermit2.json +865 -0
  58. package/abis/IPermit2Forwarder.json +138 -0
  59. package/abis/IPoolConfigEncoding.json +46 -0
  60. package/abis/IPoolInitializer_v4.json +53 -0
  61. package/abis/IPoolManager.json +1286 -0
  62. package/abis/IPositionManager.json +712 -0
  63. package/abis/IProtocolFees.json +174 -0
  64. package/abis/ISignatureTransfer.json +394 -0
  65. package/abis/ISubscriber.json +89 -0
  66. package/abis/ISwapPathRouter.json +92 -0
  67. package/abis/ISwapRouter.json +82 -0
  68. package/abis/IUniversalRouter.json +61 -0
  69. package/abis/IUnlockCallback.json +21 -0
  70. package/abis/IUnorderedNonce.json +44 -0
  71. package/abis/IV4Quoter.json +310 -0
  72. package/abis/IV4Router.json +47 -0
  73. package/abis/IZoraFactory.json +328 -4
  74. package/abis/IZoraV4CoinHook.json +427 -0
  75. package/abis/ImmutableState.json +36 -0
  76. package/abis/LPFeeLibrary.json +65 -0
  77. package/abis/MockERC20.json +21 -0
  78. package/abis/MultiOwnableTest.json +60 -91
  79. package/abis/{CoinConfigurationVersions.json → Position.json} +1 -1
  80. package/abis/PrintUpgradeCommand.json +9 -0
  81. package/abis/ProxyShim.json +24 -0
  82. package/abis/Simulate.json +0 -91
  83. package/abis/StateLibrary.json +80 -0
  84. package/abis/TestDeployedCoinVersionLookupImplementation.json +39 -0
  85. package/abis/TestV4Swap.json +9 -0
  86. package/abis/{CoinSetup.json → UniV3BuySell.json} +5 -0
  87. package/abis/UniV3Errors.json +32 -0
  88. package/abis/UpgradeCoinImpl.json +47 -0
  89. package/abis/UpgradeFactoryImpl.json +9 -0
  90. package/abis/UpgradesTest.json +671 -0
  91. package/abis/Vm.json +1482 -111
  92. package/abis/VmSafe.json +856 -32
  93. package/abis/ZoraFactoryImpl.json +450 -1
  94. package/abis/ZoraV4CoinHook.json +1439 -0
  95. package/addresses/8453.json +8 -3
  96. package/addresses/84532.json +8 -3
  97. package/dist/index.cjs +1998 -184
  98. package/dist/index.cjs.map +1 -1
  99. package/dist/index.js +1989 -178
  100. package/dist/index.js.map +1 -1
  101. package/dist/wagmiGenerated.d.ts +2852 -688
  102. package/dist/wagmiGenerated.d.ts.map +1 -1
  103. package/package/wagmiGenerated.ts +1992 -173
  104. package/package.json +7 -2
  105. package/remappings.txt +6 -1
  106. package/script/CoinsDeployerBase.sol +105 -10
  107. package/script/DeployDevFactory.s.sol +21 -0
  108. package/script/DeployHooks.s.sol +22 -0
  109. package/script/PrintUpgradeCommand.s.sol +13 -0
  110. package/script/Simulate.s.sol +4 -12
  111. package/script/TestBackingCoinSwap.s.sol +146 -0
  112. package/script/TestV4Swap.s.sol +136 -0
  113. package/script/UpgradeCoinImpl.sol +2 -2
  114. package/script/UpgradeFactoryImpl.s.sol +23 -0
  115. package/src/BaseCoin.sol +176 -0
  116. package/src/Coin.sol +93 -515
  117. package/src/CoinV4.sol +121 -0
  118. package/src/ZoraFactoryImpl.sol +257 -57
  119. package/src/hooks/ZoraV4CoinHook.sol +195 -0
  120. package/src/hooks/deployment/BaseCoinDeployHook.sol +62 -0
  121. package/src/hooks/deployment/BuySupplyWithSwapRouterHook.sol +80 -0
  122. package/src/interfaces/ICoin.sol +35 -39
  123. package/src/interfaces/ICoinDeployHook.sol +8 -0
  124. package/src/interfaces/ICoinV3.sol +71 -0
  125. package/src/interfaces/ICoinV4.sol +69 -0
  126. package/src/interfaces/IDeployedCoinVersionLookup.sol +11 -0
  127. package/src/interfaces/IMsgSender.sol +9 -0
  128. package/src/interfaces/IPoolConfigEncoding.sol +14 -0
  129. package/src/interfaces/ISwapPathRouter.sol +14 -0
  130. package/src/interfaces/ISwapRouter.sol +1 -35
  131. package/src/interfaces/IZoraFactory.sol +97 -7
  132. package/src/interfaces/IZoraV4CoinHook.sol +116 -0
  133. package/src/libs/CoinCommon.sol +15 -0
  134. package/src/libs/CoinConfigurationVersions.sol +116 -1
  135. package/src/{utils → libs}/CoinConstants.sol +11 -6
  136. package/src/libs/CoinDopplerMultiCurve.sol +134 -0
  137. package/src/libs/CoinDopplerUniV3.sol +19 -171
  138. package/src/libs/CoinRewards.sol +195 -0
  139. package/src/libs/CoinRewardsV4.sol +180 -0
  140. package/src/libs/CoinSetup.sol +40 -20
  141. package/src/libs/CoinSetupV3.sol +50 -0
  142. package/src/libs/DopplerMath.sol +156 -0
  143. package/src/libs/HooksDeployment.sol +84 -0
  144. package/src/libs/MarketConstants.sol +4 -0
  145. package/src/libs/PoolStateReader.sol +22 -0
  146. package/src/libs/UniV3BuySell.sol +231 -0
  147. package/src/libs/UniV3Errors.sol +11 -0
  148. package/src/libs/UniV4SwapHelper.sol +65 -0
  149. package/src/libs/UniV4SwapToCurrency.sol +109 -0
  150. package/src/libs/V4Liquidity.sol +129 -0
  151. package/src/types/PoolConfiguration.sol +15 -0
  152. package/src/utils/DeployedCoinVersionLookup.sol +52 -0
  153. package/src/version/ContractVersionBase.sol +1 -1
  154. package/test/Coin.t.sol +94 -101
  155. package/test/CoinDopplerUniV3.t.sol +35 -184
  156. package/test/CoinUniV4.t.sol +752 -0
  157. package/test/DeploymentHooks.t.sol +270 -0
  158. package/test/Factory.t.sol +84 -50
  159. package/test/MultiOwnable.t.sol +6 -3
  160. package/test/Upgrades.t.sol +68 -0
  161. package/test/mocks/MockERC20.sol +12 -0
  162. package/test/utils/BaseTest.sol +124 -59
  163. package/test/utils/DeployedCoinVersionLookup.t.sol +127 -0
  164. package/test/utils/FeeEstimatorHook.sol +84 -0
  165. package/test/utils/ProxyShim.sol +17 -0
  166. package/wagmi.config.ts +10 -9
  167. package/src/libs/CoinLegacy.sol +0 -48
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zoralabs/coins",
3
- "version": "0.7.1",
3
+ "version": "1.0.0",
4
4
  "type": "module",
5
5
  "main": "./dist/index.cjs",
6
6
  "module": "./dist/index.js",
@@ -21,16 +21,21 @@
21
21
  "@types/node": "^20.1.2",
22
22
  "@wagmi/cli": "^1.0.1",
23
23
  "@solidity-parser/parser": "0.19.0",
24
+ "@uniswap/v4-core": "https://github.com/Uniswap/v4-core#a7cf038cd568801a79a9b4cf92cd5b52c95c8585",
25
+ "@uniswap/v4-periphery": "https://github.com/Uniswap/v4-periphery#eeb3eff28dd5f5f17aa94180fa3610ff59b0e1c8",
26
+ "@uniswap/universal-router": "https://github.com/Uniswap/universal-router#3663f6db6e2fe121753cd2d899699c2dc75dca86",
27
+ "@uniswap/permit2": "https://github.com/Uniswap/permit2#cc56ad0f3439c502c246fc5cfcc3db92bb8b7219",
24
28
  "ds-test": "https://github.com/dapphub/ds-test#cd98eff28324bfac652e63a239a60632a761790b",
25
29
  "forge-std": "https://github.com/foundry-rs/forge-std#v1.9.1",
26
30
  "prettier": "^3.0.3",
27
31
  "prettier-plugin-solidity": "^1.4.1",
28
32
  "solady": "0.0.132",
33
+ "solmate": "6.8.0",
29
34
  "tsup": "^7.2.0",
30
35
  "tsx": "^3.13.0",
31
36
  "typescript": "^5.2.2",
32
37
  "viem": "^2.21.18",
33
- "@zoralabs/shared-contracts": "^0.0.2",
38
+ "@zoralabs/shared-contracts": "^0.0.3",
34
39
  "@zoralabs/shared-scripts": "^0.0.0",
35
40
  "@zoralabs/tsconfig": "^0.0.1"
36
41
  },
package/remappings.txt CHANGED
@@ -2,4 +2,9 @@ ds-test/=node_modules/ds-test/src/
2
2
  forge-std/=node_modules/forge-std/src/
3
3
  @openzeppelin/=node_modules/@openzeppelin/
4
4
  @zoralabs/shared-contracts/=node_modules/@zoralabs/shared-contracts/src/
5
- solady/=node_modules/solady/src/
5
+ solady/=node_modules/solady/src/
6
+ @uniswap/v4-core/=node_modules/@uniswap/v4-core/
7
+ @uniswap/v4-periphery/=node_modules/@uniswap/v4-periphery/
8
+ permit2/src/=node_modules/@uniswap/permit2/src/
9
+ @uniswap/universal-router/contracts/=node_modules/@uniswap/universal-router/contracts/
10
+ solmate/=node_modules/solmate/src/
@@ -8,6 +8,15 @@ import {UUPSUpgradeable} from "@openzeppelin/contracts-upgradeable/proxy/utils/U
8
8
  import {ZoraFactoryImpl} from "../src/ZoraFactoryImpl.sol";
9
9
  import {Coin} from "../src/Coin.sol";
10
10
  import {IVersionedContract} from "@zoralabs/shared-contracts/interfaces/IVersionedContract.sol";
11
+ import {BuySupplyWithSwapRouterHook} from "../src/hooks/deployment/BuySupplyWithSwapRouterHook.sol";
12
+ import {IZoraFactory} from "../src/interfaces/IZoraFactory.sol";
13
+ import {CoinV4} from "../src/CoinV4.sol";
14
+ import {IHooks} from "@uniswap/v4-core/src/interfaces/IHooks.sol";
15
+ import {ZoraV4CoinHook} from "../src/hooks/ZoraV4CoinHook.sol";
16
+ import {IPoolManager} from "@uniswap/v4-core/src/interfaces/IPoolManager.sol";
17
+ import {ZoraFactory} from "../src/proxy/ZoraFactory.sol";
18
+ import {IHooks} from "@uniswap/v4-core/src/interfaces/IHooks.sol";
19
+ import {HooksDeployment} from "../src/libs/HooksDeployment.sol";
11
20
 
12
21
  contract CoinsDeployerBase is ProxyDeployerScript {
13
22
  address internal constant PROTOCOL_REWARDS = 0x7777777F279eba3d3Ad8F4E708545291A6fDBA8B;
@@ -19,8 +28,14 @@ contract CoinsDeployerBase is ProxyDeployerScript {
19
28
  address zoraFactory;
20
29
  address zoraFactoryImpl;
21
30
  // Implementation
22
- address coinImpl;
31
+ address coinV3Impl;
32
+ address coinV4Impl;
23
33
  string coinVersion;
34
+ // hooks
35
+ address buySupplyWithSwapRouterHook;
36
+ address zoraV4CoinHook;
37
+ address devFactory;
38
+ address trustedMessageSenders;
24
39
  }
25
40
 
26
41
  function addressesFile() internal view returns (string memory) {
@@ -33,7 +48,12 @@ contract CoinsDeployerBase is ProxyDeployerScript {
33
48
  vm.serializeAddress(objectKey, "ZORA_FACTORY", deployment.zoraFactory);
34
49
  vm.serializeAddress(objectKey, "ZORA_FACTORY_IMPL", deployment.zoraFactoryImpl);
35
50
  vm.serializeString(objectKey, "COIN_VERSION", deployment.coinVersion);
36
- string memory result = vm.serializeAddress(objectKey, "COIN_IMPL", deployment.coinImpl);
51
+ vm.serializeAddress(objectKey, "BUY_SUPPLY_WITH_SWAP_ROUTER_HOOK", deployment.buySupplyWithSwapRouterHook);
52
+ vm.serializeAddress(objectKey, "COIN_V3_IMPL", deployment.coinV3Impl);
53
+ vm.serializeAddress(objectKey, "DEV_FACTORY", deployment.devFactory);
54
+ vm.serializeAddress(objectKey, "ZORA_V4_COIN_HOOK", deployment.zoraV4CoinHook);
55
+ vm.serializeAddress(objectKey, "TRUSTED_MESSAGE_SENDERS", deployment.trustedMessageSenders);
56
+ string memory result = vm.serializeAddress(objectKey, "COIN_V4_IMPL", deployment.coinV4Impl);
37
57
 
38
58
  vm.writeJson(result, addressesFile());
39
59
  }
@@ -47,23 +67,67 @@ contract CoinsDeployerBase is ProxyDeployerScript {
47
67
 
48
68
  deployment.zoraFactory = readAddressOrDefaultToZero(json, "ZORA_FACTORY");
49
69
  deployment.zoraFactoryImpl = readAddressOrDefaultToZero(json, "ZORA_FACTORY_IMPL");
50
- deployment.coinImpl = readAddressOrDefaultToZero(json, "COIN_IMPL");
70
+ deployment.coinV3Impl = readAddressOrDefaultToZero(json, "COIN_V3_IMPL");
71
+ deployment.coinV4Impl = readAddressOrDefaultToZero(json, "COIN_V4_IMPL");
51
72
  deployment.coinVersion = readStringOrDefaultToEmpty(json, "COIN_VERSION");
73
+ deployment.buySupplyWithSwapRouterHook = readAddressOrDefaultToZero(json, "BUY_SUPPLY_WITH_SWAP_ROUTER_HOOK");
74
+ deployment.zoraV4CoinHook = readAddressOrDefaultToZero(json, "ZORA_V4_COIN_HOOK");
75
+ deployment.devFactory = readAddressOrDefaultToZero(json, "DEV_FACTORY");
76
+ deployment.trustedMessageSenders = readAddressOrDefaultToZero(json, "TRUSTED_MESSAGE_SENDERS");
52
77
  }
53
78
 
54
- function deployCoinImpl() internal returns (Coin) {
55
- return new Coin(getZoraRecipient(), PROTOCOL_REWARDS, getWeth(), getUniswapV3Factory(), getUniswapSwapRouter(), getDopplerAirlock());
79
+ function deployCoinV3Impl() internal returns (Coin) {
80
+ return
81
+ new Coin({
82
+ protocolRewardRecipient_: getZoraRecipient(),
83
+ protocolRewards_: PROTOCOL_REWARDS,
84
+ weth_: getWeth(),
85
+ v3Factory_: getUniswapV3Factory(),
86
+ swapRouter_: getUniswapSwapRouter(),
87
+ airlock_: getDopplerAirlock()
88
+ });
56
89
  }
57
90
 
58
- function deployZoraFactoryImpl(address coinImpl) internal returns (ZoraFactoryImpl) {
59
- return new ZoraFactoryImpl(coinImpl);
91
+ function deployCoinV4Impl(address zoraV4CoinHook) internal returns (CoinV4) {
92
+ return
93
+ new CoinV4({
94
+ protocolRewardRecipient_: getZoraRecipient(),
95
+ protocolRewards_: PROTOCOL_REWARDS,
96
+ poolManager_: IPoolManager(getUniswapV4PoolManager()),
97
+ airlock_: getDopplerAirlock(),
98
+ hooks_: IHooks(zoraV4CoinHook)
99
+ });
100
+ }
101
+
102
+ function deployZoraFactoryImpl(address coinV3Impl, address coinV4Impl) internal returns (ZoraFactoryImpl) {
103
+ return new ZoraFactoryImpl(coinV3Impl, coinV4Impl);
104
+ }
105
+
106
+ function deployBuySupplyWithSwapRouterHook(CoinsDeployment memory deployment) internal returns (BuySupplyWithSwapRouterHook) {
107
+ return new BuySupplyWithSwapRouterHook(IZoraFactory(deployment.zoraFactory), getUniswapSwapRouter());
108
+ }
109
+
110
+ function deployZoraV4CoinHook(address zoraFactory) internal returns (IHooks) {
111
+ return HooksDeployment.deployZoraV4CoinHookFromScript(getUniswapV4PoolManager(), zoraFactory, getDefaultTrustedMessageSenders());
112
+ }
113
+
114
+ function getDefaultTrustedMessageSenders() internal view returns (address[] memory) {
115
+ address[] memory trustedMessageSenders = new address[](2);
116
+ trustedMessageSenders[0] = getUniswapUniversalRouter();
117
+ trustedMessageSenders[1] = getUniswapV4PositionManager();
118
+ return trustedMessageSenders;
60
119
  }
61
120
 
62
121
  function deployImpls(CoinsDeployment memory deployment) internal returns (CoinsDeployment memory) {
122
+ address zoraFactoryImpl = address(deployZoraFactoryImpl(deployment.coinV3Impl, deployment.coinV4Impl));
123
+
63
124
  // Deploy implementation contracts
64
- deployment.coinImpl = address(deployCoinImpl());
65
- deployment.zoraFactoryImpl = address(deployZoraFactoryImpl(deployment.coinImpl));
66
- deployment.coinVersion = IVersionedContract(deployment.coinImpl).contractVersion();
125
+ deployment.coinV3Impl = address(deployCoinV3Impl());
126
+ deployment.zoraV4CoinHook = address(deployZoraV4CoinHook(zoraFactoryImpl));
127
+ deployment.coinV4Impl = address(deployCoinV4Impl(deployment.zoraV4CoinHook));
128
+ deployment.zoraFactoryImpl = zoraFactoryImpl;
129
+ deployment.coinVersion = IVersionedContract(deployment.coinV3Impl).contractVersion();
130
+ deployment.buySupplyWithSwapRouterHook = address(deployBuySupplyWithSwapRouterHook(deployment));
67
131
 
68
132
  return deployment;
69
133
  }
@@ -101,4 +165,35 @@ contract CoinsDeployerBase is ProxyDeployerScript {
101
165
  // validate that the zora factory owner is the proxy admin
102
166
  require(ZoraFactoryImpl(deployment.zoraFactory).owner() == getProxyAdmin(), "Zora factory owner is not the proxy admin");
103
167
  }
168
+
169
+ function deployDevFactory(CoinsDeployment memory deployment) internal returns (ZoraFactory devFactory) {
170
+ address owner = 0x63545B401283c993320A5b886ecF0fc6CB5668a9;
171
+
172
+ devFactory = new ZoraFactory(deployment.zoraFactoryImpl);
173
+
174
+ ZoraFactoryImpl(address(devFactory)).initialize(owner);
175
+
176
+ deployment.devFactory = address(devFactory);
177
+ }
178
+
179
+ function printUpgradeFactoryCommand(CoinsDeployment memory deployment) internal view {
180
+ // build upgrade to and call for factory, with init call
181
+ bytes memory call = abi.encodeWithSelector(UUPSUpgradeable.upgradeToAndCall.selector, deployment.zoraFactoryImpl, "");
182
+
183
+ address proxyAdmin = getProxyAdmin();
184
+
185
+ address target = address(deployment.zoraFactory);
186
+
187
+ // print the details for upgrading:
188
+
189
+ console.log("To upgrade the factory, this is the call information:");
190
+
191
+ console.log("Multisig:", proxyAdmin);
192
+ console.log("Target (the factory proxy):", target);
193
+ console.log("Upgrade call:");
194
+ console.logBytes(call);
195
+ console.log("Function to call: upgradeToAndCall");
196
+ // concat the args into a string, factoryImpl, ""
197
+ console.log("Args: ", string.concat(vm.toString(deployment.zoraFactoryImpl), ",", '"'));
198
+ }
104
199
  }
@@ -0,0 +1,21 @@
1
+ // SPDX-License-Identifier: MIT
2
+ pragma solidity ^0.8.28;
3
+
4
+ import {ProxyDeployerScript, DeterministicDeployerAndCaller} from "@zoralabs/shared-contracts/deployment/ProxyDeployerScript.sol";
5
+ import {CoinsDeployerBase} from "./CoinsDeployerBase.sol";
6
+
7
+ contract DeployScript is CoinsDeployerBase {
8
+ function run() public {
9
+ CoinsDeployment memory deployment = readDeployment();
10
+
11
+ vm.startBroadcast();
12
+
13
+ // get deployer contract
14
+ deployDevFactory(deployment);
15
+
16
+ vm.stopBroadcast();
17
+
18
+ // save the deployment json
19
+ saveDeployment(deployment);
20
+ }
21
+ }
@@ -0,0 +1,22 @@
1
+ // SPDX-License-Identifier: MIT
2
+ pragma solidity ^0.8.28;
3
+
4
+ import {CoinsDeployerBase} from "./CoinsDeployerBase.sol";
5
+ import {ZoraFactoryImpl} from "../src/ZoraFactoryImpl.sol";
6
+
7
+ contract DeployHooks is CoinsDeployerBase {
8
+ function run() public {
9
+ CoinsDeployment memory deployment = readDeployment();
10
+
11
+ vm.startBroadcast();
12
+
13
+ address buySupplyWithSwapRouterHook = address(deployBuySupplyWithSwapRouterHook(deployment));
14
+
15
+ deployment.buySupplyWithSwapRouterHook = buySupplyWithSwapRouterHook;
16
+
17
+ vm.stopBroadcast();
18
+
19
+ // save the deployment json
20
+ saveDeployment(deployment);
21
+ }
22
+ }
@@ -0,0 +1,13 @@
1
+ // SPDX-License-Identifier: MIT
2
+ pragma solidity ^0.8.26;
3
+
4
+ import {ProxyDeployerScript, DeterministicDeployerAndCaller} from "@zoralabs/shared-contracts/deployment/ProxyDeployerScript.sol";
5
+ import {CoinsDeployerBase} from "./CoinsDeployerBase.sol";
6
+
7
+ contract PrintUpgradeCommand is CoinsDeployerBase {
8
+ function run() public {
9
+ CoinsDeployment memory deployment = readDeployment();
10
+
11
+ printUpgradeFactoryCommand(deployment);
12
+ }
13
+ }
@@ -3,12 +3,13 @@ pragma solidity ^0.8.13;
3
3
 
4
4
  import {Script, console} from "forge-std/Script.sol";
5
5
 
6
- import {Coin, CoinConstants} from "../src/Coin.sol";
6
+ import {Coin} from "../src/Coin.sol";
7
+ import {CoinConstants} from "../src/libs/CoinConstants.sol";
7
8
  import {ZoraFactoryImpl} from "../src/ZoraFactoryImpl.sol";
8
9
  import {ZoraFactory} from "../src/proxy/ZoraFactory.sol";
9
10
 
10
11
  /// @dev For simulating pre-buys -- eg `forge script script/Simulate.s.sol --private-key $DEPLOYER_PK --rpc-url $BASE_MAINNET_RPC_URL -vvvv`
11
- contract Simulate is Script, CoinConstants {
12
+ contract Simulate is Script {
12
13
  // https://basescan.org/address/0x02B2705500096Ff83F9eF78873ca5DFB06C00Ddc
13
14
  address internal constant TEST_ZORA_FACTORY_ADDRESS_BASE_MAINNET = 0x02B2705500096Ff83F9eF78873ca5DFB06C00Ddc;
14
15
  address internal constant WETH_ADDRESS = 0x4200000000000000000000000000000000000006;
@@ -41,16 +42,7 @@ contract Simulate is Script, CoinConstants {
41
42
 
42
43
  // Prebuy order size
43
44
  uint256 orderSize = 0.000111 ether;
44
- (address coinAddress, uint256 coinsPurchased) = factory.deploy{value: orderSize}(
45
- payoutAddress,
46
- owners,
47
- uri,
48
- name,
49
- symbol,
50
- poolConfig,
51
- payoutAddress,
52
- orderSize
53
- );
45
+ factory.deploy{value: orderSize}(payoutAddress, owners, uri, name, symbol, poolConfig, payoutAddress, orderSize);
54
46
 
55
47
  vm.stopBroadcast();
56
48
  }
@@ -0,0 +1,146 @@
1
+ // SPDX-License-Identifier: MIT
2
+ pragma solidity ^0.8.28;
3
+
4
+ import {ProxyDeployerScript, DeterministicDeployerAndCaller} from "@zoralabs/shared-contracts/deployment/ProxyDeployerScript.sol";
5
+ import {CoinsDeployerBase} from "./CoinsDeployerBase.sol";
6
+
7
+ import {IZoraFactory} from "../src/interfaces/IZoraFactory.sol";
8
+ import {CoinConfigurationVersions} from "../src/libs/CoinConfigurationVersions.sol";
9
+ import {MarketConstants} from "../src/libs/MarketConstants.sol";
10
+ import {UniV4SwapHelper} from "../src/libs/UniV4SwapHelper.sol";
11
+ import {CoinV4} from "../src/CoinV4.sol";
12
+ import {PoolKey} from "@uniswap/v4-core/src/types/PoolKey.sol";
13
+ import {IUniversalRouter} from "@uniswap/universal-router/contracts/interfaces/IUniversalRouter.sol";
14
+ import {IPermit2} from "permit2/src/interfaces/IPermit2.sol";
15
+ import {MockERC20} from "../test/mocks/MockERC20.sol";
16
+ import {MarketConstants} from "../src/libs/MarketConstants.sol";
17
+ import {Currency} from "@uniswap/v4-core/src/types/Currency.sol";
18
+ import {IERC20} from "@openzeppelin/contracts/token/ERC20/IERC20.sol";
19
+ import {ICoinV4} from "../src/interfaces/ICoinV4.sol";
20
+
21
+ import {console} from "forge-std/console.sol";
22
+
23
+ contract TestV4Swap is CoinsDeployerBase {
24
+ int24 internal constant DEFAULT_DISCOVERY_TICK_LOWER = -777000;
25
+ int24 internal constant DEFAULT_DISCOVERY_TICK_UPPER = 222000;
26
+ uint16 internal constant DEFAULT_NUM_DISCOVERY_POSITIONS = 10; // will be 11 total with tail position
27
+ uint256 internal constant DEFAULT_DISCOVERY_SUPPLY_SHARE = 0.495e18; //
28
+
29
+ function _deployCoin(
30
+ address currency,
31
+ address creator,
32
+ string memory name,
33
+ string memory symbol,
34
+ string memory uri,
35
+ address createReferral,
36
+ bytes32 salt
37
+ ) internal returns (ICoinV4 coin) {
38
+ CoinsDeployment memory deployment = readDeployment();
39
+ address[] memory owners = new address[](1);
40
+ owners[0] = creator;
41
+
42
+ bytes memory poolConfig = CoinConfigurationVersions.defaultDopplerMultiCurveUniV4(address(currency));
43
+
44
+ (address coinAddress, ) = IZoraFactory(deployment.devFactory).deploy(
45
+ creator,
46
+ owners,
47
+ uri,
48
+ name,
49
+ symbol,
50
+ poolConfig,
51
+ createReferral,
52
+ address(0),
53
+ "",
54
+ salt
55
+ );
56
+
57
+ coin = ICoinV4(coinAddress);
58
+ }
59
+
60
+ function _swap(address currencyIn, uint128 amountIn, ICoinV4 coin, address trader, address tradeReferral) internal returns (uint256 amountOut) {
61
+ uint128 minAmountOut = 0;
62
+
63
+ PoolKey memory poolKey = coin.getPoolKey();
64
+
65
+ bytes memory hookData = tradeReferral != address(0) ? abi.encode(tradeReferral) : bytes("");
66
+
67
+ address currencyOut = Currency.unwrap(Currency.unwrap(poolKey.currency0) == currencyIn ? poolKey.currency1 : poolKey.currency0);
68
+
69
+ // now we need to swap some currency into the coin
70
+ // first let
71
+ (bytes memory commands, bytes[] memory inputs) = UniV4SwapHelper.buildExactInputSingleSwapCommand(
72
+ currencyIn,
73
+ amountIn,
74
+ currencyOut,
75
+ minAmountOut,
76
+ poolKey,
77
+ hookData
78
+ );
79
+
80
+ UniV4SwapHelper.approveTokenWithPermit2(
81
+ IPermit2(getUniswapPermit2()),
82
+ getUniswapUniversalRouter(),
83
+ currencyIn,
84
+ amountIn,
85
+ uint48(block.timestamp + 1 days)
86
+ );
87
+
88
+ uint256 balanceBefore = IERC20(currencyOut).balanceOf(trader);
89
+
90
+ // Execute the swap
91
+ uint256 deadline = block.timestamp + 1 days;
92
+ IUniversalRouter(getUniswapUniversalRouter()).execute(commands, inputs, deadline);
93
+
94
+ amountOut = IERC20(currencyOut).balanceOf(trader) - balanceBefore;
95
+ }
96
+
97
+ function run() public {
98
+ address trader = vm.envAddress("TRADER");
99
+
100
+ require(block.chainid == 8453, "only on base");
101
+
102
+ address zora = 0x1111111111166b7FE7bd91427724B487980aFc69;
103
+
104
+ vm.startBroadcast(trader);
105
+
106
+ // address createReferral = 0xC077e4cC02fa01A5b7fAca1acE9BBe9f5ac5Af9F;
107
+ address tradeReferral = 0xC077e4cC02fa01A5b7fAca1acE9BBe9f5ac5Af9F;
108
+ // ICoinV4 backingCoin = _deployCoin(zora, trader, "TestCCoin", "CRE", "https://testc.com", createReferral, bytes32("creator"));
109
+ // ICoinV4 contentCoin = _deployCoin(
110
+ // address(backingCoin),
111
+ // trader,
112
+ // "Content Coin",
113
+ // "CONTENT",
114
+ // "https://content.com",
115
+ // createReferral,
116
+ // bytes32("content coin")
117
+ // );
118
+ ICoinV4 backingCoin = ICoinV4(0xeA734b5997F35cD469921cCa7BB9A03C104f2f64);
119
+ ICoinV4 contentCoin = ICoinV4(0x72218BFEEc7D556BD3Dd8eFf2a317CEd49533769);
120
+
121
+ console.log("backingCoin", address(backingCoin));
122
+ console.log("contentCoin", address(contentCoin));
123
+ // console.log("currency", address(currency));
124
+
125
+ // (MockERC20 currency, address coinAddress) = _deployMockCurrencyAndCoin(trader, createReferral);
126
+
127
+ // address coinAddress = vm.parseAddress("0x58c0d8803Ae97bEF212EdFA8ba2FE303670cca9D");
128
+ // console.log("currency", address(currency));
129
+ // console.log("coinAddress", coinAddress);
130
+
131
+ // swap in 2 ether of currency into the coin
132
+ uint128 amountIn = uint128(IERC20(zora).balanceOf(trader));
133
+ // currency.mint(trader, amountIn);
134
+
135
+ // // swap some currency into the backing coin
136
+ uint256 backingCoinReceived = _swap(zora, amountIn, backingCoin, trader, tradeReferral);
137
+
138
+ // // swap balance of backing coin into the content coin
139
+ uint256 contentCoinReceived = _swap(address(backingCoin), uint128(backingCoinReceived), contentCoin, trader, tradeReferral);
140
+
141
+ // swap balance of content coin into the currency
142
+ _swap(address(contentCoin), uint128(contentCoinReceived), contentCoin, trader, tradeReferral);
143
+
144
+ vm.stopBroadcast();
145
+ }
146
+ }
@@ -0,0 +1,136 @@
1
+ // SPDX-License-Identifier: MIT
2
+ pragma solidity ^0.8.28;
3
+
4
+ import {ProxyDeployerScript, DeterministicDeployerAndCaller} from "@zoralabs/shared-contracts/deployment/ProxyDeployerScript.sol";
5
+ import {CoinsDeployerBase} from "./CoinsDeployerBase.sol";
6
+
7
+ import {IZoraFactory} from "../src/interfaces/IZoraFactory.sol";
8
+ import {CoinConfigurationVersions} from "../src/libs/CoinConfigurationVersions.sol";
9
+ import {MarketConstants} from "../src/libs/MarketConstants.sol";
10
+ import {UniV4SwapHelper} from "../src/libs/UniV4SwapHelper.sol";
11
+ import {CoinV4} from "../src/CoinV4.sol";
12
+ import {PoolKey} from "@uniswap/v4-core/src/types/PoolKey.sol";
13
+ import {IUniversalRouter} from "@uniswap/universal-router/contracts/interfaces/IUniversalRouter.sol";
14
+ import {IPermit2} from "permit2/src/interfaces/IPermit2.sol";
15
+ import {MockERC20} from "../test/mocks/MockERC20.sol";
16
+ import {MarketConstants} from "../src/libs/MarketConstants.sol";
17
+ import {Currency} from "@uniswap/v4-core/src/types/Currency.sol";
18
+ import {IERC20} from "@openzeppelin/contracts/token/ERC20/IERC20.sol";
19
+ import {ICoinV4} from "../src/interfaces/ICoinV4.sol";
20
+
21
+ import {console} from "forge-std/console.sol";
22
+
23
+ contract TestV4Swap is CoinsDeployerBase {
24
+ int24 internal constant DEFAULT_DISCOVERY_TICK_LOWER = -777000;
25
+ int24 internal constant DEFAULT_DISCOVERY_TICK_UPPER = 222000;
26
+ uint16 internal constant DEFAULT_NUM_DISCOVERY_POSITIONS = 10; // will be 11 total with tail position
27
+ uint256 internal constant DEFAULT_DISCOVERY_SUPPLY_SHARE = 0.495e18; //
28
+
29
+ function _deployMockCurrency() internal returns (MockERC20 currency) {
30
+ currency = new MockERC20("Testcoin", "TEST");
31
+ currency.mint(getUniswapV4PoolManager(), 1000000 ether);
32
+ }
33
+
34
+ function _deployMockCoin(address currency, address creator, address createReferral, bytes32 salt) internal returns (ICoinV4 coin) {
35
+ CoinsDeployment memory deployment = readDeployment();
36
+ address[] memory owners = new address[](1);
37
+ owners[0] = creator;
38
+
39
+ bytes memory poolConfig = CoinConfigurationVersions.defaultDopplerMultiCurveUniV4(address(currency));
40
+
41
+ (address coinAddress, ) = IZoraFactory(deployment.zoraFactory).deploy(
42
+ creator,
43
+ owners,
44
+ "https://test.com",
45
+ "Testcoin",
46
+ "TEST",
47
+ poolConfig,
48
+ createReferral,
49
+ address(0),
50
+ "",
51
+ salt
52
+ );
53
+
54
+ coin = ICoinV4(coinAddress);
55
+ }
56
+
57
+ function _swap(address currencyIn, uint128 amountIn, ICoinV4 coin, address trader, address tradeReferral) internal returns (uint256 amountOut) {
58
+ uint128 minAmountOut = 0;
59
+
60
+ PoolKey memory poolKey = coin.getPoolKey();
61
+
62
+ bytes memory hookData = tradeReferral != address(0) ? abi.encode(tradeReferral) : bytes("");
63
+
64
+ address currencyOut = Currency.unwrap(Currency.unwrap(poolKey.currency0) == currencyIn ? poolKey.currency1 : poolKey.currency0);
65
+
66
+ // now we need to swap some currency into the coin
67
+ // first let
68
+ (bytes memory commands, bytes[] memory inputs) = UniV4SwapHelper.buildExactInputSingleSwapCommand(
69
+ currencyIn,
70
+ amountIn,
71
+ currencyOut,
72
+ minAmountOut,
73
+ poolKey,
74
+ hookData
75
+ );
76
+
77
+ UniV4SwapHelper.approveTokenWithPermit2(
78
+ IPermit2(getUniswapPermit2()),
79
+ getUniswapUniversalRouter(),
80
+ currencyIn,
81
+ amountIn,
82
+ uint48(block.timestamp + 1 days)
83
+ );
84
+
85
+ uint256 balanceBefore = IERC20(currencyOut).balanceOf(trader);
86
+
87
+ // Execute the swap
88
+ uint256 deadline = block.timestamp + 1 days;
89
+ IUniversalRouter(getUniswapUniversalRouter()).execute(commands, inputs, deadline);
90
+
91
+ amountOut = IERC20(currencyOut).balanceOf(trader) - balanceBefore;
92
+ }
93
+
94
+ function run() public {
95
+ address trader = vm.envAddress("TRADER");
96
+
97
+ vm.startBroadcast(trader);
98
+
99
+ // address createReferral = 0xC077e4cC02fa01A5b7fAca1acE9BBe9f5ac5Af9F;
100
+ address tradeReferral = 0xC077e4cC02fa01A5b7fAca1acE9BBe9f5ac5Af9F;
101
+
102
+ // MockERC20 currency = _deployMockCurrency();
103
+
104
+ // ICoinV4 backingCoin = _deployMockCoin(address(currency), trader, createReferral, bytes32("backing coin"));
105
+ // ICoinV4 contentCoin = _deployMockCoin(address(backingCoin), trader, createReferral, bytes32("content coin"));
106
+
107
+ MockERC20 currency = MockERC20(0x21E3bde504fF56C440851ACB6A16e7E35405B278);
108
+ ICoinV4 backingCoin = ICoinV4(0xa8bb679A2be09eCCabdb76700170ec387C896570);
109
+ ICoinV4 contentCoin = ICoinV4(0x3cfE4CE87A821FB2c7eAB4359dD6eA6F9e492c61);
110
+
111
+ console.log("backingCoin", address(backingCoin));
112
+ console.log("contentCoin", address(contentCoin));
113
+ console.log("currency", address(currency));
114
+
115
+ // (MockERC20 currency, address coinAddress) = _deployMockCurrencyAndCoin(trader, createReferral);
116
+
117
+ // address coinAddress = vm.parseAddress("0x58c0d8803Ae97bEF212EdFA8ba2FE303670cca9D");
118
+ // console.log("currency", address(currency));
119
+ // console.log("coinAddress", coinAddress);
120
+
121
+ // swap in 2 ether of currency into the coin
122
+ uint128 amountIn = 2 ether;
123
+ currency.mint(trader, amountIn);
124
+
125
+ // swap some currency into the backing coin
126
+ uint256 backingCoinReceived = _swap(address(currency), amountIn, backingCoin, trader, tradeReferral);
127
+
128
+ // swap balance of backing coin into the content coin
129
+ uint256 contentCoinReceived = _swap(address(backingCoin), uint128(backingCoinReceived), contentCoin, trader, tradeReferral);
130
+
131
+ // swap balance of content coin into the currency
132
+ _swap(address(contentCoin), uint128(contentCoinReceived), contentCoin, trader, tradeReferral);
133
+
134
+ vm.stopBroadcast();
135
+ }
136
+ }
@@ -11,13 +11,13 @@ contract UpgradeCoinImpl is CoinsDeployerBase {
11
11
  vm.startBroadcast();
12
12
 
13
13
  // get deployer contract
14
- DeterministicDeployerAndCaller deployer = createOrGetDeployerAndCaller();
15
-
16
14
  deployment = deployImpls(deployment);
17
15
 
18
16
  vm.stopBroadcast();
19
17
 
20
18
  // save the deployment json
21
19
  saveDeployment(deployment);
20
+
21
+ printUpgradeFactoryCommand(deployment);
22
22
  }
23
23
  }
@@ -0,0 +1,23 @@
1
+ // SPDX-License-Identifier: MIT
2
+ pragma solidity ^0.8.28;
3
+
4
+ import {CoinsDeployerBase} from "./CoinsDeployerBase.sol";
5
+ import {ZoraFactoryImpl} from "../src/ZoraFactoryImpl.sol";
6
+
7
+ contract UpgradeFactoryImpl is CoinsDeployerBase {
8
+ function run() public {
9
+ CoinsDeployment memory deployment = readDeployment();
10
+
11
+ vm.startBroadcast();
12
+
13
+ ZoraFactoryImpl zoraFactoryImpl = deployZoraFactoryImpl(deployment.coinV3Impl, deployment.coinV4Impl);
14
+
15
+ deployment.zoraFactoryImpl = address(zoraFactoryImpl);
16
+
17
+ vm.stopBroadcast();
18
+
19
+ // save the deployment json
20
+ saveDeployment(deployment);
21
+ printUpgradeFactoryCommand(deployment);
22
+ }
23
+ }