@etherisc/gif-next 0.0.2-e46206a-486 → 0.0.2-e4b632c-016

Sign up to get free protection for your applications and to get access to all the features.
Files changed (280) hide show
  1. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +1 -1
  2. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +13 -0
  3. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
  4. package/artifacts/contracts/components/Distribution.sol/Distribution.json +86 -33
  5. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +1 -1
  6. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +13 -0
  7. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  8. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -25
  9. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  10. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -59
  11. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  12. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -50
  13. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  14. package/artifacts/contracts/components/Pool.sol/Pool.json +123 -65
  15. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  16. package/artifacts/contracts/components/Product.sol/Product.json +184 -44
  17. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +1 -1
  18. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +1 -1
  19. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +1 -1
  20. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
  21. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
  22. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
  23. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
  24. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
  25. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
  26. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
  27. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
  28. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
  29. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
  30. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
  31. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +2 -2
  32. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
  33. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
  34. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
  35. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +2 -2
  36. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
  37. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +2 -2
  38. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
  39. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
  40. package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +4 -0
  41. package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.json +114 -0
  42. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +4 -0
  43. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +1132 -0
  44. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +4 -0
  45. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +1082 -0
  46. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  47. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +181 -1677
  48. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
  49. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +480 -0
  50. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  51. package/artifacts/contracts/instance/Instance.sol/Instance.json +2198 -1023
  52. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
  53. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +930 -0
  54. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
  55. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1283 -0
  56. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
  57. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +755 -0
  58. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
  59. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +432 -0
  60. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +1 -1
  61. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +1 -1
  62. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  63. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +27 -158
  64. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  65. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  66. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +37 -253
  67. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  68. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +2 -2
  69. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
  70. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +211 -0
  71. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
  72. package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
  73. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
  74. package/artifacts/contracts/instance/module/{distribution/IDistribution.sol → IDistribution.sol}/IDistribution.json +1 -1
  75. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
  76. package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
  77. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
  78. package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
  79. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
  80. package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/ISetup.sol/ISetup.json} +2 -2
  81. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
  82. package/artifacts/contracts/instance/module/{treasury/ITreasury.sol → ITreasury.sol}/ITreasury.json +1 -1
  83. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +1 -1
  84. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +32 -48
  85. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
  86. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +18 -60
  87. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  88. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +428 -0
  89. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +1 -1
  90. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  91. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
  92. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
  93. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  94. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  95. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  96. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  97. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  98. package/artifacts/contracts/registry/Registry.sol/Registry.json +2 -2
  99. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  100. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +8 -8
  101. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  102. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +5 -5
  103. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
  104. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  105. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  106. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  107. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
  108. package/artifacts/contracts/{instance/base → shared}/IService.sol/IService.json +1 -1
  109. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  110. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  111. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +2 -2
  112. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  113. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +2 -2
  114. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  115. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +2 -2
  116. package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +4 -0
  117. package/artifacts/contracts/{instance/base/InstanceBase.sol/InstanceBase.json → shared/RegisterableUpgradable.sol/RegisterableUpgradable.json} +2 -104
  118. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
  119. package/artifacts/contracts/{instance/base/ServiceBase.sol/ServiceBase.json → shared/Service.sol/Service.json} +2 -2
  120. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
  121. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
  122. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  123. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  124. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
  125. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
  126. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +2 -2
  127. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
  128. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
  129. package/artifacts/contracts/test/TestService.sol/TestService.json +11 -11
  130. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
  131. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
  132. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
  133. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
  134. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  135. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  136. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  137. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  138. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
  139. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
  140. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  141. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  142. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
  143. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  144. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
  145. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
  146. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
  147. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
  148. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
  149. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
  150. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
  151. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
  152. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
  153. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
  154. package/contracts/components/BaseComponent.sol +9 -2
  155. package/contracts/components/Distribution.sol +25 -14
  156. package/contracts/components/IBaseComponent.sol +7 -2
  157. package/contracts/components/IDistributionComponent.sol +0 -3
  158. package/contracts/components/IPoolComponent.sol +0 -2
  159. package/contracts/components/IProductComponent.sol +1 -3
  160. package/contracts/components/Pool.sol +41 -28
  161. package/contracts/components/Product.sol +40 -42
  162. package/contracts/instance/AccessManagedSimple.sol +122 -0
  163. package/contracts/instance/AccessManagerSimple.sol +692 -0
  164. package/contracts/instance/IAccessManagerSimple.sol +391 -0
  165. package/contracts/instance/IInstance.sol +25 -44
  166. package/contracts/instance/IInstanceService.sol +30 -0
  167. package/contracts/instance/Instance.sol +423 -64
  168. package/contracts/instance/InstanceAccessManager.sol +288 -0
  169. package/contracts/instance/InstanceReader.sol +290 -0
  170. package/contracts/instance/InstanceService.sol +138 -0
  171. package/contracts/instance/InstanceServiceManager.sol +56 -0
  172. package/contracts/instance/base/ComponentServiceBase.sol +3 -13
  173. package/contracts/instance/base/IKeyValueStore.sol +13 -14
  174. package/contracts/instance/base/ILifecycle.sol +3 -3
  175. package/contracts/instance/base/KeyValueStore.sol +49 -39
  176. package/contracts/instance/base/Lifecycle.sol +1 -1
  177. package/contracts/instance/module/IAccess.sol +38 -0
  178. package/contracts/instance/module/IBundle.sol +19 -0
  179. package/contracts/instance/module/IDistribution.sol +39 -0
  180. package/contracts/instance/module/IPolicy.sol +45 -0
  181. package/contracts/instance/module/IRisk.sol +11 -0
  182. package/contracts/instance/module/ISetup.sol +43 -0
  183. package/contracts/instance/module/ITreasury.sol +23 -0
  184. package/contracts/instance/service/ComponentOwnerService.sol +62 -60
  185. package/contracts/instance/service/DistributionService.sol +33 -17
  186. package/contracts/instance/service/DistributionServiceManager.sol +53 -0
  187. package/contracts/instance/service/IComponentOwnerService.sol +1 -1
  188. package/contracts/instance/service/IDistributionService.sol +1 -1
  189. package/contracts/instance/service/IPoolService.sol +1 -1
  190. package/contracts/instance/service/IProductService.sol +2 -2
  191. package/contracts/registry/IRegistry.sol +1 -0
  192. package/contracts/registry/IRegistryService.sol +8 -8
  193. package/contracts/registry/Registry.sol +1 -1
  194. package/contracts/registry/RegistryService.sol +17 -14
  195. package/contracts/{instance/base → shared}/IService.sol +3 -3
  196. package/contracts/shared/RegisterableUpgradable.sol +16 -0
  197. package/contracts/shared/Service.sol +54 -0
  198. package/contracts/shared/TokenHandler.sol +27 -0
  199. package/contracts/test/TestService.sol +3 -5
  200. package/contracts/types/StateId.sol +4 -0
  201. package/package.json +1 -1
  202. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
  203. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
  204. package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
  205. package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
  206. package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
  207. package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
  208. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
  209. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -297
  210. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
  211. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
  212. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -297
  213. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
  214. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +0 -117
  215. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
  216. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
  217. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
  218. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +0 -117
  219. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +0 -4
  220. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +0 -10
  221. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +0 -4
  222. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +0 -4
  223. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +0 -10
  224. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
  225. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
  226. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -271
  227. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
  228. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -271
  229. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
  230. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
  231. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
  232. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -164
  233. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
  234. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -164
  235. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
  236. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
  237. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -113
  238. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
  239. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -131
  240. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
  241. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
  242. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -638
  243. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
  244. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
  245. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
  246. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -638
  247. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
  248. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -769
  249. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
  250. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -1076
  251. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +0 -4
  252. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +0 -557
  253. package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
  254. package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -716
  255. package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
  256. package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -744
  257. package/contracts/instance/IInstanceLinked.sol +0 -8
  258. package/contracts/instance/base/InstanceBase.sol +0 -89
  259. package/contracts/instance/base/ModuleBase.sol +0 -57
  260. package/contracts/instance/base/ServiceBase.sol +0 -44
  261. package/contracts/instance/module/bundle/BundleModule.sol +0 -134
  262. package/contracts/instance/module/bundle/IBundle.sol +0 -53
  263. package/contracts/instance/module/component/ComponentModule.sol +0 -71
  264. package/contracts/instance/module/component/IComponent.sol +0 -28
  265. package/contracts/instance/module/distribution/DistributionModule.sol +0 -17
  266. package/contracts/instance/module/distribution/IDistribution.sol +0 -10
  267. package/contracts/instance/module/policy/IPolicy.sol +0 -63
  268. package/contracts/instance/module/policy/PolicyModule.sol +0 -91
  269. package/contracts/instance/module/pool/IPoolModule.sol +0 -41
  270. package/contracts/instance/module/pool/PoolModule.sol +0 -95
  271. package/contracts/instance/module/risk/IRisk.sol +0 -26
  272. package/contracts/instance/module/risk/RiskModule.sol +0 -62
  273. package/contracts/instance/module/treasury/ITreasury.sol +0 -84
  274. package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
  275. package/contracts/instance/module/treasury/TreasuryModule.sol +0 -131
  276. package/contracts/instance/service/PoolService.sol +0 -149
  277. package/contracts/instance/service/ProductService.sol +0 -510
  278. package/contracts/test/TestDistribution.sol +0 -22
  279. package/contracts/test/TestPool.sol +0 -27
  280. package/contracts/test/TestProduct.sol +0 -74
@@ -0,0 +1,23 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
5
+
6
+ import {Fee} from "../../types/Fee.sol";
7
+ import {NftId} from "../../types/NftId.sol";
8
+ import {TokenHandler} from "../../shared/TokenHandler.sol";
9
+
10
+ interface ITreasury {
11
+ struct TreasuryInfo {
12
+ IERC20Metadata token;
13
+ TokenHandler tokenHandler;
14
+ NftId distributionNftId;
15
+ NftId poolNftId;
16
+ Fee distributionFee; // default distribution fee (no referral id)
17
+ Fee productFee; // product fee on net premium
18
+ Fee processingFee; // product fee on payout amounts
19
+ Fee poolFee; // pool fee on net premium
20
+ Fee stakingFee; // pool fee on staked capital from investor
21
+ Fee performanceFee; // pool fee on profits from capital investors
22
+ }
23
+ }
@@ -6,9 +6,9 @@ import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IER
6
6
  import {IRegistry} from "../../registry/IRegistry.sol";
7
7
  import {IInstance} from "../IInstance.sol";
8
8
 
9
- import {ITreasury, ITreasuryModule} from "../module/treasury/ITreasury.sol";
10
- import {TreasuryModule} from "../module/treasury/TreasuryModule.sol";
11
- import {IComponent, IComponentModule} from "../module/component/IComponent.sol";
9
+ import {ITreasury} from "../module/ITreasury.sol";
10
+ // import {TreasuryModule} from "../module/TreasuryModule.sol";
11
+ import {ISetup} from "../module/ISetup.sol";
12
12
  import {IBaseComponent} from "../../components/IBaseComponent.sol";
13
13
  import {IPoolComponent} from "../../components/IPoolComponent.sol";
14
14
  import {IKeyValueStore} from "../../instance/base/IKeyValueStore.sol";
@@ -27,15 +27,15 @@ import {UFixed, UFixedLib} from "../../types/UFixed.sol";
27
27
  import {IDistributionComponent} from "../../components/IDistributionComponent.sol";
28
28
  import {IPoolComponent} from "../../components/IPoolComponent.sol";
29
29
  import {IProductComponent} from "../../components/IProductComponent.sol";
30
- import {IService} from "../base/IService.sol";
30
+ import {IService} from "../../shared/IService.sol";
31
31
  import {IComponentOwnerService} from "./IComponentOwnerService.sol";
32
- import {ServiceBase} from "../base/ServiceBase.sol";
33
- import {IPool, IPoolModule} from "../module/pool/IPoolModule.sol";
32
+ import {Service} from "../../shared/Service.sol";
33
+ // import {IPool, IPoolModule} from "../module/IPoolModule.sol";
34
34
 
35
35
  import {IRegistryService} from "../../registry/IRegistryService.sol";
36
36
 
37
37
  contract ComponentOwnerService is
38
- ServiceBase,
38
+ Service,
39
39
  IComponentOwnerService
40
40
  {
41
41
  using NftIdLib for NftId;
@@ -64,11 +64,11 @@ contract ComponentOwnerService is
64
64
  address initialOwner
65
65
  )
66
66
  {
67
- _initializeServiceBase(registry, registryNftId, initialOwner);
67
+ _initializeService(registry, initialOwner);
68
68
  _registerInterface(type(IComponentOwnerService).interfaceId);
69
69
  }
70
70
 
71
- function getName() public pure override(IService, ServiceBase) returns(string memory name) {
71
+ function getName() public pure override(IService, Service) returns(string memory name) {
72
72
  return NAME;
73
73
  }
74
74
 
@@ -184,7 +184,7 @@ contract ComponentOwnerService is
184
184
  IInstance instance = component.getInstance();
185
185
  NftId nftId = component.getNftId();
186
186
  Key32 key = nftId.toKey32(COMPONENT());
187
- instance.updateState(key, PAUSED());
187
+ // instance.updateState(key, PAUSED());
188
188
  }
189
189
 
190
190
  function unlock(
@@ -194,7 +194,7 @@ contract ComponentOwnerService is
194
194
  IInstance instance = component.getInstance();
195
195
  NftId nftId = component.getNftId();
196
196
  Key32 key = nftId.toKey32(COMPONENT());
197
- instance.updateState(key, ACTIVE());
197
+ // instance.updateState(key, ACTIVE());
198
198
  }
199
199
 
200
200
  // Internals
@@ -207,58 +207,60 @@ contract ComponentOwnerService is
207
207
  )
208
208
  internal
209
209
  {
210
- (
211
- ITreasury.TreasuryInfo memory info,
212
- address wallet
213
- ) = abi.decode(data, (ITreasury.TreasuryInfo, address));
210
+ // TODO change treasury info to product setup info
211
+ (ISetup.ProductSetupInfo memory info) = abi.decode(data, (ISetup.ProductSetupInfo));
212
+ // (
213
+ // ITreasury.TreasuryInfo memory info,
214
+ // address wallet
215
+ // ) = abi.decode(data, (ITreasury.TreasuryInfo, address));
214
216
 
215
- IRegistry _registry = getRegistry();
217
+ // IRegistry _registry = getRegistry();
216
218
 
217
- if(wallet == address(0)) {
218
- revert WalletIsZero();
219
- }
219
+ // if(wallet == address(0)) {
220
+ // revert WalletIsZero();
221
+ // }
220
222
 
221
- IRegistry.ObjectInfo memory tokenInfo = _registry.getObjectInfo(address(info.token));
223
+ // IRegistry.ObjectInfo memory tokenInfo = _registry.getObjectInfo(address(info.token));
222
224
 
223
- if(tokenInfo.objectType != TOKEN()) {
224
- revert InvalidToken();
225
- }
225
+ // if(tokenInfo.objectType != TOKEN()) {
226
+ // revert InvalidToken();
227
+ // }
226
228
 
227
- IRegistry.ObjectInfo memory poolInfo = _registry.getObjectInfo(info.poolNftId);
229
+ // IRegistry.ObjectInfo memory poolInfo = _registry.getObjectInfo(info.poolNftId);
228
230
 
229
- if(poolInfo.objectType != POOL()) {
230
- revert InvalidPool();
231
- }
231
+ // if(poolInfo.objectType != POOL()) {
232
+ // revert InvalidPool();
233
+ // }
232
234
 
233
- if(poolInfo.parentNftId != instanceNftId) {
234
- revert InvalidPoolsInstance();
235
- }
236
- // TODO pool have the same token
237
- //ITreasury.PoolSetup memory poolSetup = instance.getPoolSetup(info.poolNftId);
238
- //require(tokenInfo.objectAddress == address(poolSetup.token), "ERROR:COS-018:PRODUCT_POOL_TOKEN_MISMATCH");
239
- // TODO pool is not linked
235
+ // if(poolInfo.parentNftId != instanceNftId) {
236
+ // revert InvalidPoolsInstance();
237
+ // }
238
+ // // TODO pool have the same token
239
+ // //ITreasury.PoolSetup memory poolSetup = instance.getPoolSetup(info.poolNftId);
240
+ // //require(tokenInfo.objectAddress == address(poolSetup.token), "ERROR:COS-018:PRODUCT_POOL_TOKEN_MISMATCH");
241
+ // // TODO pool is not linked
240
242
 
241
- IRegistry.ObjectInfo memory distributionInfo = _registry.getObjectInfo(info.distributionNftId);
243
+ // IRegistry.ObjectInfo memory distributionInfo = _registry.getObjectInfo(info.distributionNftId);
242
244
 
243
- if(distributionInfo.objectType != DISTRIBUTION()) {
244
- revert InvalidDistribution();
245
- }
245
+ // if(distributionInfo.objectType != DISTRIBUTION()) {
246
+ // revert InvalidDistribution();
247
+ // }
246
248
 
247
- if(distributionInfo.parentNftId != instanceNftId) {
248
- revert InvalidDistributionsInstance();
249
- }
250
- // TODO distribution have the same token
251
- // TODO distribution is not linked
252
-
253
- // component module
254
- instance.registerComponent(
255
- nftId,
256
- info.token,
257
- wallet // TODO move wallet into TreasuryInfo?
258
- );
249
+ // if(distributionInfo.parentNftId != instanceNftId) {
250
+ // revert InvalidDistributionsInstance();
251
+ // }
252
+ // // TODO distribution have the same token
253
+ // // TODO distribution is not linked
254
+
255
+ // // component module
256
+ // instance.registerComponent(
257
+ // nftId,
258
+ // info.token,
259
+ // wallet // TODO move wallet into TreasuryInfo?
260
+ // );
259
261
 
260
262
  // treasury module
261
- instance.registerProductSetup(
263
+ instance.createProductSetup(
262
264
  nftId,
263
265
  info
264
266
  );
@@ -273,13 +275,13 @@ contract ComponentOwnerService is
273
275
  internal
274
276
  {
275
277
  (
276
- IPool.PoolInfo memory info,
278
+ ISetup.PoolSetupInfo memory info,
277
279
  address wallet,
278
280
  IERC20Metadata token,
279
281
  /*poolFee*/,
280
282
  /*stakingFee*/,
281
283
  /*performanceFee*/
282
- ) = abi.decode(data, (IPool.PoolInfo, address, IERC20Metadata, Fee, Fee, Fee));
284
+ ) = abi.decode(data, (ISetup.PoolSetupInfo, address, IERC20Metadata, Fee, Fee, Fee));
283
285
 
284
286
  IRegistry _registry = getRegistry();
285
287
 
@@ -299,15 +301,15 @@ contract ComponentOwnerService is
299
301
 
300
302
  // TODO add more validations
301
303
 
302
- // component module
303
- instance.registerComponent(
304
- nftId,
305
- token,
306
- wallet
307
- );
304
+ // // component module
305
+ // instance.registerComponent(
306
+ // nftId,
307
+ // token,
308
+ // wallet
309
+ // );
308
310
 
309
311
  // pool module
310
- instance.registerPool(
312
+ instance.createPoolSetup(
311
313
  nftId,
312
314
  info
313
315
  );
@@ -3,39 +3,53 @@ pragma solidity ^0.8.19;
3
3
 
4
4
  import {IRegistry} from "../../registry/IRegistry.sol";
5
5
  import {IInstance} from "../../instance/IInstance.sol";
6
- import {ITreasury} from "../../instance/module/treasury/ITreasury.sol";
6
+ import {InstanceReader} from "../../instance/InstanceReader.sol";
7
+ import {ISetup} from "../../instance/module/ISetup.sol";
8
+ import {ITreasury} from "../../instance/module/ITreasury.sol";
7
9
 
8
10
  import {NftId} from "../../types/NftId.sol";
9
11
  import {Fee} from "../../types/Fee.sol";
12
+ import {KEEP_STATE} from "../../types/StateId.sol";
10
13
  import {DISTRIBUTION} from "../../types/ObjectType.sol";
11
14
  import {Version, VersionLib} from "../../types/Version.sol";
12
15
 
13
16
  import {IVersionable} from "../../shared/IVersionable.sol";
14
17
  import {Versionable} from "../../shared/Versionable.sol";
15
18
 
16
- import {IService} from "../base/IService.sol";
17
- import {ServiceBase} from "../base/ServiceBase.sol";
19
+ import {IService} from "../../shared/IService.sol";
20
+ import {Service} from "../../shared/Service.sol";
18
21
  import {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
19
22
  import {IDistributionService} from "./IDistributionService.sol";
20
23
 
24
+ string constant DISTRIBUTION_SERVICE_NAME = "DistributionService";
25
+
21
26
  contract DistributionService is
22
27
  ComponentServiceBase,
23
28
  IDistributionService
24
29
  {
25
- string public constant NAME = "DistributionService";
26
-
27
- constructor(
28
- address registry,
29
- NftId registryNftId,
30
- address initialOwner
31
- ) ComponentServiceBase(registry, registryNftId, initialOwner)
30
+
31
+ address internal _registryAddress;
32
+
33
+ function initialize(
34
+ address owner,
35
+ bytes memory data
36
+ )
37
+ internal
38
+ initializer
39
+ virtual
32
40
  {
41
+ address initialOwner = address(0);
42
+ (_registryAddress, initialOwner) = abi.decode(data, (address, address));
43
+
44
+ // IRegistry registry = IRegistry(_registryAddress);
45
+
46
+ _initializeService(_registryAddress, initialOwner);
33
47
  _registerInterface(type(IDistributionService).interfaceId);
34
48
  }
35
49
 
36
50
 
37
- function getName() public pure override(IService, ServiceBase) returns(string memory name) {
38
- return NAME;
51
+ function getName() public pure override(IService, Service) returns(string memory name) {
52
+ return DISTRIBUTION_SERVICE_NAME;
39
53
  }
40
54
 
41
55
  function setFees(
@@ -44,11 +58,13 @@ contract DistributionService is
44
58
  external
45
59
  override
46
60
  {
47
- (IRegistry.ObjectInfo memory distributionInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(DISTRIBUTION());
61
+ (IRegistry.ObjectInfo memory info , IInstance instance) = _getAndVerifyComponentInfoAndInstance(DISTRIBUTION());
62
+ InstanceReader instanceReader = instance.getInstanceReader();
63
+ NftId distributionNftId = info.nftId;
48
64
 
49
- NftId productNftId = instance.getProductNftId(distributionInfo.nftId);
50
- ITreasury.TreasuryInfo memory treasuryInfo = instance.getTreasuryInfo(productNftId);
51
- treasuryInfo.distributionFee = distributionFee;
52
- instance.setTreasuryInfo(productNftId, treasuryInfo);
65
+ ISetup.DistributionSetupInfo memory distSetupInfo = instanceReader.getDistributionSetupInfo(distributionNftId);
66
+ distSetupInfo.distributionFee = distributionFee;
67
+
68
+ instance.updateDistributionSetup(distributionNftId, distSetupInfo, KEEP_STATE());
53
69
  }
54
70
  }
@@ -0,0 +1,53 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {IVersionable} from "../../shared/IVersionable.sol";
5
+ import {ProxyManager} from "../../shared/ProxyManager.sol";
6
+ import {DistributionService} from "./DistributionService.sol";
7
+ import {Registry} from "../../registry/Registry.sol";
8
+ import {RegistryService} from "../../registry/RegistryService.sol";
9
+ import {VersionLib} from "../../types/Version.sol";
10
+
11
+ contract DistributionServiceManager is ProxyManager {
12
+
13
+ DistributionService private _distributionService;
14
+
15
+ /// @dev initializes proxy manager with distribution service implementation and deploys instance
16
+ constructor(
17
+ address registryAddress
18
+ )
19
+ ProxyManager()
20
+ {
21
+ DistributionService distSrv = new DistributionService();
22
+ bytes memory data = abi.encode(registryAddress, address(this));
23
+ IVersionable versionable = deploy(
24
+ address(distSrv),
25
+ data);
26
+
27
+ _distributionService = DistributionService(address(versionable));
28
+
29
+ Registry registry = Registry(registryAddress);
30
+ address registryServiceAddress = registry.getServiceAddress(_distributionService.getName(), VersionLib.toVersion(3, 0, 0).toMajorPart());
31
+ RegistryService registryService = RegistryService(registryServiceAddress);
32
+
33
+ registryService.registerService(_distributionService);
34
+
35
+ // link ownership of instance service manager ot nft owner of instance service
36
+ _linkToNftOwnable(
37
+ address(registryAddress),
38
+ address(_distributionService));
39
+
40
+ // implies that after this constructor call only upgrade functionality is available
41
+ _isDeployed = true;
42
+ }
43
+
44
+ //--- view functions ----------------------------------------------------//
45
+ function getDistributionService()
46
+ external
47
+ view
48
+ returns (DistributionService distributionService)
49
+ {
50
+ return _distributionService;
51
+ }
52
+
53
+ }
@@ -5,7 +5,7 @@ import {NftId} from "../../types/NftId.sol";
5
5
  import {ObjectType} from "../../types/ObjectType.sol";
6
6
  import {RoleId} from "../../types/RoleId.sol";
7
7
  import {IBaseComponent} from "../../components/IBaseComponent.sol";
8
- import {IService} from "../base/IService.sol";
8
+ import {IService} from "../../shared/IService.sol";
9
9
 
10
10
  // TODO rename to registry service
11
11
  interface IComponentOwnerService is IService {
@@ -3,7 +3,7 @@ pragma solidity ^0.8.19;
3
3
 
4
4
  import {NftId} from "../../types/NftId.sol";
5
5
  import {Fee} from "../../types/Fee.sol";
6
- import {IService} from "../base/IService.sol";
6
+ import {IService} from "../../shared/IService.sol";
7
7
 
8
8
  interface IDistributionService is IService {
9
9
  function setFees(
@@ -3,7 +3,7 @@ pragma solidity ^0.8.19;
3
3
 
4
4
  import {NftId} from "../../types/NftId.sol";
5
5
  import {Fee} from "../../types/Fee.sol";
6
- import {IService} from "../base/IService.sol";
6
+ import {IService} from "../../shared/IService.sol";
7
7
 
8
8
  interface IPoolService is IService {
9
9
  function setFees(
@@ -1,8 +1,8 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.19;
3
3
 
4
- import {IRisk} from "../module/risk/IRisk.sol";
5
- import {IService} from "../base/IService.sol";
4
+ import {IRisk} from "../module/IRisk.sol";
5
+ import {IService} from "../../shared/IService.sol";
6
6
 
7
7
  import {NftId} from "../../types/NftId.sol";
8
8
  import {ReferralId} from "../../types/Referral.sol";
@@ -24,6 +24,7 @@ interface IRegistry is IERC165 {
24
24
  address initialOwner;
25
25
  bytes data;
26
26
  }// TODO delete nftId and initialOwner(if not used) from struct
27
+ // TODO strong disagree, keep nftId there (lets keep get object info return object consistent)
27
28
 
28
29
  function register(ObjectInfo memory info) external returns (NftId nftId);
29
30
 
@@ -1,14 +1,14 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {NftId} from "../../contracts/types/NftId.sol";
5
- import {ObjectType} from "../../contracts/types/ObjectType.sol";
6
- import {RoleId} from "../../contracts/types/RoleId.sol";
7
- import {IService} from "../../contracts/instance/base/IService.sol";
8
- import {IRegistry} from "../../contracts/registry/IRegistry.sol";
9
-
10
- import {IRegisterable} from "../../contracts/shared/IRegisterable.sol";
11
- import {IBaseComponent} from "../../contracts/components/IBaseComponent.sol";
4
+ import {NftId} from "../types/NftId.sol";
5
+ import {ObjectType} from "../types/ObjectType.sol";
6
+ import {RoleId} from "../types/RoleId.sol";
7
+ import {IService} from "../shared/IService.sol";
8
+ import {IRegistry} from "./IRegistry.sol";
9
+
10
+ import {IRegisterable} from "../shared/IRegisterable.sol";
11
+ import {IBaseComponent} from "../components/IBaseComponent.sol";
12
12
 
13
13
  interface IRegistryService is IService {
14
14
 
@@ -2,7 +2,7 @@
2
2
  pragma solidity ^0.8.20;
3
3
 
4
4
  import {IRegisterable} from "../shared/IRegisterable.sol";
5
- import {IService} from "../instance/base/IService.sol";
5
+ import {IService} from "../shared/IService.sol";
6
6
 
7
7
  import {ChainNft} from "./ChainNft.sol";
8
8
  import {IRegistry} from "./IRegistry.sol";
@@ -10,8 +10,8 @@ import {IRegistry} from "./IRegistry.sol";
10
10
  import {IInstance} from "../instance/IInstance.sol";
11
11
 
12
12
  import {ContractDeployerLib} from "../shared/ContractDeployerLib.sol";
13
- import {IComponent, IComponentModule} from "../../contracts/instance/module/component/IComponent.sol";
14
- import {IPool} from "../../contracts/instance/module/pool/IPoolModule.sol";
13
+ // import {IComponent, IComponentModule} from "../../contracts/instance/module/component/IComponent.sol";
14
+ // import {IPool} from "../../contracts/instance/module/pool/IPoolModule.sol";
15
15
  import {IBaseComponent} from "../../contracts/components/IBaseComponent.sol";
16
16
  import {IPoolComponent} from "../../contracts/components/IPoolComponent.sol";
17
17
  import {IProductComponent} from "../../contracts/components/IProductComponent.sol";
@@ -28,15 +28,15 @@ import {NftId, NftIdLib, zeroNftId} from "../../contracts/types/NftId.sol";
28
28
  import {Fee, FeeLib} from "../../contracts/types/Fee.sol";
29
29
  import {Version, VersionPart, VersionLib} from "../../contracts/types/Version.sol";
30
30
 
31
- import {ServiceBase} from "../../contracts/instance/base/ServiceBase.sol";
32
- import {IService} from "../../contracts/instance/base/IService.sol";
31
+ import {Service} from "../shared/Service.sol";
32
+ import {IService} from "../shared/IService.sol";
33
33
  import {IRegistryService} from "./IRegistryService.sol";
34
34
  import {Registry} from "./Registry.sol";
35
35
  import {ChainNft} from "./ChainNft.sol";
36
36
 
37
37
  contract RegistryService is
38
38
  AccessManagedUpgradeable,
39
- ServiceBase,
39
+ Service,
40
40
  IRegistryService
41
41
  {
42
42
  using NftIdLib for NftId;
@@ -119,6 +119,9 @@ contract RegistryService is
119
119
  // IMPORTANT: MUST NOT check owner before calling external contract
120
120
  function registerService(IService service)
121
121
  external
122
+ // TODO restrict access - registryService.registerService must use accessmanager for checking permissions as
123
+ // services are not always owned by registry owner - actually only registry service is owned by registry owner
124
+
122
125
  returns(
123
126
  IRegistry.ObjectInfo memory info,
124
127
  bytes memory data
@@ -135,10 +138,6 @@ contract RegistryService is
135
138
  data
136
139
  ) = _getAndVerifyContractInfo(service, SERVICE(), msg.sender);
137
140
 
138
- if(msg.sender != _registry.getOwner()) {
139
- revert NotRegistryOwner();
140
- }
141
-
142
141
  info.nftId = _registry.register(info);
143
142
  service.linkToRegisteredNftId();
144
143
  return (
@@ -159,7 +158,6 @@ contract RegistryService is
159
158
  bytes memory data
160
159
  )
161
160
  {
162
-
163
161
  if(!instance.supportsInterface(type(IInstance).interfaceId)) {
164
162
  revert NotInstance();
165
163
  }
@@ -291,7 +289,7 @@ contract RegistryService is
291
289
 
292
290
 
293
291
  // From IService
294
- function getName() public pure override(IService, ServiceBase) returns(string memory) {
292
+ function getName() public pure override(IService, Service) returns(string memory) {
295
293
  return NAME;
296
294
  }
297
295
  //function getType() public pure override(IService, ServiceBase) returns(ObjectType serviceType) {
@@ -335,7 +333,7 @@ contract RegistryService is
335
333
 
336
334
  NftId registryNftId = registry.getNftId(address(registry));
337
335
 
338
- _initializeServiceBase(address(registry), registryNftId, owner);
336
+ _initializeService(address(registry), owner);
339
337
 
340
338
  // TODO why do registry service proxy need to keep its nftId??? -> no registryServiceNftId checks in implementation
341
339
  // if they are -> use registry address to obtain owner of registry service nft (works the same with any registerable and(or) implementation)
@@ -368,8 +366,13 @@ contract RegistryService is
368
366
 
369
367
  address owner = info.initialOwner;
370
368
 
371
- if(owner != expectedOwner) { // registerable owner protection
372
- revert NotRegisterableOwner(expectedOwner);
369
+ // solhint-disable-next-line
370
+ if(expectedType == INSTANCE()) {
371
+ // any address may create a new instance via instance service
372
+ } else {
373
+ if(owner != expectedOwner) { // registerable owner protection
374
+ revert NotRegisterableOwner(expectedOwner);
375
+ }
373
376
  }
374
377
 
375
378
  if(owner == address(registerable)) {
@@ -1,10 +1,10 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.19;
3
3
 
4
- import {VersionPart} from "../../types/Version.sol";
4
+ import {VersionPart} from "../types/Version.sol";
5
5
 
6
- import {IRegisterable} from "../../shared/IRegisterable.sol";
7
- import {IVersionable} from "../../shared/IVersionable.sol";
6
+ import {IRegisterable} from "./IRegisterable.sol";
7
+ import {IVersionable} from "./IVersionable.sol";
8
8
 
9
9
  interface IService is
10
10
  IRegisterable,
@@ -0,0 +1,16 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.19;
3
+
4
+ import {Registerable} from "./Registerable.sol";
5
+ import {Versionable} from "./Versionable.sol";
6
+
7
+ /// @dev base contract for upgradable objects like services and upgradable components
8
+ /// deriving contracs need to call _initializeRegisterable
9
+ /// TODO internalizes versionable here, a non-registerable versionalbe might itself have some value but is outside the scope of the gif
10
+ /// after this merge versionable will no longer exist on its own in gif
11
+ /// only registerable and upgradable (which is a registerable too) will remain
12
+ abstract contract RegisterableUpgradable is
13
+ Registerable,
14
+ Versionable
15
+ {
16
+ }
@@ -0,0 +1,54 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.19;
3
+
4
+ import {IRegistry} from "../registry/IRegistry.sol";
5
+ import {IService} from "./IService.sol";
6
+ import {IVersionable} from "./IVersionable.sol";
7
+ import {NftId, zeroNftId} from "../types/NftId.sol";
8
+ import {RegisterableUpgradable} from "./RegisterableUpgradable.sol";
9
+ import {SERVICE} from "../types/ObjectType.sol";
10
+ import {Version, VersionPart, VersionLib} from "../types/Version.sol";
11
+ import {Versionable} from "./Versionable.sol";
12
+
13
+ /// @dev service base contract
14
+ abstract contract Service is
15
+ RegisterableUpgradable,
16
+ IService
17
+ {
18
+ function getName() public pure virtual override returns(string memory name);
19
+
20
+ function getMajorVersion() public view virtual override returns(VersionPart majorVersion) {
21
+ return getVersion().toMajorPart();
22
+ }
23
+
24
+ // from Versionable
25
+ function getVersion()
26
+ public
27
+ pure
28
+ virtual override (IVersionable, Versionable)
29
+ returns(Version)
30
+ {
31
+ return VersionLib.toVersion(3,0,0);
32
+ }
33
+
34
+ function _initializeService(
35
+ address registry,
36
+ address initialOwner
37
+ )
38
+ internal
39
+ //onlyInitializing //TODO uncomment when "fully" upgradeable
40
+ {
41
+ // service must provide its name and version upon registration
42
+ bytes memory data = abi.encode(getName(), getMajorVersion());
43
+ NftId registryNftId = _getRegistryNftId(registry);
44
+ bool isInterceptor = false;
45
+
46
+ _initializeRegisterable(registry, registryNftId, SERVICE(), isInterceptor, initialOwner, data);
47
+ _registerInterface(type(IService).interfaceId);
48
+ }
49
+
50
+ // this is just a conveniene function, actual validation will be done upon registration
51
+ function _getRegistryNftId(address registryAddress) internal view returns (NftId) {
52
+ return IRegistry(registryAddress).getNftId(registryAddress);
53
+ }
54
+ }
@@ -0,0 +1,27 @@
1
+ // SPDX-License-Identifier: Apache-2.0
2
+ pragma solidity ^0.8.20;
3
+
4
+ import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
5
+ import {SafeERC20} from "@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol";
6
+
7
+ contract TokenHandler {
8
+ IERC20Metadata private _token;
9
+
10
+ constructor(address token) {
11
+ _token = IERC20Metadata(token);
12
+ }
13
+
14
+ // TODO add logging
15
+ function transfer(
16
+ address from,
17
+ address to,
18
+ uint256 amount // TODO add authz (only treasury/instance/product/pool/ service)
19
+ ) external {
20
+ SafeERC20.safeTransferFrom(_token, from, to, amount);
21
+ // _token.transferFrom(from, to, amount);
22
+ }
23
+
24
+ function getToken() external view returns (IERC20Metadata) {
25
+ return _token;
26
+ }
27
+ }