@etherisc/gif-next 0.0.2-e46206a-486 → 0.0.2-e510b92-393

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 (320) hide show
  1. package/README.md +67 -1
  2. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +1 -1
  3. package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +152 -0
  4. package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
  5. package/artifacts/contracts/components/Distribution.sol/Distribution.json +220 -33
  6. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +1 -1
  7. package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +114 -0
  8. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  9. package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -25
  10. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  11. package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +24 -57
  12. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  13. package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -50
  14. package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
  15. package/artifacts/contracts/components/Pool.sol/Pool.json +291 -68
  16. package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
  17. package/artifacts/contracts/components/Product.sol/Product.json +299 -58
  18. package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +1 -1
  19. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +1 -1
  20. package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +1 -1
  21. package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
  22. package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
  23. package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
  24. package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
  25. package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
  26. package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
  27. package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
  28. package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
  29. package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
  30. package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
  31. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
  32. package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +2 -2
  33. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
  34. package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
  35. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
  36. package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +2 -2
  37. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
  38. package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +2 -2
  39. package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
  40. package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
  41. package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +4 -0
  42. package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.json +101 -0
  43. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +4 -0
  44. package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +1132 -0
  45. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
  46. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +775 -0
  47. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
  48. package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +185 -0
  49. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +4 -0
  50. package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +1082 -0
  51. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  52. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +778 -1020
  53. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
  54. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +485 -0
  55. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  56. package/artifacts/contracts/instance/Instance.sol/Instance.json +2286 -1032
  57. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
  58. package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +917 -0
  59. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
  60. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1422 -0
  61. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
  62. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +970 -0
  63. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
  64. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +512 -0
  65. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
  66. package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +272 -0
  67. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +1 -1
  68. package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +59 -0
  69. package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +1 -1
  70. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  71. package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +27 -158
  72. package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  73. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  74. package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +37 -253
  75. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  76. package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +2 -2
  77. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
  78. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +211 -0
  79. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
  80. package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
  81. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
  82. package/artifacts/contracts/instance/module/{distribution/IDistribution.sol → IDistribution.sol}/IDistribution.json +1 -1
  83. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
  84. package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
  85. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
  86. package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
  87. package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
  88. package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/ISetup.sol/ISetup.json} +2 -2
  89. package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
  90. package/artifacts/contracts/instance/module/{treasury/ITreasury.sol → ITreasury.sol}/ITreasury.json +1 -1
  91. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +1 -1
  92. package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +32 -48
  93. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
  94. package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +111 -41
  95. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
  96. package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +444 -0
  97. package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +1 -1
  98. package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  99. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
  100. package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +167 -0
  101. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
  102. package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +40 -31
  103. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
  104. package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +322 -42
  105. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
  106. package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +464 -0
  107. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
  108. package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +176 -105
  109. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
  110. package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +488 -0
  111. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  112. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  113. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +201 -0
  114. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  115. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +94 -19
  116. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  117. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  118. package/artifacts/contracts/registry/Registry.sol/Registry.json +172 -49
  119. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  120. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +61 -29
  121. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  122. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +47 -34
  123. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
  124. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +410 -0
  125. package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
  126. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
  127. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
  128. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  129. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  130. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
  131. package/artifacts/contracts/{instance/base → shared}/IService.sol/IService.json +1 -1
  132. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
  133. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  134. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +2 -2
  135. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
  136. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +2 -2
  137. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  138. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +4 -4
  139. package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +4 -0
  140. package/artifacts/contracts/{instance/base/InstanceBase.sol/InstanceBase.json → shared/RegisterableUpgradable.sol/RegisterableUpgradable.json} +2 -104
  141. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
  142. package/artifacts/contracts/{instance/base/ServiceBase.sol/ServiceBase.json → shared/Service.sol/Service.json} +2 -2
  143. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
  144. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
  145. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
  146. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
  147. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
  148. package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
  149. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
  150. package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +4 -4
  151. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
  152. package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +2 -2
  153. package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
  154. package/artifacts/contracts/test/TestService.sol/TestService.json +11 -11
  155. package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
  156. package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
  157. package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
  158. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
  159. package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +2 -2
  160. package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
  161. package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  162. package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  163. package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
  164. package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  165. package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
  166. package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
  167. package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
  168. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  169. package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
  170. package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
  171. package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  172. package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
  173. package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
  174. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
  175. package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
  176. package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
  177. package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
  178. package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
  179. package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
  180. package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
  181. package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
  182. package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
  183. package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
  184. package/artifacts/contracts/types/Version.sol/VersionPartLib.json +22 -3
  185. package/contracts/components/BaseComponent.sol +64 -11
  186. package/contracts/components/Distribution.sol +22 -14
  187. package/contracts/components/IBaseComponent.sol +14 -2
  188. package/contracts/components/IDistributionComponent.sol +1 -3
  189. package/contracts/components/IPoolComponent.sol +5 -3
  190. package/contracts/components/IProductComponent.sol +1 -3
  191. package/contracts/components/Pool.sol +50 -29
  192. package/contracts/components/Product.sol +50 -60
  193. package/contracts/instance/AccessManagedSimple.sol +115 -0
  194. package/contracts/instance/AccessManagerSimple.sol +692 -0
  195. package/contracts/instance/BundleManager.sol +129 -0
  196. package/contracts/instance/Cloneable.sol +46 -0
  197. package/contracts/instance/IAccessManagerSimple.sol +391 -0
  198. package/contracts/instance/IInstance.sol +48 -44
  199. package/contracts/instance/IInstanceService.sol +32 -0
  200. package/contracts/instance/Instance.sol +434 -63
  201. package/contracts/instance/InstanceAccessManager.sol +288 -0
  202. package/contracts/instance/InstanceReader.sol +315 -0
  203. package/contracts/instance/InstanceService.sol +232 -0
  204. package/contracts/instance/InstanceServiceManager.sol +57 -0
  205. package/contracts/instance/ObjectManager.sol +95 -0
  206. package/contracts/instance/base/ComponentServiceBase.sol +93 -8
  207. package/contracts/instance/base/IKeyValueStore.sol +13 -14
  208. package/contracts/instance/base/ILifecycle.sol +3 -3
  209. package/contracts/instance/base/KeyValueStore.sol +49 -39
  210. package/contracts/instance/base/Lifecycle.sol +1 -1
  211. package/contracts/instance/module/IAccess.sol +38 -0
  212. package/contracts/instance/module/IBundle.sol +20 -0
  213. package/contracts/instance/module/IDistribution.sol +39 -0
  214. package/contracts/instance/module/IPolicy.sol +45 -0
  215. package/contracts/instance/module/IRisk.sol +11 -0
  216. package/contracts/instance/module/ISetup.sol +46 -0
  217. package/contracts/instance/module/ITreasury.sol +23 -0
  218. package/contracts/instance/service/ComponentOwnerService.sol +62 -60
  219. package/contracts/instance/service/DistributionService.sol +49 -15
  220. package/contracts/instance/service/DistributionServiceManager.sol +54 -0
  221. package/contracts/instance/service/IComponentOwnerService.sol +1 -1
  222. package/contracts/instance/service/IDistributionService.sol +1 -1
  223. package/contracts/instance/service/IPoolService.sol +17 -3
  224. package/contracts/instance/service/IProductService.sol +8 -5
  225. package/contracts/instance/service/PoolService.sol +183 -45
  226. package/contracts/instance/service/PoolServiceManager.sol +54 -0
  227. package/contracts/instance/service/ProductService.sol +175 -115
  228. package/contracts/instance/service/ProductServiceManager.sol +54 -0
  229. package/contracts/registry/IRegistry.sol +26 -2
  230. package/contracts/registry/IRegistryService.sol +34 -19
  231. package/contracts/registry/Registry.sol +61 -36
  232. package/contracts/registry/RegistryService.sol +42 -125
  233. package/contracts/registry/RegistryServiceManager.sol +21 -5
  234. package/contracts/registry/TokenRegistry.sol +111 -0
  235. package/contracts/shared/ERC165.sol +6 -2
  236. package/contracts/{instance/base → shared}/IService.sol +3 -3
  237. package/contracts/shared/NftOwnable.sol +2 -4
  238. package/contracts/shared/Registerable.sol +1 -0
  239. package/contracts/shared/RegisterableUpgradable.sol +16 -0
  240. package/contracts/shared/Service.sol +55 -0
  241. package/contracts/shared/TokenHandler.sol +27 -0
  242. package/contracts/test/TestService.sol +3 -5
  243. package/contracts/types/NftIdSet.sol +26 -24
  244. package/contracts/types/RoleId.sol +8 -0
  245. package/contracts/types/StateId.sol +4 -0
  246. package/contracts/types/Version.sol +4 -1
  247. package/package.json +1 -1
  248. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
  249. package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
  250. package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
  251. package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
  252. package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
  253. package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
  254. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
  255. package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -297
  256. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
  257. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
  258. package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -297
  259. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
  260. package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +0 -117
  261. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
  262. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
  263. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
  264. package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +0 -117
  265. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +0 -4
  266. package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +0 -10
  267. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +0 -4
  268. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +0 -4
  269. package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +0 -10
  270. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
  271. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
  272. package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -271
  273. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
  274. package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -271
  275. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
  276. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
  277. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
  278. package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -164
  279. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
  280. package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -164
  281. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
  282. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
  283. package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -113
  284. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
  285. package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -131
  286. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
  287. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
  288. package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -638
  289. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
  290. package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
  291. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
  292. package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -638
  293. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +0 -4
  294. package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +0 -557
  295. package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
  296. package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -716
  297. package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
  298. package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -744
  299. package/contracts/instance/IInstanceLinked.sol +0 -8
  300. package/contracts/instance/base/InstanceBase.sol +0 -89
  301. package/contracts/instance/base/ModuleBase.sol +0 -57
  302. package/contracts/instance/base/ServiceBase.sol +0 -44
  303. package/contracts/instance/module/bundle/BundleModule.sol +0 -134
  304. package/contracts/instance/module/bundle/IBundle.sol +0 -53
  305. package/contracts/instance/module/component/ComponentModule.sol +0 -71
  306. package/contracts/instance/module/component/IComponent.sol +0 -28
  307. package/contracts/instance/module/distribution/DistributionModule.sol +0 -17
  308. package/contracts/instance/module/distribution/IDistribution.sol +0 -10
  309. package/contracts/instance/module/policy/IPolicy.sol +0 -63
  310. package/contracts/instance/module/policy/PolicyModule.sol +0 -91
  311. package/contracts/instance/module/pool/IPoolModule.sol +0 -41
  312. package/contracts/instance/module/pool/PoolModule.sol +0 -95
  313. package/contracts/instance/module/risk/IRisk.sol +0 -26
  314. package/contracts/instance/module/risk/RiskModule.sol +0 -62
  315. package/contracts/instance/module/treasury/ITreasury.sol +0 -84
  316. package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
  317. package/contracts/instance/module/treasury/TreasuryModule.sol +0 -131
  318. package/contracts/test/TestDistribution.sol +0 -22
  319. package/contracts/test/TestPool.sol +0 -27
  320. package/contracts/test/TestProduct.sol +0 -74
@@ -1,35 +1,50 @@
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";
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
9
 
10
- import {IRegisterable} from "../../contracts/shared/IRegisterable.sol";
11
- import {IBaseComponent} from "../../contracts/components/IBaseComponent.sol";
10
+ import {IRegisterable} from "../shared/IRegisterable.sol";
11
+ import {IBaseComponent} from "../components/IBaseComponent.sol";
12
12
 
13
13
  interface IRegistryService is IService {
14
14
 
15
- function registerToken(address tokenAddress) external returns(NftId nftId);
15
+ error SelfRegistration();
16
+ error NotRegistryOwner();
16
17
 
17
- function registerService(IService service) external returns(IRegistry.ObjectInfo memory info, bytes memory data);
18
+ error NotService();
19
+ error NotInstance();
20
+ error NotProduct();
21
+ error NotPool();
22
+ error NotDistribution();
18
23
 
19
- function registerInstance(IRegisterable instance)
20
- external returns(IRegistry.ObjectInfo memory info, bytes memory data);
24
+ error UnexpectedRegisterableType(ObjectType expected, ObjectType found);
25
+ error NotRegisterableOwner(address expectedOwner);
26
+ error RegisterableOwnerIsZero();
27
+ error RegisterableOwnerIsRegistered();
28
+ error InvalidInitialOwner(address initialOwner);
29
+ error InvalidAddress(address registerableAddress);
21
30
 
22
- function registerProduct(IBaseComponent product, address owner)
23
- external returns(IRegistry.ObjectInfo memory info, bytes memory data);
24
31
 
25
- function registerPool(IBaseComponent pool, address owner)
26
- external returns(IRegistry.ObjectInfo memory info, bytes memory data);
32
+ function registerService(IService service) external returns(IRegistry.ObjectInfo memory info, bytes memory data);
27
33
 
28
- function registerDistribution(IBaseComponent distribution, address owner)
29
- external returns(IRegistry.ObjectInfo memory info, bytes memory data);
34
+ function registerInstance(IRegisterable instance)
35
+ external returns(IRegistry.ObjectInfo memory info, bytes memory data);
30
36
 
31
- function registerPolicy(IRegistry.ObjectInfo memory info) external returns(NftId nftId); // -> easy to upgrade
37
+ function registerProduct(IBaseComponent product, address owner)
38
+ external returns(IRegistry.ObjectInfo memory info, bytes memory data);
32
39
 
33
- function registerBundle(IRegistry.ObjectInfo memory info) external returns(NftId nftId);
40
+ function registerPool(IBaseComponent pool, address owner)
41
+ external returns(IRegistry.ObjectInfo memory info, bytes memory data);
42
+
43
+ function registerDistribution(IBaseComponent distribution, address owner)
44
+ external returns(IRegistry.ObjectInfo memory info, bytes memory data);
45
+
46
+ function registerPolicy(IRegistry.ObjectInfo memory info) external returns(NftId nftId); // -> easy to upgrade
47
+
48
+ function registerBundle(IRegistry.ObjectInfo memory info) external returns(NftId nftId);
34
49
  }
35
50
 
@@ -2,12 +2,12 @@
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";
9
9
  import {NftId, toNftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
10
- import {Version, VersionPart, VersionLib} from "../types/Version.sol";
10
+ import {Version, VersionPart, VersionLib, VersionPartLib} from "../types/Version.sol";
11
11
  import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, PRODUCT, DISTRIBUTION, ORACLE, POOL, POLICY, BUNDLE} from "../types/ObjectType.sol";
12
12
  import {ITransferInterceptor} from "./ITransferInterceptor.sol";
13
13
 
@@ -28,30 +28,17 @@ contract Registry is
28
28
  ERC165,
29
29
  IRegistry
30
30
  {
31
- // register
32
- error NotRegistryService();
33
- error ZeroParentAddress();
34
- error ContractAlreadyRegistered(address objectAddress);
35
- error InvalidServiceVersion(VersionPart majorVersion);
36
- error ServiceNameAlreadyRegistered(string name, VersionPart majorVersion);
37
-
38
- // approve
39
- error NotOwner();
40
- error NotRegisteredContract(NftId registrarNftId);
41
- error NotService(NftId registrarNftId);
42
- error InvalidTypesCombination(ObjectType objectType, ObjectType parentType);
43
-
44
- uint256 public constant MAJOR_VERSION_MIN = 3;
31
+ uint256 public constant GIF_MAJOR_VERSION_AT_DEPLOYMENT = 3;
45
32
  address public constant NFT_LOCK_ADDRESS = address(0x1);
33
+ uint256 public constant REGISTRY_TOKEN_SEQUENCE_ID = 2;
46
34
  uint256 public constant REGISTRY_SERVICE_TOKEN_SEQUENCE_ID = 3;
47
35
  string public constant EMPTY_URI = "";
48
36
 
37
+ VersionPart internal _majorVersion;
38
+
49
39
  mapping(NftId nftId => ObjectInfo info) internal _info;
50
40
  mapping(address object => NftId nftId) internal _nftIdByAddress;
51
41
 
52
- mapping(NftId registrator => mapping(
53
- ObjectType objectType => bool)) internal _isApproved;
54
-
55
42
  mapping(ObjectType objectType => mapping(
56
43
  ObjectType parentType => bool)) internal _isValidContractCombination;
57
44
 
@@ -69,13 +56,12 @@ contract Registry is
69
56
 
70
57
  modifier onlyOwner() {
71
58
  if(msg.sender != getOwner()) {
72
- revert NotOwner();
59
+ revert NotOwner(msg.sender);
73
60
  }
74
61
  _;
75
62
  }
76
63
 
77
64
  modifier onlyRegistryService() {
78
-
79
65
  if(msg.sender != _info[_serviceNftId].objectAddress) {
80
66
  revert NotRegistryService();
81
67
  }
@@ -85,7 +71,10 @@ contract Registry is
85
71
  constructor(address registryOwner, VersionPart majorVersion)
86
72
  {
87
73
  require(registryOwner > address(0), "Registry: registry owner is 0");
88
- require(majorVersion.toInt() == MAJOR_VERSION_MIN, "Registry: initial major version of registry service is not MAJOR_VERSION_MIN");
74
+
75
+ // major version at constructor time
76
+ _majorVersion = VersionLib.toVersionPart(GIF_MAJOR_VERSION_AT_DEPLOYMENT);
77
+ emit LogInitialMajorVersionSet(_majorVersion);
89
78
 
90
79
  // deploy NFT
91
80
  _chainNft = new ChainNft(address(this));// adds 10kb to deployment size
@@ -101,6 +90,24 @@ contract Registry is
101
90
  _registerInterface(type(IRegistry).interfaceId);
102
91
  }
103
92
 
93
+ // from IRegistry
94
+
95
+ /// @dev latest GIF release version
96
+ function setMajorVersion(VersionPart newMajorVersion)
97
+ external
98
+ onlyOwner
99
+ {
100
+ // ensure major version increments is one
101
+ uint256 oldMax = _majorVersion.toInt();
102
+ uint256 newMax = newMajorVersion.toInt();
103
+ if (newMax <= oldMax || newMax - oldMax != 1) {
104
+ revert MajorVersionMaxIncreaseInvalid(newMajorVersion, _majorVersion);
105
+ }
106
+
107
+ _majorVersion = newMajorVersion;
108
+ emit LogMajorVersionSet(_majorVersion);
109
+ }
110
+
104
111
  /// @dev registry protects only against tampering existing records, registering with invalid types pairs and 0 parent address
105
112
  // TODO service registration means its approval for some type?
106
113
  // TODO registration of precompile addresses
@@ -168,13 +175,35 @@ contract Registry is
168
175
 
169
176
  emit LogRegistration(info);
170
177
  }
178
+ /// @dev earliest GIF major version
179
+ function getMajorVersionMin() external view returns (VersionPart) {
180
+ return VersionLib.toVersionPart(GIF_MAJOR_VERSION_AT_DEPLOYMENT);
181
+ }
182
+
183
+ // TODO make distinction between active an not yet active version
184
+ // need to be thought trough, not yet clear if necessary
185
+ // need to answer question: what is the latest version during the upgrade process?
186
+ // likely setting up a new gif version does not fit into a single tx
187
+ // in this case we might want to have a period where the latest version is
188
+ // in the process of being set up while the latest active version is 1 major release smaller
189
+ /// @dev latest GIF major version (might not yet be active)
190
+ function getMajorVersionMax() external view returns (VersionPart) {
191
+ return _majorVersion;
192
+ }
193
+
194
+ /// @dev latest active GIF release version
195
+ function getMajorVersion() external view returns (VersionPart) {
196
+ return _majorVersion;
197
+ }
171
198
 
172
- // from IRegistry
173
199
  function getObjectCount() external view override returns (uint256) {
174
-
175
200
  return _chainNft.totalSupply();
176
201
  }
177
202
 
203
+ function getNftId() external view returns (NftId nftId) {
204
+ return _registryNftId;
205
+ }
206
+
178
207
  function getNftId(address object) external view override returns (NftId id) {
179
208
  return _nftIdByAddress[object];
180
209
  }
@@ -184,7 +213,6 @@ contract Registry is
184
213
  }
185
214
 
186
215
  function ownerOf(address contractAddress) public view returns (address) {
187
-
188
216
  return _chainNft.ownerOf(_nftIdByAddress[contractAddress].toInt());
189
217
  }
190
218
 
@@ -193,7 +221,6 @@ contract Registry is
193
221
  }
194
222
 
195
223
  function getObjectInfo(address object) external view override returns (ObjectInfo memory) {
196
-
197
224
  return _info[_nftIdByAddress[object]];
198
225
  }
199
226
 
@@ -205,6 +232,10 @@ contract Registry is
205
232
  return _nftIdByAddress[object].gtz();
206
233
  }
207
234
 
235
+ function isRegisteredService(address object) external view override returns (bool) {
236
+ return _nftIdByAddress[object].gtz() && _info[_nftIdByAddress[object]].objectType == SERVICE();
237
+ }
238
+
208
239
  function getServiceName(NftId nftId) external view returns (string memory) {
209
240
  return _string[nftId];
210
241
  }
@@ -238,14 +269,8 @@ contract Registry is
238
269
  ) = abi.decode(info.data, (string, VersionPart));
239
270
  bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
240
271
 
241
- // TODO MUST guarantee consistency of service.getVersion() and majorVersion here
242
- // TODO update _serviceNftId when registryService with new major version is registered? -> it is fixed in current setup -> can lock up
243
- // TODO do not use names -> each object type is registered by corresponding service -> conflicting with approve()
244
- if(
245
- majorVersion.toInt() < MAJOR_VERSION_MIN ||
246
- (majorVersion.toInt() > MAJOR_VERSION_MIN &&
247
- _service[serviceNameHash][VersionLib.toVersionPart(majorVersion.toInt() - 1)] == address(0) )
248
- ) {
272
+ // ensures consistency of service.getVersion() and majorVersion here
273
+ if(majorVersion != _majorVersion) {
249
274
  revert InvalidServiceVersion(majorVersion);
250
275
  }
251
276
 
@@ -312,7 +337,7 @@ contract Registry is
312
337
  function _registerRegistry(address registryOwner)
313
338
  internal
314
339
  {
315
- uint256 registryId = _chainNft.calculateTokenId(2);
340
+ uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
316
341
  NftId registryNftId = toNftId(registryId);
317
342
 
318
343
  NftId parentNftId;
@@ -386,7 +411,7 @@ contract Registry is
386
411
 
387
412
  string memory serviceName = "RegistryService";
388
413
  bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
389
- _service[serviceNameHash][VersionLib.toVersionPart(MAJOR_VERSION_MIN)] = msg.sender;
414
+ _service[serviceNameHash][VersionLib.toVersionPart(GIF_MAJOR_VERSION_AT_DEPLOYMENT)] = msg.sender;
390
415
  _string[serviceNftId] = serviceName;
391
416
  _serviceNftId = serviceNftId;
392
417
  }
@@ -1,17 +1,13 @@
1
1
  // SPDX-License-Identifier: Apache-2.0
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
5
4
  import {ERC165Checker} from "@openzeppelin/contracts/utils/introspection/ERC165Checker.sol";
6
- import {IERC721Receiver} from "@openzeppelin/contracts/token/ERC721/IERC721Receiver.sol";
7
5
  import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
8
6
 
9
7
  import {IRegistry} from "./IRegistry.sol";
10
8
  import {IInstance} from "../instance/IInstance.sol";
11
9
 
12
10
  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";
15
11
  import {IBaseComponent} from "../../contracts/components/IBaseComponent.sol";
16
12
  import {IPoolComponent} from "../../contracts/components/IPoolComponent.sol";
17
13
  import {IProductComponent} from "../../contracts/components/IProductComponent.sol";
@@ -22,42 +18,24 @@ import {Versionable} from "../../contracts/shared/Versionable.sol";
22
18
  import {IRegisterable} from "../../contracts/shared/IRegisterable.sol";
23
19
 
24
20
  import {RoleId, PRODUCT_OWNER_ROLE, POOL_OWNER_ROLE, ORACLE_OWNER_ROLE} from "../../contracts/types/RoleId.sol";
25
- import {ObjectType, REGISTRY, TOKEN, SERVICE, PRODUCT, ORACLE, POOL, TOKEN, INSTANCE, DISTRIBUTION, POLICY, BUNDLE} from "../../contracts/types/ObjectType.sol";
21
+ import {ObjectType, REGISTRY, SERVICE, PRODUCT, ORACLE, POOL, INSTANCE, DISTRIBUTION, POLICY, BUNDLE, STAKE} from "../../contracts/types/ObjectType.sol";
26
22
  import {StateId, ACTIVE, PAUSED} from "../../contracts/types/StateId.sol";
27
23
  import {NftId, NftIdLib, zeroNftId} from "../../contracts/types/NftId.sol";
28
24
  import {Fee, FeeLib} from "../../contracts/types/Fee.sol";
29
25
  import {Version, VersionPart, VersionLib} from "../../contracts/types/Version.sol";
30
26
 
31
- import {ServiceBase} from "../../contracts/instance/base/ServiceBase.sol";
32
- import {IService} from "../../contracts/instance/base/IService.sol";
27
+ import {Service} from "../shared/Service.sol";
28
+ import {IService} from "../shared/IService.sol";
33
29
  import {IRegistryService} from "./IRegistryService.sol";
34
30
  import {Registry} from "./Registry.sol";
35
- import {ChainNft} from "./ChainNft.sol";
36
31
 
37
32
  contract RegistryService is
38
33
  AccessManagedUpgradeable,
39
- ServiceBase,
34
+ Service,
40
35
  IRegistryService
41
36
  {
42
37
  using NftIdLib for NftId;
43
38
 
44
- error SelfRegistration();
45
- error NotRegistryOwner();
46
-
47
- error NotToken();
48
- error NotService();
49
- error NotInstance();
50
- error NotProduct();
51
- error NotPool();
52
- error NotDistribution();
53
-
54
- error UnexpectedRegisterableType(ObjectType expected, ObjectType found);
55
- error NotRegisterableOwner(address expectedOwner);
56
- error RegisterableOwnerIsZero();
57
- error RegisterableOwnerIsRegistered();
58
- error InvalidInitialOwner(address initialOwner);
59
- error InvalidAddress(address registerableAddress);
60
-
61
39
 
62
40
  // Initial value for constant variable has to be compile-time constant
63
41
  // TODO define types as constants?
@@ -69,48 +47,6 @@ contract RegistryService is
69
47
 
70
48
  address public constant NFT_LOCK_ADDRESS = address(0x1);
71
49
 
72
- /// @dev
73
- // msg.sender - ONLY registry owner
74
- // CAN NOT register itself
75
- // CAN NOT register IRegisterable address
76
- // CAN register ONLY valid object-parent types combinations for TOKEN
77
- // IMPORTANT: MUST NOT call untrusted contract inbetween calls to registry/instance (trusted contracts)
78
- // motivation: registry/instance state may change during external call
79
- // TODO it may be usefull to have transferable token nft in order to delist token, make it invalid for new beginings
80
- // TODO: MUST prohibit registration of precompiles addresses
81
- function registerToken(address tokenAddress)
82
- external
83
- returns(NftId nftId)
84
- {
85
- if(msg.sender == tokenAddress) {
86
- revert SelfRegistration();
87
- }
88
-
89
- // MUST not revert if no ERC165 support
90
- if(tokenAddress.code.length == 0 ||
91
- ERC165Checker.supportsInterface(tokenAddress, type(IRegisterable).interfaceId)) {
92
- revert NotToken();
93
- }
94
-
95
- NftId registryNftId = _registry.getNftId(address(_registry));
96
-
97
- if(msg.sender != _registry.ownerOf(registryNftId)) {
98
- revert NotRegistryOwner();
99
- }
100
-
101
- IRegistry.ObjectInfo memory info = IRegistry.ObjectInfo(
102
- zeroNftId(), // any value
103
- registryNftId, // parent nft id
104
- TOKEN(),
105
- false, // isInterceptor
106
- tokenAddress,
107
- NFT_LOCK_ADDRESS,
108
- "" // any value
109
- );
110
-
111
- nftId = _registry.register(info);
112
- }
113
-
114
50
  /// @dev
115
51
  // msg.sender - ONLY registry owner
116
52
  // CAN NOT register itself
@@ -119,6 +55,7 @@ contract RegistryService is
119
55
  // IMPORTANT: MUST NOT check owner before calling external contract
120
56
  function registerService(IService service)
121
57
  external
58
+ restricted
122
59
  returns(
123
60
  IRegistry.ObjectInfo memory info,
124
61
  bytes memory data
@@ -135,23 +72,11 @@ contract RegistryService is
135
72
  data
136
73
  ) = _getAndVerifyContractInfo(service, SERVICE(), msg.sender);
137
74
 
138
- if(msg.sender != _registry.getOwner()) {
139
- revert NotRegistryOwner();
140
- }
141
-
142
75
  info.nftId = _registry.register(info);
143
76
  service.linkToRegisteredNftId();
144
- return (
145
- info,
146
- data
147
- );
77
+ return (info, data);
148
78
  }
149
79
 
150
- // If msg.sender is approved service:
151
- // 1) add owner arg (service MUST pass it's msg.sender as owner)
152
- // 2) check service allowance
153
- // 3) comment self registrstion check
154
- //function registerInstance(IRegisterable instance, address owner)
155
80
  function registerInstance(IRegisterable instance)
156
81
  external
157
82
  returns(
@@ -159,7 +84,6 @@ contract RegistryService is
159
84
  bytes memory data
160
85
  )
161
86
  {
162
-
163
87
  if(!instance.supportsInterface(type(IInstance).interfaceId)) {
164
88
  revert NotInstance();
165
89
  }
@@ -172,10 +96,7 @@ contract RegistryService is
172
96
  info.nftId = _registry.register(info);
173
97
  instance.linkToRegisteredNftId(); // asume safe
174
98
 
175
- return (
176
- info,
177
- data
178
- );
99
+ return (info, data);
179
100
  }
180
101
 
181
102
  function registerProduct(IBaseComponent product, address owner)
@@ -196,16 +117,11 @@ contract RegistryService is
196
117
  data
197
118
  ) = _getAndVerifyContractInfo(product, PRODUCT(), owner);
198
119
 
199
- NftId serviceNftId = _registry.getNftId(msg.sender);
200
-
201
120
  info.nftId = _registry.register(info);
202
121
  // TODO unsafe, let component or its owner derive nftId latter, when state assumptions and modifications of GIF contracts are finished
203
122
  product.linkToRegisteredNftId();
204
123
 
205
- return (
206
- info,
207
- data
208
- );
124
+ return (info, data);
209
125
  }
210
126
 
211
127
  function registerPool(IBaseComponent pool, address owner)
@@ -225,15 +141,10 @@ contract RegistryService is
225
141
  data
226
142
  ) = _getAndVerifyContractInfo(pool, POOL(), owner);
227
143
 
228
- NftId serviceNftId = _registry.getNftId(msg.sender);
229
-
230
144
  info.nftId = _registry.register(info);
231
145
  pool.linkToRegisteredNftId();
232
146
 
233
- return (
234
- info,
235
- data
236
- );
147
+ return (info, data);
237
148
  }
238
149
 
239
150
  function registerDistribution(IBaseComponent distribution, address owner)
@@ -253,15 +164,10 @@ contract RegistryService is
253
164
  data
254
165
  ) = _getAndVerifyContractInfo(distribution, DISTRIBUTION(), owner);
255
166
 
256
- NftId serviceNftId = _registry.getNftId(msg.sender);
257
-
258
167
  info.nftId = _registry.register(info);
259
168
  distribution.linkToRegisteredNftId();
260
169
 
261
- return (
262
- info,
263
- data
264
- );
170
+ return (info, data);
265
171
  }
266
172
 
267
173
  function registerPolicy(IRegistry.ObjectInfo memory info)
@@ -269,8 +175,6 @@ contract RegistryService is
269
175
  restricted
270
176
  returns(NftId nftId)
271
177
  {
272
- NftId senderNftId = _registry.getNftId(msg.sender);
273
-
274
178
  _verifyObjectInfo(info, POLICY());
275
179
 
276
180
  nftId = _registry.register(info);
@@ -281,17 +185,23 @@ contract RegistryService is
281
185
  restricted
282
186
  returns(NftId nftId)
283
187
  {
284
-
285
- NftId senderNftId = _registry.getNftId(msg.sender);
286
-
287
188
  _verifyObjectInfo(info, BUNDLE());
288
189
 
289
190
  nftId = _registry.register(info);
290
191
  }
291
192
 
193
+ function registerStake(IRegistry.ObjectInfo memory info)
194
+ external
195
+ restricted
196
+ returns(NftId nftId)
197
+ {
198
+ _verifyObjectInfo(info, STAKE());
199
+
200
+ nftId = _registry.register(info);
201
+ }
292
202
 
293
203
  // From IService
294
- function getName() public pure override(IService, ServiceBase) returns(string memory) {
204
+ function getName() public pure override(IService, Service) returns(string memory) {
295
205
  return NAME;
296
206
  }
297
207
  //function getType() public pure override(IService, ServiceBase) returns(ObjectType serviceType) {
@@ -335,7 +245,7 @@ contract RegistryService is
335
245
 
336
246
  NftId registryNftId = registry.getNftId(address(registry));
337
247
 
338
- _initializeServiceBase(address(registry), registryNftId, owner);
248
+ _initializeService(address(registry), owner);
339
249
 
340
250
  // TODO why do registry service proxy need to keep its nftId??? -> no registryServiceNftId checks in implementation
341
251
  // if they are -> use registry address to obtain owner of registry service nft (works the same with any registerable and(or) implementation)
@@ -343,7 +253,6 @@ contract RegistryService is
343
253
  _registerInterface(type(IRegistryService).interfaceId);
344
254
  }
345
255
 
346
- // parent check done in registry because of approve()
347
256
  function _getAndVerifyContractInfo(
348
257
  IRegisterable registerable,
349
258
  ObjectType expectedType, // assume can be valid only
@@ -368,8 +277,13 @@ contract RegistryService is
368
277
 
369
278
  address owner = info.initialOwner;
370
279
 
371
- if(owner != expectedOwner) { // registerable owner protection
372
- revert NotRegisterableOwner(expectedOwner);
280
+ // solhint-disable-next-line
281
+ if(expectedType == INSTANCE()) {
282
+ // any address may create a new instance via instance service
283
+ } else {
284
+ if(owner != expectedOwner) { // registerable owner protection
285
+ revert NotRegisterableOwner(expectedOwner);
286
+ }
373
287
  }
374
288
 
375
289
  if(owner == address(registerable)) {
@@ -397,25 +311,28 @@ contract RegistryService is
397
311
  );
398
312
  }
399
313
 
400
- // parent checks done in registry because of approve()
401
314
  function _verifyObjectInfo(
402
315
  IRegistry.ObjectInfo memory info,
403
- ObjectType objectType
316
+ ObjectType expectedType
404
317
  )
405
318
  internal
406
319
  view
407
320
  {
408
- if(info.objectAddress > address(0)) {
409
- revert InvalidAddress(info.objectAddress);
321
+ // enforce instead of check
322
+ info.objectAddress = address(0);
323
+
324
+ if(info.objectType != expectedType) {// type is checked in registry anyway...but service logic may depend on expected value
325
+ revert UnexpectedRegisterableType(expectedType, info.objectType);
326
+ }
327
+
328
+ address owner = info.initialOwner;
329
+
330
+ if(owner == address(0)) {
331
+ revert RegisterableOwnerIsZero();
410
332
  }
411
333
 
412
- if(
413
- getRegistry().isRegistered(info.initialOwner) ||
414
- info.initialOwner == address(0)) {
415
- // TODO non registered address can register object(e.g. POLICY()) and then transfer associated nft to registered contract
416
- // what are motivations to do so?
417
- // at least registered contract can not register objects by itself, SERVICE,
418
- revert InvalidInitialOwner(info.initialOwner);
334
+ if(getRegistry().isRegistered(owner)) {
335
+ revert RegisterableOwnerIsRegistered();
419
336
  }
420
337
 
421
338
  // can catch all 3 if check that initialOwner is not registered
@@ -9,6 +9,7 @@ import {Registry} from "./Registry.sol";
9
9
  import {IVersionable} from "../shared/IVersionable.sol";
10
10
  import {ProxyManager} from "../shared/ProxyManager.sol";
11
11
  import {RegistryService} from "./RegistryService.sol";
12
+ import {TokenRegistry} from "./TokenRegistry.sol";
12
13
 
13
14
 
14
15
  contract RegistryServiceManager is
@@ -16,9 +17,9 @@ contract RegistryServiceManager is
16
17
  {
17
18
  bytes32 constant public ACCESS_MANAGER_CREATION_CODE_HASH = 0x0;
18
19
 
19
- RegistryService private _registryService;
20
-
21
20
  AccessManager private _accessManager;
21
+ RegistryService private _registryService;
22
+ TokenRegistry private _tokenRegistry;
22
23
 
23
24
  /// @dev initializes proxy manager with registry service implementation and deploys registry
24
25
  constructor(
@@ -41,11 +42,26 @@ contract RegistryServiceManager is
41
42
  address(_registryService.getRegistry()),
42
43
  address(_registryService));
43
44
 
45
+ // deploy token registry
46
+
47
+ // _tokenRegistry = new TokenRegistry(
48
+ // address(_registryService.getRegistry()),
49
+ // address(_registryService));
50
+
44
51
  // implies that after this constructor call only upgrade functionality is available
45
52
  _isDeployed = true;
46
53
  }
47
54
 
48
55
  //--- view functions ----------------------------------------------------//
56
+
57
+ function getAccessManager()
58
+ external
59
+ view
60
+ returns (AccessManager)
61
+ {
62
+ return _accessManager;
63
+ }
64
+
49
65
  function getRegistryService()
50
66
  external
51
67
  view
@@ -54,11 +70,11 @@ contract RegistryServiceManager is
54
70
  return _registryService;
55
71
  }
56
72
 
57
- function getAccessManager()
73
+ function getTokenRegistry()
58
74
  external
59
75
  view
60
- returns (AccessManager)
76
+ returns (TokenRegistry)
61
77
  {
62
- return _accessManager;
78
+ return _tokenRegistry;
63
79
  }
64
80
  }