@etherisc/gif-next 0.0.2-8b116c2-371 → 0.0.2-8c1d8cd-727

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 (526) hide show
  1. package/README.md +49 -4
  2. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
  3. package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1293 -0
  4. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
  5. package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1206 -0
  6. package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
  7. package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +414 -0
  8. package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
  9. package/artifacts/contracts/authorization/IAccess.sol/IAccess.json +10 -0
  10. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
  11. package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1060 -0
  12. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
  13. package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +295 -0
  14. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
  15. package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +167 -0
  16. package/artifacts/contracts/authorization/ReleaseAccessManager.sol/ReleaseAccessManager.dbg.json +4 -0
  17. package/artifacts/contracts/{shared/AccessManagerCustom.sol/AccessManagerCustom.json → authorization/ReleaseAccessManager.sol/ReleaseAccessManager.json} +28 -25
  18. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
  19. package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +253 -0
  20. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
  21. package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1402 -0
  22. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
  23. package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +470 -0
  24. package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
  25. package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +133 -501
  26. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
  27. package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +319 -229
  28. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
  29. package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +115 -103
  30. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
  31. package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +164 -210
  32. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
  33. package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +194 -47
  34. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
  35. package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
  36. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
  37. package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1538 -0
  38. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
  39. package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +470 -0
  40. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
  41. package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2077 -0
  42. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
  43. package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +470 -0
  44. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
  45. package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
  46. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
  47. package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1471 -0
  48. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
  49. package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1231 -0
  50. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
  51. package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1592 -0
  52. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
  53. package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2095 -0
  54. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
  55. package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +703 -0
  56. package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
  57. package/artifacts/contracts/instance/IInstance.sol/IInstance.json +105 -103
  58. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
  59. package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +163 -111
  60. package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
  61. package/artifacts/contracts/instance/Instance.sol/Instance.json +108 -243
  62. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
  63. package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1210 -265
  64. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
  65. package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +561 -0
  66. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
  67. package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +511 -154
  68. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
  69. package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +210 -268
  70. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
  71. package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +83 -95
  72. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
  73. package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +324 -288
  74. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
  75. package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
  76. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
  77. package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
  78. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
  79. package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
  80. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
  81. package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
  82. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
  83. package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +181 -0
  84. package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
  85. package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
  86. package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
  87. package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
  88. package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
  89. package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
  90. package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
  91. package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
  92. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
  93. package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +1039 -0
  94. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
  95. package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +478 -0
  96. package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
  97. package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +43 -1
  98. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
  99. package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +109 -80
  100. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
  101. package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +56 -9
  102. package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
  103. package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +119 -358
  104. package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
  105. package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +110 -141
  106. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
  107. package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +82 -78
  108. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
  109. package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1299 -0
  110. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
  111. package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +470 -0
  112. package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
  113. package/artifacts/contracts/pool/BundleService.sol/BundleService.json +517 -157
  114. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
  115. package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +176 -88
  116. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
  117. package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +271 -1
  118. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
  119. package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +125 -319
  120. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
  121. package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +410 -192
  122. package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
  123. package/artifacts/contracts/pool/Pool.sol/Pool.json +165 -632
  124. package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
  125. package/artifacts/contracts/pool/PoolService.sol/PoolService.json +524 -331
  126. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
  127. package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +111 -83
  128. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
  129. package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +95 -158
  130. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
  131. package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +79 -91
  132. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
  133. package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1173 -0
  134. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
  135. package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +470 -0
  136. package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
  137. package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +322 -169
  138. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
  139. package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +126 -98
  140. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
  141. package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +47 -0
  142. package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
  143. package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +189 -6
  144. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
  145. package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +336 -118
  146. package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
  147. package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +127 -85
  148. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
  149. package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +154 -137
  150. package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
  151. package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +44 -2
  152. package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
  153. package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +451 -295
  154. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
  155. package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +123 -95
  156. package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
  157. package/artifacts/contracts/product/PricingService.sol/PricingService.json +207 -283
  158. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
  159. package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +96 -112
  160. package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
  161. package/artifacts/contracts/product/Product.sol/Product.json +168 -434
  162. package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
  163. package/artifacts/contracts/product/RiskService.sol/RiskService.json +622 -0
  164. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
  165. package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +694 -0
  166. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
  167. package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
  168. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
  169. package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +311 -55
  170. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
  171. package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +55 -146
  172. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
  173. package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
  174. package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
  175. package/artifacts/contracts/registry/Registry.sol/Registry.json +533 -113
  176. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
  177. package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1635 -162
  178. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
  179. package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +96 -265
  180. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
  181. package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +74 -70
  182. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
  183. package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
  184. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
  185. package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1067 -0
  186. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
  187. package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +272 -0
  188. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
  189. package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +4 -4
  190. package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
  191. package/artifacts/contracts/shared/Component.sol/Component.json +65 -236
  192. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
  193. package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +541 -263
  194. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
  195. package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +136 -114
  196. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
  197. package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +51 -103
  198. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
  199. package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +92 -0
  200. package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
  201. package/artifacts/contracts/shared/IComponent.sol/IComponent.json +55 -54
  202. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
  203. package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +487 -19
  204. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
  205. package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +98 -80
  206. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
  207. package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +45 -3
  208. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
  209. package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +34 -3
  210. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
  211. package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +16 -0
  212. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
  213. package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
  214. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
  215. package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +29 -0
  216. package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
  217. package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
  218. package/artifacts/contracts/shared/IService.sol/IService.json +42 -0
  219. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
  220. package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
  221. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
  222. package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +111 -318
  223. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
  224. package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +55 -88
  225. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
  226. package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -62
  227. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
  228. package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
  229. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
  230. package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +22 -57
  231. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
  232. package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
  233. package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
  234. package/artifacts/contracts/shared/Registerable.sol/Registerable.json +58 -89
  235. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
  236. package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
  237. package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
  238. package/artifacts/contracts/shared/Service.sol/Service.json +51 -103
  239. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
  240. package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +330 -11
  241. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
  242. package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +108 -0
  243. package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
  244. package/artifacts/contracts/staking/IStaking.sol/IStaking.json +82 -55
  245. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
  246. package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +78 -28
  247. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
  248. package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +97 -101
  249. package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
  250. package/artifacts/contracts/staking/Staking.sol/Staking.json +168 -325
  251. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +4 -0
  252. package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +205 -0
  253. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
  254. package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +103 -104
  255. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
  256. package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +7 -17
  257. package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
  258. package/artifacts/contracts/staking/StakingService.sol/StakingService.json +123 -198
  259. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
  260. package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +76 -92
  261. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
  262. package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +241 -147
  263. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
  264. package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +59 -23
  265. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
  266. package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
  267. package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
  268. package/artifacts/contracts/type/Amount.sol/AmountLib.json +61 -8
  269. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
  270. package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +2 -2
  271. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
  272. package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
  273. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
  274. package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +4 -4
  275. package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
  276. package/artifacts/contracts/type/Fee.sol/FeeLib.json +17 -12
  277. package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
  278. package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
  279. package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
  280. package/artifacts/contracts/type/NftId.sol/NftIdLib.json +4 -4
  281. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
  282. package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
  283. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
  284. package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +136 -2
  285. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
  286. package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
  287. package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
  288. package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
  289. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
  290. package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +4 -4
  291. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
  292. package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +60 -4
  293. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
  294. package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +219 -6
  295. package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
  296. package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +50 -2
  297. package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
  298. package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
  299. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
  300. package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
  301. package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
  302. package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
  303. package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
  304. package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
  305. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
  306. package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +23 -4
  307. package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
  308. package/artifacts/contracts/type/UFixed.sol/MathLib.json +9 -3
  309. package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
  310. package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +71 -2
  311. package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
  312. package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
  313. package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
  314. package/artifacts/contracts/type/Version.sol/VersionPartLib.json +21 -2
  315. package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
  316. package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +1 -1
  317. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
  318. package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +602 -0
  319. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
  320. package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
  321. package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
  322. package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.json +1 -1
  323. package/contracts/authorization/AccessAdmin.sol +596 -0
  324. package/contracts/authorization/AccessManagerCloneable.sol +16 -0
  325. package/contracts/authorization/Authorization.sol +289 -0
  326. package/contracts/authorization/IAccess.sol +49 -0
  327. package/contracts/authorization/IAccessAdmin.sol +137 -0
  328. package/contracts/authorization/IAuthorization.sol +60 -0
  329. package/contracts/authorization/IServiceAuthorization.sol +40 -0
  330. package/contracts/authorization/ReleaseAccessManager.sol +38 -0
  331. package/contracts/authorization/ServiceAuthorization.sol +106 -0
  332. package/contracts/distribution/BasicDistribution.sol +139 -0
  333. package/contracts/distribution/BasicDistributionAuthorization.sol +47 -0
  334. package/contracts/distribution/Distribution.sol +140 -116
  335. package/contracts/distribution/DistributionService.sol +140 -83
  336. package/contracts/distribution/DistributionServiceManager.sol +8 -11
  337. package/contracts/distribution/IDistributionComponent.sol +26 -40
  338. package/contracts/distribution/IDistributionService.sol +23 -3
  339. package/contracts/examples/fire/DamageLevel.sol +59 -0
  340. package/contracts/examples/fire/FirePool.sol +75 -0
  341. package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
  342. package/contracts/examples/fire/FireProduct.sol +418 -0
  343. package/contracts/examples/fire/FireProductAuthorization.sol +44 -0
  344. package/contracts/examples/fire/FireUSD.sol +26 -0
  345. package/contracts/examples/unpermissioned/SimpleDistribution.sol +50 -0
  346. package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
  347. package/contracts/examples/unpermissioned/SimplePool.sol +76 -0
  348. package/contracts/examples/unpermissioned/SimpleProduct.sol +351 -0
  349. package/contracts/instance/{BundleManager.sol → BundleSet.sol} +23 -23
  350. package/contracts/instance/IInstance.sol +24 -40
  351. package/contracts/instance/IInstanceService.sol +27 -36
  352. package/contracts/instance/Instance.sol +123 -127
  353. package/contracts/instance/InstanceAdmin.sol +216 -270
  354. package/contracts/instance/InstanceAuthorizationV3.sol +194 -0
  355. package/contracts/instance/InstanceReader.sol +139 -34
  356. package/contracts/instance/InstanceService.sol +177 -128
  357. package/contracts/instance/InstanceServiceManager.sol +8 -13
  358. package/contracts/instance/InstanceStore.sol +26 -20
  359. package/contracts/instance/base/BalanceStore.sol +11 -6
  360. package/contracts/instance/base/Cloneable.sol +2 -25
  361. package/contracts/instance/base/ObjectLifecycle.sol +111 -0
  362. package/contracts/instance/base/{ObjectManager.sol → ObjectSet.sol} +11 -14
  363. package/contracts/instance/module/IBundle.sol +1 -1
  364. package/contracts/instance/module/IComponents.sol +10 -11
  365. package/contracts/instance/module/IDistribution.sol +0 -1
  366. package/contracts/instance/module/IPolicy.sol +24 -24
  367. package/contracts/mock/Dip.sol +1 -1
  368. package/contracts/oracle/BasicOracle.sol +47 -0
  369. package/contracts/oracle/BasicOracleAuthorization.sol +46 -0
  370. package/contracts/oracle/IOracle.sol +16 -0
  371. package/contracts/oracle/IOracleComponent.sol +2 -1
  372. package/contracts/oracle/IOracleService.sol +2 -1
  373. package/contracts/oracle/Oracle.sol +64 -53
  374. package/contracts/oracle/OracleService.sol +51 -37
  375. package/contracts/oracle/OracleServiceManager.sol +8 -11
  376. package/contracts/pool/BasicPool.sol +154 -0
  377. package/contracts/pool/BasicPoolAuthorization.sol +57 -0
  378. package/contracts/pool/BundleService.sol +284 -87
  379. package/contracts/pool/BundleServiceManager.sol +8 -11
  380. package/contracts/pool/IBundleService.sol +42 -5
  381. package/contracts/pool/IPoolComponent.sol +24 -68
  382. package/contracts/pool/IPoolService.sol +56 -39
  383. package/contracts/pool/Pool.sol +184 -148
  384. package/contracts/pool/PoolService.sol +262 -171
  385. package/contracts/pool/PoolServiceManager.sol +6 -9
  386. package/contracts/product/ApplicationService.sol +75 -70
  387. package/contracts/product/ApplicationServiceManager.sol +6 -6
  388. package/contracts/product/BasicProduct.sol +53 -0
  389. package/contracts/product/BasicProductAuthorization.sol +42 -0
  390. package/contracts/product/ClaimService.sol +321 -151
  391. package/contracts/product/ClaimServiceManager.sol +6 -6
  392. package/contracts/product/IApplicationService.sol +1 -0
  393. package/contracts/product/IClaimService.sol +31 -7
  394. package/contracts/product/IPolicyService.sol +34 -32
  395. package/contracts/product/IPricingService.sol +10 -10
  396. package/contracts/product/IProductComponent.sol +26 -9
  397. package/contracts/product/{IProductService.sol → IRiskService.sol} +1 -1
  398. package/contracts/product/PolicyService.sol +424 -202
  399. package/contracts/product/PolicyServiceManager.sol +6 -9
  400. package/contracts/product/PricingService.sol +58 -59
  401. package/contracts/product/PricingServiceManager.sol +5 -8
  402. package/contracts/product/Product.sol +211 -133
  403. package/contracts/product/{ProductService.sol → RiskService.sol} +18 -46
  404. package/contracts/product/RiskServiceManager.sol +39 -0
  405. package/contracts/registry/ChainNft.sol +68 -38
  406. package/contracts/registry/IRegistry.sol +69 -22
  407. package/contracts/registry/IRegistryService.sol +3 -10
  408. package/contracts/registry/ITransferInterceptor.sol +1 -2
  409. package/contracts/registry/Registry.sol +354 -213
  410. package/contracts/registry/RegistryAdmin.sol +360 -149
  411. package/contracts/registry/RegistryService.sol +44 -69
  412. package/contracts/registry/RegistryServiceManager.sol +4 -9
  413. package/contracts/registry/ReleaseLifecycle.sol +30 -0
  414. package/contracts/registry/ReleaseRegistry.sol +501 -0
  415. package/contracts/registry/ServiceAuthorizationV3.sol +194 -0
  416. package/contracts/registry/TokenRegistry.sol +2 -2
  417. package/contracts/shared/Component.sol +47 -63
  418. package/contracts/shared/ComponentService.sol +316 -189
  419. package/contracts/shared/ComponentServiceManager.sol +10 -7
  420. package/contracts/shared/ComponentVerifyingService.sol +24 -15
  421. package/contracts/shared/ContractLib.sol +38 -0
  422. package/contracts/shared/IComponent.sol +10 -6
  423. package/contracts/shared/IComponentService.sol +38 -20
  424. package/contracts/shared/IInstanceLinkedComponent.sol +11 -16
  425. package/contracts/shared/IKeyValueStore.sol +1 -0
  426. package/contracts/shared/ILifecycle.sol +3 -2
  427. package/contracts/shared/INftOwnable.sol +2 -0
  428. package/contracts/shared/IPolicyHolder.sol +12 -22
  429. package/contracts/shared/IRegisterable.sol +11 -0
  430. package/contracts/shared/IService.sol +8 -1
  431. package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +3 -3
  432. package/contracts/shared/InstanceLinkedComponent.sol +106 -37
  433. package/contracts/shared/KeyValueStore.sol +7 -3
  434. package/contracts/shared/Lifecycle.sol +30 -72
  435. package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +1 -1
  436. package/contracts/shared/NftOwnable.sol +29 -9
  437. package/contracts/shared/PolicyHolder.sol +17 -57
  438. package/contracts/shared/Registerable.sol +19 -9
  439. package/contracts/shared/RegistryLinked.sol +3 -2
  440. package/contracts/shared/Service.sol +43 -36
  441. package/contracts/shared/TokenHandler.sol +100 -19
  442. package/contracts/shared/TokenHandlerDeployerLib.sol +12 -0
  443. package/contracts/staking/IStaking.sol +3 -3
  444. package/contracts/staking/IStakingService.sol +22 -14
  445. package/contracts/staking/StakeManagerLib.sol +70 -25
  446. package/contracts/staking/Staking.sol +86 -140
  447. package/contracts/staking/StakingLifecycle.sol +23 -0
  448. package/contracts/staking/StakingManager.sol +10 -12
  449. package/contracts/staking/StakingReader.sol +23 -20
  450. package/contracts/staking/StakingService.sol +69 -82
  451. package/contracts/staking/StakingServiceManager.sol +4 -5
  452. package/contracts/staking/StakingStore.sol +93 -60
  453. package/contracts/staking/TargetManagerLib.sol +7 -3
  454. package/contracts/type/Amount.sol +27 -5
  455. package/contracts/type/Blocknumber.sol +7 -1
  456. package/contracts/type/ClaimId.sol +6 -1
  457. package/contracts/type/NftId.sol +1 -0
  458. package/contracts/type/ObjectType.sol +172 -64
  459. package/contracts/type/PayoutId.sol +10 -10
  460. package/contracts/type/Referral.sol +1 -0
  461. package/contracts/type/RiskId.sol +15 -1
  462. package/contracts/type/RoleId.sol +97 -81
  463. package/contracts/type/Seconds.sol +21 -1
  464. package/contracts/type/Selector.sol +102 -0
  465. package/contracts/type/StateId.sol +15 -1
  466. package/contracts/type/String.sol +53 -0
  467. package/contracts/type/Timestamp.sol +11 -1
  468. package/contracts/type/UFixed.sol +38 -9
  469. package/contracts/type/Version.sol +3 -1
  470. package/contracts/{shared → upgradeability}/ProxyManager.sol +71 -38
  471. package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
  472. package/contracts/{shared → upgradeability}/Versionable.sol +2 -2
  473. package/package.json +7 -4
  474. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
  475. package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -778
  476. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +0 -4
  477. package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +0 -228
  478. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
  479. package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +0 -256
  480. package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
  481. package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
  482. package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -679
  483. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
  484. package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -694
  485. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
  486. package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1292
  487. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +0 -4
  488. package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +0 -137
  489. package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +0 -4
  490. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +0 -4
  491. package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +0 -1715
  492. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +0 -4
  493. package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +0 -1728
  494. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +0 -4
  495. package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +0 -1806
  496. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +0 -4
  497. package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +0 -1824
  498. package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
  499. package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
  500. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +0 -4
  501. package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +0 -1562
  502. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +0 -4
  503. package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +0 -1600
  504. package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
  505. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
  506. package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
  507. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
  508. package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +0 -306
  509. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
  510. package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -617
  511. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
  512. package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +0 -129
  513. package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
  514. package/contracts/instance/InstanceAuthorizationsLib.sol +0 -377
  515. package/contracts/product/ProductServiceManager.sol +0 -42
  516. package/contracts/registry/ReleaseManager.sol +0 -600
  517. package/contracts/registry/ServiceAuthorizationsLib.sol +0 -173
  518. package/contracts/shared/AccessManagerCustom.sol +0 -736
  519. package/contracts/shared/AccessManagerExtended.sol +0 -470
  520. package/contracts/shared/AccessManagerExtendedInitializeable.sol +0 -13
  521. package/contracts/shared/AccessManagerExtendedWithDisable.sol +0 -137
  522. package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +0 -14
  523. package/contracts/shared/IAccessManagerExtended.sol +0 -74
  524. package/contracts/shared/IAccessManagerExtendedWithDisable.sol +0 -18
  525. package/contracts/shared/InitializableCustom.sol +0 -177
  526. /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
@@ -1,18 +1,19 @@
1
1
  // SPDX-License-Identifier: UNLICENSED
2
2
  pragma solidity ^0.8.20;
3
3
 
4
- import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
5
- import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
6
- import {AuthorityUtils} from "@openzeppelin/contracts/access/manager/AuthorityUtils.sol";
7
-
8
- import {RoleId, RoleIdLib, GIF_MANAGER_ROLE, GIF_ADMIN_ROLE} from "../type/RoleId.sol";
9
-
10
- import {AccessManagerExtendedInitializeable} from "../shared/AccessManagerExtendedInitializeable.sol";
11
- import {InitializableCustom} from "../shared/InitializableCustom.sol";
12
-
4
+ import {AccessAdmin} from "../authorization/AccessAdmin.sol";
5
+ import {IAccess} from "../authorization/IAccess.sol";
13
6
  import {IRegistry} from "./IRegistry.sol";
14
- import {ReleaseManager} from "./ReleaseManager.sol";
7
+ import {IService} from "../shared/IService.sol";
8
+ import {IServiceAuthorization} from "../authorization/IServiceAuthorization.sol";
9
+ import {IStaking} from "../staking/IStaking.sol";
10
+ import {ObjectType, ObjectTypeLib, ALL, REGISTRY, STAKING, POOL, RELEASE} from "../type/ObjectType.sol";
11
+ import {ReleaseRegistry} from "./ReleaseRegistry.sol";
12
+ import {RoleId, RoleIdLib, ADMIN_ROLE, GIF_MANAGER_ROLE, GIF_ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
13
+ import {StakingStore} from "../staking/StakingStore.sol";
14
+ import {TokenHandler} from "../shared/TokenHandler.sol";
15
15
  import {TokenRegistry} from "./TokenRegistry.sol";
16
+ import {VersionPart} from "../type/Version.sol";
16
17
 
17
18
  /*
18
19
  1) GIF_MANAGER_ROLE
@@ -26,121 +27,108 @@ import {TokenRegistry} from "./TokenRegistry.sol";
26
27
  - granted/revoked ONLY in transferAdminRole() -> consider lock out situations!!!
27
28
  - responsible for creation and activation of releases
28
29
  */
29
-
30
- // !!! USE BUILDER PATTERN FOR CONFIG
31
- // introduce class - config
32
- // create instance of this class in admin initializer function
33
- // call it "add"/"push" function for each entry in config (provide entry parameneters)
34
- // each call will configure access manager for given parameneters
35
- // in the end you have fully configured access manager and config object
36
-
37
- // grants GIF_ADMIN_ROLE to registry owner as registryOwner is transaction sender
38
- // grants GIF_MANAGER_ROLE to registry owner via contructor argument
39
30
  contract RegistryAdmin is
40
- AccessManaged,
41
- InitializableCustom
31
+ AccessAdmin
42
32
  {
43
- error ErrorRegistryAdminReleaseManagerAuthorityMismatch();
44
- error ErrorRegistryAdminTokenRegistryAuthorityMismatch();
45
- error ErrorRegistryAdminStakingAuthorityMismatch();
46
-
47
33
  string public constant GIF_ADMIN_ROLE_NAME = "GifAdminRole";
48
34
  string public constant GIF_MANAGER_ROLE_NAME = "GifManagerRole";
49
-
50
- string public constant RELEASE_MANAGER_TARGET_NAME = "ReleaseManager";
35
+ string public constant POOL_SERVICE_ROLE_NAME = "PoolServiceRole";
36
+ string public constant RELEASE_REGISTRY_ROLE_NAME = "ReleaseRegistryRole";
37
+ string public constant REGISTRY_SERVICE_ROLE_NAME = "RegistryServiceRole";
38
+ string public constant STAKING_SERVICE_ROLE_NAME = "StakingServiceRole";
39
+ string public constant STAKING_ROLE_NAME = "StakingRole";
40
+
41
+ string public constant REGISTRY_TARGET_NAME = "Registry";
42
+ string public constant RELEASE_REGISTRY_TARGET_NAME = "ReleaseRegistry";
51
43
  string public constant TOKEN_REGISTRY_TARGET_NAME = "TokenRegistry";
52
44
  string public constant STAKING_TARGET_NAME = "Staking";
53
-
54
- address private _releaseManager;
45
+ string public constant STAKING_STORE_TARGET_NAME = "StakingStore";
46
+
47
+ uint8 public constant MAX_NUM_RELEASES = 99;
48
+ // TODO consider deleting this
49
+ mapping(address service => VersionPart majorVersion) private _ServiceRelease;
50
+
51
+ address internal _registry;
52
+ address private _releaseRegistry;
55
53
  address private _tokenRegistry;
56
54
  address private _staking;
55
+ address private _stakingStore;
57
56
 
58
- constructor(address initialOwner)
59
- AccessManaged(msg.sender)
60
- InitializableCustom(initialOwner)
61
- {
62
- AccessManagerExtendedInitializeable accessManager = new AccessManagerExtendedInitializeable();
63
- accessManager.initialize(address(this));
64
- setAuthority(address(accessManager));
65
- }
57
+ constructor() AccessAdmin() { }
66
58
 
67
- function initialize(
59
+ function completeSetup(
68
60
  IRegistry registry,
69
61
  address gifAdmin,
70
62
  address gifManager
71
63
  )
72
64
  external
73
65
  initializer
66
+ onlyDeployer()
74
67
  {
75
- // validate input
76
- address releaseManagerAddress = registry.getReleaseManagerAddress();
77
- if(IAccessManaged(releaseManagerAddress).authority() != authority()) {
78
- revert ErrorRegistryAdminReleaseManagerAuthorityMismatch();
79
- }
80
-
81
- address tokenRegistryAddress = registry.getTokenRegistryAddress();
82
- if(IAccessManaged(tokenRegistryAddress).authority() != authority()) {
83
- revert ErrorRegistryAdminTokenRegistryAuthorityMismatch();
84
- }
85
-
86
- address stakingAddress = registry.getStakingAddress();
87
- if(IAccessManaged(stakingAddress).authority() != authority()) {
88
- revert ErrorRegistryAdminStakingAuthorityMismatch();
89
- }
90
-
91
- _releaseManager = releaseManagerAddress;
92
- _tokenRegistry = tokenRegistryAddress;
93
- _staking = stakingAddress;
68
+ _registry = address(registry);
69
+ _releaseRegistry = registry.getReleaseRegistryAddress();
70
+ _tokenRegistry = registry.getTokenRegistryAddress();
71
+ _staking = registry.getStakingAddress();
72
+ _stakingStore = address(
73
+ IStaking(_staking).getStakingStore());
94
74
 
95
75
  // at this moment all registry contracts are deployed and fully intialized
96
- _createRole(GIF_ADMIN_ROLE(), GIF_ADMIN_ROLE_NAME);
97
- _createRole(GIF_MANAGER_ROLE(), GIF_MANAGER_ROLE_NAME);
76
+ _createTarget(_tokenRegistry, TOKEN_REGISTRY_TARGET_NAME, true, false);
98
77
 
99
- _createTarget(_releaseManager, RELEASE_MANAGER_TARGET_NAME);
100
- _createTarget(_tokenRegistry, TOKEN_REGISTRY_TARGET_NAME);
101
- _createTarget(_staking, STAKING_TARGET_NAME);
78
+ _setupGifAdminRole(gifAdmin);
79
+ _setupGifManagerRole(gifManager);
102
80
 
103
- _setGifAdminRole();
104
- _setGifManagerRole();
81
+ _setupReleaseRegistry();
82
+ _setupRegistry();
83
+ _setupStaking();
84
+ }
105
85
 
106
- _grantRole(GIF_ADMIN_ROLE(), gifAdmin, 0);
107
- _grantRole(GIF_MANAGER_ROLE(), gifManager, 0);
108
86
 
109
- // set gif manager role admin
110
- _setRoleAdmin(GIF_MANAGER_ROLE(), GIF_ADMIN_ROLE());
87
+ /// @dev Sets up authorizaion for specified service.
88
+ /// For all authorized services its authorized functions are enabled.
89
+ /// Permissioned function: Access is restricted to release manager.
90
+ function authorizeService(
91
+ IServiceAuthorization serviceAuthorization,
92
+ IService service,
93
+ ObjectType serviceDomain,
94
+ VersionPart releaseVersion
95
+ )
96
+ external
97
+ restricted()
98
+ {
99
+ _createServiceTargetAndRole(service, serviceDomain, releaseVersion);
100
+ _authorizeServiceFunctions(serviceAuthorization, service, serviceDomain, releaseVersion);
111
101
  }
112
102
 
113
- // TODO makes sense to do this in intialize() function
114
- // it is a single contract
115
- // but if many token registries a possible...
116
- /*function setTokenRegistry(
117
- address tokenRegistry
103
+ function grantServiceRole(
104
+ IService service,
105
+ ObjectType domain,
106
+ VersionPart version
118
107
  )
119
108
  external
120
- restricted() // GIF_ADMIN_ROLE
109
+ restricted()
121
110
  {
122
- // for TokenRegistry
123
- bytes4[] memory functionSelector = new bytes4[](5);
124
- functionSelector[0] = TokenRegistry.registerToken.selector;
125
- functionSelector[1] = TokenRegistry.registerRemoteToken.selector;
126
- functionSelector[2] = TokenRegistry.setActive.selector;
127
- functionSelector[3] = TokenRegistry.setActiveForVersion.selector;
128
-
129
- // only needed for testing TODO find a better way
130
- functionSelector[4] = TokenRegistry.setActiveWithVersionCheck.selector;
131
- _setTargetFunctionRole(address(tokenRegistry), functionSelector, GIF_MANAGER_ROLE());
132
- }*/
111
+ _grantRoleToAccount(
112
+ RoleIdLib.roleForTypeAndVersion(
113
+ domain,
114
+ version),
115
+ address(service));
116
+ }
133
117
 
118
+ function grantServiceRoleForAllVersions(IService service, ObjectType domain)
119
+ external
120
+ restricted()
121
+ {
122
+ _grantRoleToAccount(
123
+ RoleIdLib.roleForTypeAndAllVersions(domain),
124
+ address(service));
125
+ }
134
126
 
135
- function setTargetFunctionRole(
136
- address target,
137
- bytes4[] memory selector,
138
- RoleId roleId
139
- )
127
+ function setServiceLocked(IService service, bool locked)
140
128
  external
141
- restricted // RELEASE_MANAGER_ROLE -> TODO create this role
129
+ restricted()
142
130
  {
143
- _setTargetFunctionRole(target, selector, roleId);
131
+ _setTargetClosed(address(service), locked);
144
132
  }
145
133
 
146
134
  /*function transferAdmin(address to)
@@ -153,85 +141,308 @@ contract RegistryAdmin is
153
141
 
154
142
  //--- view functions ----------------------------------------------------//
155
143
 
156
- function hasRole(address account, RoleId roleId) external view returns(bool) {
157
- (bool isMember,) = AccessManagerExtendedInitializeable(authority()).hasRole(roleId.toInt(), account);
158
- return isMember;
144
+ function getGifAdminRole() external view returns (RoleId) {
145
+ return GIF_ADMIN_ROLE();
146
+ }
147
+
148
+ function getGifManagerRole() external view returns (RoleId) {
149
+ return GIF_MANAGER_ROLE();
159
150
  }
160
151
 
152
+ //--- private functions -------------------------------------------------//
161
153
 
162
- function canCall(
163
- address account,
164
- address target,
165
- bytes4 functionSelector
154
+ function _createServiceTargetAndRole(
155
+ IService service,
156
+ ObjectType serviceDomain,
157
+ VersionPart releaseVersion
166
158
  )
167
- external
168
- view
169
- returns(bool)
159
+ private
170
160
  {
171
- (bool immediate,) = AuthorityUtils.canCallWithDelay(
172
- authority(),
173
- account,
174
- target,
175
- functionSelector);
176
-
177
- return immediate;
161
+ string memory baseName = ObjectTypeLib.toName(serviceDomain);
162
+ uint256 versionInt = releaseVersion.toInt();
163
+
164
+ // create service target
165
+ string memory serviceTargetName = ObjectTypeLib.toVersionedName(
166
+ baseName, "Service", versionInt);
167
+
168
+ _createTarget(
169
+ address(service),
170
+ serviceTargetName,
171
+ true,
172
+ false);
173
+
174
+ _setTargetClosed(address(service), true);
175
+
176
+ // create service role
177
+ RoleId serviceRoleId = RoleIdLib.roleForTypeAndVersion(
178
+ serviceDomain,
179
+ releaseVersion);
180
+
181
+ _createRole(
182
+ serviceRoleId,
183
+ toRole({
184
+ adminRoleId: ADMIN_ROLE(),
185
+ roleType: RoleType.Contract,
186
+ maxMemberCount: 1,
187
+ name: ObjectTypeLib.toVersionedName(
188
+ baseName,
189
+ "ServiceRole",
190
+ versionInt)}));
191
+
192
+ _grantRoleToAccount(
193
+ serviceRoleId,
194
+ address(service));
178
195
  }
179
196
 
180
- //--- private functions -------------------------------------------------//
181
197
 
182
- function _setGifAdminRole() private
198
+ function _authorizeServiceFunctions(
199
+ IServiceAuthorization serviceAuthorization,
200
+ IService service,
201
+ ObjectType serviceDomain,
202
+ VersionPart releaseVersion
203
+ )
204
+ private
183
205
  {
184
- // for ReleaseManager
185
- bytes4[] memory functionSelector2 = new bytes4[](2);
186
- //functionSelector2[0] = ReleaseManager.registerStaking.selector;
187
- functionSelector2[0] = ReleaseManager.createNextRelease.selector;
188
- functionSelector2[1] = ReleaseManager.activateNextRelease.selector;
206
+ ObjectType authorizedDomain;
207
+ RoleId authorizedRoleId;
208
+
209
+ ObjectType[] memory authorizedDomains = serviceAuthorization.getAuthorizedDomains(serviceDomain);
210
+
211
+ for (uint256 i = 0; i < authorizedDomains.length; i++) {
212
+ authorizedDomain = authorizedDomains[i];
213
+
214
+ // derive authorized role from authorized domain
215
+ if (authorizedDomain == ALL()) {
216
+ authorizedRoleId = PUBLIC_ROLE();
217
+ } else {
218
+ authorizedRoleId = RoleIdLib.roleForTypeAndVersion(
219
+ authorizedDomain,
220
+ releaseVersion);
221
+ }
222
+
223
+ // get authorized functions for authorized domain
224
+ IAccess.FunctionInfo[] memory authorizatedFunctions = serviceAuthorization.getAuthorizedFunctions(
225
+ serviceDomain,
226
+ authorizedDomain);
227
+
228
+ _authorizeTargetFunctions(
229
+ address(service),
230
+ authorizedRoleId,
231
+ authorizatedFunctions);
232
+ }
233
+ }
189
234
 
190
- _setTargetFunctionRole(_releaseManager, functionSelector2, GIF_ADMIN_ROLE());
235
+ //--- private initialization functions -------------------------------------------//
191
236
 
192
- // for Staking
237
+ function _setupGifAdminRole(address gifAdmin)
238
+ private
239
+ onlyInitializing()
240
+ {
241
+
242
+ _createRole(
243
+ GIF_ADMIN_ROLE(),
244
+ toRole({
245
+ adminRoleId: ADMIN_ROLE(),
246
+ roleType: RoleType.Gif,
247
+ maxMemberCount: 2, // TODO decide on max member count
248
+ name: GIF_ADMIN_ROLE_NAME}));
249
+
250
+ // for Registry
251
+ FunctionInfo[] memory functions;
252
+ functions = new FunctionInfo[](1);
253
+ functions[0] = toFunction(IRegistry.registerRegistry.selector, "registerRegistry");
254
+ _authorizeTargetFunctions(_registry, GIF_ADMIN_ROLE(), functions);
255
+
256
+ // for ReleaseRegistry
257
+ functions = new FunctionInfo[](4);
258
+ functions[0] = toFunction(ReleaseRegistry.createNextRelease.selector, "createNextRelease");
259
+ functions[1] = toFunction(ReleaseRegistry.activateNextRelease.selector, "activateNextRelease");
260
+ functions[2] = toFunction(ReleaseRegistry.pauseRelease.selector, "pauseRelease");
261
+ functions[3] = toFunction(ReleaseRegistry.unpauseRelease.selector, "unpauseRelease");
262
+ _authorizeTargetFunctions(_releaseRegistry, GIF_ADMIN_ROLE(), functions);
263
+
264
+ _grantRoleToAccount(GIF_ADMIN_ROLE(), gifAdmin);
193
265
  }
194
266
 
195
- function _setGifManagerRole() private
267
+ function _setupGifManagerRole(address gifManager)
268
+ private
269
+ onlyInitializing()
196
270
  {
271
+
272
+ _createRole(
273
+ GIF_MANAGER_ROLE(),
274
+ toRole({
275
+ adminRoleId: ADMIN_ROLE(),
276
+ roleType: RoleType.Gif,
277
+ maxMemberCount: 1,
278
+ name: GIF_MANAGER_ROLE_NAME}));
279
+
197
280
  // for TokenRegistry
198
- bytes4[] memory functionSelectorTr = new bytes4[](5);
199
- functionSelectorTr[0] = TokenRegistry.registerToken.selector;
200
- functionSelectorTr[1] = TokenRegistry.registerRemoteToken.selector;
201
- functionSelectorTr[2] = TokenRegistry.setActive.selector;
202
- functionSelectorTr[3] = TokenRegistry.setActiveForVersion.selector;
203
-
204
- // only needed for testing TODO find a better way
205
- functionSelectorTr[4] = TokenRegistry.setActiveWithVersionCheck.selector;
206
- _setTargetFunctionRole(_tokenRegistry, functionSelectorTr, GIF_MANAGER_ROLE());
207
-
208
- // for ReleaseManager
209
- bytes4[] memory functionSelectorRm = new bytes4[](2);
210
- functionSelectorRm[0] = ReleaseManager.registerService.selector;
211
- functionSelectorRm[1] = ReleaseManager.prepareNextRelease.selector;
212
- _setTargetFunctionRole(_releaseManager, functionSelectorRm, GIF_MANAGER_ROLE());
213
-
214
- // for Staking
281
+ FunctionInfo[] memory functions;
282
+ functions = new FunctionInfo[](5);
283
+ functions[0] = toFunction(TokenRegistry.registerToken.selector, "registerToken");
284
+ functions[1] = toFunction(TokenRegistry.registerRemoteToken.selector, "registerRemoteToken");
285
+ functions[2] = toFunction(TokenRegistry.setActive.selector, "setActive");
286
+ functions[3] = toFunction(TokenRegistry.setActiveForVersion.selector, "setActiveForVersion");
287
+ // TODO find a better way (only needed for testing)
288
+ functions[4] = toFunction(TokenRegistry.setActiveWithVersionCheck.selector, "setActiveWithVersionCheck");
289
+ _authorizeTargetFunctions(_tokenRegistry, GIF_MANAGER_ROLE(), functions);
290
+
291
+ // for ReleaseRegistry
292
+ functions = new FunctionInfo[](2);
293
+ functions[0] = toFunction(ReleaseRegistry.prepareNextRelease.selector, "prepareNextRelease");
294
+ functions[1] = toFunction(ReleaseRegistry.registerService.selector, "registerService");
295
+ _authorizeTargetFunctions(_releaseRegistry, GIF_MANAGER_ROLE(), functions);
296
+
297
+ _grantRoleToAccount(GIF_MANAGER_ROLE(), gifManager);
215
298
  }
216
299
 
217
300
 
218
- function _setTargetFunctionRole(address target, bytes4[] memory selectors, RoleId roleId) private {
219
- AccessManagerExtendedInitializeable(authority()).setTargetFunctionRole(target, selectors, roleId.toInt());
220
- }
301
+ function _setupReleaseRegistry()
302
+ private
303
+ onlyInitializing()
304
+ {
221
305
 
222
- function _setRoleAdmin(RoleId roleId, RoleId adminRoleId) private {
223
- AccessManagerExtendedInitializeable(authority()).setRoleAdmin(roleId.toInt(), adminRoleId.toInt());
306
+ _createTarget(_releaseRegistry, RELEASE_REGISTRY_TARGET_NAME, true, false);
307
+
308
+ RoleId releaseRegistryRoleId = RoleIdLib.roleForType(RELEASE());
309
+ _createRole(
310
+ releaseRegistryRoleId,
311
+ toRole({
312
+ adminRoleId: ADMIN_ROLE(),
313
+ roleType: RoleType.Contract,
314
+ maxMemberCount: 1,
315
+ name: RELEASE_REGISTRY_ROLE_NAME}));
316
+
317
+ FunctionInfo[] memory functions;
318
+ functions = new FunctionInfo[](4);
319
+ functions[0] = toFunction(RegistryAdmin.authorizeService.selector, "authorizeService");
320
+ functions[1] = toFunction(RegistryAdmin.grantServiceRoleForAllVersions.selector, "grantServiceRoleForAllVersions");
321
+ functions[2] = toFunction(RegistryAdmin.grantServiceRole.selector, "grantServiceRole");
322
+ functions[3] = toFunction(RegistryAdmin.setServiceLocked.selector, "setServiceLocked");
323
+ _authorizeTargetFunctions(address(this), releaseRegistryRoleId, functions);
324
+
325
+ _grantRoleToAccount(releaseRegistryRoleId, _releaseRegistry);
224
326
  }
225
327
 
226
- function _grantRole(RoleId roleId, address account, uint32 executionDelay) private {
227
- AccessManagerExtendedInitializeable(authority()).grantRole(roleId.toInt(), account, executionDelay);
228
- }
229
328
 
230
- function _createRole(RoleId roleId, string memory roleName) private {
231
- AccessManagerExtendedInitializeable(authority()).createRole(roleId.toInt(), roleName);
329
+ function _setupRegistry()
330
+ internal
331
+ virtual
332
+ onlyInitializing()
333
+ {
334
+ _createTarget(_registry, REGISTRY_TARGET_NAME, true, false);
335
+
336
+ // registry function authorization for registry service
337
+ RoleId registryServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(REGISTRY());
338
+ _createRole(
339
+ registryServiceRoleId,
340
+ toRole({
341
+ adminRoleId: ADMIN_ROLE(),
342
+ roleType: RoleType.Contract,
343
+ maxMemberCount: MAX_NUM_RELEASES,
344
+ name: REGISTRY_SERVICE_ROLE_NAME}));
345
+
346
+ // authorize registry service
347
+ FunctionInfo[] memory functions;
348
+ functions = new FunctionInfo[](2);
349
+ functions[0] = toFunction(IRegistry.register.selector, "register");
350
+ functions[1] = toFunction(IRegistry.registerWithCustomType.selector, "registerWithCustomType");
351
+ _authorizeTargetFunctions(_registry, registryServiceRoleId, functions);
352
+
353
+ // authorize release registry
354
+ RoleId releaseRegistryRoleId = RoleIdLib.roleForType(RELEASE());
355
+ functions = new FunctionInfo[](1);
356
+ functions[0] = toFunction(IRegistry.registerService.selector, "registerService");
357
+ _authorizeTargetFunctions(_registry, releaseRegistryRoleId, functions);
232
358
  }
233
359
 
234
- function _createTarget(address target, string memory targetName) private {
235
- AccessManagerExtendedInitializeable(authority()).createTarget(target, targetName);
360
+
361
+ function _setupStaking()
362
+ private
363
+ onlyInitializing()
364
+ {
365
+ _createTarget(_staking, STAKING_TARGET_NAME, true, false);
366
+ _createTarget(_stakingStore, STAKING_STORE_TARGET_NAME, true, false);
367
+
368
+ // staking function authorization for staking service
369
+ RoleId stakingServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(STAKING());
370
+ _createRole(
371
+ stakingServiceRoleId,
372
+ toRole({
373
+ adminRoleId: ADMIN_ROLE(),
374
+ roleType: RoleType.Contract,
375
+ maxMemberCount: MAX_NUM_RELEASES,
376
+ name: STAKING_SERVICE_ROLE_NAME}));
377
+
378
+ FunctionInfo[] memory functions;
379
+ functions = new FunctionInfo[](13);
380
+ functions[0] = toFunction(IStaking.registerTarget.selector, "registerTarget");
381
+ functions[1] = toFunction(IStaking.setLockingPeriod.selector, "setLockingPeriod");
382
+ functions[2] = toFunction(IStaking.setRewardRate.selector, "setRewardRate");
383
+ functions[3] = toFunction(IStaking.refillRewardReserves.selector, "refillRewardReserves");
384
+ functions[4] = toFunction(IStaking.withdrawRewardReserves.selector, "withdrawRewardReserves");
385
+ functions[5] = toFunction(IStaking.createStake.selector, "createStake");
386
+ functions[6] = toFunction(IStaking.stake.selector, "stake");
387
+ functions[7] = toFunction(IStaking.unstake.selector, "unstake");
388
+ functions[8] = toFunction(IStaking.restake.selector, "restake");
389
+ functions[9] = toFunction(IStaking.updateRewards.selector, "updateRewards");
390
+ functions[10] = toFunction(IStaking.claimRewards.selector, "claimRewards");
391
+ functions[11] = toFunction(IStaking.collectDipAmount.selector, "collectDipAmount");
392
+ functions[12] = toFunction(IStaking.transferDipAmount.selector, "transferDipAmount");
393
+ _authorizeTargetFunctions(_staking, stakingServiceRoleId, functions);
394
+
395
+ // staking function authorization for pool service
396
+ RoleId poolServiceRoleId = RoleIdLib.roleForTypeAndAllVersions(POOL());
397
+ _createRole(
398
+ poolServiceRoleId,
399
+ toRole({
400
+ adminRoleId: ADMIN_ROLE(),
401
+ roleType: RoleType.Contract,
402
+ maxMemberCount: MAX_NUM_RELEASES,
403
+ name: POOL_SERVICE_ROLE_NAME}));
404
+
405
+ // staking function authorizations
406
+ functions = new FunctionInfo[](2);
407
+ functions[0] = toFunction(IStaking.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
408
+ functions[1] = toFunction(IStaking.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
409
+ _authorizeTargetFunctions(_staking, poolServiceRoleId, functions);
410
+
411
+ // staking store function authorizations
412
+ RoleId stakingRoleId = RoleIdLib.roleForType(STAKING());
413
+ _createRole(
414
+ stakingRoleId,
415
+ toRole({
416
+ adminRoleId: ADMIN_ROLE(),
417
+ roleType: RoleType.Contract,
418
+ maxMemberCount: 1,
419
+ name: STAKING_ROLE_NAME}));
420
+
421
+ functions = new FunctionInfo[](14);
422
+ functions[0] = toFunction(StakingStore.setStakingRate.selector, "setStakingRate");
423
+ functions[1] = toFunction(StakingStore.createTarget.selector, "createTarget");
424
+ functions[2] = toFunction(StakingStore.updateTarget.selector, "updateTarget");
425
+ functions[3] = toFunction(StakingStore.increaseReserves.selector, "increaseReserves");
426
+ functions[4] = toFunction(StakingStore.decreaseReserves.selector, "decreaseReserves");
427
+ functions[5] = toFunction(StakingStore.increaseTotalValueLocked.selector, "increaseTotalValueLocked");
428
+ functions[6] = toFunction(StakingStore.decreaseTotalValueLocked.selector, "decreaseTotalValueLocked");
429
+ functions[7] = toFunction(StakingStore.create.selector, "create");
430
+ functions[8] = toFunction(StakingStore.update.selector, "update");
431
+ functions[9] = toFunction(StakingStore.increaseStake.selector, "increaseStake");
432
+ functions[10] = toFunction(StakingStore.restakeRewards.selector, "restakeRewards");
433
+ functions[11] = toFunction(StakingStore.updateRewards.selector, "updateRewards");
434
+ functions[12] = toFunction(StakingStore.claimUpTo.selector, "claimUpTo");
435
+ functions[13] = toFunction(StakingStore.unstakeUpTo.selector, "unstakeUpTo");
436
+ _authorizeTargetFunctions(_stakingStore, stakingRoleId, functions);
437
+
438
+ _grantRoleToAccount(stakingRoleId, _staking);
439
+
440
+ // grant token handler authorizations
441
+ IStaking staking = IStaking(_staking);
442
+ functions = new FunctionInfo[](2);
443
+ functions[0] = toFunction(TokenHandler.collectTokens.selector, "collectTokens");
444
+ functions[1] = toFunction(TokenHandler.distributeTokens.selector, "distributeTokens");
445
+
446
+ _authorizeTargetFunctions(address(staking.getTokenHandler()), stakingRoleId, functions);
236
447
  }
237
448
  }