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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (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
+ }