@etherisc/gif-next 0.0.2-f02157b-803 → 0.0.2-f080b71-868
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.
- package/README.md +75 -14
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/components/Component.sol/Component.json +842 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +948 -229
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IComponent.sol/IComponent.json +605 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +848 -31
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +864 -49
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +682 -9
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +849 -247
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +637 -224
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +778 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{AccessManagedSimple.sol/AccessManagedSimple.json → Cloneable.sol/Cloneable.json} +91 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +468 -246
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +389 -156
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +445 -2985
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +606 -175
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +124 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +252 -210
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +540 -179
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +322 -73
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2677 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.json +639 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +40 -10
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +71 -45
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.json +10 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +860 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +641 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1276 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +717 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +849 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +641 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1539 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +769 -0
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/ServiceBase.sol/ServiceBase.json → service/IApplicationService.sol/IApplicationService.json} +191 -184
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +680 -0
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/{IComponentOwnerService.sol/IComponentOwnerService.json → IClaimService.sol/IClaimService.json} +217 -208
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +585 -160
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +648 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +437 -154
- package/artifacts/contracts/instance/service/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/IService.sol/IService.json → service/IPricingService.sol/IPricingService.json} +270 -173
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +90 -391
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1166 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +697 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +1269 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +661 -0
- package/artifacts/contracts/instance/service/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PricingService.sol/PricingService.json +988 -0
- package/artifacts/contracts/instance/service/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PricingServiceManager.sol/PricingServiceManager.json +689 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +872 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +653 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +373 -61
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +223 -229
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +333 -188
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +227 -330
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +304 -138
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +559 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +498 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +40 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +129 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +21 -34
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IB.sol/IB.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +18 -20
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/{components/BaseComponent.sol/BaseComponent.json → shared/IService.sol/IService.json} +98 -77
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +120 -27
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +248 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +294 -61
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +129 -51
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +84 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/Service.sol/Service.json} +185 -170
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +129 -51
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +6 -6
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +210 -214
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -190
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/types/Amount.sol/AmountLib.json +161 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +40 -9
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +25 -7
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +22 -3
- package/contracts/components/Component.sol +253 -0
- package/contracts/components/Distribution.sol +200 -86
- package/contracts/components/IComponent.sol +76 -0
- package/contracts/components/IDistributionComponent.sol +44 -16
- package/contracts/components/IPoolComponent.sol +88 -37
- package/contracts/components/IProductComponent.sol +10 -5
- package/contracts/components/Pool.sol +225 -181
- package/contracts/components/Product.sol +136 -137
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/instance/BundleManager.sol +127 -0
- package/contracts/instance/Cloneable.sol +51 -0
- package/contracts/instance/IInstance.sol +45 -13
- package/contracts/instance/IInstanceService.sol +74 -7
- package/contracts/instance/Instance.sol +152 -361
- package/contracts/instance/InstanceAccessManager.sol +428 -176
- package/contracts/instance/InstanceAuthorizationsLib.sol +299 -0
- package/contracts/instance/InstanceReader.sol +49 -30
- package/contracts/instance/InstanceService.sol +274 -56
- package/contracts/instance/InstanceServiceManager.sol +11 -13
- package/contracts/instance/InstanceStore.sol +219 -0
- package/contracts/instance/ObjectManager.sol +82 -0
- package/contracts/instance/base/ComponentService.sol +147 -0
- package/contracts/instance/base/KeyValueStore.sol +13 -5
- package/contracts/instance/base/Lifecycle.sol +11 -2
- package/contracts/instance/module/IAccess.sol +36 -20
- package/contracts/instance/module/IBundle.sol +8 -4
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +2 -0
- package/contracts/instance/module/IPolicy.sol +30 -3
- package/contracts/instance/module/ISetup.sol +9 -19
- package/contracts/instance/service/ApplicationService.sol +183 -0
- package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
- package/contracts/instance/service/BundleService.sol +431 -0
- package/contracts/instance/service/BundleServiceManager.sol +51 -0
- package/contracts/instance/service/ClaimService.sol +145 -0
- package/contracts/instance/service/ClaimServiceManager.sol +35 -0
- package/contracts/instance/service/DistributionService.sol +346 -0
- package/contracts/instance/service/DistributionServiceManager.sol +51 -0
- package/contracts/instance/service/IApplicationService.sol +64 -0
- package/contracts/instance/service/IBundleService.sol +94 -0
- package/contracts/instance/service/IClaimService.sol +61 -0
- package/contracts/instance/service/IDistributionService.sol +74 -1
- package/contracts/instance/service/IPolicyService.sol +74 -0
- package/contracts/instance/service/IPoolService.sol +80 -18
- package/contracts/instance/service/IPricingService.sol +36 -0
- package/contracts/instance/service/IProductService.sol +7 -74
- package/contracts/instance/service/PolicyService.sol +376 -0
- package/contracts/instance/service/PolicyServiceManager.sol +54 -0
- package/contracts/instance/service/PoolService.sol +303 -0
- package/contracts/instance/service/PoolServiceManager.sol +51 -0
- package/contracts/instance/service/PricingService.sol +275 -0
- package/contracts/instance/service/PricingServiceManager.sol +51 -0
- package/contracts/instance/service/ProductService.sol +210 -0
- package/contracts/instance/service/ProductServiceManager.sol +54 -0
- package/contracts/registry/ChainNft.sol +9 -1
- package/contracts/registry/IRegistry.sol +52 -8
- package/contracts/registry/IRegistryService.sol +53 -20
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +270 -226
- package/contracts/registry/RegistryAccessManager.sol +216 -0
- package/contracts/registry/RegistryService.sol +118 -271
- package/contracts/registry/RegistryServiceManager.sol +24 -26
- package/contracts/registry/ReleaseManager.sol +324 -0
- package/contracts/registry/TokenRegistry.sol +116 -0
- package/contracts/shared/ERC165.sol +14 -8
- package/contracts/shared/INftOwnable.sol +11 -10
- package/contracts/shared/IPolicyHolder.sol +26 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +12 -0
- package/contracts/shared/IService.sol +16 -0
- package/contracts/shared/IVersionable.sol +4 -47
- package/contracts/shared/NftOwnable.sol +67 -83
- package/contracts/shared/PolicyHolder.sol +81 -0
- package/contracts/shared/ProxyManager.sol +100 -25
- package/contracts/shared/Registerable.sol +16 -31
- package/contracts/shared/RegistryLinked.sol +48 -0
- package/contracts/shared/Service.sol +72 -0
- package/contracts/shared/TokenHandler.sol +11 -5
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/test/TestRegisterable.sol +1 -1
- package/contracts/test/TestService.sol +6 -7
- package/contracts/types/Amount.sol +60 -0
- package/contracts/types/Blocknumber.sol +1 -0
- package/contracts/types/ClaimId.sol +52 -0
- package/contracts/types/DistributorType.sol +2 -2
- package/contracts/types/Fee.sol +13 -5
- package/contracts/types/NftId.sol +8 -0
- package/contracts/types/NftIdSet.sol +26 -24
- package/contracts/types/ObjectType.sol +14 -5
- package/contracts/types/PayoutId.sol +54 -0
- package/contracts/types/Referral.sol +4 -0
- package/contracts/types/RoleId.sol +26 -11
- package/contracts/types/Seconds.sol +54 -0
- package/contracts/types/StateId.sol +5 -0
- package/contracts/types/Timestamp.sol +13 -13
- package/contracts/types/UFixed.sol +1 -0
- package/contracts/types/Version.sol +5 -1
- package/package.json +3 -3
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -267
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +0 -1119
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +0 -1082
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/contracts/components/BaseComponent.sol +0 -86
- package/contracts/components/IBaseComponent.sol +0 -24
- package/contracts/experiment/cloning/Cloner.sol +0 -47
- package/contracts/experiment/errors/Require.sol +0 -38
- package/contracts/experiment/errors/Revert.sol +0 -44
- package/contracts/experiment/inheritance/A.sol +0 -53
- package/contracts/experiment/inheritance/B.sol +0 -28
- package/contracts/experiment/inheritance/C.sol +0 -34
- package/contracts/experiment/inheritance/IA.sol +0 -13
- package/contracts/experiment/inheritance/IB.sol +0 -10
- package/contracts/experiment/inheritance/IC.sol +0 -12
- package/contracts/experiment/statemachine/Dummy.sol +0 -27
- package/contracts/experiment/statemachine/ISM.sol +0 -25
- package/contracts/experiment/statemachine/SM.sol +0 -57
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
- package/contracts/experiment/types/TypeA.sol +0 -47
- package/contracts/experiment/types/TypeB.sol +0 -29
- package/contracts/instance/AccessManagedSimple.sol +0 -114
- package/contracts/instance/AccessManagerSimple.sol +0 -682
- package/contracts/instance/IAccessManagerSimple.sol +0 -391
- package/contracts/instance/base/ComponentServiceBase.sol +0 -49
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- package/contracts/instance/base/IService.sol +0 -15
- package/contracts/instance/base/ServiceBase.sol +0 -44
- package/contracts/instance/service/ComponentOwnerService.sol +0 -317
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
@@ -1,436 +1,227 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {
|
5
|
-
|
4
|
+
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
|
+
|
6
|
+
import {NftId} from "../types/NftId.sol";
|
7
|
+
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET, COMPONENT, DISTRIBUTOR, DISTRIBUTOR_TYPE} from "../types/ObjectType.sol";
|
8
|
+
import {RoleId, RoleIdLib, eqRoleId, ADMIN_ROLE, INSTANCE_ROLE, INSTANCE_OWNER_ROLE} from "../types/RoleId.sol";
|
9
|
+
import {VersionPart, VersionPartLib} from "../types/Version.sol";
|
10
|
+
|
11
|
+
import {ERC165} from "../shared/ERC165.sol";
|
12
|
+
import {Registerable} from "../shared/Registerable.sol";
|
13
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
14
|
+
|
15
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
16
|
+
|
17
|
+
import {IInstance} from "./IInstance.sol";
|
18
|
+
import {InstanceReader} from "./InstanceReader.sol";
|
19
|
+
import {InstanceAccessManager} from "./InstanceAccessManager.sol";
|
20
|
+
import {BundleManager} from "./BundleManager.sol";
|
21
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
22
|
+
|
23
|
+
import {KeyValueStore} from "./base/KeyValueStore.sol";
|
6
24
|
|
7
|
-
import {AccessManagedSimple} from "./AccessManagedSimple.sol";
|
8
|
-
import {AccessManagerSimple} from "./AccessManagerSimple.sol";
|
9
25
|
import {IAccess} from "./module/IAccess.sol";
|
10
26
|
import {IBundle} from "./module/IBundle.sol";
|
27
|
+
import {IComponents} from "./module/IComponents.sol";
|
28
|
+
import {IDistribution} from "./module/IDistribution.sol";
|
11
29
|
import {IPolicy} from "./module/IPolicy.sol";
|
12
30
|
import {IRisk} from "./module/IRisk.sol";
|
13
31
|
import {ISetup} from "./module/ISetup.sol";
|
14
|
-
|
15
|
-
import {
|
16
|
-
import {
|
17
|
-
import {
|
18
|
-
import {
|
19
|
-
import {
|
20
|
-
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET} from "../types/ObjectType.sol";
|
21
|
-
import {RiskId, RiskIdLib} from "../types/RiskId.sol";
|
22
|
-
import {RoleId, RoleIdLib} from "../types/RoleId.sol";
|
23
|
-
import {StateId, ACTIVE} from "../types/StateId.sol";
|
24
|
-
import {ERC165} from "../shared/ERC165.sol";
|
25
|
-
import {Registerable} from "../shared/Registerable.sol";
|
26
|
-
import {ComponentOwnerService} from "./service/ComponentOwnerService.sol";
|
27
|
-
import {IComponentOwnerService} from "./service/IComponentOwnerService.sol";
|
28
|
-
import {VersionPart} from "../types/Version.sol";
|
32
|
+
|
33
|
+
import {IDistributionService} from "./service/IDistributionService.sol";
|
34
|
+
import {IPoolService} from "./service/IPoolService.sol";
|
35
|
+
import {IProductService} from "./service/IProductService.sol";
|
36
|
+
import {IPolicyService} from "./service/IPolicyService.sol";
|
37
|
+
import {IBundleService} from "./service/IBundleService.sol";
|
29
38
|
|
30
39
|
contract Instance is
|
31
|
-
AccessManagedSimple,
|
32
|
-
KeyValueStore,
|
33
40
|
IInstance,
|
34
|
-
|
41
|
+
AccessManagedUpgradeable,
|
35
42
|
Registerable
|
36
43
|
{
|
44
|
+
error InstanceErrorReaderInstanceMismatch(address expectedInstance, address foundInstance);
|
37
45
|
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
uint32 public constant EXECUTION_DELAY = 0;
|
43
|
-
|
44
|
-
mapping(ShortString name => RoleId roleId) internal _role;
|
45
|
-
mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers;
|
46
|
-
RoleId [] internal _roles;
|
47
|
-
|
48
|
-
mapping(ShortString name => address target) internal _target;
|
49
|
-
|
50
|
-
AccessManagerSimple internal _accessManager;
|
51
|
-
InstanceReader internal _instanceReader;
|
52
|
-
|
53
|
-
constructor(address accessManagerAddress, address registryAddress, NftId registryNftId)
|
54
|
-
AccessManagedSimple(accessManagerAddress)
|
55
|
-
{
|
56
|
-
// TODO move to initializer method and remove constructor - required for the instance to be cloneable
|
57
|
-
_accessManager = AccessManagerSimple(accessManagerAddress);
|
58
|
-
_createRole(RoleIdLib.toRoleId(ADMIN_ROLE), "AdminRole", false, false);
|
59
|
-
_createRole(RoleIdLib.toRoleId(PUBLIC_ROLE), "PublicRole", false, false);
|
60
|
-
|
61
|
-
_initializeRegisterable(registryAddress, registryNftId, INSTANCE(), false, msg.sender, "");
|
62
|
-
|
63
|
-
_registerInterface(type(IInstance).interfaceId);
|
64
|
-
}
|
65
|
-
|
66
|
-
//--- Role ------------------------------------------------------//
|
67
|
-
function createStandardRole(RoleId roleId, string memory name) external restricted() {
|
68
|
-
_createRole(roleId, name, false, true);
|
69
|
-
}
|
70
|
-
|
71
|
-
function createCustomRole(RoleId roleId, string memory name) external restricted() {
|
72
|
-
_createRole(roleId, name, true, true);
|
73
|
-
}
|
74
|
-
|
75
|
-
function updateRole(RoleId roleId, string memory name, StateId newState) external restricted() {
|
76
|
-
(bool isCustom,) = _validateRoleParameters(roleId, name, false);
|
77
|
-
IAccess.RoleInfo memory role = _toRole(roleId, name, isCustom);
|
78
|
-
update(toRoleKey32(roleId), abi.encode(role), newState);
|
79
|
-
}
|
80
|
-
|
81
|
-
function updateRoleState(RoleId roleId, StateId newState) external restricted() {
|
82
|
-
updateState(toRoleKey32(roleId), newState);
|
83
|
-
}
|
84
|
-
|
85
|
-
function grantRole(RoleId roleId, address member) external restricted() returns (bool granted) {
|
86
|
-
Key32 roleKey = toRoleKey32(roleId);
|
46
|
+
error InstanceErrorBundleManagerAlreadySet();
|
47
|
+
error InstanceErrorBundleManagerAuthorityMismatch();
|
48
|
+
error InstanceErrorBundleManagerInstanceMismatch(address expectedInstance, address foundInstance);
|
87
49
|
|
88
|
-
|
89
|
-
|
90
|
-
}
|
91
|
-
|
92
|
-
if (getState(roleKey) != ACTIVE()) {
|
93
|
-
revert IAccess.ErrorRoleIdNotActive(roleId);
|
94
|
-
}
|
95
|
-
|
96
|
-
if (!EnumerableSet.contains(_roleMembers[roleId], member)) {
|
97
|
-
_accessManager.grantRole(roleId.toInt(), member, EXECUTION_DELAY);
|
98
|
-
EnumerableSet.add(_roleMembers[roleId], member);
|
99
|
-
return true;
|
100
|
-
}
|
50
|
+
error InstanceErrorAccessManagerAlreadySet();
|
51
|
+
error InstanceErrorAccessManagerAuthorityMismatch();
|
101
52
|
|
102
|
-
|
103
|
-
|
53
|
+
error InstanceErrorInstanceStoreAlreadySet();
|
54
|
+
error InstanceErrorInstanceStoreAuthorityMismatch();
|
104
55
|
|
105
|
-
|
106
|
-
Key32 roleKey = toRoleKey32(roleId);
|
56
|
+
uint256 public constant GIF_MAJOR_VERSION = 3;
|
107
57
|
|
108
|
-
|
109
|
-
revert IAccess.ErrorRevokeNonexstentRole(roleId);
|
110
|
-
}
|
58
|
+
bool private _initialized;
|
111
59
|
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
}
|
117
|
-
|
118
|
-
return false;
|
119
|
-
}
|
120
|
-
|
121
|
-
/// @dev not restricted function by intention
|
122
|
-
/// the restriction to role members is already enforced by the call to the access manger
|
123
|
-
function renounceRole(RoleId roleId) external returns (bool revoked) {
|
124
|
-
address member = msg.sender;
|
125
|
-
Key32 roleKey = toRoleKey32(roleId);
|
126
|
-
|
127
|
-
if (!exists(roleKey)) {
|
128
|
-
revert IAccess.ErrorRenounceNonexstentRole(roleId);
|
129
|
-
}
|
130
|
-
|
131
|
-
if (EnumerableSet.contains(_roleMembers[roleId], member)) {
|
132
|
-
_accessManager.renounceRole(roleId.toInt(), member);
|
133
|
-
EnumerableSet.remove(_roleMembers[roleId], member);
|
134
|
-
return true;
|
135
|
-
}
|
136
|
-
|
137
|
-
return false;
|
138
|
-
}
|
139
|
-
|
140
|
-
function roles() external view returns (uint256 numberOfRoles) {
|
141
|
-
return _roles.length;
|
142
|
-
}
|
143
|
-
|
144
|
-
function getRoleId(uint256 idx) external view returns (RoleId roleId) {
|
145
|
-
return _roles[idx];
|
146
|
-
}
|
147
|
-
|
148
|
-
function getRole(RoleId roleId) external view returns (IAccess.RoleInfo memory role) {
|
149
|
-
return abi.decode(getData(roleId.toKey32()), (IAccess.RoleInfo));
|
150
|
-
}
|
151
|
-
|
152
|
-
function roleMembers(RoleId roleId) external view returns (uint256 numberOfMembers) {
|
153
|
-
return EnumerableSet.length(_roleMembers[roleId]);
|
154
|
-
}
|
155
|
-
|
156
|
-
function getRoleMember(RoleId roleId, uint256 idx) external view returns (address roleMember) {
|
157
|
-
return EnumerableSet.at(_roleMembers[roleId], idx);
|
158
|
-
}
|
159
|
-
|
160
|
-
function _createRole(RoleId roleId, string memory name, bool isCustom, bool validateParameters) internal {
|
161
|
-
if (validateParameters) {
|
162
|
-
_validateRoleParameters(roleId, name, isCustom);
|
163
|
-
}
|
164
|
-
|
165
|
-
IAccess.RoleInfo memory role = _toRole(roleId, name, isCustom);
|
166
|
-
_role[role.name] = roleId;
|
167
|
-
_roles.push(roleId);
|
168
|
-
|
169
|
-
create(toRoleKey32(roleId), abi.encode(role));
|
170
|
-
}
|
171
|
-
|
172
|
-
//--- Target ------------------------------------------------------//
|
173
|
-
function createTarget(address target, IAccess.TargetInfo memory targetInfo) external restricted() {
|
174
|
-
_validateTargetParameters(target, targetInfo);
|
175
|
-
create(toTargetKey32(target), abi.encode(targetInfo));
|
176
|
-
}
|
60
|
+
InstanceAccessManager internal _accessManager;
|
61
|
+
InstanceReader internal _instanceReader;
|
62
|
+
BundleManager internal _bundleManager;
|
63
|
+
InstanceStore internal _instanceStore;
|
177
64
|
|
178
|
-
|
179
|
-
if (
|
180
|
-
revert
|
65
|
+
modifier onlyChainNft() {
|
66
|
+
if(msg.sender != getRegistry().getChainNftAddress()) {
|
67
|
+
revert();
|
181
68
|
}
|
182
|
-
|
183
|
-
_accessManager.setTargetClosed(target, closed);
|
69
|
+
_;
|
184
70
|
}
|
185
71
|
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
function updateProductSetupState(NftId productNftId, StateId newState) external restricted() {
|
196
|
-
updateState(_toNftKey32(productNftId, PRODUCT()), newState);
|
197
|
-
}
|
198
|
-
|
199
|
-
//--- DistributionSetup ------------------------------------------------------//
|
200
|
-
function createDistributionSetup(NftId distributionNftId, ISetup.DistributionSetupInfo memory setup) external restricted() {
|
201
|
-
create(_toNftKey32(distributionNftId, DISTRIBUTION()), abi.encode(setup));
|
202
|
-
}
|
203
|
-
|
204
|
-
function updateDistributionSetup(NftId distributionNftId, ISetup.DistributionSetupInfo memory setup, StateId newState) external restricted() {
|
205
|
-
update(_toNftKey32(distributionNftId, DISTRIBUTION()), abi.encode(setup), newState);
|
206
|
-
}
|
207
|
-
|
208
|
-
function updateDistributionSetupState(NftId distributionNftId, StateId newState) external restricted() {
|
209
|
-
updateState(_toNftKey32(distributionNftId, DISTRIBUTION()), newState);
|
210
|
-
}
|
211
|
-
|
212
|
-
//--- PoolSetup ------------------------------------------------------//
|
213
|
-
function createPoolSetup(NftId distributionNftId, ISetup.PoolSetupInfo memory setup) external restricted() {
|
214
|
-
create(_toNftKey32(distributionNftId, POOL()), abi.encode(setup));
|
215
|
-
}
|
216
|
-
|
217
|
-
function updatePoolSetup(NftId distributionNftId, ISetup.PoolSetupInfo memory setup, StateId newState) external restricted() {
|
218
|
-
update(_toNftKey32(distributionNftId, POOL()), abi.encode(setup), newState);
|
219
|
-
}
|
220
|
-
|
221
|
-
function updatePoolSetupState(NftId distributionNftId, StateId newState) external restricted() {
|
222
|
-
updateState(_toNftKey32(distributionNftId, POOL()), newState);
|
223
|
-
}
|
224
|
-
|
225
|
-
//--- DistributorType ---------------------------------------------------//
|
226
|
-
function createDistributorType(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
227
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
228
|
-
}
|
229
|
-
|
230
|
-
function updateDistributorType(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout, StateId newState) external restricted() {
|
231
|
-
update(toPolicyKey32(policyNftId), abi.encode(payout), newState);
|
232
|
-
}
|
233
|
-
|
234
|
-
function updateDistributorTypeState(NftId policyNftId, StateId newState) external restricted() {
|
235
|
-
updateState(toPolicyKey32(policyNftId), newState);
|
236
|
-
}
|
237
|
-
|
238
|
-
//--- Distributor -------------------------------------------------------//
|
239
|
-
function createDistributor(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
240
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
241
|
-
}
|
242
|
-
|
243
|
-
function updateDistributor(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout, StateId newState) external restricted() {
|
244
|
-
update(toPolicyKey32(policyNftId), abi.encode(payout), newState);
|
245
|
-
}
|
246
|
-
|
247
|
-
function updateDistributorState(NftId policyNftId, StateId newState) external restricted() {
|
248
|
-
updateState(toPolicyKey32(policyNftId), newState);
|
249
|
-
}
|
72
|
+
function initialize(address authority, address registryAddress, address initialOwner)
|
73
|
+
external
|
74
|
+
initializer()
|
75
|
+
{
|
76
|
+
__AccessManaged_init(authority);
|
77
|
+
|
78
|
+
IRegistry registry = IRegistry(registryAddress);
|
79
|
+
initializeRegisterable(registryAddress, registry.getNftId(), INSTANCE(), true, initialOwner, "");
|
250
80
|
|
251
|
-
|
252
|
-
function createReferral(NftId policyNftId, NumberId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
253
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
81
|
+
registerInterface(type(IInstance).interfaceId);
|
254
82
|
}
|
255
83
|
|
256
|
-
|
257
|
-
update(toPolicyKey32(policyNftId), abi.encode(payout), newState);
|
258
|
-
}
|
84
|
+
//--- Roles ------------------------------------------------------------//
|
259
85
|
|
260
|
-
function
|
261
|
-
|
86
|
+
function createRole(string memory roleName, string memory adminName)
|
87
|
+
external
|
88
|
+
restricted // INSTANCE_OWNER_ROLE
|
89
|
+
returns (RoleId roleId, RoleId admin)
|
90
|
+
{
|
91
|
+
(roleId, admin) = _accessManager.createRole(roleName, adminName);
|
262
92
|
}
|
263
93
|
|
264
|
-
|
265
|
-
|
266
|
-
|
94
|
+
function grantRole(RoleId roleId, address account)
|
95
|
+
external
|
96
|
+
restricted // INSTANCE_OWNER_ROLE
|
97
|
+
{
|
98
|
+
_accessManager.grantRole(roleId, account);
|
267
99
|
}
|
268
100
|
|
269
|
-
function
|
270
|
-
|
101
|
+
function revokeRole(RoleId roleId, address account)
|
102
|
+
external
|
103
|
+
restricted // INSTANCE_OWNER_ROLE
|
104
|
+
{
|
105
|
+
_accessManager.revokeRole(roleId, account);
|
271
106
|
}
|
272
107
|
|
273
|
-
|
274
|
-
updateState(toBundleKey32(bundleNftId), newState);
|
275
|
-
}
|
108
|
+
//--- Targets ------------------------------------------------------------//
|
276
109
|
|
277
|
-
|
278
|
-
|
279
|
-
|
110
|
+
function createTarget(address target, string memory name)
|
111
|
+
external
|
112
|
+
restricted // INSTANCE_OWNER_ROLE
|
113
|
+
{
|
114
|
+
_accessManager.createTarget(target, name);
|
280
115
|
}
|
281
116
|
|
282
|
-
function
|
283
|
-
|
117
|
+
function setTargetFunctionRole(
|
118
|
+
string memory targetName,
|
119
|
+
bytes4[] calldata selectors,
|
120
|
+
RoleId roleId
|
121
|
+
)
|
122
|
+
external
|
123
|
+
restricted // INSTANCE_OWNER_ROLE
|
124
|
+
{
|
125
|
+
_accessManager.setTargetFunctionRole(targetName, selectors, roleId);
|
284
126
|
}
|
285
127
|
|
286
|
-
function
|
287
|
-
|
128
|
+
function setTargetLocked(address target, bool locked)
|
129
|
+
external
|
130
|
+
restricted // INSTANCE_OWNER_ROLE
|
131
|
+
{
|
132
|
+
_accessManager.setTargetLockedByInstance(target, locked);
|
288
133
|
}
|
289
134
|
|
290
|
-
//---
|
291
|
-
function
|
292
|
-
|
135
|
+
//--- ITransferInterceptor ------------------------------------------------------------//
|
136
|
+
function nftMint(address to, uint256 tokenId) external onlyChainNft {
|
137
|
+
assert(_accessManager.roleMembers(INSTANCE_OWNER_ROLE()) == 0);// temp
|
138
|
+
assert(_accessManager.grantRole(INSTANCE_OWNER_ROLE(), to) == true);
|
293
139
|
}
|
294
140
|
|
295
|
-
function
|
296
|
-
|
141
|
+
function nftTransferFrom(address from, address to, uint256 tokenId) external onlyChainNft {
|
142
|
+
assert(_accessManager.revokeRole(INSTANCE_OWNER_ROLE(), from) == true);
|
143
|
+
assert(_accessManager.grantRole(INSTANCE_OWNER_ROLE(), to) == true);
|
297
144
|
}
|
298
145
|
|
299
|
-
function
|
300
|
-
|
146
|
+
function getDistributionService() external view returns (IDistributionService) {
|
147
|
+
return IDistributionService(getRegistry().getServiceAddress(DISTRIBUTION(), VersionPart.wrap(3)));
|
301
148
|
}
|
302
149
|
|
303
|
-
|
304
|
-
|
305
|
-
create(toPolicyKey32(policyNftId), abi.encode(claim));
|
150
|
+
function getProductService() external view returns (IProductService) {
|
151
|
+
return IProductService(getRegistry().getServiceAddress(PRODUCT(), VersionPart.wrap(3)));
|
306
152
|
}
|
307
153
|
|
308
|
-
function
|
309
|
-
|
154
|
+
function getPoolService() external view returns (IPoolService) {
|
155
|
+
return IPoolService(getRegistry().getServiceAddress(POOL(), VersionPart.wrap(3)));
|
310
156
|
}
|
311
157
|
|
312
|
-
function
|
313
|
-
|
158
|
+
function getPolicyService() external view returns (IPolicyService) {
|
159
|
+
return IPolicyService(getRegistry().getServiceAddress(POLICY(), VersionPart.wrap(3)));
|
314
160
|
}
|
315
161
|
|
316
|
-
|
317
|
-
|
318
|
-
create(toPolicyKey32(policyNftId), abi.encode(payout));
|
162
|
+
function getBundleService() external view returns (IBundleService) {
|
163
|
+
return IBundleService(getRegistry().getServiceAddress(BUNDLE(), VersionPart.wrap(3)));
|
319
164
|
}
|
320
165
|
|
321
|
-
function
|
322
|
-
|
166
|
+
function setInstanceReader(InstanceReader instanceReader) external restricted() {
|
167
|
+
if(instanceReader.getInstance() != Instance(this)) {
|
168
|
+
revert InstanceErrorReaderInstanceMismatch(address(this), address(instanceReader.getInstance()));
|
169
|
+
}
|
170
|
+
_instanceReader = instanceReader;
|
323
171
|
}
|
324
172
|
|
325
|
-
function
|
326
|
-
|
173
|
+
function getMajorVersion() external pure returns (VersionPart majorVersion) {
|
174
|
+
return VersionPartLib.toVersionPart(GIF_MAJOR_VERSION);
|
327
175
|
}
|
328
176
|
|
329
|
-
|
330
|
-
|
331
|
-
internal
|
332
|
-
pure
|
333
|
-
returns (IAccess.RoleInfo memory role)
|
334
|
-
{
|
335
|
-
return IAccess.RoleInfo(
|
336
|
-
ShortStrings.toShortString(name),
|
337
|
-
isCustom);
|
177
|
+
function getInstanceReader() external view returns (InstanceReader) {
|
178
|
+
return _instanceReader;
|
338
179
|
}
|
339
|
-
|
340
|
-
function
|
341
|
-
|
342
|
-
|
343
|
-
bool isCustom
|
344
|
-
)
|
345
|
-
internal
|
346
|
-
view
|
347
|
-
returns (
|
348
|
-
bool roleExists,
|
349
|
-
bool roleIsCustom
|
350
|
-
)
|
351
|
-
{
|
352
|
-
Key32 roleKey = toRoleKey32(roleId);
|
353
|
-
roleExists = exists(roleKey);
|
354
|
-
if (roleExists) {
|
355
|
-
roleIsCustom = abi.decode(getData(roleKey), (IAccess.RoleInfo)).isCustom;
|
356
|
-
} else {
|
357
|
-
roleIsCustom = isCustom;
|
180
|
+
|
181
|
+
function setBundleManager(BundleManager bundleManager) external restricted() {
|
182
|
+
if(address(_bundleManager) != address(0)) {
|
183
|
+
revert InstanceErrorBundleManagerAlreadySet();
|
358
184
|
}
|
359
|
-
|
360
|
-
|
361
|
-
uint64 roleIdInt = RoleId.unwrap(roleId);
|
362
|
-
if(roleIdInt == ADMIN_ROLE || roleIdInt == PUBLIC_ROLE) {
|
363
|
-
revert IAccess.ErrorRoleIdInvalid(roleId);
|
185
|
+
if(bundleManager.getInstance() != Instance(this)) {
|
186
|
+
revert InstanceErrorBundleManagerInstanceMismatch(address(this), address(bundleManager.getInstance()));
|
364
187
|
}
|
365
|
-
|
366
|
-
|
367
|
-
revert IAccess.ErrorRoleIdTooSmall(roleId);
|
368
|
-
} else if (roleIsCustom && roleIdInt >= CUSTOM_ROLE_ID_MIN) {
|
369
|
-
revert IAccess.ErrorRoleIdTooBig(roleId);
|
188
|
+
if(bundleManager.authority() != authority()) {
|
189
|
+
revert InstanceErrorBundleManagerAuthorityMismatch();
|
370
190
|
}
|
371
|
-
|
372
|
-
// role name checks
|
373
|
-
ShortString nameShort = ShortStrings.toShortString(name);
|
374
|
-
if (ShortStrings.byteLength(nameShort) == 0) {
|
375
|
-
revert IAccess.ErrorRoleNameEmpty(roleId);
|
376
|
-
}
|
377
|
-
|
378
|
-
if (_role[nameShort] != RoleIdLib.zero() && _role[nameShort] != roleId) {
|
379
|
-
revert IAccess.ErrorRoleNameNotUnique(_role[nameShort], nameShort);
|
380
|
-
}
|
381
|
-
}
|
382
|
-
|
383
|
-
function _validateTargetParameters(address target, IAccess.TargetInfo memory targetInfo) internal view {
|
384
|
-
|
191
|
+
_bundleManager = bundleManager;
|
385
192
|
}
|
386
193
|
|
387
|
-
function
|
388
|
-
return
|
194
|
+
function getBundleManager() external view returns (BundleManager) {
|
195
|
+
return _bundleManager;
|
389
196
|
}
|
390
197
|
|
391
|
-
function
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
function toBundleKey32(NftId bundleNftId) public pure returns (Key32) {
|
400
|
-
return bundleNftId.toKey32(BUNDLE());
|
401
|
-
}
|
402
|
-
|
403
|
-
function toPolicyKey32(NftId policyNftId) public pure returns (Key32) {
|
404
|
-
return policyNftId.toKey32(POLICY());
|
198
|
+
function setInstanceAccessManager(InstanceAccessManager accessManager) external restricted {
|
199
|
+
if(address(_accessManager) != address(0)) {
|
200
|
+
revert InstanceErrorAccessManagerAlreadySet();
|
201
|
+
}
|
202
|
+
if(accessManager.authority() != authority()) {
|
203
|
+
revert InstanceErrorAccessManagerAuthorityMismatch();
|
204
|
+
}
|
205
|
+
_accessManager = accessManager;
|
405
206
|
}
|
406
207
|
|
407
|
-
function
|
408
|
-
return
|
208
|
+
function getInstanceAccessManager() external view returns (InstanceAccessManager) {
|
209
|
+
return _accessManager;
|
409
210
|
}
|
410
211
|
|
411
|
-
|
412
|
-
|
413
|
-
|
414
|
-
// }
|
415
|
-
|
416
|
-
// TODO reactivate when services are available
|
417
|
-
// function getProductService() external view returns (IProductService) {
|
418
|
-
// return ProductService(_registry.getServiceAddress("ProductService", VersionPart.wrap(3)));
|
419
|
-
// }
|
420
|
-
|
421
|
-
// TODO reactivate when services are available
|
422
|
-
// function getPoolService() external view returns (IPoolService) {
|
423
|
-
// return PoolService(_registry.getServiceAddress("PoolService", VersionPart.wrap(3)));
|
424
|
-
// }
|
425
|
-
|
426
|
-
function setInstanceReader(InstanceReader instanceReader) external restricted() {
|
427
|
-
if (address(_instanceReader) != address(0)) {
|
428
|
-
revert("InstanceReader is set");
|
212
|
+
function setInstanceStore(InstanceStore instanceStore) external restricted {
|
213
|
+
if(address(_instanceStore) != address(0)) {
|
214
|
+
revert InstanceErrorInstanceStoreAlreadySet();
|
429
215
|
}
|
430
|
-
|
216
|
+
if(instanceStore.authority() != authority()) {
|
217
|
+
revert InstanceErrorInstanceStoreAuthorityMismatch();
|
218
|
+
}
|
219
|
+
_instanceStore = instanceStore;
|
431
220
|
}
|
432
221
|
|
433
|
-
function
|
434
|
-
return
|
222
|
+
function getInstanceStore() external view returns (InstanceStore) {
|
223
|
+
return _instanceStore;
|
435
224
|
}
|
436
|
-
|
225
|
+
|
226
|
+
//--- internal view/pure functions --------------------------------------//
|
227
|
+
}
|