@etherisc/gif-next 0.0.2-f2b0fa2-473 → 0.0.2-f30e0eb-805

Sign up to get free protection for your applications and to get access to all the features.
Files changed (379) hide show
  1. package/README.md +140 -2
  2. package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
  3. package/artifacts/contracts/components/Component.sol/Component.json +832 -0
  4. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
  5. package/artifacts/contracts/components/Distribution.sol/Distribution.json +938 -229
  6. package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
  7. package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → components/IComponent.sol/IComponent.json} +192 -168
  8. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  9. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +743 -26
  10. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  11. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +755 -50
  12. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  13. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +582 -9
  14. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  15. package/artifacts/contracts/components/Pool.sol/Pool.json +818 -236
  16. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  17. package/artifacts/contracts/components/Product.sol/Product.json +627 -224
  18. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
  19. package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
  20. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
  21. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +778 -0
  22. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
  23. package/artifacts/contracts/instance/{AccessManagedSimple.sol/AccessManagedSimple.json → Cloneable.sol/Cloneable.json} +91 -2
  24. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  25. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +2185 -189
  26. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  27. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +299 -153
  28. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  29. package/artifacts/contracts/instance/Instance.sol/Instance.json +993 -1183
  30. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
  31. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +571 -177
  32. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  33. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +232 -210
  34. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  35. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +520 -190
  36. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  37. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +352 -75
  38. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  39. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +256 -0
  40. package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
  41. package/artifacts/contracts/{shared/RegisterableUpgradable.sol/RegisterableUpgradable.json → instance/base/ComponentService.sol/ComponentService.json} +236 -126
  42. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  43. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  44. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  45. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +40 -10
  46. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  47. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
  48. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  49. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +69 -43
  50. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  51. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
  52. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.json +10 -0
  53. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  54. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  55. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  56. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
  57. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
  58. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
  59. package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +968 -0
  60. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
  61. package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +665 -0
  62. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
  63. package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1093 -0
  64. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
  65. package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +661 -0
  66. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
  67. package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +754 -0
  68. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
  69. package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +637 -0
  70. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
  71. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1732 -0
  72. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  73. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +805 -0
  74. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
  75. package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +556 -0
  76. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
  77. package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +630 -0
  78. package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
  79. package/artifacts/contracts/instance/service/{IComponentOwnerService.sol/IComponentOwnerService.json → IClaimService.sol/IClaimService.json} +150 -207
  80. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  81. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +727 -160
  82. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
  83. package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +540 -0
  84. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
  85. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +84 -217
  86. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
  87. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +47 -414
  88. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
  89. package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1021 -0
  90. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
  91. package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +689 -0
  92. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
  93. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +824 -0
  94. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  95. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +657 -0
  96. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
  97. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +777 -0
  98. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  99. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +649 -0
  100. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  101. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
  102. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  103. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +373 -61
  104. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  105. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +234 -216
  106. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  107. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
  108. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  109. package/artifacts/contracts/registry/Registry.sol/Registry.json +333 -188
  110. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
  111. package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
  112. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  113. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +229 -313
  114. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  115. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +304 -138
  116. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
  117. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +547 -0
  118. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
  119. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +498 -0
  120. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
  121. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  122. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
  123. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  124. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +40 -29
  125. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
  126. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +129 -0
  127. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  128. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +21 -34
  129. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
  130. package/artifacts/contracts/{experiment/inheritance/IB.sol/IB.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +18 -20
  131. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  132. package/artifacts/contracts/shared/IService.sol/IService.json +31 -183
  133. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  134. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
  135. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  136. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +120 -27
  137. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
  138. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +248 -0
  139. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  140. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +294 -61
  141. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  142. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +129 -51
  143. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
  144. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +84 -0
  145. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  146. package/artifacts/contracts/shared/Service.sol/Service.json +127 -170
  147. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  148. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
  149. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  150. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  151. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  152. package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
  153. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
  154. package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
  155. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
  156. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +129 -51
  157. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
  158. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +6 -6
  159. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
  160. package/artifacts/contracts/test/TestService.sol/TestService.json +148 -227
  161. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
  162. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
  163. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
  164. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
  165. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -190
  166. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
  167. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  168. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  169. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
  170. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  171. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
  172. package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
  173. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  174. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
  175. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
  176. package/artifacts/contracts/types/Fee.sol/FeeLib.json +2 -2
  177. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
  178. package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
  179. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  180. package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
  181. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  182. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
  183. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
  184. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  185. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
  186. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
  187. package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
  188. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
  189. package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
  190. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
  191. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
  192. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
  193. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
  194. package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
  195. package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
  196. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
  197. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
  198. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
  199. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +25 -7
  200. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
  201. package/artifacts/contracts/types/UFixed.sol/MathLib.json +2 -2
  202. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
  203. package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +2 -2
  204. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
  205. package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
  206. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
  207. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +22 -3
  208. package/contracts/components/Component.sol +251 -0
  209. package/contracts/components/Distribution.sol +200 -86
  210. package/contracts/components/IComponent.sol +74 -0
  211. package/contracts/components/IDistributionComponent.sol +44 -16
  212. package/contracts/components/IPoolComponent.sol +88 -37
  213. package/contracts/components/IProductComponent.sol +10 -5
  214. package/contracts/components/Pool.sol +217 -177
  215. package/contracts/components/Product.sol +130 -134
  216. package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +13 -0
  217. package/contracts/instance/BundleManager.sol +127 -0
  218. package/contracts/instance/Cloneable.sol +51 -0
  219. package/contracts/instance/IInstance.sol +81 -11
  220. package/contracts/instance/IInstanceService.sol +56 -1
  221. package/contracts/instance/Instance.sol +156 -265
  222. package/contracts/instance/InstanceAccessManager.sol +410 -176
  223. package/contracts/instance/InstanceReader.sol +39 -29
  224. package/contracts/instance/InstanceService.sol +448 -55
  225. package/contracts/instance/InstanceServiceManager.sol +11 -13
  226. package/contracts/instance/ObjectManager.sol +82 -0
  227. package/contracts/instance/base/ComponentService.sol +134 -0
  228. package/contracts/instance/base/KeyValueStore.sol +5 -2
  229. package/contracts/instance/base/Lifecycle.sol +11 -2
  230. package/contracts/instance/module/IAccess.sol +36 -20
  231. package/contracts/instance/module/IBundle.sol +2 -0
  232. package/contracts/instance/module/IComponents.sol +35 -0
  233. package/contracts/instance/module/IDistribution.sol +2 -0
  234. package/contracts/instance/module/IPolicy.sol +30 -3
  235. package/contracts/instance/module/ISetup.sol +9 -19
  236. package/contracts/instance/service/ApplicationService.sol +350 -0
  237. package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
  238. package/contracts/instance/service/BundleService.sol +336 -0
  239. package/contracts/instance/service/BundleServiceManager.sol +51 -0
  240. package/contracts/instance/service/ClaimService.sol +151 -0
  241. package/contracts/instance/service/ClaimServiceManager.sol +35 -0
  242. package/contracts/instance/service/DistributionService.sol +467 -0
  243. package/contracts/instance/service/DistributionServiceManager.sol +51 -0
  244. package/contracts/instance/service/IApplicationService.sol +82 -0
  245. package/contracts/instance/service/IBundleService.sol +62 -0
  246. package/contracts/instance/service/IClaimService.sol +61 -0
  247. package/contracts/instance/service/IDistributionService.sol +86 -0
  248. package/contracts/instance/service/IPolicyService.sol +72 -0
  249. package/contracts/instance/service/IPoolService.sol +21 -23
  250. package/contracts/instance/service/IProductService.sol +6 -73
  251. package/contracts/instance/service/PolicyService.sol +403 -0
  252. package/contracts/instance/service/PolicyServiceManager.sol +54 -0
  253. package/contracts/instance/service/PoolService.sol +220 -0
  254. package/contracts/instance/service/PoolServiceManager.sol +51 -0
  255. package/contracts/instance/service/ProductService.sol +241 -0
  256. package/contracts/instance/service/ProductServiceManager.sol +54 -0
  257. package/contracts/registry/ChainNft.sol +9 -1
  258. package/contracts/registry/IRegistry.sol +52 -8
  259. package/contracts/registry/IRegistryService.sol +46 -14
  260. package/contracts/registry/ITransferInterceptor.sol +1 -0
  261. package/contracts/registry/Registry.sol +270 -226
  262. package/contracts/registry/RegistryAccessManager.sol +216 -0
  263. package/contracts/registry/RegistryService.sol +110 -266
  264. package/contracts/registry/RegistryServiceManager.sol +24 -26
  265. package/contracts/registry/ReleaseManager.sol +322 -0
  266. package/contracts/registry/TokenRegistry.sol +116 -0
  267. package/contracts/shared/ERC165.sol +14 -8
  268. package/contracts/shared/INftOwnable.sol +11 -10
  269. package/contracts/shared/IPolicyHolder.sol +26 -0
  270. package/contracts/shared/IRegisterable.sol +4 -6
  271. package/contracts/shared/IRegistryLinked.sol +12 -0
  272. package/contracts/shared/IService.sol +4 -1
  273. package/contracts/shared/IVersionable.sol +4 -47
  274. package/contracts/shared/NftOwnable.sol +67 -83
  275. package/contracts/shared/PolicyHolder.sol +81 -0
  276. package/contracts/shared/ProxyManager.sol +100 -25
  277. package/contracts/shared/Registerable.sol +16 -31
  278. package/contracts/shared/RegistryLinked.sol +48 -0
  279. package/contracts/shared/Service.sol +26 -22
  280. package/contracts/shared/TokenHandler.sol +11 -5
  281. package/contracts/shared/Versionable.sol +4 -92
  282. package/contracts/test/TestRegisterable.sol +1 -1
  283. package/contracts/test/TestService.sol +4 -3
  284. package/contracts/types/Blocknumber.sol +1 -0
  285. package/contracts/types/ClaimId.sol +52 -0
  286. package/contracts/types/DistributorType.sol +2 -2
  287. package/contracts/types/Fee.sol +1 -0
  288. package/contracts/types/NftId.sol +8 -0
  289. package/contracts/types/NftIdSet.sol +26 -24
  290. package/contracts/types/ObjectType.sol +10 -5
  291. package/contracts/types/PayoutId.sol +54 -0
  292. package/contracts/types/Referral.sol +4 -0
  293. package/contracts/types/RoleId.sol +26 -11
  294. package/contracts/types/Seconds.sol +54 -0
  295. package/contracts/types/StateId.sol +5 -0
  296. package/contracts/types/Timestamp.sol +13 -13
  297. package/contracts/types/UFixed.sol +1 -0
  298. package/contracts/types/Version.sol +5 -1
  299. package/package.json +3 -3
  300. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
  301. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -314
  302. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
  303. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -267
  304. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
  305. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
  306. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
  307. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
  308. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
  309. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
  310. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
  311. package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
  312. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
  313. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
  314. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
  315. package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
  316. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
  317. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
  318. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
  319. package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
  320. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
  321. package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
  322. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
  323. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
  324. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
  325. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
  326. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
  327. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
  328. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
  329. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
  330. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
  331. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
  332. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
  333. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
  334. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
  335. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
  336. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
  337. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
  338. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
  339. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
  340. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
  341. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
  342. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
  343. package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +0 -4
  344. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +0 -4
  345. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +0 -1119
  346. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
  347. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +0 -1082
  348. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
  349. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
  350. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
  351. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
  352. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
  353. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
  354. package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
  355. package/contracts/components/BaseComponent.sol +0 -86
  356. package/contracts/components/IBaseComponent.sol +0 -24
  357. package/contracts/experiment/cloning/Cloner.sol +0 -47
  358. package/contracts/experiment/errors/Require.sol +0 -38
  359. package/contracts/experiment/errors/Revert.sol +0 -44
  360. package/contracts/experiment/inheritance/A.sol +0 -53
  361. package/contracts/experiment/inheritance/B.sol +0 -28
  362. package/contracts/experiment/inheritance/C.sol +0 -34
  363. package/contracts/experiment/inheritance/IA.sol +0 -13
  364. package/contracts/experiment/inheritance/IB.sol +0 -10
  365. package/contracts/experiment/inheritance/IC.sol +0 -12
  366. package/contracts/experiment/statemachine/Dummy.sol +0 -27
  367. package/contracts/experiment/statemachine/ISM.sol +0 -25
  368. package/contracts/experiment/statemachine/SM.sol +0 -57
  369. package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
  370. package/contracts/experiment/types/TypeA.sol +0 -47
  371. package/contracts/experiment/types/TypeB.sol +0 -29
  372. package/contracts/instance/AccessManagedSimple.sol +0 -114
  373. package/contracts/instance/AccessManagerSimple.sol +0 -682
  374. package/contracts/instance/IAccessManagerSimple.sol +0 -391
  375. package/contracts/instance/base/ComponentServiceBase.sol +0 -49
  376. package/contracts/instance/base/IInstanceBase.sol +0 -23
  377. package/contracts/instance/service/ComponentOwnerService.sol +0 -317
  378. package/contracts/instance/service/IComponentOwnerService.sol +0 -20
  379. package/contracts/shared/RegisterableUpgradable.sol +0 -16
@@ -1,682 +0,0 @@
1
- // SPDX-License-Identifier: Apache-2.0
2
- pragma solidity ^0.8.20;
3
-
4
- import {Context} from "@openzeppelin/contracts/utils/Context.sol";
5
- import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
6
-
7
- import {IAccessManagerSimple} from "./IAccessManagerSimple.sol";
8
-
9
- type Delay is uint112;
10
-
11
- // @dev as oz5 AccessManager but without multicall and without timing logic
12
- contract AccessManagerSimple is Context, IAccessManagerSimple {
13
- // Structure that stores the details for a target contract.
14
- struct TargetConfig {
15
- mapping(bytes4 selector => uint64 roleId) allowedRoles;
16
- uint112 adminDelay;
17
- bool closed;
18
- }
19
-
20
- // Structure that stores the details for a role/account pair. This structures fit into a single slot.
21
- struct Access {
22
- // Timepoint at which the user gets the permission.
23
- // If this is either 0 or in the future, then the role permission is not available.
24
- uint48 since;
25
- // Delay for execution. Only applies to restricted() / execute() calls.
26
- Delay delay;
27
- }
28
-
29
- // Structure that stores the details of a role.
30
- struct Role {
31
- // Members of the role.
32
- mapping(address user => Access access) members;
33
- // Admin who can grant or revoke permissions.
34
- uint64 admin;
35
- // Guardian who can cancel operations targeting functions that need this role.
36
- uint64 guardian;
37
- // Delay in which the role takes effect after being granted.
38
- Delay grantDelay;
39
- }
40
-
41
- // Structure that stores the details for a scheduled operation. This structure fits into a single slot.
42
- struct Schedule {
43
- // Moment at which the operation can be executed.
44
- uint48 timepoint;
45
- // Operation nonce to allow third-party contracts to identify the operation.
46
- uint32 nonce;
47
- }
48
-
49
- uint64 public constant ADMIN_ROLE = type(uint64).min; // 0
50
- uint64 public constant PUBLIC_ROLE = type(uint64).max; // 2**64-1
51
-
52
- mapping(address target => TargetConfig mode) private _targets;
53
- mapping(uint64 roleId => Role) private _roles;
54
- mapping(bytes32 operationId => Schedule) private _schedules;
55
-
56
- // Used to identify operations that are currently being executed via {execute}.
57
- // This should be transient storage when supported by the EVM.
58
- bytes32 private _executionId;
59
-
60
- /**
61
- * @dev Check that the caller is authorized to perform the operation, following the restrictions encoded in
62
- * {_getAdminRestrictions}.
63
- */
64
- modifier onlyAuthorized() {
65
- _checkAuthorized();
66
- _;
67
- }
68
-
69
- constructor(address initialAdmin) {
70
- if (initialAdmin == address(0)) {
71
- revert AccessManagerInvalidInitialAdmin(address(0));
72
- }
73
-
74
- // admin is active immediately and without any execution delay.
75
- _grantRole(ADMIN_ROLE, initialAdmin, 0, 0);
76
- }
77
-
78
- // =================================================== GETTERS ====================================================
79
- /// @inheritdoc IAccessManagerSimple
80
- function canCall(
81
- address caller,
82
- address target,
83
- bytes4 selector
84
- ) public view virtual returns (bool immediate, uint32 delay) {
85
- if (isTargetClosed(target)) {
86
- return (false, 0);
87
- // } else if (caller == address(this)) {
88
- // // Caller is AccessManager, this means the call was sent through {execute} and it already checked
89
- // // permissions. We verify that the call "identifier", which is set during {execute}, is correct.
90
- // return (_isExecuting(target, selector), 0);
91
- } else {
92
- uint64 roleId = getTargetFunctionRole(target, selector);
93
- (bool isMember, uint32 currentDelay) = hasRole(roleId, caller);
94
- return isMember ? (currentDelay == 0, currentDelay) : (false, 0);
95
- }
96
- }
97
-
98
- /// @inheritdoc IAccessManagerSimple
99
- function expiration() public view virtual returns (uint32) {
100
- return 1 weeks;
101
- }
102
-
103
- /// @inheritdoc IAccessManagerSimple
104
- function minSetback() public view virtual returns (uint32) {
105
- return 5 days;
106
- }
107
-
108
- /// @inheritdoc IAccessManagerSimple
109
- function isTargetClosed(address target) public view virtual returns (bool) {
110
- return _targets[target].closed;
111
- }
112
-
113
- /// @inheritdoc IAccessManagerSimple
114
- function getTargetFunctionRole(address target, bytes4 selector) public view virtual returns (uint64) {
115
- return _targets[target].allowedRoles[selector];
116
- }
117
-
118
- /// @inheritdoc IAccessManagerSimple
119
- function getTargetAdminDelay(address target) public view virtual returns (uint32) {
120
- // return _targets[target].adminDelay.get();
121
- }
122
-
123
- /// @inheritdoc IAccessManagerSimple
124
- function getRoleAdmin(uint64 roleId) public view virtual returns (uint64) {
125
- return _roles[roleId].admin;
126
- }
127
-
128
- /// @inheritdoc IAccessManagerSimple
129
- function getRoleGuardian(uint64 roleId) public view virtual returns (uint64) {
130
- return _roles[roleId].guardian;
131
- }
132
-
133
- /// @inheritdoc IAccessManagerSimple
134
- function getRoleGrantDelay(uint64 roleId) public view virtual returns (uint32) {
135
- // return _roles[roleId].grantDelay.get();
136
- }
137
-
138
- /// @inheritdoc IAccessManagerSimple
139
- function getAccess(
140
- uint64 roleId,
141
- address account
142
- ) public view virtual returns (uint48 since, uint32 currentDelay, uint32 pendingDelay, uint48 effect) {
143
- Access storage access = _roles[roleId].members[account];
144
-
145
- since = access.since;
146
- // (currentDelay, pendingDelay, effect) = access.delay.getFull();
147
-
148
- return (since, currentDelay, pendingDelay, effect);
149
- }
150
-
151
- /// @inheritdoc IAccessManagerSimple
152
- function hasRole(
153
- uint64 roleId,
154
- address account
155
- ) public view virtual returns (bool isMember, uint32 executionDelay) {
156
- if (roleId == PUBLIC_ROLE) {
157
- return (true, 0);
158
- } else {
159
- (uint48 hasRoleSince, uint32 currentDelay, , ) = getAccess(roleId, account);
160
- // return (hasRoleSince != 0 && hasRoleSince <= Time.timestamp(), currentDelay);
161
- return (hasRoleSince != 0 && hasRoleSince <= uint48(block.timestamp), currentDelay);
162
- }
163
- }
164
-
165
- // =============================================== ROLE MANAGEMENT ===============================================
166
- /// @inheritdoc IAccessManagerSimple
167
- function labelRole(uint64 roleId, string calldata label) public virtual onlyAuthorized {
168
- if (roleId == ADMIN_ROLE || roleId == PUBLIC_ROLE) {
169
- revert AccessManagerLockedRole(roleId);
170
- }
171
- emit RoleLabel(roleId, label);
172
- }
173
-
174
- /// @inheritdoc IAccessManagerSimple
175
- function grantRole(uint64 roleId, address account, uint32 executionDelay) public virtual onlyAuthorized {
176
- _grantRole(roleId, account, getRoleGrantDelay(roleId), executionDelay);
177
- }
178
-
179
- /// @inheritdoc IAccessManagerSimple
180
- function revokeRole(uint64 roleId, address account) public virtual onlyAuthorized {
181
- _revokeRole(roleId, account);
182
- }
183
-
184
- /// @inheritdoc IAccessManagerSimple
185
- function renounceRole(uint64 roleId, address callerConfirmation) public virtual {
186
- if (callerConfirmation != _msgSender()) {
187
- revert AccessManagerBadConfirmation();
188
- }
189
- _revokeRole(roleId, callerConfirmation);
190
- }
191
-
192
- /// @inheritdoc IAccessManagerSimple
193
- function setRoleAdmin(uint64 roleId, uint64 admin) public virtual onlyAuthorized {
194
- _setRoleAdmin(roleId, admin);
195
- }
196
-
197
- /// @inheritdoc IAccessManagerSimple
198
- function setRoleGuardian(uint64 roleId, uint64 guardian) public virtual onlyAuthorized {
199
- _setRoleGuardian(roleId, guardian);
200
- }
201
-
202
- /// @inheritdoc IAccessManagerSimple
203
- function setGrantDelay(uint64 roleId, uint32 newDelay) public virtual onlyAuthorized {
204
- // _setGrantDelay(roleId, newDelay);
205
- }
206
-
207
- /**
208
- * @dev Internal version of {grantRole} without access control. Returns true if the role was newly granted.
209
- *
210
- * Emits a {RoleGranted} event.
211
- */
212
- function _grantRole(
213
- uint64 roleId,
214
- address account,
215
- uint32 grantDelay,
216
- uint32 executionDelay
217
- ) internal virtual returns (bool) {
218
- if (roleId == PUBLIC_ROLE) {
219
- revert AccessManagerLockedRole(roleId);
220
- }
221
-
222
- bool newMember = _roles[roleId].members[account].since == 0;
223
- uint48 since;
224
-
225
- if (newMember) {
226
- since = uint48(block.timestamp); // Time.timestamp() + grantDelay;
227
- _roles[roleId].members[account] = Access({since: since, delay: Delay.wrap(0)});
228
- }
229
- // else {
230
- // // No setback here. Value can be reset by doing revoke + grant, effectively allowing the admin to perform
231
- // // any change to the execution delay within the duration of the role admin delay.
232
- // (_roles[roleId].members[account].delay, since) = _roles[roleId].members[account].delay.withUpdate(
233
- // executionDelay,
234
- // 0
235
- // );
236
- // }
237
-
238
- emit RoleGranted(roleId, account, executionDelay, since, newMember);
239
- return newMember;
240
- }
241
-
242
- /**
243
- * @dev Internal version of {revokeRole} without access control. This logic is also used by {renounceRole}.
244
- * Returns true if the role was previously granted.
245
- *
246
- * Emits a {RoleRevoked} event if the account had the role.
247
- */
248
- function _revokeRole(uint64 roleId, address account) internal virtual returns (bool) {
249
- if (roleId == PUBLIC_ROLE) {
250
- revert AccessManagerLockedRole(roleId);
251
- }
252
-
253
- if (_roles[roleId].members[account].since == 0) {
254
- return false;
255
- }
256
-
257
- delete _roles[roleId].members[account];
258
-
259
- emit RoleRevoked(roleId, account);
260
- return true;
261
- }
262
-
263
- /**
264
- * @dev Internal version of {setRoleAdmin} without access control.
265
- *
266
- * Emits a {RoleAdminChanged} event.
267
- *
268
- * NOTE: Setting the admin role as the `PUBLIC_ROLE` is allowed, but it will effectively allow
269
- * anyone to set grant or revoke such role.
270
- */
271
- function _setRoleAdmin(uint64 roleId, uint64 admin) internal virtual {
272
- if (roleId == ADMIN_ROLE || roleId == PUBLIC_ROLE) {
273
- revert AccessManagerLockedRole(roleId);
274
- }
275
-
276
- _roles[roleId].admin = admin;
277
-
278
- emit RoleAdminChanged(roleId, admin);
279
- }
280
-
281
- /**
282
- * @dev Internal version of {setRoleGuardian} without access control.
283
- *
284
- * Emits a {RoleGuardianChanged} event.
285
- *
286
- * NOTE: Setting the guardian role as the `PUBLIC_ROLE` is allowed, but it will effectively allow
287
- * anyone to cancel any scheduled operation for such role.
288
- */
289
- function _setRoleGuardian(uint64 roleId, uint64 guardian) internal virtual {
290
- if (roleId == ADMIN_ROLE || roleId == PUBLIC_ROLE) {
291
- revert AccessManagerLockedRole(roleId);
292
- }
293
-
294
- _roles[roleId].guardian = guardian;
295
-
296
- emit RoleGuardianChanged(roleId, guardian);
297
- }
298
-
299
- /**
300
- * @dev Internal version of {setGrantDelay} without access control.
301
- *
302
- * Emits a {RoleGrantDelayChanged} event.
303
- */
304
- // function _setGrantDelay(uint64 roleId, uint32 newDelay) internal virtual {
305
- // if (roleId == PUBLIC_ROLE) {
306
- // revert AccessManagerLockedRole(roleId);
307
- // }
308
-
309
- // uint48 effect;
310
- // (_roles[roleId].grantDelay, effect) = _roles[roleId].grantDelay.withUpdate(newDelay, minSetback());
311
-
312
- // emit RoleGrantDelayChanged(roleId, newDelay, effect);
313
- // }
314
-
315
- // ============================================= FUNCTION MANAGEMENT ==============================================
316
- /// @inheritdoc IAccessManagerSimple
317
- function setTargetFunctionRole(
318
- address target,
319
- bytes4[] calldata selectors,
320
- uint64 roleId
321
- ) public virtual onlyAuthorized {
322
- for (uint256 i = 0; i < selectors.length; ++i) {
323
- _setTargetFunctionRole(target, selectors[i], roleId);
324
- }
325
- }
326
-
327
- /**
328
- * @dev Internal version of {setTargetFunctionRole} without access control.
329
- *
330
- * Emits a {TargetFunctionRoleUpdated} event.
331
- */
332
- function _setTargetFunctionRole(address target, bytes4 selector, uint64 roleId) internal virtual {
333
- _targets[target].allowedRoles[selector] = roleId;
334
- emit TargetFunctionRoleUpdated(target, selector, roleId);
335
- }
336
-
337
- /// @inheritdoc IAccessManagerSimple
338
- function setTargetAdminDelay(address target, uint32 newDelay) public virtual onlyAuthorized {
339
- // _setTargetAdminDelay(target, newDelay);
340
- }
341
-
342
- /**
343
- * @dev Internal version of {setTargetAdminDelay} without access control.
344
- *
345
- * Emits a {TargetAdminDelayUpdated} event.
346
- */
347
- // function _setTargetAdminDelay(address target, uint32 newDelay) internal virtual {
348
- // uint48 effect;
349
- // (_targets[target].adminDelay, effect) = _targets[target].adminDelay.withUpdate(newDelay, minSetback());
350
-
351
- // emit TargetAdminDelayUpdated(target, newDelay, effect);
352
- // }
353
-
354
- // =============================================== MODE MANAGEMENT ================================================
355
- /// @inheritdoc IAccessManagerSimple
356
- function setTargetClosed(address target, bool closed) public virtual onlyAuthorized {
357
- _setTargetClosed(target, closed);
358
- }
359
-
360
- /**
361
- * @dev Set the closed flag for a contract. This is an internal setter with no access restrictions.
362
- *
363
- * Emits a {TargetClosed} event.
364
- */
365
- function _setTargetClosed(address target, bool closed) internal virtual {
366
- if (target == address(this)) {
367
- revert AccessManagerLockedAccount(target);
368
- }
369
- _targets[target].closed = closed;
370
- emit TargetClosed(target, closed);
371
- }
372
-
373
- // ============================================== DELAYED OPERATIONS ==============================================
374
- /// @inheritdoc IAccessManagerSimple
375
- function getSchedule(bytes32 id) public view virtual returns (uint48) {
376
- // uint48 timepoint = _schedules[id].timepoint;
377
- // return _isExpired(timepoint) ? 0 : timepoint;
378
- }
379
-
380
- /// @inheritdoc IAccessManagerSimple
381
- function getNonce(bytes32 id) public view virtual returns (uint32) {
382
- // return _schedules[id].nonce;
383
- }
384
-
385
- /// @inheritdoc IAccessManagerSimple
386
- function schedule(
387
- address target,
388
- bytes calldata data,
389
- uint48 when
390
- ) public virtual returns (bytes32 operationId, uint32 nonce) {
391
- // address caller = _msgSender();
392
-
393
- // // Fetch restrictions that apply to the caller on the targeted function
394
- // (, uint32 setback) = _canCallExtended(caller, target, data);
395
-
396
- // uint48 minWhen = Time.timestamp() + setback;
397
-
398
- // // if call with delay is not authorized, or if requested timing is too soon
399
- // if (setback == 0 || (when > 0 && when < minWhen)) {
400
- // revert AccessManagerUnauthorizedCall(caller, target, _checkSelector(data));
401
- // }
402
-
403
- // // Reuse variable due to stack too deep
404
- // when = uint48(Math.max(when, minWhen)); // cast is safe: both inputs are uint48
405
-
406
- // // If caller is authorised, schedule operation
407
- // operationId = hashOperation(caller, target, data);
408
-
409
- // _checkNotScheduled(operationId);
410
-
411
- // unchecked {
412
- // // It's not feasible to overflow the nonce in less than 1000 years
413
- // nonce = _schedules[operationId].nonce + 1;
414
- // }
415
- // _schedules[operationId].timepoint = when;
416
- // _schedules[operationId].nonce = nonce;
417
- // emit OperationScheduled(operationId, nonce, when, caller, target, data);
418
-
419
- // // Using named return values because otherwise we get stack too deep
420
- }
421
-
422
- /**
423
- * @dev Reverts if the operation is currently scheduled and has not expired.
424
- * (Note: This function was introduced due to stack too deep errors in schedule.)
425
- */
426
- // function _checkNotScheduled(bytes32 operationId) private view {
427
- // uint48 prevTimepoint = _schedules[operationId].timepoint;
428
- // if (prevTimepoint != 0 && !_isExpired(prevTimepoint)) {
429
- // revert AccessManagerAlreadyScheduled(operationId);
430
- // }
431
- // }
432
-
433
- /// @inheritdoc IAccessManagerSimple
434
- // Reentrancy is not an issue because permissions are checked on msg.sender. Additionally,
435
- // _consumeScheduledOp guarantees a scheduled operation is only executed once.
436
- // slither-disable-next-line reentrancy-no-eth
437
- function execute(address target, bytes calldata data) public payable virtual returns (uint32) {
438
- // address caller = _msgSender();
439
-
440
- // // Fetch restrictions that apply to the caller on the targeted function
441
- // (bool immediate, uint32 setback) = _canCallExtended(caller, target, data);
442
-
443
- // // If caller is not authorised, revert
444
- // if (!immediate && setback == 0) {
445
- // revert AccessManagerUnauthorizedCall(caller, target, _checkSelector(data));
446
- // }
447
-
448
- // bytes32 operationId = hashOperation(caller, target, data);
449
- // uint32 nonce;
450
-
451
- // // If caller is authorised, check operation was scheduled early enough
452
- // // Consume an available schedule even if there is no currently enforced delay
453
- // if (setback != 0 || getSchedule(operationId) != 0) {
454
- // nonce = _consumeScheduledOp(operationId);
455
- // }
456
-
457
- // // Mark the target and selector as authorised
458
- // bytes32 executionIdBefore = _executionId;
459
- // _executionId = _hashExecutionId(target, _checkSelector(data));
460
-
461
- // // Perform call
462
- // Address.functionCallWithValue(target, data, msg.value);
463
-
464
- // // Reset execute identifier
465
- // _executionId = executionIdBefore;
466
-
467
- // return nonce;
468
- }
469
-
470
- /// @inheritdoc IAccessManagerSimple
471
- function cancel(address caller, address target, bytes calldata data) public virtual returns (uint32) {
472
- // address msgsender = _msgSender();
473
- // bytes4 selector = _checkSelector(data);
474
-
475
- // bytes32 operationId = hashOperation(caller, target, data);
476
- // if (_schedules[operationId].timepoint == 0) {
477
- // revert AccessManagerNotScheduled(operationId);
478
- // } else if (caller != msgsender) {
479
- // // calls can only be canceled by the account that scheduled them, a global admin, or by a guardian of the required role.
480
- // (bool isAdmin, ) = hasRole(ADMIN_ROLE, msgsender);
481
- // (bool isGuardian, ) = hasRole(getRoleGuardian(getTargetFunctionRole(target, selector)), msgsender);
482
- // if (!isAdmin && !isGuardian) {
483
- // revert AccessManagerUnauthorizedCancel(msgsender, caller, target, selector);
484
- // }
485
- // }
486
-
487
- // delete _schedules[operationId].timepoint; // reset the timepoint, keep the nonce
488
- // uint32 nonce = _schedules[operationId].nonce;
489
- // emit OperationCanceled(operationId, nonce);
490
-
491
- // return nonce;
492
- }
493
-
494
- /// @inheritdoc IAccessManagerSimple
495
- function consumeScheduledOp(address caller, bytes calldata data) public virtual {
496
- // address target = _msgSender();
497
- // if (IAccessManaged(target).isConsumingScheduledOp() != IAccessManaged.isConsumingScheduledOp.selector) {
498
- // revert AccessManagerUnauthorizedConsume(target);
499
- // }
500
- // _consumeScheduledOp(hashOperation(caller, target, data));
501
- }
502
-
503
- // /**
504
- // * @dev Internal variant of {consumeScheduledOp} that operates on bytes32 operationId.
505
- // *
506
- // * Returns the nonce of the scheduled operation that is consumed.
507
- // */
508
- // function _consumeScheduledOp(bytes32 operationId) internal virtual returns (uint32) {
509
- // uint48 timepoint = _schedules[operationId].timepoint;
510
- // uint32 nonce = _schedules[operationId].nonce;
511
-
512
- // if (timepoint == 0) {
513
- // revert AccessManagerNotScheduled(operationId);
514
- // } else if (timepoint > Time.timestamp()) {
515
- // revert AccessManagerNotReady(operationId);
516
- // } else if (_isExpired(timepoint)) {
517
- // revert AccessManagerExpired(operationId);
518
- // }
519
-
520
- // delete _schedules[operationId].timepoint; // reset the timepoint, keep the nonce
521
- // emit OperationExecuted(operationId, nonce);
522
-
523
- // return nonce;
524
- // }
525
-
526
- /// @inheritdoc IAccessManagerSimple
527
- function hashOperation(address caller, address target, bytes calldata data) public view virtual returns (bytes32) {
528
- return keccak256(abi.encode(caller, target, data));
529
- }
530
-
531
- // ==================================================== OTHERS ====================================================
532
- /// @inheritdoc IAccessManagerSimple
533
- function updateAuthority(address target, address newAuthority) public virtual onlyAuthorized {
534
- IAccessManaged(target).setAuthority(newAuthority);
535
- }
536
-
537
- // ================================================= ADMIN LOGIC ==================================================
538
- /**
539
- * @dev Check if the current call is authorized according to admin logic.
540
- */
541
- function _checkAuthorized() private {
542
- address caller = _msgSender();
543
- (bool immediate, uint32 delay) = _canCallSelf(caller, _msgData());
544
- if (!immediate) {
545
- if (delay == 0) {
546
- (, uint64 requiredRole, ) = _getAdminRestrictions(_msgData());
547
- revert AccessManagerUnauthorizedAccount(caller, requiredRole);
548
- }
549
- // else {
550
- // _consumeScheduledOp(hashOperation(caller, address(this), _msgData()));
551
- // }
552
- }
553
- }
554
-
555
- /**
556
- * @dev Get the admin restrictions of a given function call based on the function and arguments involved.
557
- *
558
- * Returns:
559
- * - bool restricted: does this data match a restricted operation
560
- * - uint64: which role is this operation restricted to
561
- * - uint32: minimum delay to enforce for that operation (max between operation's delay and admin's execution delay)
562
- */
563
- function _getAdminRestrictions(
564
- bytes calldata data
565
- ) private view returns (bool restricted, uint64 roleAdminId, uint32 executionDelay) {
566
- if (data.length < 4) {
567
- return (false, 0, 0);
568
- }
569
-
570
- bytes4 selector = _checkSelector(data);
571
-
572
- // Restricted to ADMIN with no delay beside any execution delay the caller may have
573
- if (
574
- selector == this.labelRole.selector ||
575
- selector == this.setRoleAdmin.selector ||
576
- selector == this.setRoleGuardian.selector ||
577
- selector == this.setGrantDelay.selector ||
578
- selector == this.setTargetAdminDelay.selector
579
- ) {
580
- return (true, ADMIN_ROLE, 0);
581
- }
582
-
583
- // Restricted to ADMIN with the admin delay corresponding to the target
584
- if (
585
- selector == this.updateAuthority.selector ||
586
- selector == this.setTargetClosed.selector ||
587
- selector == this.setTargetFunctionRole.selector
588
- ) {
589
- // First argument is a target.
590
- address target = abi.decode(data[0x04:0x24], (address));
591
- uint32 delay = getTargetAdminDelay(target);
592
- return (true, ADMIN_ROLE, delay);
593
- }
594
-
595
- // Restricted to that role's admin with no delay beside any execution delay the caller may have.
596
- if (selector == this.grantRole.selector || selector == this.revokeRole.selector) {
597
- // First argument is a roleId.
598
- uint64 roleId = abi.decode(data[0x04:0x24], (uint64));
599
- return (true, getRoleAdmin(roleId), 0);
600
- }
601
-
602
- return (false, 0, 0);
603
- }
604
-
605
- // =================================================== HELPERS ====================================================
606
- /**
607
- * @dev An extended version of {canCall} for internal usage that checks {_canCallSelf}
608
- * when the target is this contract.
609
- *
610
- * Returns:
611
- * - bool immediate: whether the operation can be executed immediately (with no delay)
612
- * - uint32 delay: the execution delay
613
- */
614
- function _canCallExtended(
615
- address caller,
616
- address target,
617
- bytes calldata data
618
- ) private view returns (bool immediate, uint32 delay) {
619
- if (target == address(this)) {
620
- return _canCallSelf(caller, data);
621
- } else {
622
- return data.length < 4 ? (false, 0) : canCall(caller, target, _checkSelector(data));
623
- }
624
- }
625
-
626
- /**
627
- * @dev A version of {canCall} that checks for admin restrictions in this contract.
628
- */
629
- function _canCallSelf(address caller, bytes calldata data) private view returns (bool immediate, uint32 delay) {
630
- if (data.length < 4) {
631
- return (false, 0);
632
- }
633
-
634
- // if (caller == address(this)) {
635
- // // Caller is AccessManager, this means the call was sent through {execute} and it already checked
636
- // // permissions. We verify that the call "identifier", which is set during {execute}, is correct.
637
- // return (_isExecuting(address(this), _checkSelector(data)), 0);
638
- // }
639
-
640
- (bool enabled, uint64 roleId, uint32 operationDelay) = _getAdminRestrictions(data);
641
- if (!enabled) {
642
- return (false, 0);
643
- }
644
-
645
- (bool inRole, uint32 executionDelay) = hasRole(roleId, caller);
646
- if (!inRole) {
647
- return (false, 0);
648
- }
649
-
650
- // downcast is safe because both options are uint32
651
- delay = 0; // uint32(Math.max(operationDelay, executionDelay));
652
- return (delay == 0, delay);
653
- }
654
-
655
- // /**
656
- // * @dev Returns true if a call with `target` and `selector` is being executed via {executed}.
657
- // */
658
- // function _isExecuting(address target, bytes4 selector) private view returns (bool) {
659
- // return _executionId == _hashExecutionId(target, selector);
660
- // }
661
-
662
- // /**
663
- // * @dev Returns true if a schedule timepoint is past its expiration deadline.
664
- // */
665
- // function _isExpired(uint48 timepoint) private view returns (bool) {
666
- // return timepoint + expiration() <= Time.timestamp();
667
- // }
668
-
669
- /**
670
- * @dev Extracts the selector from calldata. Panics if data is not at least 4 bytes
671
- */
672
- function _checkSelector(bytes calldata data) private pure returns (bytes4) {
673
- return bytes4(data[0:4]);
674
- }
675
-
676
- /**
677
- * @dev Hashing function for execute protection
678
- */
679
- // function _hashExecutionId(address target, bytes4 selector) private pure returns (bytes32) {
680
- // return keccak256(abi.encode(target, selector));
681
- // }
682
- }