@etherisc/gif-next 0.0.2-fe88ad7-208 → 0.0.2-ff282a4-523
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 +8 -13
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1376 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1556 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +780 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +1000 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +840 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +73 -83
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +275 -1359
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +264 -218
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +441 -2539
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +479 -178
- 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 +432 -280
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +399 -383
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +295 -99
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2847 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +6 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +49 -0
- 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 +93 -14
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +38 -13
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +58 -75
- 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/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1288 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +696 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +316 -250
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1095 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1077 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +1407 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1622 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +708 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +918 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +648 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1386 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +748 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → product/IApplicationService.sol/IApplicationService.json} +218 -191
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +753 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +264 -277
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IPricingService.sol/IPricingService.json} +241 -230
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Product.sol/Product.json → product/IProductComponent.sol/IProductComponent.json} +254 -168
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +72 -166
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1281 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +740 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +1004 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +688 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/product/Product.sol/Product.json +1198 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +864 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +640 -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 +165 -5
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +158 -215
- 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 +196 -31
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +20 -20
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +270 -254
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +291 -85
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +151 -77
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +142 -54
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/{components/Pool.sol/Pool.json → shared/Component.sol/Component.json} +358 -327
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentServiceBase.sol/ComponentServiceBase.json → shared/ComponentService.sol/ComponentService.json} +263 -164
- 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/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Distribution.sol/Distribution.json → shared/IComponent.sol/IComponent.json} +173 -212
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +27 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +189 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +8 -34
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +71 -165
- 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 +109 -29
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +302 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +285 -65
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +118 -53
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +173 -153
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +24 -6
- 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/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/{components/IBaseComponent.sol/IBaseComponent.json → staking/IStaking.sol/IStaking.json} +62 -150
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/{components/BaseComponent.sol/BaseComponent.json → staking/IStakingService.sol/IStakingService.json} +232 -169
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +497 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +623 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +797 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +632 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +281 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Blocknumber.sol/BlocknumberLib.json +3 -3
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +166 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/ObjectType.sol/ObjectTypeLib.json +3 -3
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +39 -8
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
- package/contracts/distribution/Distribution.sol +285 -0
- package/contracts/distribution/DistributionService.sol +349 -0
- package/contracts/{instance/service → distribution}/DistributionServiceManager.sol +6 -6
- package/contracts/distribution/IDistributionComponent.sol +71 -0
- package/contracts/distribution/IDistributionService.sol +87 -0
- package/contracts/instance/BundleManager.sol +22 -25
- package/contracts/instance/IInstance.sol +56 -41
- package/contracts/instance/IInstanceService.sol +49 -16
- package/contracts/instance/Instance.sol +149 -196
- package/contracts/instance/InstanceAccessManager.sol +406 -166
- package/contracts/instance/InstanceAuthorizationsLib.sol +308 -0
- package/contracts/instance/InstanceReader.sol +102 -49
- package/contracts/instance/InstanceService.sol +206 -248
- package/contracts/instance/InstanceServiceManager.sol +2 -2
- package/contracts/instance/InstanceStore.sol +211 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
- package/contracts/instance/base/IKeyValueStore.sol +14 -10
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +44 -47
- package/contracts/instance/base/Lifecycle.sol +28 -7
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +16 -35
- package/contracts/instance/module/IAccess.sol +24 -18
- package/contracts/instance/module/IBundle.sol +11 -8
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +7 -4
- package/contracts/instance/module/IPolicy.sol +50 -17
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/instance/module/ISetup.sol +9 -22
- package/contracts/instance/module/ITreasury.sol +2 -2
- package/contracts/pool/BundleService.sol +382 -0
- package/contracts/{instance/service → pool}/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +118 -0
- package/contracts/pool/IPoolComponent.sol +114 -0
- package/contracts/pool/IPoolService.sol +114 -0
- package/contracts/pool/Pool.sol +302 -0
- package/contracts/pool/PoolService.sol +403 -0
- package/contracts/{instance/service → pool}/PoolServiceManager.sol +6 -6
- package/contracts/product/ApplicationService.sol +186 -0
- package/contracts/product/ApplicationServiceManager.sol +35 -0
- package/contracts/product/ClaimService.sol +442 -0
- package/contracts/product/ClaimServiceManager.sol +35 -0
- package/contracts/product/IApplicationService.sol +62 -0
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/product/IPolicyService.sol +80 -0
- package/contracts/product/IPricingService.sol +37 -0
- package/contracts/product/IProductComponent.sol +41 -0
- package/contracts/{instance/service → product}/IProductService.sol +10 -10
- package/contracts/product/PolicyService.sol +376 -0
- package/contracts/{instance/service → product}/PolicyServiceManager.sol +7 -7
- package/contracts/product/PricingService.sol +275 -0
- package/contracts/product/PricingServiceManager.sol +51 -0
- package/contracts/product/Product.sol +379 -0
- package/contracts/product/ProductService.sol +210 -0
- package/contracts/{instance/service → product}/ProductServiceManager.sol +7 -7
- package/contracts/registry/ChainNft.sol +15 -1
- package/contracts/registry/IRegistry.sol +33 -14
- package/contracts/registry/IRegistryService.sol +28 -17
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +184 -75
- package/contracts/registry/RegistryAccessManager.sol +32 -35
- package/contracts/registry/RegistryService.sol +126 -145
- package/contracts/registry/RegistryServiceManager.sol +13 -15
- package/contracts/registry/ReleaseManager.sol +157 -145
- package/contracts/registry/TokenRegistry.sol +21 -15
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/shared/Component.sol +271 -0
- package/contracts/shared/ComponentService.sol +150 -0
- package/contracts/shared/ERC165.sol +14 -12
- package/contracts/shared/IComponent.sol +90 -0
- package/contracts/shared/INftOwnable.sol +12 -11
- package/contracts/shared/IPolicyHolder.sol +40 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +6 -4
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/NftOwnable.sol +64 -80
- package/contracts/shared/PolicyHolder.sol +94 -0
- package/contracts/shared/ProxyManager.sol +100 -25
- package/contracts/shared/Registerable.sol +26 -41
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +37 -23
- package/contracts/shared/TokenHandler.sol +14 -6
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/staking/IStaking.sol +15 -0
- package/contracts/staking/IStakingService.sol +105 -0
- package/contracts/staking/Staking.sol +64 -0
- package/contracts/staking/StakingManager.sol +44 -0
- package/contracts/staking/StakingService.sol +204 -0
- package/contracts/staking/StakingServiceManager.sol +41 -0
- package/contracts/type/Amount.sol +109 -0
- package/contracts/{types → type}/Blocknumber.sol +1 -0
- package/contracts/type/ClaimId.sol +75 -0
- package/contracts/{types → type}/DistributorType.sol +2 -2
- package/contracts/{types → type}/Fee.sol +17 -8
- package/contracts/{types → type}/NftId.sol +8 -0
- package/contracts/{types → type}/NftIdSet.sol +1 -1
- package/contracts/{types → type}/ObjectType.sol +21 -7
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +4 -0
- package/contracts/{types → type}/RoleId.sol +56 -14
- package/contracts/type/Seconds.sol +54 -0
- package/contracts/{types → type}/StateId.sol +7 -2
- package/contracts/{types → type}/Timestamp.sol +18 -13
- package/contracts/{types → type}/UFixed.sol +1 -0
- package/contracts/{types → type}/Version.sol +1 -0
- package/package.json +3 -3
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -152
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -275
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -157
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- 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/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
- 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/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.json +0 -448
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +0 -763
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -285
- 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/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -945
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -432
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -814
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -693
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -420
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +0 -446
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -993
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -464
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -727
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -420
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -777
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -420
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +0 -442
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -305
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -600
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -286
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
- package/contracts/components/BaseComponent.sol +0 -159
- package/contracts/components/Distribution.sol +0 -163
- package/contracts/components/IBaseComponent.sol +0 -34
- package/contracts/components/IDistributionComponent.sol +0 -44
- package/contracts/components/IPoolComponent.sol +0 -66
- package/contracts/components/IProductComponent.sol +0 -35
- package/contracts/components/Pool.sol +0 -271
- package/contracts/components/Product.sol +0 -292
- 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/AccessManagerUpgradeableInitializeable.sol +0 -23
- package/contracts/instance/IInstanceBase.sol +0 -26
- package/contracts/instance/InstanceBase.sol +0 -41
- package/contracts/instance/base/ComponentServiceBase.sol +0 -82
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- package/contracts/instance/service/BundleService.sol +0 -260
- package/contracts/instance/service/ComponentOwnerService.sol +0 -315
- package/contracts/instance/service/DistributionService.sol +0 -113
- package/contracts/instance/service/IBundleService.sol +0 -45
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPolicyService.sol +0 -87
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/PolicyService.sol +0 -503
- package/contracts/instance/service/PoolService.sol +0 -124
- package/contracts/instance/service/ProductService.sol +0 -170
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -25
- package/contracts/test/TestToken.sol +0 -26
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- package/contracts/test/Usdc.sol +0 -26
- package/contracts/types/ChainId.sol +0 -38
- package/contracts/types/NumberId.sol +0 -52
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -1,260 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {Pool} from "../../components/Pool.sol";
|
5
|
-
import {IRegistry} from "../../registry/IRegistry.sol";
|
6
|
-
import {IInstance} from "../../instance/IInstance.sol";
|
7
|
-
import {IBundle} from "../../instance/module/IBundle.sol";
|
8
|
-
import {TokenHandler} from "../../instance/module/ITreasury.sol";
|
9
|
-
import {ISetup} from "../module/ISetup.sol";
|
10
|
-
import {IPolicy} from "../module/IPolicy.sol";
|
11
|
-
|
12
|
-
import {IVersionable} from "../../shared/IVersionable.sol";
|
13
|
-
import {Versionable} from "../../shared/Versionable.sol";
|
14
|
-
import {INftOwnable} from "../../shared/INftOwnable.sol";
|
15
|
-
|
16
|
-
import {NftId, NftIdLib, zeroNftId} from "../../types/NftId.sol";
|
17
|
-
import {ObjectType, POOL, BUNDLE} from "../../types/ObjectType.sol";
|
18
|
-
import {POOL_OWNER_ROLE, RoleId} from "../../types/RoleId.sol";
|
19
|
-
import {Fee, FeeLib} from "../../types/Fee.sol";
|
20
|
-
import {Version, VersionLib} from "../../types/Version.sol";
|
21
|
-
import {KEEP_STATE, StateId} from "../../types/StateId.sol";
|
22
|
-
import {TimestampLib, zeroTimestamp} from "../../types/Timestamp.sol";
|
23
|
-
|
24
|
-
import {IService} from "../../shared/IService.sol";
|
25
|
-
import {Service} from "../../shared/Service.sol";
|
26
|
-
import {BundleManager} from "../BundleManager.sol";
|
27
|
-
import {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
|
28
|
-
import {IBundleService} from "./IBundleService.sol";
|
29
|
-
import {IRegistryService} from "../../registry/IRegistryService.sol";
|
30
|
-
import {InstanceService} from "../InstanceService.sol";
|
31
|
-
import {InstanceReader} from "../InstanceReader.sol";
|
32
|
-
import {IBaseComponent} from "../../components/IBaseComponent.sol";
|
33
|
-
|
34
|
-
string constant BUNDLE_SERVICE_NAME = "BundleService";
|
35
|
-
|
36
|
-
contract BundleService is
|
37
|
-
ComponentServiceBase,
|
38
|
-
IBundleService
|
39
|
-
{
|
40
|
-
using NftIdLib for NftId;
|
41
|
-
|
42
|
-
string public constant NAME = "BundleService";
|
43
|
-
|
44
|
-
address internal _registryAddress;
|
45
|
-
|
46
|
-
function _initialize(
|
47
|
-
address owner,
|
48
|
-
bytes memory data
|
49
|
-
)
|
50
|
-
internal
|
51
|
-
initializer
|
52
|
-
virtual override
|
53
|
-
{
|
54
|
-
address registryAddress;
|
55
|
-
address initialOwner;
|
56
|
-
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
57
|
-
// TODO while PoolService is not deployed in PoolServiceManager constructor
|
58
|
-
// owner is PoolServiceManager deployer
|
59
|
-
_initializeService(registryAddress, owner);
|
60
|
-
|
61
|
-
_registerInterface(type(IBundleService).interfaceId);
|
62
|
-
}
|
63
|
-
|
64
|
-
function getDomain() public pure override(Service, IService) returns(ObjectType) {
|
65
|
-
return BUNDLE();
|
66
|
-
}
|
67
|
-
|
68
|
-
function createBundle(
|
69
|
-
address owner,
|
70
|
-
Fee memory fee,
|
71
|
-
uint256 stakingAmount,
|
72
|
-
uint256 lifetime,
|
73
|
-
bytes calldata filter
|
74
|
-
)
|
75
|
-
external
|
76
|
-
override
|
77
|
-
returns(NftId bundleNftId)
|
78
|
-
{
|
79
|
-
(IRegistry.ObjectInfo memory info, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
80
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
81
|
-
NftId poolNftId = info.nftId;
|
82
|
-
|
83
|
-
IBundle.BundleInfo memory bundleInfo = IBundle.BundleInfo(
|
84
|
-
poolNftId,
|
85
|
-
fee,
|
86
|
-
filter,
|
87
|
-
stakingAmount,
|
88
|
-
0,
|
89
|
-
stakingAmount,
|
90
|
-
lifetime,
|
91
|
-
zeroTimestamp(),
|
92
|
-
zeroTimestamp()
|
93
|
-
);
|
94
|
-
|
95
|
-
// register bundle with registry
|
96
|
-
bundleNftId = getRegistryService().registerBundle(
|
97
|
-
IRegistry.ObjectInfo(
|
98
|
-
zeroNftId(),
|
99
|
-
poolNftId,
|
100
|
-
BUNDLE(),
|
101
|
-
false, // intercepting property for bundles is defined on pool
|
102
|
-
address(0),
|
103
|
-
owner,
|
104
|
-
abi.encode(bundleInfo)
|
105
|
-
)
|
106
|
-
);
|
107
|
-
|
108
|
-
// create bundle info in instance
|
109
|
-
instance.createBundle(bundleNftId, bundleInfo);
|
110
|
-
|
111
|
-
BundleManager bundleManager = instance.getBundleManager();
|
112
|
-
bundleManager.add(bundleNftId);
|
113
|
-
|
114
|
-
_processStakingByTreasury(
|
115
|
-
instanceReader,
|
116
|
-
poolNftId,
|
117
|
-
bundleNftId,
|
118
|
-
stakingAmount);
|
119
|
-
|
120
|
-
// TODO add logging
|
121
|
-
}
|
122
|
-
|
123
|
-
function setBundleFee(
|
124
|
-
NftId bundleNftId,
|
125
|
-
Fee memory fee
|
126
|
-
)
|
127
|
-
external
|
128
|
-
override
|
129
|
-
{
|
130
|
-
(IRegistry.ObjectInfo memory info , IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
131
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
132
|
-
NftId poolNftId = info.nftId;
|
133
|
-
|
134
|
-
IBundle.BundleInfo memory bundleInfo = instanceReader.getBundleInfo(bundleNftId);
|
135
|
-
require(bundleInfo.poolNftId.gtz(), "ERROR:PLS-010:BUNDLE_UNKNOWN");
|
136
|
-
require(poolNftId == bundleInfo.poolNftId, "ERROR:PLS-011:BUNDLE_POOL_MISMATCH");
|
137
|
-
|
138
|
-
bundleInfo.fee = fee;
|
139
|
-
|
140
|
-
instance.updateBundle(bundleNftId, bundleInfo, KEEP_STATE());
|
141
|
-
}
|
142
|
-
|
143
|
-
function updateBundle(NftId instanceNftId, NftId bundleNftId, IBundle.BundleInfo memory bundleInfo, StateId state)
|
144
|
-
external
|
145
|
-
onlyService
|
146
|
-
{
|
147
|
-
IRegistry.ObjectInfo memory instanceInfo = getRegistry().getObjectInfo(instanceNftId);
|
148
|
-
IInstance instance = IInstance(instanceInfo.objectAddress);
|
149
|
-
instance.updateBundle(bundleNftId, bundleInfo, state);
|
150
|
-
}
|
151
|
-
|
152
|
-
function lockBundle(NftId bundleNftId)
|
153
|
-
external
|
154
|
-
{
|
155
|
-
(, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
156
|
-
BundleManager bundleManager = instance.getBundleManager();
|
157
|
-
bundleManager.lock(bundleNftId);
|
158
|
-
}
|
159
|
-
|
160
|
-
function unlockBundle(NftId bundleNftId)
|
161
|
-
external
|
162
|
-
{
|
163
|
-
(, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
164
|
-
BundleManager bundleManager = instance.getBundleManager();
|
165
|
-
bundleManager.unlock(bundleNftId);
|
166
|
-
}
|
167
|
-
|
168
|
-
function underwritePolicy(IInstance instance,
|
169
|
-
NftId policyNftId,
|
170
|
-
NftId bundleNftId,
|
171
|
-
uint256 collateralAmount,
|
172
|
-
uint256 netPremiumAmount
|
173
|
-
)
|
174
|
-
external
|
175
|
-
onlyService
|
176
|
-
{
|
177
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
178
|
-
IBundle.BundleInfo memory bundleInfo = instanceReader.getBundleInfo(bundleNftId);
|
179
|
-
|
180
|
-
// lock collateral
|
181
|
-
bundleInfo.lockedAmount += collateralAmount;
|
182
|
-
bundleInfo.balanceAmount += netPremiumAmount;
|
183
|
-
|
184
|
-
instance.updateBundle(bundleNftId, bundleInfo, KEEP_STATE());
|
185
|
-
|
186
|
-
linkPolicy(instance, policyNftId);
|
187
|
-
}
|
188
|
-
|
189
|
-
/// @dev links policy to bundle
|
190
|
-
function linkPolicy(IInstance instance, NftId policyNftId)
|
191
|
-
internal
|
192
|
-
onlyService
|
193
|
-
{
|
194
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
195
|
-
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
196
|
-
|
197
|
-
// ensure policy has not yet been activated
|
198
|
-
if (policyInfo.activatedAt.gtz()) {
|
199
|
-
revert BundleManager.ErrorBundleManagerErrorPolicyAlreadyActivated(policyNftId);
|
200
|
-
}
|
201
|
-
|
202
|
-
BundleManager bundleManager = instance.getBundleManager();
|
203
|
-
bundleManager.linkPolicy(policyNftId);
|
204
|
-
}
|
205
|
-
|
206
|
-
/// @dev unlinks policy from bundle
|
207
|
-
function unlinkPolicy(IInstance instance, NftId policyNftId)
|
208
|
-
internal
|
209
|
-
onlyService
|
210
|
-
{
|
211
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
212
|
-
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
213
|
-
|
214
|
-
// ensure policy has no open claims
|
215
|
-
if (policyInfo.openClaimsCount > 0) {
|
216
|
-
revert BundleManager.ErrorBundleManagerPolicyWithOpenClaims(
|
217
|
-
policyNftId,
|
218
|
-
policyInfo.openClaimsCount);
|
219
|
-
}
|
220
|
-
|
221
|
-
// ensure policy is closeable
|
222
|
-
if (policyInfo.expiredAt < TimestampLib.blockTimestamp()
|
223
|
-
|| policyInfo.payoutAmount < policyInfo.sumInsuredAmount)
|
224
|
-
{
|
225
|
-
revert BundleManager.ErrorBundleManagerPolicyNotCloseable(policyNftId);
|
226
|
-
}
|
227
|
-
|
228
|
-
BundleManager bundleManager = instance.getBundleManager();
|
229
|
-
bundleManager.unlinkPolicy(policyNftId);
|
230
|
-
}
|
231
|
-
|
232
|
-
function _processStakingByTreasury(
|
233
|
-
InstanceReader instanceReader,
|
234
|
-
NftId poolNftId,
|
235
|
-
NftId bundleNftId,
|
236
|
-
uint256 stakingAmount
|
237
|
-
)
|
238
|
-
internal
|
239
|
-
{
|
240
|
-
// process token transfer(s)
|
241
|
-
if(stakingAmount > 0) {
|
242
|
-
ISetup.PoolSetupInfo memory poolInfo = instanceReader.getPoolSetupInfo(poolNftId);
|
243
|
-
TokenHandler tokenHandler = poolInfo.tokenHandler;
|
244
|
-
address bundleOwner = getRegistry().ownerOf(bundleNftId);
|
245
|
-
Fee memory stakingFee = poolInfo.stakingFee;
|
246
|
-
|
247
|
-
tokenHandler.transfer(
|
248
|
-
bundleOwner,
|
249
|
-
poolInfo.wallet,
|
250
|
-
stakingAmount
|
251
|
-
);
|
252
|
-
|
253
|
-
|
254
|
-
if (! FeeLib.feeIsZero(stakingFee)) {
|
255
|
-
(uint256 stakingFeeAmount, uint256 netAmount) = FeeLib.calculateFee(stakingFee, stakingAmount);
|
256
|
-
// TODO: track staking fees in pool's state (issue #177)
|
257
|
-
}
|
258
|
-
}
|
259
|
-
}
|
260
|
-
}
|
@@ -1,315 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.20;
|
3
|
-
|
4
|
-
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
-
|
6
|
-
import {IRegistry} from "../../registry/IRegistry.sol";
|
7
|
-
import {IInstance} from "../IInstance.sol";
|
8
|
-
|
9
|
-
import {ITreasury} from "../module/ITreasury.sol";
|
10
|
-
// import {TreasuryModule} from "../module/TreasuryModule.sol";
|
11
|
-
import {ISetup} from "../module/ISetup.sol";
|
12
|
-
import {IBaseComponent} from "../../components/IBaseComponent.sol";
|
13
|
-
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
14
|
-
import {IKeyValueStore} from "../../instance/base/IKeyValueStore.sol";
|
15
|
-
import {IVersionable} from "../../shared/IVersionable.sol";
|
16
|
-
import {Versionable} from "../../shared/Versionable.sol";
|
17
|
-
|
18
|
-
import {RoleId, PRODUCT_OWNER_ROLE, POOL_OWNER_ROLE, DISTRIBUTION_OWNER_ROLE, ORACLE_OWNER_ROLE} from "../../types/RoleId.sol";
|
19
|
-
import {ObjectType, REGISTRY, TOKEN, COMPONENT, PRODUCT, ORACLE, POOL, DISTRIBUTION} from "../../types/ObjectType.sol";
|
20
|
-
import {StateId, ACTIVE, PAUSED} from "../../types/StateId.sol";
|
21
|
-
import {Key32} from "../../types/Key32.sol";
|
22
|
-
import {NftId, NftIdLib, zeroNftId} from "../../types/NftId.sol";
|
23
|
-
import {Fee} from "../../types/Fee.sol";
|
24
|
-
import {Version, VersionLib} from "../../types/Version.sol";
|
25
|
-
import {UFixed, UFixedLib} from "../../types/UFixed.sol";
|
26
|
-
|
27
|
-
import {IDistributionComponent} from "../../components/IDistributionComponent.sol";
|
28
|
-
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
29
|
-
import {IProductComponent} from "../../components/IProductComponent.sol";
|
30
|
-
import {IService} from "../../shared/IService.sol";
|
31
|
-
import {IComponentOwnerService} from "./IComponentOwnerService.sol";
|
32
|
-
import {Service} from "../../shared/Service.sol";
|
33
|
-
// import {IPool, IPoolModule} from "../module/IPoolModule.sol";
|
34
|
-
|
35
|
-
import {IRegistryService} from "../../registry/IRegistryService.sol";
|
36
|
-
|
37
|
-
contract ComponentOwnerService is
|
38
|
-
Service,
|
39
|
-
IComponentOwnerService
|
40
|
-
{
|
41
|
-
using NftIdLib for NftId;
|
42
|
-
|
43
|
-
error MissingTypeRole();
|
44
|
-
error WalletIsZero();
|
45
|
-
error InvalidToken();
|
46
|
-
error InvalidPool();
|
47
|
-
error InvalidDistribution();
|
48
|
-
error InvalidPoolsInstance();
|
49
|
-
error InvalidDistributionsInstance();
|
50
|
-
|
51
|
-
error CollateralizationLevelIsZero();
|
52
|
-
|
53
|
-
modifier onlyRegisteredComponent(IBaseComponent component) {
|
54
|
-
NftId nftId = getRegistry().getNftId(address(component));
|
55
|
-
require(nftId.gtz(), "ERROR:COS-001:COMPONENT_UNKNOWN");
|
56
|
-
_;
|
57
|
-
}
|
58
|
-
|
59
|
-
constructor(
|
60
|
-
address registry,
|
61
|
-
NftId registryNftId,
|
62
|
-
address initialOwner
|
63
|
-
)
|
64
|
-
{
|
65
|
-
_initializeService(registry, initialOwner);
|
66
|
-
_registerInterface(type(IComponentOwnerService).interfaceId);
|
67
|
-
}
|
68
|
-
|
69
|
-
function getDomain() public pure override(Service, IService) returns(ObjectType) {
|
70
|
-
return COMPONENT();
|
71
|
-
}
|
72
|
-
|
73
|
-
function getRoleForType(
|
74
|
-
ObjectType cType
|
75
|
-
) public pure override returns (RoleId role) {
|
76
|
-
if (cType == PRODUCT()) {
|
77
|
-
return PRODUCT_OWNER_ROLE();
|
78
|
-
}
|
79
|
-
if (cType == POOL()) {
|
80
|
-
return POOL_OWNER_ROLE();
|
81
|
-
}
|
82
|
-
if (cType == DISTRIBUTION()) {
|
83
|
-
return DISTRIBUTION_OWNER_ROLE();
|
84
|
-
}
|
85
|
-
if (cType == ORACLE()) {
|
86
|
-
return ORACLE_OWNER_ROLE();
|
87
|
-
}
|
88
|
-
}
|
89
|
-
|
90
|
-
function getRegistryService() public view virtual returns (IRegistryService) {
|
91
|
-
address service = getRegistry().getServiceAddress(REGISTRY(), getMajorVersion());
|
92
|
-
return IRegistryService(service);
|
93
|
-
}
|
94
|
-
|
95
|
-
function registerProduct(
|
96
|
-
IBaseComponent product
|
97
|
-
) external returns (NftId nftId) {
|
98
|
-
|
99
|
-
// TODO some info parameters from component and from register may differ -> getObjectInfo() after registration?
|
100
|
-
(
|
101
|
-
IRegistry.ObjectInfo memory info,
|
102
|
-
bytes memory data
|
103
|
-
) = getRegistryService().registerProduct(
|
104
|
-
product,
|
105
|
-
msg.sender);
|
106
|
-
|
107
|
-
NftId instanceNftId = info.parentNftId;
|
108
|
-
address instanceAddress = getRegistry().getObjectInfo(instanceNftId).objectAddress;
|
109
|
-
IInstance instance = IInstance(instanceAddress);
|
110
|
-
|
111
|
-
RoleId typeRole = getRoleForType(PRODUCT());
|
112
|
-
// TODO refactor to use access manager infra
|
113
|
-
// if(instance.hasRole(typeRole, msg.sender) == false) {
|
114
|
-
// revert MissingTypeRole();
|
115
|
-
// }
|
116
|
-
|
117
|
-
_registerProduct(
|
118
|
-
info.nftId,
|
119
|
-
instanceNftId,
|
120
|
-
instance,
|
121
|
-
data
|
122
|
-
);
|
123
|
-
}
|
124
|
-
|
125
|
-
function registerPool(
|
126
|
-
IBaseComponent pool
|
127
|
-
) external returns (NftId nftId) {
|
128
|
-
|
129
|
-
// TODO some info parameters from component and from register may differ -> getObjectInfo() after registration?
|
130
|
-
(
|
131
|
-
IRegistry.ObjectInfo memory info,
|
132
|
-
bytes memory data
|
133
|
-
) = getRegistryService().registerPool(
|
134
|
-
pool,
|
135
|
-
msg.sender);
|
136
|
-
|
137
|
-
NftId instanceNftId = info.parentNftId;
|
138
|
-
address instanceAddress = getRegistry().getObjectInfo(instanceNftId).objectAddress;
|
139
|
-
IInstance instance = IInstance(instanceAddress);
|
140
|
-
|
141
|
-
RoleId typeRole = getRoleForType(POOL());
|
142
|
-
// TODO refactor to use access manager infra
|
143
|
-
// if(instance.hasRole(typeRole, msg.sender) == false) {
|
144
|
-
// revert MissingTypeRole();
|
145
|
-
// }
|
146
|
-
|
147
|
-
_registerPool(
|
148
|
-
info.nftId,
|
149
|
-
instanceNftId,
|
150
|
-
instance,
|
151
|
-
data
|
152
|
-
);
|
153
|
-
}
|
154
|
-
|
155
|
-
function registerDistribution(
|
156
|
-
IBaseComponent distribution
|
157
|
-
) external returns (NftId nftId) {
|
158
|
-
|
159
|
-
// TODO some info parameters from component and from register may differ -> getObjectInfo() after registration?
|
160
|
-
(
|
161
|
-
IRegistry.ObjectInfo memory info,
|
162
|
-
bytes memory data
|
163
|
-
) = getRegistryService().registerDistribution(
|
164
|
-
distribution,
|
165
|
-
msg.sender);
|
166
|
-
|
167
|
-
NftId instanceNftId = info.parentNftId;
|
168
|
-
address instanceAddress = getRegistry().getObjectInfo(instanceNftId).objectAddress;
|
169
|
-
IInstance instance = IInstance(instanceAddress);
|
170
|
-
|
171
|
-
RoleId typeRole = getRoleForType(DISTRIBUTION());
|
172
|
-
// TODO refactor to use access manager infra
|
173
|
-
// if(instance.hasRole(typeRole, msg.sender) == false) {
|
174
|
-
// revert MissingTypeRole();
|
175
|
-
// }
|
176
|
-
}
|
177
|
-
|
178
|
-
function lock(
|
179
|
-
IBaseComponent component
|
180
|
-
) external override onlyRegisteredComponent(component) {
|
181
|
-
// TODO use msg.sender to get component and get instance via registered parent nft id
|
182
|
-
IInstance instance = component.getInstance();
|
183
|
-
NftId nftId = component.getNftId();
|
184
|
-
Key32 key = nftId.toKey32(COMPONENT());
|
185
|
-
// instance.updateState(key, PAUSED());
|
186
|
-
}
|
187
|
-
|
188
|
-
function unlock(
|
189
|
-
IBaseComponent component
|
190
|
-
) external override onlyRegisteredComponent(component) {
|
191
|
-
// TODO use msg.sender to get component and get instance via registered parent nft id
|
192
|
-
IInstance instance = component.getInstance();
|
193
|
-
NftId nftId = component.getNftId();
|
194
|
-
Key32 key = nftId.toKey32(COMPONENT());
|
195
|
-
// instance.updateState(key, ACTIVE());
|
196
|
-
}
|
197
|
-
|
198
|
-
// Internals
|
199
|
-
|
200
|
-
function _registerProduct(
|
201
|
-
NftId nftId,
|
202
|
-
NftId instanceNftId,
|
203
|
-
IInstance instance,
|
204
|
-
bytes memory data
|
205
|
-
)
|
206
|
-
internal
|
207
|
-
{
|
208
|
-
// TODO change treasury info to product setup info
|
209
|
-
(ISetup.ProductSetupInfo memory info) = abi.decode(data, (ISetup.ProductSetupInfo));
|
210
|
-
// (
|
211
|
-
// ITreasury.TreasuryInfo memory info,
|
212
|
-
// address wallet
|
213
|
-
// ) = abi.decode(data, (ITreasury.TreasuryInfo, address));
|
214
|
-
|
215
|
-
// IRegistry _registry = getRegistry();
|
216
|
-
|
217
|
-
// if(wallet == address(0)) {
|
218
|
-
// revert WalletIsZero();
|
219
|
-
// }
|
220
|
-
|
221
|
-
// IRegistry.ObjectInfo memory tokenInfo = _registry.getObjectInfo(address(info.token));
|
222
|
-
|
223
|
-
// if(tokenInfo.objectType != TOKEN()) {
|
224
|
-
// revert InvalidToken();
|
225
|
-
// }
|
226
|
-
|
227
|
-
// IRegistry.ObjectInfo memory poolInfo = _registry.getObjectInfo(info.poolNftId);
|
228
|
-
|
229
|
-
// if(poolInfo.objectType != POOL()) {
|
230
|
-
// revert InvalidPool();
|
231
|
-
// }
|
232
|
-
|
233
|
-
// if(poolInfo.parentNftId != instanceNftId) {
|
234
|
-
// revert InvalidPoolsInstance();
|
235
|
-
// }
|
236
|
-
// // TODO pool have the same token
|
237
|
-
// //ITreasury.PoolSetup memory poolSetup = instance.getPoolSetup(info.poolNftId);
|
238
|
-
// //require(tokenInfo.objectAddress == address(poolSetup.token), "ERROR:COS-018:PRODUCT_POOL_TOKEN_MISMATCH");
|
239
|
-
// // TODO pool is not linked
|
240
|
-
|
241
|
-
// IRegistry.ObjectInfo memory distributionInfo = _registry.getObjectInfo(info.distributionNftId);
|
242
|
-
|
243
|
-
// if(distributionInfo.objectType != DISTRIBUTION()) {
|
244
|
-
// revert InvalidDistribution();
|
245
|
-
// }
|
246
|
-
|
247
|
-
// if(distributionInfo.parentNftId != instanceNftId) {
|
248
|
-
// revert InvalidDistributionsInstance();
|
249
|
-
// }
|
250
|
-
// // TODO distribution have the same token
|
251
|
-
// // TODO distribution is not linked
|
252
|
-
|
253
|
-
// // component module
|
254
|
-
// instance.registerComponent(
|
255
|
-
// nftId,
|
256
|
-
// info.token,
|
257
|
-
// wallet // TODO move wallet into TreasuryInfo?
|
258
|
-
// );
|
259
|
-
|
260
|
-
// treasury module
|
261
|
-
instance.createProductSetup(
|
262
|
-
nftId,
|
263
|
-
info
|
264
|
-
);
|
265
|
-
}
|
266
|
-
|
267
|
-
function _registerPool(
|
268
|
-
NftId nftId,
|
269
|
-
NftId instanceNftId,
|
270
|
-
IInstance instance,
|
271
|
-
bytes memory data
|
272
|
-
)
|
273
|
-
internal
|
274
|
-
{
|
275
|
-
(
|
276
|
-
ISetup.PoolSetupInfo memory info,
|
277
|
-
address wallet,
|
278
|
-
IERC20Metadata token,
|
279
|
-
/*poolFee*/,
|
280
|
-
/*stakingFee*/,
|
281
|
-
/*performanceFee*/
|
282
|
-
) = abi.decode(data, (ISetup.PoolSetupInfo, address, IERC20Metadata, Fee, Fee, Fee));
|
283
|
-
|
284
|
-
IRegistry _registry = getRegistry();
|
285
|
-
|
286
|
-
if(wallet == address(0)) {
|
287
|
-
revert WalletIsZero();
|
288
|
-
}
|
289
|
-
|
290
|
-
ObjectType tokenType = _registry.getObjectInfo(address(token)).objectType;
|
291
|
-
|
292
|
-
if(tokenType != TOKEN()) {
|
293
|
-
revert InvalidToken();
|
294
|
-
}
|
295
|
-
|
296
|
-
if(UFixedLib.eqz(info.collateralizationLevel)) {
|
297
|
-
revert CollateralizationLevelIsZero();
|
298
|
-
}
|
299
|
-
|
300
|
-
// TODO add more validations
|
301
|
-
|
302
|
-
// // component module
|
303
|
-
// instance.registerComponent(
|
304
|
-
// nftId,
|
305
|
-
// token,
|
306
|
-
// wallet
|
307
|
-
// );
|
308
|
-
|
309
|
-
// pool module
|
310
|
-
instance.createPoolSetup(
|
311
|
-
nftId,
|
312
|
-
info
|
313
|
-
);
|
314
|
-
}
|
315
|
-
}
|
@@ -1,113 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
|
-
import {IInstance} from "../../instance/IInstance.sol";
|
6
|
-
import {InstanceAccessManager} from "../InstanceAccessManager.sol";
|
7
|
-
import {InstanceReader} from "../../instance/InstanceReader.sol";
|
8
|
-
import {ISetup} from "../../instance/module/ISetup.sol";
|
9
|
-
|
10
|
-
import {NftId, NftIdLib} from "../../types/NftId.sol";
|
11
|
-
import {Fee} from "../../types/Fee.sol";
|
12
|
-
import {DISTRIBUTION_OWNER_ROLE} from "../../types/RoleId.sol";
|
13
|
-
import {KEEP_STATE} from "../../types/StateId.sol";
|
14
|
-
import {ObjectType, DISTRIBUTION} from "../../types/ObjectType.sol";
|
15
|
-
import {Version, VersionLib} from "../../types/Version.sol";
|
16
|
-
|
17
|
-
import {IVersionable} from "../../shared/IVersionable.sol";
|
18
|
-
import {Versionable} from "../../shared/Versionable.sol";
|
19
|
-
|
20
|
-
import {IService} from "../../shared/IService.sol";
|
21
|
-
import {Service} from "../../shared/Service.sol";
|
22
|
-
import {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
|
23
|
-
import {InstanceService} from "../InstanceService.sol";
|
24
|
-
import {IDistributionService} from "./IDistributionService.sol";
|
25
|
-
import {IBaseComponent} from "../../components/IBaseComponent.sol";
|
26
|
-
|
27
|
-
|
28
|
-
contract DistributionService is
|
29
|
-
ComponentServiceBase,
|
30
|
-
IDistributionService
|
31
|
-
{
|
32
|
-
using NftIdLib for NftId;
|
33
|
-
|
34
|
-
address internal _registryAddress;
|
35
|
-
|
36
|
-
function _initialize(
|
37
|
-
address owner,
|
38
|
-
bytes memory data
|
39
|
-
)
|
40
|
-
internal
|
41
|
-
initializer
|
42
|
-
virtual override
|
43
|
-
{
|
44
|
-
address initialOwner;
|
45
|
-
address registryAddress;
|
46
|
-
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
47
|
-
// TODO while DistributionService is not deployed in DistributionServiceManager constructor
|
48
|
-
// owner is DistributionServiceManager deployer
|
49
|
-
_initializeService(registryAddress, owner);
|
50
|
-
|
51
|
-
_registerInterface(type(IDistributionService).interfaceId);
|
52
|
-
}
|
53
|
-
|
54
|
-
function getDomain() public pure override(Service, IService) returns(ObjectType) {
|
55
|
-
return DISTRIBUTION();
|
56
|
-
}
|
57
|
-
|
58
|
-
function register(address distributionAddress)
|
59
|
-
external
|
60
|
-
returns(NftId distributionNftId)
|
61
|
-
{
|
62
|
-
address distributionOwner = msg.sender;
|
63
|
-
IBaseComponent distribution = IBaseComponent(distributionAddress);
|
64
|
-
|
65
|
-
IRegistry.ObjectInfo memory info;
|
66
|
-
bytes memory data;
|
67
|
-
(info, data) = getRegistryService().registerDistribution(distribution, distributionOwner);
|
68
|
-
|
69
|
-
IInstance instance = _getInstance(info.parentNftId);
|
70
|
-
InstanceService instanceService = getInstanceService();
|
71
|
-
|
72
|
-
bool hasRole = instanceService.hasRole(
|
73
|
-
distributionOwner,
|
74
|
-
DISTRIBUTION_OWNER_ROLE(),
|
75
|
-
address(instance));
|
76
|
-
|
77
|
-
if(!hasRole) {
|
78
|
-
revert ExpectedRoleMissing(DISTRIBUTION_OWNER_ROLE(), distributionOwner);
|
79
|
-
}
|
80
|
-
|
81
|
-
distributionNftId = info.nftId;
|
82
|
-
ISetup.DistributionSetupInfo memory initialSetup = _decodeAndVerifyDistributionSetup(data);
|
83
|
-
instance.createDistributionSetup(distributionNftId, initialSetup);
|
84
|
-
|
85
|
-
instanceService.createTarget(_getInstanceNftId(info), distributionAddress, distribution.getName());
|
86
|
-
}
|
87
|
-
|
88
|
-
function _decodeAndVerifyDistributionSetup(bytes memory data) internal returns(ISetup.DistributionSetupInfo memory setup)
|
89
|
-
{
|
90
|
-
setup = abi.decode(
|
91
|
-
data,
|
92
|
-
(ISetup.DistributionSetupInfo)
|
93
|
-
);
|
94
|
-
|
95
|
-
// TODO add checks if applicable
|
96
|
-
}
|
97
|
-
|
98
|
-
function setFees(
|
99
|
-
Fee memory distributionFee
|
100
|
-
)
|
101
|
-
external
|
102
|
-
override
|
103
|
-
{
|
104
|
-
(IRegistry.ObjectInfo memory info , IInstance instance) = _getAndVerifyComponentInfoAndInstance(DISTRIBUTION());
|
105
|
-
InstanceReader instanceReader = instance.getInstanceReader();
|
106
|
-
NftId distributionNftId = info.nftId;
|
107
|
-
|
108
|
-
ISetup.DistributionSetupInfo memory distSetupInfo = instanceReader.getDistributionSetupInfo(distributionNftId);
|
109
|
-
distSetupInfo.distributionFee = distributionFee;
|
110
|
-
|
111
|
-
instance.updateDistributionSetup(distributionNftId, distSetupInfo, KEEP_STATE());
|
112
|
-
}
|
113
|
-
}
|